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

Side by Side Diff: sky/engine/core/editing/FrameSelection.cpp

Issue 922893002: Merge the Sky Engine changes from the SkyDart branch (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: Created 5 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) 2004, 2008, 2009, 2010 Apple Inc. All rights reserved. 2 * Copyright (C) 2004, 2008, 2009, 2010 Apple 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 5 * modification, are permitted provided that the following conditions
6 * are met: 6 * are met:
7 * 1. Redistributions of source code must retain the above copyright 7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer. 8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright 9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the 10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution. 11 * documentation and/or other materials provided with the distribution.
12 * 12 *
13 * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY 13 * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY
14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR 16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR
17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY 20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24 */ 24 */
25 25
26 #include "sky/engine/config.h" 26 #include "sky/engine/config.h"
27 #include "sky/engine/core/editing/FrameSelection.h" 27 #include "sky/engine/core/editing/FrameSelection.h"
28 28
29 #include <stdio.h> 29 #include <stdio.h>
30 #include "sky/engine/bindings/core/v8/ExceptionState.h" 30 #include "sky/engine/bindings2/exception_state.h"
31 #include "sky/engine/core/css/StylePropertySet.h" 31 #include "sky/engine/core/css/StylePropertySet.h"
32 #include "sky/engine/core/dom/CharacterData.h" 32 #include "sky/engine/core/dom/CharacterData.h"
33 #include "sky/engine/core/dom/Document.h" 33 #include "sky/engine/core/dom/Document.h"
34 #include "sky/engine/core/dom/Element.h" 34 #include "sky/engine/core/dom/Element.h"
35 #include "sky/engine/core/dom/ElementTraversal.h" 35 #include "sky/engine/core/dom/ElementTraversal.h"
36 #include "sky/engine/core/dom/NodeTraversal.h" 36 #include "sky/engine/core/dom/NodeTraversal.h"
37 #include "sky/engine/core/dom/Text.h" 37 #include "sky/engine/core/dom/Text.h"
38 #include "sky/engine/core/editing/Editor.h" 38 #include "sky/engine/core/editing/Editor.h"
39 #include "sky/engine/core/editing/InputMethodController.h" 39 #include "sky/engine/core/editing/InputMethodController.h"
40 #include "sky/engine/core/editing/RenderedPosition.h" 40 #include "sky/engine/core/editing/RenderedPosition.h"
(...skipping 290 matching lines...) Expand 10 before | Expand all | Expand 10 after
331 // Change the base and extent to the start and end, but don't re-validat e the 331 // Change the base and extent to the start and end, but don't re-validat e the
332 // selection, since doing so could move the start and end into the node 332 // selection, since doing so could move the start and end into the node
333 // that is about to be removed. 333 // that is about to be removed.
334 if (m_selection.isBaseFirst()) 334 if (m_selection.isBaseFirst())
335 m_selection.setWithoutValidation(m_selection.start(), m_selection.en d()); 335 m_selection.setWithoutValidation(m_selection.start(), m_selection.en d());
336 else 336 else
337 m_selection.setWithoutValidation(m_selection.end(), m_selection.star t()); 337 m_selection.setWithoutValidation(m_selection.end(), m_selection.star t());
338 } else if (RefPtr<Range> range = m_selection.firstRange()) { 338 } else if (RefPtr<Range> range = m_selection.firstRange()) {
339 TrackExceptionState exceptionState; 339 TrackExceptionState exceptionState;
340 Range::CompareResults compareResult = range->compareNode(&node, exceptio nState); 340 Range::CompareResults compareResult = range->compareNode(&node, exceptio nState);
341 if (!exceptionState.hadException() && (compareResult == Range::NODE_BEFO RE_AND_AFTER || compareResult == Range::NODE_INSIDE)) { 341 if (!exceptionState.had_exception() && (compareResult == Range::NODE_BEF ORE_AND_AFTER || compareResult == Range::NODE_INSIDE)) {
342 // If we did nothing here, when this node's renderer was destroyed, the rect that it 342 // If we did nothing here, when this node's renderer was destroyed, the rect that it
343 // occupied would be invalidated, but, selection gaps that change as a result of 343 // occupied would be invalidated, but, selection gaps that change as a result of
344 // the removal wouldn't be invalidated. 344 // the removal wouldn't be invalidated.
345 // FIXME: Don't do so much unnecessary invalidation. 345 // FIXME: Don't do so much unnecessary invalidation.
346 clearRenderTreeSelection = true; 346 clearRenderTreeSelection = true;
347 } 347 }
348 } 348 }
349 349
350 if (clearRenderTreeSelection) 350 if (clearRenderTreeSelection)
351 m_selection.start().document()->renderView()->clearSelection(); 351 m_selection.start().document()->renderView()->clearSelection();
(...skipping 1277 matching lines...) Expand 10 before | Expand all | Expand 10 after
1629 sel.showTreeForThis(); 1629 sel.showTreeForThis();
1630 } 1630 }
1631 1631
1632 void showTree(const blink::FrameSelection* sel) 1632 void showTree(const blink::FrameSelection* sel)
1633 { 1633 {
1634 if (sel) 1634 if (sel)
1635 sel->showTreeForThis(); 1635 sel->showTreeForThis();
1636 } 1636 }
1637 1637
1638 #endif 1638 #endif
OLDNEW
« no previous file with comments | « sky/engine/core/editing/EditorCommand.cpp ('k') | sky/engine/core/editing/InsertIntoTextNodeCommand.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698