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

Side by Side Diff: third_party/WebKit/Source/core/page/FrameTree.cpp

Issue 1635873003: Replicating WebFrame::uniqueName across renderers. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@dump-render-tree3
Patch Set: Addressed CR feedback from Charlie. Created 4 years, 10 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) Research In Motion Limited 2010. All rights reserved. 2 * Copyright (C) Research In Motion Limited 2010. All rights reserved.
3 * Copyright (C) 2006 Apple Computer, Inc. 3 * Copyright (C) 2006 Apple Computer, Inc.
4 * 4 *
5 * This library is free software; you can redistribute it and/or 5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Library General Public 6 * modify it under the terms of the GNU Library General Public
7 * License as published by the Free Software Foundation; either 7 * License as published by the Free Software Foundation; either
8 * version 2 of the License, or (at your option) any later version. 8 * version 2 of the License, or (at your option) any later version.
9 * 9 *
10 * This library is distributed in the hope that it will be useful, 10 * This library is distributed in the hope that it will be useful,
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after
51 { 51 {
52 } 52 }
53 53
54 void FrameTree::setName(const AtomicString& name, const AtomicString& fallbackNa me) 54 void FrameTree::setName(const AtomicString& name, const AtomicString& fallbackNa me)
55 { 55 {
56 m_name = name; 56 m_name = name;
57 if (!parent()) { 57 if (!parent()) {
58 m_uniqueName = name; 58 m_uniqueName = name;
59 return; 59 return;
60 } 60 }
61 m_uniqueName = AtomicString(); // Remove our old frame name so it's not cons idered in uniqueChildName. 61
62 m_uniqueName = parent()->tree().uniqueChildName(name.isEmpty() ? fallbackNam e : name); 62 // Remove our old frame name so it's not considered in calculateUniqueNameFo rChildFrame.
63 m_uniqueName = AtomicString();
64
65 m_uniqueName = parent()->tree().calculateUniqueNameForChildFrame(true, name, fallbackName);
63 } 66 }
64 67
65 void FrameTree::setNameForReplacementFrame(const AtomicString& name, const Atomi cString& uniqueName) 68 void FrameTree::setReplicatedName(const AtomicString& name, const AtomicString& uniqueName)
66 { 69 {
70 if (!parent()) {
71 ASSERT(uniqueName == name);
72 } else {
73 ASSERT(!uniqueName.isEmpty());
74 }
75
67 m_name = name; 76 m_name = name;
68 m_uniqueName = uniqueName; 77 m_uniqueName = uniqueName;
69 } 78 }
70 79
71 Frame* FrameTree::parent() const 80 Frame* FrameTree::parent() const
72 { 81 {
73 if (!m_thisFrame->client()) 82 if (!m_thisFrame->client())
74 return nullptr; 83 return nullptr;
75 return m_thisFrame->client()->parent(); 84 return m_thisFrame->client()->parent();
76 } 85 }
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after
116 125
117 bool FrameTree::uniqueNameExists(const AtomicString& name) const 126 bool FrameTree::uniqueNameExists(const AtomicString& name) const
118 { 127 {
119 for (Frame* frame = top(); frame; frame = frame->tree().traverseNext()) { 128 for (Frame* frame = top(); frame; frame = frame->tree().traverseNext()) {
120 if (frame->tree().uniqueName() == name) 129 if (frame->tree().uniqueName() == name)
121 return true; 130 return true;
122 } 131 }
123 return false; 132 return false;
124 } 133 }
125 134
126 AtomicString FrameTree::uniqueChildName(const AtomicString& requestedName) const 135 AtomicString FrameTree::calculateUniqueNameForNewChildFrame(
136 const AtomicString& name,
137 const AtomicString& fallbackName) const
127 { 138 {
139 return calculateUniqueNameForChildFrame(false, name, fallbackName);
140 }
141
142 AtomicString FrameTree::calculateUniqueNameForChildFrame(
143 bool existingChildFrame,
144 const AtomicString& originalRequestedName,
145 const AtomicString& fallbackName) const
146 {
147 const AtomicString& requestedName =
148 originalRequestedName.isEmpty() ? fallbackName : originalRequestedName;
128 if (!requestedName.isEmpty() && !uniqueNameExists(requestedName) && requeste dName != "_blank") 149 if (!requestedName.isEmpty() && !uniqueNameExists(requestedName) && requeste dName != "_blank")
129 return requestedName; 150 return requestedName;
130 151
131 // Create a repeatable name for a child about to be added to us. The name mu st be 152 // Create a repeatable name for a child about to be added to us. The name mu st be
132 // unique within the frame tree. The string we generate includes a "path" of names 153 // unique within the frame tree. The string we generate includes a "path" of names
133 // from the root frame down to us. For this path to be unique, each set of s iblings must 154 // from the root frame down to us. For this path to be unique, each set of s iblings must
134 // contribute a unique name to the path, which can't collide with any HTML-a ssigned names. 155 // contribute a unique name to the path, which can't collide with any HTML-a ssigned names.
135 // We generate this path component by index in the child list along with an unlikely 156 // We generate this path component by index in the child list along with an unlikely
136 // frame name that can't be set in HTML because it collides with comment syn tax. 157 // frame name that can't be set in HTML because it collides with comment syn tax.
137 158
(...skipping 15 matching lines...) Expand all
153 name.append(frame->tree().uniqueName().string().substring(framePathPrefi xLength, 174 name.append(frame->tree().uniqueName().string().substring(framePathPrefi xLength,
154 frame->tree().uniqueName().length() - framePathPrefixLength - frameP athSuffixLength)); 175 frame->tree().uniqueName().length() - framePathPrefixLength - frameP athSuffixLength));
155 } 176 }
156 for (int i = chain.size() - 1; i >= 0; --i) { 177 for (int i = chain.size() - 1; i >= 0; --i) {
157 frame = chain[i]; 178 frame = chain[i];
158 name.append('/'); 179 name.append('/');
159 name.append(frame->tree().uniqueName()); 180 name.append(frame->tree().uniqueName());
160 } 181 }
161 182
162 name.appendLiteral("/<!--frame"); 183 name.appendLiteral("/<!--frame");
163 name.appendNumber(childCount() - 1); 184 name.appendNumber(childCount() - (existingChildFrame ? 1 : 0));
dcheng 2016/02/16 22:17:29 Is it possible to pull the FrameTree changes into
Łukasz Anforowicz 2016/02/16 23:39:53 I think it is not possible. 1. I've added propaga
164 name.appendLiteral("-->-->"); 185 name.appendLiteral("-->-->");
165 186
166 return name.toAtomicString(); 187 return name.toAtomicString();
167 } 188 }
168 189
169 Frame* FrameTree::scopedChild(unsigned index) const 190 Frame* FrameTree::scopedChild(unsigned index) const
170 { 191 {
171 unsigned scopedIndex = 0; 192 unsigned scopedIndex = 0;
172 for (Frame* child = firstChild(); child; child = child->tree().nextSibling() ) { 193 for (Frame* child = firstChild(); child; child = child->tree().nextSibling() ) {
173 if (child->client()->inShadowTree()) 194 if (child->client()->inShadowTree())
(...skipping 228 matching lines...) Expand 10 before | Expand all | Expand 10 after
402 { 423 {
403 if (!frame) { 424 if (!frame) {
404 printf("Null input frame\n"); 425 printf("Null input frame\n");
405 return; 426 return;
406 } 427 }
407 428
408 printFrames(frame->tree().top(), frame, 0); 429 printFrames(frame->tree().top(), frame, 0);
409 } 430 }
410 431
411 #endif 432 #endif
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698