OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 1999 Lars Knoll (knoll@kde.org) | 2 * Copyright (C) 1999 Lars Knoll (knoll@kde.org) |
3 * (C) 1999 Antti Koivisto (koivisto@kde.org) | 3 * (C) 1999 Antti Koivisto (koivisto@kde.org) |
4 * Copyright (C) 2003, 2004, 2005, 2006, 2007, 2008, 2009 Apple Inc. All rights
reserved. | 4 * Copyright (C) 2003, 2004, 2005, 2006, 2007, 2008, 2009 Apple Inc. All rights
reserved. |
5 * | 5 * |
6 * This library is free software; you can redistribute it and/or | 6 * This library is free software; you can redistribute it and/or |
7 * modify it under the terms of the GNU Library General Public | 7 * modify it under the terms of the GNU Library General Public |
8 * License as published by the Free Software Foundation; either | 8 * License as published by the Free Software Foundation; either |
9 * version 2 of the License, or (at your option) any later version. | 9 * version 2 of the License, or (at your option) any later version. |
10 * | 10 * |
11 * This library is distributed in the hope that it will be useful, | 11 * This library is distributed in the hope that it will be useful, |
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of | 12 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
14 * Library General Public License for more details. | 14 * Library General Public License for more details. |
15 * | 15 * |
16 * You should have received a copy of the GNU Library General Public License | 16 * You should have received a copy of the GNU Library General Public License |
17 * along with this library; see the file COPYING.LIB. If not, write to | 17 * along with this library; see the file COPYING.LIB. If not, write to |
18 * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, | 18 * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, |
19 * Boston, MA 02110-1301, USA. | 19 * Boston, MA 02110-1301, USA. |
20 * | 20 * |
21 */ | 21 */ |
22 | 22 |
23 #include "core/layout/LayoutInline.h" | 23 #include "core/layout/LayoutInline.h" |
24 | 24 |
25 #include "core/dom/Fullscreen.h" | 25 #include "core/dom/Fullscreen.h" |
26 #include "core/dom/StyleEngine.h" | 26 #include "core/dom/StyleEngine.h" |
27 #include "core/layout/HitTestResult.h" | 27 #include "core/layout/HitTestResult.h" |
28 #include "core/layout/LayoutBlock.h" | 28 #include "core/layout/LayoutBlock.h" |
| 29 #include "core/layout/LayoutFullScreen.h" |
29 #include "core/layout/LayoutGeometryMap.h" | 30 #include "core/layout/LayoutGeometryMap.h" |
30 #include "core/layout/LayoutTheme.h" | 31 #include "core/layout/LayoutTheme.h" |
31 #include "core/layout/LayoutView.h" | 32 #include "core/layout/LayoutView.h" |
32 #include "core/layout/api/LineLayoutBoxModel.h" | 33 #include "core/layout/api/LineLayoutBoxModel.h" |
33 #include "core/layout/line/InlineTextBox.h" | 34 #include "core/layout/line/InlineTextBox.h" |
34 #include "core/paint/BoxPainter.h" | 35 #include "core/paint/BoxPainter.h" |
35 #include "core/paint/InlinePainter.h" | 36 #include "core/paint/InlinePainter.h" |
36 #include "core/paint/ObjectPainter.h" | 37 #include "core/paint/ObjectPainter.h" |
37 #include "core/paint/PaintLayer.h" | 38 #include "core/paint/PaintLayer.h" |
38 #include "core/style/StyleInheritedData.h" | 39 #include "core/style/StyleInheritedData.h" |
(...skipping 303 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
342 child = currentChild->nextSibling(); | 343 child = currentChild->nextSibling(); |
343 to->addChildIgnoringContinuation(children()->removeChildNode(this, curre
ntChild), nullptr); | 344 to->addChildIgnoringContinuation(children()->removeChildNode(this, curre
ntChild), nullptr); |
344 } | 345 } |
345 } | 346 } |
346 | 347 |
347 void LayoutInline::splitInlines(LayoutBlockFlow* fromBlock, LayoutBlockFlow* toB
lock, | 348 void LayoutInline::splitInlines(LayoutBlockFlow* fromBlock, LayoutBlockFlow* toB
lock, |
348 LayoutBlockFlow* middleBlock, LayoutObject* beforeChild, LayoutBoxModelObjec
t* oldCont) | 349 LayoutBlockFlow* middleBlock, LayoutObject* beforeChild, LayoutBoxModelObjec
t* oldCont) |
349 { | 350 { |
350 ASSERT(isDescendantOf(fromBlock)); | 351 ASSERT(isDescendantOf(fromBlock)); |
351 | 352 |
| 353 // If we're splitting the inline containing the fullscreened element, |
| 354 // |beforeChild| may be the layoutObject for the fullscreened element. Howev
er, |
| 355 // that layoutObject is wrapped in a LayoutFullScreen, so |this| is not its |
| 356 // parent. Since the splitting logic expects |this| to be the parent, set |
| 357 // |beforeChild| to be the LayoutFullScreen. |
| 358 if (Fullscreen* fullscreen = Fullscreen::fromIfExists(document())) { |
| 359 const Element* fullScreenElement = fullscreen->webkitCurrentFullScreenEl
ement(); |
| 360 if (fullScreenElement && beforeChild && beforeChild->node() == fullScree
nElement) |
| 361 beforeChild = fullscreen->fullScreenLayoutObject(); |
| 362 } |
| 363 |
352 // FIXME: Because splitting is O(n^2) as tags nest pathologically, we cap th
e depth at which we're willing to clone. | 364 // FIXME: Because splitting is O(n^2) as tags nest pathologically, we cap th
e depth at which we're willing to clone. |
353 // There will eventually be a better approach to this problem that will let
us nest to a much | 365 // There will eventually be a better approach to this problem that will let
us nest to a much |
354 // greater depth (see bugzilla bug 13430) but for now we have a limit. This
*will* result in | 366 // greater depth (see bugzilla bug 13430) but for now we have a limit. This
*will* result in |
355 // incorrect rendering, but the alternative is to hang forever. | 367 // incorrect rendering, but the alternative is to hang forever. |
356 const unsigned cMaxSplitDepth = 200; | 368 const unsigned cMaxSplitDepth = 200; |
357 Vector<LayoutInline*> inlinesToClone; | 369 Vector<LayoutInline*> inlinesToClone; |
358 LayoutInline* topMostInline = this; | 370 LayoutInline* topMostInline = this; |
359 for (LayoutObject* o = this; o != fromBlock; o = o->parent()) { | 371 for (LayoutObject* o = this; o != fromBlock; o = o->parent()) { |
360 topMostInline = toLayoutInline(o); | 372 topMostInline = toLayoutInline(o); |
361 if (inlinesToClone.size() < cMaxSplitDepth) | 373 if (inlinesToClone.size() < cMaxSplitDepth) |
(...skipping 984 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1346 | 1358 |
1347 void LayoutInline::invalidateDisplayItemClients(PaintInvalidationReason invalida
tionReason) const | 1359 void LayoutInline::invalidateDisplayItemClients(PaintInvalidationReason invalida
tionReason) const |
1348 { | 1360 { |
1349 LayoutBoxModelObject::invalidateDisplayItemClients(invalidationReason); | 1361 LayoutBoxModelObject::invalidateDisplayItemClients(invalidationReason); |
1350 | 1362 |
1351 for (InlineFlowBox* box = firstLineBox(); box; box = box->nextLineBox()) | 1363 for (InlineFlowBox* box = firstLineBox(); box; box = box->nextLineBox()) |
1352 invalidateDisplayItemClient(*box, invalidationReason); | 1364 invalidateDisplayItemClient(*box, invalidationReason); |
1353 } | 1365 } |
1354 | 1366 |
1355 } // namespace blink | 1367 } // namespace blink |
OLD | NEW |