Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(21)

Side by Side Diff: third_party/WebKit/Source/core/editing/commands/ReplaceNodeWithSpanCommand.cpp

Issue 1858163002: Rename inDocument() to inShadowIncludingDocument() (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2009 Google Inc. All rights reserved. 2 * Copyright (c) 2009 Google Inc. All rights reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are 5 * modification, are permitted provided that the following conditions are
6 * met: 6 * met:
7 * 7 *
8 * * Redistributions of source code must retain the above copyright 8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above 10 * * Redistributions in binary form must reproduce the above
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after
43 43
44 ReplaceNodeWithSpanCommand::ReplaceNodeWithSpanCommand(RawPtr<HTMLElement> eleme nt) 44 ReplaceNodeWithSpanCommand::ReplaceNodeWithSpanCommand(RawPtr<HTMLElement> eleme nt)
45 : SimpleEditCommand(element->document()) 45 : SimpleEditCommand(element->document())
46 , m_elementToReplace(element) 46 , m_elementToReplace(element)
47 { 47 {
48 ASSERT(m_elementToReplace); 48 ASSERT(m_elementToReplace);
49 } 49 }
50 50
51 static void swapInNodePreservingAttributesAndChildren(HTMLElement* newElement, H TMLElement& elementToReplace) 51 static void swapInNodePreservingAttributesAndChildren(HTMLElement* newElement, H TMLElement& elementToReplace)
52 { 52 {
53 ASSERT(elementToReplace.inDocument()); 53 ASSERT(elementToReplace.inShadowIncludingDocument());
54 RawPtr<ContainerNode> parentNode = elementToReplace.parentNode(); 54 RawPtr<ContainerNode> parentNode = elementToReplace.parentNode();
55 parentNode->insertBefore(newElement, &elementToReplace); 55 parentNode->insertBefore(newElement, &elementToReplace);
56 56
57 NodeVector children; 57 NodeVector children;
58 getChildNodes(elementToReplace, children); 58 getChildNodes(elementToReplace, children);
59 for (const auto& child : children) 59 for (const auto& child : children)
60 newElement->appendChild(child); 60 newElement->appendChild(child);
61 61
62 // FIXME: Fix this to send the proper MutationRecords when MutationObservers are present. 62 // FIXME: Fix this to send the proper MutationRecords when MutationObservers are present.
63 newElement->cloneDataFromElement(elementToReplace); 63 newElement->cloneDataFromElement(elementToReplace);
64 64
65 parentNode->removeChild(&elementToReplace, ASSERT_NO_EXCEPTION); 65 parentNode->removeChild(&elementToReplace, ASSERT_NO_EXCEPTION);
66 } 66 }
67 67
68 void ReplaceNodeWithSpanCommand::doApply(EditingState*) 68 void ReplaceNodeWithSpanCommand::doApply(EditingState*)
69 { 69 {
70 if (!m_elementToReplace->inDocument()) 70 if (!m_elementToReplace->inShadowIncludingDocument())
71 return; 71 return;
72 if (!m_spanElement) 72 if (!m_spanElement)
73 m_spanElement = HTMLSpanElement::create(m_elementToReplace->document()); 73 m_spanElement = HTMLSpanElement::create(m_elementToReplace->document());
74 swapInNodePreservingAttributesAndChildren(m_spanElement.get(), *m_elementToR eplace); 74 swapInNodePreservingAttributesAndChildren(m_spanElement.get(), *m_elementToR eplace);
75 } 75 }
76 76
77 void ReplaceNodeWithSpanCommand::doUnapply() 77 void ReplaceNodeWithSpanCommand::doUnapply()
78 { 78 {
79 if (!m_spanElement->inDocument()) 79 if (!m_spanElement->inShadowIncludingDocument())
80 return; 80 return;
81 swapInNodePreservingAttributesAndChildren(m_elementToReplace.get(), *m_spanE lement); 81 swapInNodePreservingAttributesAndChildren(m_elementToReplace.get(), *m_spanE lement);
82 } 82 }
83 83
84 DEFINE_TRACE(ReplaceNodeWithSpanCommand) 84 DEFINE_TRACE(ReplaceNodeWithSpanCommand)
85 { 85 {
86 visitor->trace(m_elementToReplace); 86 visitor->trace(m_elementToReplace);
87 visitor->trace(m_spanElement); 87 visitor->trace(m_spanElement);
88 SimpleEditCommand::trace(visitor); 88 SimpleEditCommand::trace(visitor);
89 } 89 }
90 90
91 } // namespace blink 91 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698