OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009 Apple Inc. All rights reserv
ed. | 2 * Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009 Apple Inc. All rights reserv
ed. |
3 * Copyright (C) 2008, 2009, 2010, 2011 Google Inc. All rights reserved. | 3 * Copyright (C) 2008, 2009, 2010, 2011 Google Inc. All rights reserved. |
4 * Copyright (C) 2011 Igalia S.L. | 4 * Copyright (C) 2011 Igalia S.L. |
5 * Copyright (C) 2011 Motorola Mobility. All rights reserved. | 5 * Copyright (C) 2011 Motorola Mobility. All rights reserved. |
6 * | 6 * |
7 * Redistribution and use in source and binary forms, with or without | 7 * Redistribution and use in source and binary forms, with or without |
8 * modification, are permitted provided that the following conditions | 8 * modification, are permitted provided that the following conditions |
9 * are met: | 9 * are met: |
10 * 1. Redistributions of source code must retain the above copyright | 10 * 1. Redistributions of source code must retain the above copyright |
(...skipping 81 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
92 QualifiedName m_name; | 92 QualifiedName m_name; |
93 String m_value; | 93 String m_value; |
94 }; | 94 }; |
95 | 95 |
96 static void completeURLs(DocumentFragment* fragment, const String& baseURL) | 96 static void completeURLs(DocumentFragment* fragment, const String& baseURL) |
97 { | 97 { |
98 Vector<AttributeChange> changes; | 98 Vector<AttributeChange> changes; |
99 | 99 |
100 KURL parsedBaseURL(ParsedURLString, baseURL); | 100 KURL parsedBaseURL(ParsedURLString, baseURL); |
101 | 101 |
102 for (Element* element = ElementTraversal::firstWithin(fragment); element; el
ement = ElementTraversal::next(element, fragment)) { | 102 for (Element* element = ElementTraversal::firstWithin(fragment); element; el
ement = ElementTraversal::next(*element, fragment)) { |
103 if (!element->hasAttributes()) | 103 if (!element->hasAttributes()) |
104 continue; | 104 continue; |
105 unsigned length = element->attributeCount(); | 105 unsigned length = element->attributeCount(); |
106 for (unsigned i = 0; i < length; i++) { | 106 for (unsigned i = 0; i < length; i++) { |
107 const Attribute* attribute = element->attributeItem(i); | 107 const Attribute* attribute = element->attributeItem(i); |
108 if (element->isURLAttribute(*attribute) && !attribute->value().isEmp
ty()) | 108 if (element->isURLAttribute(*attribute) && !attribute->value().isEmp
ty()) |
109 changes.append(AttributeChange(element, attribute->name(), KURL(
parsedBaseURL, attribute->value()).string())); | 109 changes.append(AttributeChange(element, attribute->name(), KURL(
parsedBaseURL, attribute->value()).string())); |
110 } | 110 } |
111 } | 111 } |
112 | 112 |
(...skipping 235 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
348 Node* lastClosed = 0; | 348 Node* lastClosed = 0; |
349 for (Node* n = startNode; n != pastEnd; n = next) { | 349 for (Node* n = startNode; n != pastEnd; n = next) { |
350 // According to <rdar://problem/5730668>, it is possible for n to blow | 350 // According to <rdar://problem/5730668>, it is possible for n to blow |
351 // past pastEnd and become null here. This shouldn't be possible. | 351 // past pastEnd and become null here. This shouldn't be possible. |
352 // This null check will prevent crashes (but create too much markup) | 352 // This null check will prevent crashes (but create too much markup) |
353 // and the ASSERT will hopefully lead us to understanding the problem. | 353 // and the ASSERT will hopefully lead us to understanding the problem. |
354 ASSERT(n); | 354 ASSERT(n); |
355 if (!n) | 355 if (!n) |
356 break; | 356 break; |
357 | 357 |
358 next = NodeTraversal::next(n); | 358 next = NodeTraversal::next(*n); |
359 bool openedTag = false; | 359 bool openedTag = false; |
360 | 360 |
361 if (isBlock(n) && canHaveChildrenForEditing(n) && next == pastEnd) | 361 if (isBlock(n) && canHaveChildrenForEditing(n) && next == pastEnd) |
362 // Don't write out empty block containers that aren't fully selected
. | 362 // Don't write out empty block containers that aren't fully selected
. |
363 continue; | 363 continue; |
364 | 364 |
365 if (!n->renderer() && !enclosingNodeWithTag(firstPositionInOrBeforeNode(
n), selectTag)) { | 365 if (!n->renderer() && !enclosingNodeWithTag(firstPositionInOrBeforeNode(
n), selectTag)) { |
366 next = NodeTraversal::nextSkippingChildren(n); | 366 next = NodeTraversal::nextSkippingChildren(n); |
367 // Don't skip over pastEnd. | 367 // Don't skip over pastEnd. |
368 if (pastEnd && pastEnd->isDescendantOf(n)) | 368 if (pastEnd && pastEnd->isDescendantOf(n)) |
(...skipping 281 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
650 if (!baseURL.isEmpty() && baseURL != blankURL() && baseURL != document.baseU
RL()) | 650 if (!baseURL.isEmpty() && baseURL != blankURL() && baseURL != document.baseU
RL()) |
651 completeURLs(fragment.get(), baseURL); | 651 completeURLs(fragment.get(), baseURL); |
652 | 652 |
653 return fragment.release(); | 653 return fragment.release(); |
654 } | 654 } |
655 | 655 |
656 static const char fragmentMarkerTag[] = "webkit-fragment-marker"; | 656 static const char fragmentMarkerTag[] = "webkit-fragment-marker"; |
657 | 657 |
658 static bool findNodesSurroundingContext(Document* document, RefPtr<Node>& nodeBe
foreContext, RefPtr<Node>& nodeAfterContext) | 658 static bool findNodesSurroundingContext(Document* document, RefPtr<Node>& nodeBe
foreContext, RefPtr<Node>& nodeAfterContext) |
659 { | 659 { |
660 for (Node* node = document->firstChild(); node; node = NodeTraversal::next(n
ode)) { | 660 for (Node* node = document->firstChild(); node; node = NodeTraversal::next(*
node)) { |
661 if (node->nodeType() == Node::COMMENT_NODE && toCharacterData(node)->dat
a() == fragmentMarkerTag) { | 661 if (node->nodeType() == Node::COMMENT_NODE && toCharacterData(node)->dat
a() == fragmentMarkerTag) { |
662 if (!nodeBeforeContext) | 662 if (!nodeBeforeContext) |
663 nodeBeforeContext = node; | 663 nodeBeforeContext = node; |
664 else { | 664 else { |
665 nodeAfterContext = node; | 665 nodeAfterContext = node; |
666 return true; | 666 return true; |
667 } | 667 } |
668 } | 668 } |
669 } | 669 } |
670 return false; | 670 return false; |
671 } | 671 } |
672 | 672 |
673 static void trimFragment(DocumentFragment* fragment, Node* nodeBeforeContext, No
de* nodeAfterContext) | 673 static void trimFragment(DocumentFragment* fragment, Node* nodeBeforeContext, No
de* nodeAfterContext) |
674 { | 674 { |
675 RefPtr<Node> next; | 675 RefPtr<Node> next; |
676 for (RefPtr<Node> node = fragment->firstChild(); node; node = next) { | 676 for (RefPtr<Node> node = fragment->firstChild(); node; node = next) { |
677 if (nodeBeforeContext->isDescendantOf(node.get())) { | 677 if (nodeBeforeContext->isDescendantOf(node.get())) { |
678 next = NodeTraversal::next(node.get()); | 678 next = NodeTraversal::next(*node); |
679 continue; | 679 continue; |
680 } | 680 } |
681 next = NodeTraversal::nextSkippingChildren(node.get()); | 681 next = NodeTraversal::nextSkippingChildren(node.get()); |
682 ASSERT(!node->contains(nodeAfterContext)); | 682 ASSERT(!node->contains(nodeAfterContext)); |
683 node->parentNode()->removeChild(node.get(), ASSERT_NO_EXCEPTION); | 683 node->parentNode()->removeChild(node.get(), ASSERT_NO_EXCEPTION); |
684 if (nodeBeforeContext == node) | 684 if (nodeBeforeContext == node) |
685 break; | 685 break; |
686 } | 686 } |
687 | 687 |
688 ASSERT(nodeAfterContext->parentNode()); | 688 ASSERT(nodeAfterContext->parentNode()); |
(...skipping 394 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1083 return; | 1083 return; |
1084 | 1084 |
1085 RefPtr<Text> textNode = toText(node.get()); | 1085 RefPtr<Text> textNode = toText(node.get()); |
1086 RefPtr<Text> textNext = toText(next); | 1086 RefPtr<Text> textNext = toText(next); |
1087 textNode->appendData(textNext->data()); | 1087 textNode->appendData(textNext->data()); |
1088 if (textNext->parentNode()) // Might have been removed by mutation event. | 1088 if (textNext->parentNode()) // Might have been removed by mutation event. |
1089 textNext->remove(es); | 1089 textNext->remove(es); |
1090 } | 1090 } |
1091 | 1091 |
1092 } | 1092 } |
OLD | NEW |