about summary refs log tree commit diff stats
path: root/color-repl.mu
diff options
context:
space:
mode:
authorKartik K. Agaram <vc@akkartik.com>2015-01-28 01:44:22 -0800
committerKartik K. Agaram <vc@akkartik.com>2015-01-28 01:44:22 -0800
commitfa4e97359f7d00c774c5b6d496a639c035eefee6 (patch)
tree43ef468d4f38e6a2613ab8f56c7452ef25744f99 /color-repl.mu
parent34aa8a8b529d59e3dc2cf106673c1f91204d1c4b (diff)
downloadmu-fa4e97359f7d00c774c5b6d496a639c035eefee6.tar.gz
655 - repl app can now backspace into strings, etc.
Diffstat (limited to 'color-repl.mu')
-rw-r--r--color-repl.mu33
1 files changed, 29 insertions, 4 deletions
diff --git a/color-repl.mu b/color-repl.mu
index eb0bc62d..d33888eb 100644
--- a/color-repl.mu
+++ b/color-repl.mu
@@ -19,7 +19,7 @@
     (len:integer-address <- get-address result:buffer-address/deref length:offset)
     ; handle backspace
     ; test: 3<backspace>4<enter>
-    ; todo: backspace into comment or string; backspace past newline
+    ; todo: backspace past newline
     { begin
       (backspace?:boolean <- equal c:character ((#\backspace literal)))
       (break-unless backspace?:boolean)
@@ -29,6 +29,30 @@
         (zero?:boolean <- lesser-or-equal len:integer-address/deref 0:literal)
         (break-if zero?:boolean)
         (len:integer-address/deref <- subtract len:integer-address/deref 1:literal)
+        ; test: "a"<backspace>bc"
+        ; test: "a\"<backspace>bc"
+        { begin
+          (backspaced-over-close-quote?:boolean <- backspaced-over-unescaped? result:buffer-address ((#\" literal)) escapes:integer-buffer-address)  ; "
+          (break-unless backspaced-over-close-quote?:boolean)
+          (slurp-string result:buffer-address escapes:integer-buffer-address)
+          (jump next-key:offset)
+        }
+        ; test: (+ 1 (<backspace>2)
+        ; test: (+ 1 #\(<backspace><backspace><backspace>2)
+        { begin
+          (backspaced-over-open-paren?:boolean <- backspaced-over-unescaped? result:buffer-address ((#\( literal)) escapes:integer-buffer-address)
+          (break-unless backspaced-over-open-paren?:boolean)
+          (open-parens:integer <- subtract open-parens:integer 1:literal)
+          (jump next-key:offset)
+        }
+        ; test: (+ 1 2)<backspace> 3)
+        ; test: (+ 1 2#\)<backspace><backspace><backspace> 3)
+        { begin
+          (backspaced-over-close-paren?:boolean <- backspaced-over-unescaped? result:buffer-address ((#\) literal)) escapes:integer-buffer-address)
+          (break-unless backspaced-over-close-paren?:boolean)
+          (open-parens:integer <- add open-parens:integer 1:literal)
+          (jump next-key:offset)
+        }
       }
       (jump next-key:offset)
     }
@@ -219,9 +243,10 @@
   ; and char before cursor is not an escape
   { begin
     (most-recent-escape:integer <- last escapes:integer-buffer-address)
-    (curr-idx:integer <- get in:buffer-address/deref length:offset)
-    (curr-idx:integer <- subtract curr-idx:integer 1:literal)
-    (was-unescaped?:boolean <- not-equal curr-idx:integer most-recent-escape:integer)
+    (last-idx:integer <- get in:buffer-address/deref length:offset)
+;?     (print-primitive-to-host most-recent-escape:integer) ;? 1
+;?     (print-primitive-to-host last-idx:integer) ;? 1
+    (was-unescaped?:boolean <- not-equal last-idx:integer most-recent-escape:integer)
     (break-if was-unescaped?:boolean)
     (reply nil:literal)
   }