| OLD | NEW |
| 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 |
| (...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 80 } | 80 } |
| 81 | 81 |
| 82 void SelectionEditor::setVisibleSelection(const VisibleSelection& newSelection,
FrameSelection::SetSelectionOptions options) | 82 void SelectionEditor::setVisibleSelection(const VisibleSelection& newSelection,
FrameSelection::SetSelectionOptions options) |
| 83 { | 83 { |
| 84 m_selection = newSelection; | 84 m_selection = newSelection; |
| 85 if (options & FrameSelection::DoNotAdjustInComposedTree) { | 85 if (options & FrameSelection::DoNotAdjustInComposedTree) { |
| 86 m_selectionInComposedTree.setWithoutValidation(toPositionInComposedTree(
m_selection.base()), toPositionInComposedTree(m_selection.extent())); | 86 m_selectionInComposedTree.setWithoutValidation(toPositionInComposedTree(
m_selection.base()), toPositionInComposedTree(m_selection.extent())); |
| 87 return; | 87 return; |
| 88 } | 88 } |
| 89 | 89 |
| 90 adjustVisibleSelectionInComposedTree(); | 90 SelectionAdjuster::adjustSelectionInComposedTree(&m_selectionInComposedTree,
m_selection); |
| 91 } | 91 } |
| 92 | 92 |
| 93 void SelectionEditor::setVisibleSelection(const VisibleSelectionInComposedTree&
newSelection, FrameSelection::SetSelectionOptions options) | 93 void SelectionEditor::setVisibleSelection(const VisibleSelectionInComposedTree&
newSelection, FrameSelection::SetSelectionOptions options) |
| 94 { | 94 { |
| 95 ASSERT(!(options & FrameSelection::DoNotAdjustInComposedTree)); | 95 ASSERT(!(options & FrameSelection::DoNotAdjustInComposedTree)); |
| 96 m_selectionInComposedTree = newSelection; | 96 m_selectionInComposedTree = newSelection; |
| 97 adjustVisibleSelectionInDOMTree(); | 97 SelectionAdjuster::adjustSelectionInDOMTree(&m_selection, m_selectionInCompo
sedTree); |
| 98 } | 98 } |
| 99 | 99 |
| 100 // Updates |m_selectionInComposedTree| to match with |m_selection|. | 100 // TODO(yosin): We should move |
| 101 void SelectionEditor::adjustVisibleSelectionInComposedTree() | 101 // |SelectionAdjuster::adjustSelectionInComposedTree()| to |
| 102 // "SelectionAdjuster.cpp" |
| 103 // Updates |selectionInComposedTree| to match with |selection|. |
| 104 void SelectionAdjuster::adjustSelectionInComposedTree(VisibleSelectionInComposed
Tree* selectionInComposedTree, const VisibleSelection& selection) |
| 102 { | 105 { |
| 103 if (m_selection.isNone()) { | 106 if (selection.isNone()) { |
| 104 m_selectionInComposedTree = VisibleSelectionInComposedTree(); | 107 *selectionInComposedTree = VisibleSelectionInComposedTree(); |
| 105 return; | 108 return; |
| 106 } | 109 } |
| 107 | 110 |
| 108 const PositionInComposedTree base = toPositionInComposedTree(m_selection.bas
e()); | 111 const PositionInComposedTree& base = toPositionInComposedTree(selection.base
()); |
| 109 const PositionInComposedTree extent = toPositionInComposedTree(m_selection.e
xtent()); | 112 const PositionInComposedTree& extent = toPositionInComposedTree(selection.ex
tent()); |
| 110 const PositionInComposedTree position1 = toPositionInComposedTree(m_selectio
n.start()); | 113 const PositionInComposedTree& position1 = toPositionInComposedTree(selection
.start()); |
| 111 const PositionInComposedTree position2 = toPositionInComposedTree(m_selectio
n.end()); | 114 const PositionInComposedTree& position2 = toPositionInComposedTree(selection
.end()); |
| 112 position1.anchorNode()->updateDistribution(); | 115 position1.anchorNode()->updateDistribution(); |
| 113 position2.anchorNode()->updateDistribution(); | 116 position2.anchorNode()->updateDistribution(); |
| 117 selectionInComposedTree->m_base = base; |
| 118 selectionInComposedTree->m_extent = extent; |
| 119 selectionInComposedTree->m_affinity = selection.m_affinity; |
| 120 selectionInComposedTree->m_isDirectional = selection.m_isDirectional; |
| 121 selectionInComposedTree->m_baseIsFirst = base.isNull() || base.compareTo(ext
ent) <= 0; |
| 114 if (position1.compareTo(position2) <= 0) { | 122 if (position1.compareTo(position2) <= 0) { |
| 115 m_selectionInComposedTree = VisibleSelectionInComposedTree::createWithou
tValidation(base, extent, position1, position2, m_selection.affinity(), m_select
ion.isDirectional()); | 123 selectionInComposedTree->m_start = position1; |
| 116 return; | 124 selectionInComposedTree->m_end = position2; |
| 125 } else { |
| 126 selectionInComposedTree->m_start = position2; |
| 127 selectionInComposedTree->m_end = position1; |
| 117 } | 128 } |
| 118 m_selectionInComposedTree = VisibleSelectionInComposedTree::createWithoutVal
idation(base, extent, position2, position1, m_selection.affinity(), m_selection.
isDirectional()); | 129 selectionInComposedTree->updateSelectionType(); |
| 119 } | 130 } |
| 120 | 131 |
| 121 static bool isCrossingShadowBoundaries(const VisibleSelectionInComposedTree& sel
ection) | 132 static bool isCrossingShadowBoundaries(const VisibleSelectionInComposedTree& sel
ection) |
| 122 { | 133 { |
| 123 if (!selection.isRange()) | 134 if (!selection.isRange()) |
| 124 return false; | 135 return false; |
| 125 TreeScope& treeScope = selection.base().anchorNode()->treeScope(); | 136 TreeScope& treeScope = selection.base().anchorNode()->treeScope(); |
| 126 return selection.extent().anchorNode()->treeScope() != treeScope | 137 return selection.extent().anchorNode()->treeScope() != treeScope |
| 127 || selection.start().anchorNode()->treeScope() != treeScope | 138 || selection.start().anchorNode()->treeScope() != treeScope |
| 128 || selection.end().anchorNode()->treeScope() != treeScope; | 139 || selection.end().anchorNode()->treeScope() != treeScope; |
| 129 } | 140 } |
| 130 | 141 |
| 131 void SelectionEditor::adjustVisibleSelectionInDOMTree() | 142 // TODO(yosin): We should move |
| 143 // |SelectionAdjuster::adjustSelectionInDOMTree()| to |
| 144 // "SelectionAdjuster.cpp" |
| 145 void SelectionAdjuster::adjustSelectionInDOMTree(VisibleSelection* selection, co
nst VisibleSelectionInComposedTree& selectionInComposedTree) |
| 132 { | 146 { |
| 133 if (m_selectionInComposedTree.isNone()) { | 147 if (selectionInComposedTree.isNone()) { |
| 134 m_selection = VisibleSelection(); | 148 *selection = VisibleSelection(); |
| 135 return; | 149 return; |
| 136 } | 150 } |
| 137 | 151 |
| 138 const Position base = toPositionInDOMTree(m_selectionInComposedTree.base()); | 152 const Position& base = toPositionInDOMTree(selectionInComposedTree.base()); |
| 139 const Position extent = toPositionInDOMTree(m_selectionInComposedTree.extent
()); | 153 const Position& extent = toPositionInDOMTree(selectionInComposedTree.extent(
)); |
| 140 | 154 |
| 141 if (isCrossingShadowBoundaries(m_selectionInComposedTree)) { | 155 if (isCrossingShadowBoundaries(selectionInComposedTree)) { |
| 142 m_selection = VisibleSelection(base, extent); | 156 *selection = VisibleSelection(base, extent); |
| 143 return; | 157 return; |
| 144 } | 158 } |
| 145 | 159 |
| 146 const Position start = toPositionInDOMTree(m_selectionInComposedTree.start()
); | 160 const Position& position1 = toPositionInDOMTree(selectionInComposedTree.star
t()); |
| 147 const Position end = toPositionInDOMTree(m_selectionInComposedTree.end()); | 161 const Position& position2 = toPositionInDOMTree(selectionInComposedTree.end(
)); |
| 148 const TextAffinity affinity = m_selectionInComposedTree.affinity(); | 162 selection->m_base = base; |
| 149 const bool isDirectional = m_selectionInComposedTree.isDirectional(); | 163 selection->m_extent = extent; |
| 150 if (start.compareTo(end) <= 0) { | 164 selection->m_affinity = selectionInComposedTree.m_affinity; |
| 151 m_selection = VisibleSelection::createWithoutValidation(base, extent, st
art, end, affinity, isDirectional); | 165 selection->m_isDirectional = selectionInComposedTree.m_isDirectional; |
| 152 return; | 166 selection->m_baseIsFirst = base.isNull() || base.compareTo(extent) <= 0; |
| 167 if (position1.compareTo(position2) <= 0) { |
| 168 selection->m_start = position1; |
| 169 selection->m_end = position2; |
| 170 } else { |
| 171 selection->m_start = position2; |
| 172 selection->m_end = position1; |
| 153 } | 173 } |
| 154 m_selection = VisibleSelection::createWithoutValidation(base, extent, end, s
tart, affinity, isDirectional); | 174 selection->updateSelectionType(); |
| 155 } | 175 } |
| 156 | 176 |
| 157 void SelectionEditor::resetXPosForVerticalArrowNavigation() | 177 void SelectionEditor::resetXPosForVerticalArrowNavigation() |
| 158 { | 178 { |
| 159 m_xPosForVerticalArrowNavigation = NoXPosForVerticalArrowNavigation(); | 179 m_xPosForVerticalArrowNavigation = NoXPosForVerticalArrowNavigation(); |
| 160 } | 180 } |
| 161 | 181 |
| 162 void SelectionEditor::setIsDirectional(bool isDirectional) | 182 void SelectionEditor::setIsDirectional(bool isDirectional) |
| 163 { | 183 { |
| 164 m_selection.setIsDirectional(isDirectional); | 184 m_selection.setIsDirectional(isDirectional); |
| (...skipping 777 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 942 DEFINE_TRACE(SelectionEditor) | 962 DEFINE_TRACE(SelectionEditor) |
| 943 { | 963 { |
| 944 visitor->trace(m_frameSelection); | 964 visitor->trace(m_frameSelection); |
| 945 visitor->trace(m_selection); | 965 visitor->trace(m_selection); |
| 946 visitor->trace(m_selectionInComposedTree); | 966 visitor->trace(m_selectionInComposedTree); |
| 947 visitor->trace(m_logicalRange); | 967 visitor->trace(m_logicalRange); |
| 948 VisibleSelectionChangeObserver::trace(visitor); | 968 VisibleSelectionChangeObserver::trace(visitor); |
| 949 } | 969 } |
| 950 | 970 |
| 951 } // namespace blink | 971 } // namespace blink |
| OLD | NEW |