commit f46d4a54a4db77dd810b33ed124106e369a187ab
parent 3cfd2d88287d0df6e43ce4c29e6b678c5544b603
Author: neauoire <aliceffekt@gmail.com>
Date:   Tue,  9 Mar 2021 20:26:33 -0800
Improved movements further
Diffstat:
1 file changed, 56 insertions(+), 57 deletions(-)
diff --git a/projects/software/left.usm b/projects/software/left.usm
@@ -4,9 +4,8 @@
 	TODO
 		- Follow cursor when moving out of the screen
 		- Save/Load
-		- Select blank lines
 		- Real scrolling distance
-		- page up/down move with ctrl+arrow
+		- Page up/down move with ctrl+arrow
 		- Double-click select word
 		- Right-click find next instance of selection
 		- Mouse down selection
@@ -14,6 +13,7 @@
 		- x scroll
 		- Don't scroll past oef
 		- Don't draw past eof
+		- Draw tab characters
 )
 
 &Console    { pad 8 stdio 1 }
@@ -162,21 +162,21 @@ BRK
 
 		( line number )
 		,no-click-line ~dev/mouse.x #0010 GTH2 JMP? POP2
-			~dev/mouse.y #0008 DIV2 ~scroll.y ADD2 =position.y #0001 =position.x ,select JSR
-			,clamp-selection JSR ,redraw JSR ,click-end JMP
+			~dev/mouse.y #0008 DIV2 ~scroll.y ADD2 =position.y #0000 =position.x 
+			,find-selection JSR DUP2 =selection.from #0001 ADD2 =selection.to
+			,redraw JSR ,click-end JMP
 		@no-click-line
 
 		( select body )
 		~dev/mouse.y #0008 DIV2 ~scroll.y ADD2 =position.y
 		~dev/mouse.x ~textarea.x1 SUB2 #0007 ADD2 #0007 DIV2 =position.x
 
-		,select JSR
+		,find-selection JSR DUP2 =selection.from #0001 ADD2 =selection.to
 		,redraw JSR
 
 	@click-end
 
-	( decr ctrl lock )
-	,skip-unlock ~ctrl_lock #00 EQU JMP? POP2 ~ctrl_lock #01 SUB =ctrl_lock @skip-unlock
+	( unlock ) ,skip-unlock ~ctrl_lock #00 EQU JMP? POP2 ~ctrl_lock #01 SUB =ctrl_lock @skip-unlock
 
 	,draw-cursor JSR
 
@@ -201,14 +201,6 @@ RTS
 
 RTS
 
-@scroll-up
-	
-	( clamp ) ~scroll.y #0000 EQU2 RTS?
-	( decr ) ~scroll.y #0001 SUB2 =scroll.y
-	,redraw JSR
-
-RTS
-
 @goto-linestart
 
 	@goto-linestart-loop
@@ -244,7 +236,8 @@ RTS
 		,find-wordstart-end ~j LDR #0a EQU JMP? POP2
 		,find-wordstart-end ~j LDR #0d EQU JMP? POP2
 		,find-wordstart-loop ~j ,document.body GTH2 JMP? POP2
-	@find-wordstart-end ~j #0001 SUB2
+	@find-wordstart-end 
+	( return ) ~j #0001 SUB2
 
 RTS
 
@@ -257,28 +250,39 @@ RTS
 		,find-wordend-end ~j LDR #0a EQU JMP? POP2
 		,find-wordend-end ~j LDR #0d EQU JMP? POP2
 		,find-wordend-loop ~j ,document.body GTH2 JMP? POP2
-	@find-wordend-end ~j #0001 ADD2
+	@find-wordend-end 
+	( return ) ~j #0001 ADD2
 
 RTS
 
-@get-position ( selection -> position )
+@find-line ( position -> addr )
 
-	,document.body =j #0000 =position.x #0000 =position.y
+	,document.body =j #0000 =pt.y
+	@find-line-loop
+		,find-line-end ~pt.y ~position.y #0001 SUB2 GTH2 JMP? POP2
+		,find-line-no-space ~j LDR #0a NEQ ~j LDR #0d NEQ #0101 EQU2 JMP? POP2
+			( incr ) ~pt.y #0001 ADD2 =pt.y
+		@find-line-no-space
+		( incr ) ~j #0001 ADD2 =j
+	,find-line-loop ~j LDR #00 NEQ JMP? POP2
+	@find-line-end
+	( return ) ~j
 
-	@get-position-loop
+RTS
 
-		,no-position-space ~j LDR #0a NEQ ~j LDR #0d NEQ #0101 EQU2 JMP? POP2
-			( incr ) ~position.y #0001 ADD2 =position.y
-			#0000 =position.x
-		@no-position-space
+@find-selection ( position -> addr )
 
-		,no-position-reached ~j ~selection.from NEQ2 JMP? POP2
-			RTS
-		@no-position-reached
+	,find-line JSR ( find line )
 
-		( incr ) ~position.x #0001 ADD2 =position.x
-		( incr ) ~j #0001 ADD2 =j
-	,get-position-loop ~j LDR #00 NEQ JMP? POP2
+	#0000 =pt.x
+
+	@find-selection-loop
+		,find-selection-end ~j ~pt.x ADD2 LDR #0a EQU JMP? POP2
+		,find-selection-end ~j ~pt.x ADD2 LDR #0d EQU JMP? POP2
+		( incr ) ~pt.x #0001 ADD2 =pt.x
+		,find-selection-loop ~pt.x ~position.x #0001 SUB2 LTH2 JMP? POP2
+	@find-selection-end
+	( return ) ~pt.x ADD2
 
 RTS
 
@@ -304,10 +308,11 @@ RTS
 
 RTS
 
+( drawing functions )
+
 @redraw
 
 	,draw-lines JSR
-
 	,draw-textarea JSR
 	,draw-scrollbar JSR
 	,draw-titlebar JSR
@@ -329,22 +334,18 @@ RTS
 @draw-lines
 	
 	#0000 =j
-	#0000 =dev/sprite.x
-	#0000 =dev/sprite.y
-
+	#0000 =dev/sprite.x #0000 =dev/sprite.y
 	@draw-lines-loop
-
-		#0000 =dev/sprite.x
-		
 		~scroll.y ~j ADD2 =addr
+		#0000 =dev/sprite.x
 		,font_hex #00 ,addr #0001 ADD2 LDR #f0 AND #04 ROR #08 MUL ADD2 =dev/sprite.addr
-		( draw ) #02 ~addr ~position.y EQU2 ADD =dev/sprite.color
-		~dev/sprite.x #0008 ADD2 =dev/sprite.x
+		( draw ) #02 ~addr ~position.y EQU2 #06 MUL ADD =dev/sprite.color
+		#0008 =dev/sprite.x
 		,font_hex #00 ,addr #0001 ADD2 LDR #0f AND #08 MUL ADD2 =dev/sprite.addr
-		( draw ) #02 ~addr ~position.y EQU2 ADD =dev/sprite.color
+		( draw ) #02 ~addr ~position.y EQU2 #06 MUL ADD =dev/sprite.color
 		( incr ) ~j #0001 ADD2 =j
 		( incr ) ~dev/sprite.y #0008 ADD2 =dev/sprite.y
-		,draw-lines-loop ~j ~dev/screen.height #0008 DIV2 NEQ2 JMP? POP2
+		,draw-lines-loop ~j ~dev/screen.height #0008 SUB2 #0008 DIV2 NEQ2 JMP? POP2
 
 RTS
 
@@ -413,11 +414,23 @@ RTS
 
 	@draw-textarea-loop
 
+		,draw-textarea-end ~dev/sprite.y ~dev/screen.height #0010 SUB2 GTH2 JMP? POP2
+
+		( get character )
+		,font #00 ~j LDR #20 SUB #0008 MUL2 ADD2 =dev/sprite.addr
+
+		( draw ) #01 
+		~j ~selection.from #0001 SUB2 GTH2 
+		~j ~selection.to LTH2 #0101 EQU2
+		#05 MUL ADD =dev/sprite.color
+
 		,no-linebreak ~j LDR #0a NEQ ~j LDR #0d NEQ #0101 EQU2 JMP? POP2
 			( draw linebreak )
 			,linebreak_icn =dev/sprite.addr
-			#02 =dev/sprite.color
-
+			( draw ) #03
+			~j ~selection.from #0001 SUB2 GTH2 
+			~j ~selection.to LTH2 #0101 EQU2
+			#05 MUL ADD =dev/sprite.color
 			( fill clear )
 			@fill-clear
 				( incr ) ~dev/sprite.x #0008 ADD2 =dev/sprite.x
@@ -428,16 +441,6 @@ RTS
 			( incr ) ~dev/sprite.y #0008 ADD2 =dev/sprite.y
 		@no-linebreak
 
-		,draw-textarea-end ~dev/sprite.y ~dev/screen.height #0010 SUB2 GTH2 JMP? POP2
-
-		( get character )
-		,font #00 ~j LDR #20 SUB #0008 MUL2 ADD2 =dev/sprite.addr
-
-		( draw ) #01 
-		~j ~selection.from #0001 SUB2 GTH2 
-		~j ~selection.to LTH2 #0101 EQU2
-		#05 MUL ADD =dev/sprite.color
-
 		( incr ) ~j #0001 ADD2 =j
 		( incr ) ~dev/sprite.x #0007 ADD2 =dev/sprite.x
 
@@ -489,10 +492,6 @@ RTS
 	( selection )
 	~selection.from ,document.body SUB2 ,draw-short JSR
 
-	( length )
-	~dev/screen.width #0040 SUB2 =dev/sprite.x
-	~document.eof ,document.body SUB2 ,draw-short JSR
-
 RTS
 
 @font_hex ( 0-F TODO: should pull from @font instead.. )