Remove LegacyException support from bindings script
[WebKit-https.git] / Source / WebCore / editing / cocoa / EditorCocoa.mm
1 /*
2  * Copyright (C) 2006-2016 Apple Inc. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
14  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE INC. OR
17  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24  */
25
26 #import "config.h"
27 #import "Editor.h"
28
29 #import "ArchiveResource.h"
30 #import "CSSValueList.h"
31 #import "CSSValuePool.h"
32 #import "DocumentFragment.h"
33 #import "EditingStyle.h"
34 #import "Frame.h"
35 #import "FrameSelection.h"
36 #import "HTMLSpanElement.h"
37 #import "NSAttributedStringSPI.h"
38 #import "RenderElement.h"
39 #import "RenderStyle.h"
40 #import "SoftLinking.h"
41 #import "Text.h"
42 #import "htmlediting.h"
43
44 #if PLATFORM(IOS)
45 SOFT_LINK_PRIVATE_FRAMEWORK(WebKitLegacy)
46 #endif
47
48 #if PLATFORM(MAC)
49 SOFT_LINK_FRAMEWORK_IN_UMBRELLA(WebKit, WebKitLegacy)
50 #endif
51
52 SOFT_LINK(WebKitLegacy, _WebCreateFragment, void, (WebCore::Document& document, NSAttributedString *string, WebCore::FragmentAndResources& result), (document, string, result))
53
54 namespace WebCore {
55
56 // FIXME: This figures out the current style by inserting a <span>!
57 const RenderStyle* Editor::styleForSelectionStart(Frame* frame, Node*& nodeToRemove)
58 {
59     nodeToRemove = nullptr;
60     
61     if (frame->selection().isNone())
62         return nullptr;
63
64     Position position = adjustedSelectionStartForStyleComputation(frame->selection().selection());
65     if (!position.isCandidate() || position.isNull())
66         return nullptr;
67
68     RefPtr<EditingStyle> typingStyle = frame->selection().typingStyle();
69     if (!typingStyle || !typingStyle->style())
70         return &position.deprecatedNode()->renderer()->style();
71
72     auto styleElement = HTMLSpanElement::create(*frame->document());
73
74     String styleText = typingStyle->style()->asText() + " display: inline";
75     styleElement->setAttribute(HTMLNames::styleAttr, styleText);
76
77     styleElement->appendChild(frame->document()->createEditingTextNode(emptyString()));
78
79     if (position.deprecatedNode()->parentNode()->appendChild(styleElement).hasException())
80         return nullptr; 
81
82     nodeToRemove = styleElement.ptr();
83
84     frame->document()->updateStyleIfNeeded();
85     return styleElement->renderer() ? &styleElement->renderer()->style() : nullptr;
86 }
87
88 void Editor::getTextDecorationAttributesRespectingTypingStyle(const RenderStyle& style, NSMutableDictionary* result) const
89 {
90     RefPtr<EditingStyle> typingStyle = m_frame.selection().typingStyle();
91     if (typingStyle && typingStyle->style()) {
92         RefPtr<CSSValue> value = typingStyle->style()->getPropertyCSSValue(CSSPropertyWebkitTextDecorationsInEffect);
93         if (value && value->isValueList()) {
94             CSSValueList& valueList = downcast<CSSValueList>(*value);
95             if (valueList.hasValue(CSSValuePool::singleton().createIdentifierValue(CSSValueLineThrough).ptr()))
96                 [result setObject:[NSNumber numberWithInt:NSUnderlineStyleSingle] forKey:NSStrikethroughStyleAttributeName];
97             if (valueList.hasValue(CSSValuePool::singleton().createIdentifierValue(CSSValueUnderline).ptr()))
98                 [result setObject:[NSNumber numberWithInt:NSUnderlineStyleSingle] forKey:NSUnderlineStyleAttributeName];
99         }
100     } else {
101         int decoration = style.textDecorationsInEffect();
102         if (decoration & TextDecorationLineThrough)
103             [result setObject:[NSNumber numberWithInt:NSUnderlineStyleSingle] forKey:NSStrikethroughStyleAttributeName];
104         if (decoration & TextDecorationUnderline)
105             [result setObject:[NSNumber numberWithInt:NSUnderlineStyleSingle] forKey:NSUnderlineStyleAttributeName];
106     }
107 }
108
109 FragmentAndResources Editor::createFragment(NSAttributedString *string)
110 {
111     // FIXME: The algorithm to convert an attributed string into HTML should be implemented here in WebCore.
112     // For now, though, we call into WebKitLegacy, which in turn calls into AppKit/TextKit.
113     FragmentAndResources result;
114     _WebCreateFragment(*m_frame.document(), string, result);
115     return result;
116 }
117
118 }