mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-26 18:02:06 +00:00 
			
		
		
		
	GTextEditor: Allow GTextDocumentSpans to be "skippable"
Setting the is_skippable flag on a GTextDocumentSpan will now cause the cursor to skip over that span when moving with Ctrl+Left/Right.
This commit is contained in:
		
							parent
							
								
									27a30fdc2a
								
							
						
					
					
						commit
						57f7009b9e
					
				
					 3 changed files with 56 additions and 26 deletions
				
			
		|  | @ -678,19 +678,15 @@ void GTextEditor::keydown_event(GKeyEvent& event) | |||
|     if (event.key() == KeyCode::Key_Left) { | ||||
|         if (event.ctrl() && document().has_spans()) { | ||||
|             // FIXME: Do something nice when the document has no spans.
 | ||||
|             for (int i = 0; i < document().spans().size(); ++i) { | ||||
|                 if (!document().spans()[i].range.contains(m_cursor)) | ||||
|                     continue; | ||||
|                 GTextPosition new_cursor = i == 0 | ||||
|                     ? GTextPosition(0, 0) | ||||
|                     : document().spans()[i - 1].range.start(); | ||||
|                 toggle_selection_if_needed_for_event(event); | ||||
|                 set_cursor(new_cursor); | ||||
|                 if (event.shift() && m_selection.start().is_valid()) { | ||||
|                     m_selection.set_end(m_cursor); | ||||
|                     did_update_selection(); | ||||
|                 } | ||||
|                 break; | ||||
|             auto span = document().first_non_skippable_span_before(m_cursor); | ||||
|             GTextPosition new_cursor = !span.has_value() | ||||
|                 ? GTextPosition(0, 0) | ||||
|                 : span.value().range.start(); | ||||
|             toggle_selection_if_needed_for_event(event); | ||||
|             set_cursor(new_cursor); | ||||
|             if (event.shift() && m_selection.start().is_valid()) { | ||||
|                 m_selection.set_end(m_cursor); | ||||
|                 did_update_selection(); | ||||
|             } | ||||
|             return; | ||||
|         } | ||||
|  | @ -717,19 +713,15 @@ void GTextEditor::keydown_event(GKeyEvent& event) | |||
|     if (event.key() == KeyCode::Key_Right) { | ||||
|         if (event.ctrl() && document().has_spans()) { | ||||
|             // FIXME: Do something nice when the document has no spans.
 | ||||
|             for (int i = 0; i < document().spans().size(); ++i) { | ||||
|                 if (!document().spans()[i].range.contains(m_cursor)) | ||||
|                     continue; | ||||
|                 GTextPosition new_cursor = i == (document().spans().size() - 1) | ||||
|                     ? document().spans().last().range.end() | ||||
|                     : document().spans()[i + 1].range.start(); | ||||
|                 toggle_selection_if_needed_for_event(event); | ||||
|                 set_cursor(new_cursor); | ||||
|                 if (event.shift() && m_selection.start().is_valid()) { | ||||
|                     m_selection.set_end(m_cursor); | ||||
|                     did_update_selection(); | ||||
|                 } | ||||
|                 break; | ||||
|             auto span = document().first_non_skippable_span_after(m_cursor); | ||||
|             GTextPosition new_cursor = !span.has_value() | ||||
|                 ? document().spans().last().range.end() | ||||
|                 : span.value().range.start(); | ||||
|             toggle_selection_if_needed_for_event(event); | ||||
|             set_cursor(new_cursor); | ||||
|             if (event.shift() && m_selection.start().is_valid()) { | ||||
|                 m_selection.set_end(m_cursor); | ||||
|                 did_update_selection(); | ||||
|             } | ||||
|             return; | ||||
|         } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Andreas Kling
						Andreas Kling