diff options
author | Ben Murdoch <benm@google.com> | 2011-05-24 11:24:40 +0100 |
---|---|---|
committer | Ben Murdoch <benm@google.com> | 2011-06-02 09:53:15 +0100 |
commit | 81bc750723a18f21cd17d1b173cd2a4dda9cea6e (patch) | |
tree | 7a9e5ed86ff429fd347a25153107221543909b19 /Source/WebCore/editing/InsertTextCommand.cpp | |
parent | 94088a6d336c1dd80a1e734af51e96abcbb689a7 (diff) | |
download | external_webkit-81bc750723a18f21cd17d1b173cd2a4dda9cea6e.zip external_webkit-81bc750723a18f21cd17d1b173cd2a4dda9cea6e.tar.gz external_webkit-81bc750723a18f21cd17d1b173cd2a4dda9cea6e.tar.bz2 |
Merge WebKit at r80534: Intial merge by Git
Change-Id: Ia7a83357124c9e1cdb1debf55d9661ec0bd09a61
Diffstat (limited to 'Source/WebCore/editing/InsertTextCommand.cpp')
-rw-r--r-- | Source/WebCore/editing/InsertTextCommand.cpp | 37 |
1 files changed, 17 insertions, 20 deletions
diff --git a/Source/WebCore/editing/InsertTextCommand.cpp b/Source/WebCore/editing/InsertTextCommand.cpp index 1ec11ad..33ebe3a 100644 --- a/Source/WebCore/editing/InsertTextCommand.cpp +++ b/Source/WebCore/editing/InsertTextCommand.cpp @@ -26,19 +26,13 @@ #include "config.h" #include "InsertTextCommand.h" -#include "CSSComputedStyleDeclaration.h" -#include "CSSMutableStyleDeclaration.h" -#include "CSSPropertyNames.h" #include "Document.h" #include "Element.h" #include "EditingText.h" #include "Editor.h" #include "Frame.h" -#include "Logging.h" #include "HTMLInterchange.h" #include "htmlediting.h" -#include "TextIterator.h" -#include "TypingCommand.h" #include "visible_units.h" #include <wtf/unicode/CharacterNames.h> @@ -53,20 +47,20 @@ void InsertTextCommand::doApply() { } -Position InsertTextCommand::prepareForTextInsertion(const Position& p) +Position InsertTextCommand::positionInsideTextNode(const Position& p) { Position pos = p; - // Prepare for text input by looking at the specified position. - // It may be necessary to insert a text node to receive characters. - if (!pos.node()->isTextNode()) { + if (isTabSpanTextNode(pos.anchorNode())) { RefPtr<Node> textNode = document()->createEditingTextNode(""); - insertNodeAt(textNode.get(), pos); + insertNodeAtTabSpanPosition(textNode.get(), pos); return firstPositionInNode(textNode.get()); } - if (isTabSpanTextNode(pos.node())) { + // Prepare for text input by looking at the specified position. + // It may be necessary to insert a text node to receive characters. + if (!pos.containerNode()->isTextNode()) { RefPtr<Node> textNode = document()->createEditingTextNode(""); - insertNodeAtTabSpanPosition(textNode.get(), pos); + insertNodeAt(textNode.get(), pos); return firstPositionInNode(textNode.get()); } @@ -147,9 +141,9 @@ void InsertTextCommand::input(const String& text, bool selectInsertedText, Rebal // It is possible for the node that contains startPosition to contain only unrendered whitespace, // and so deleteInsignificantText could remove it. Save the position before the node in case that happens. - Position positionBeforeStartNode(positionInParentBeforeNode(startPosition.node())); + Position positionBeforeStartNode(positionInParentBeforeNode(startPosition.containerNode())); deleteInsignificantText(startPosition.upstream(), startPosition.downstream()); - if (!startPosition.node()->inDocument()) + if (!startPosition.anchorNode()->inDocument()) startPosition = positionBeforeStartNode; if (!startPosition.isCandidate()) startPosition = startPosition.downstream(); @@ -165,11 +159,14 @@ void InsertTextCommand::input(const String& text, bool selectInsertedText, Rebal removePlaceholderAt(placeholder); } else { // Make sure the document is set up to receive text - startPosition = prepareForTextInsertion(startPosition); + startPosition = positionInsideTextNode(startPosition); + ASSERT(startPosition.anchorType() == Position::PositionIsOffsetInAnchor); + ASSERT(startPosition.containerNode()); + ASSERT(startPosition.containerNode()->isTextNode()); if (placeholder.isNotNull()) removePlaceholderAt(placeholder); - Text *textNode = static_cast<Text *>(startPosition.node()); - int offset = startPosition.deprecatedEditingOffset(); + Text* textNode = static_cast<Text*>(startPosition.containerNode()); + const unsigned offset = startPosition.offsetInContainerNode(); insertTextIntoNode(textNode, offset, text); endPosition = Position(textNode, offset + text.length(), Position::PositionIsOffsetInAnchor); @@ -183,7 +180,7 @@ void InsertTextCommand::input(const String& text, bool selectInsertedText, Rebal } else { ASSERT(whitespaceRebalance == RebalanceAllWhitespaces); if (canRebalance(startPosition) && canRebalance(endPosition)) - rebalanceWhitespaceOnTextSubstring(textNode, startPosition.deprecatedEditingOffset(), endPosition.deprecatedEditingOffset()); + rebalanceWhitespaceOnTextSubstring(textNode, startPosition.offsetInContainerNode(), endPosition.offsetInContainerNode()); } } @@ -209,7 +206,7 @@ Position InsertTextCommand::insertTab(const Position& pos) { Position insertPos = VisiblePosition(pos, DOWNSTREAM).deepEquivalent(); - Node *node = insertPos.node(); + Node* node = insertPos.deprecatedNode(); unsigned int offset = insertPos.deprecatedEditingOffset(); // keep tabs coalesced in tab span |