--- gforth/history.fs 2011/12/31 15:29:25 1.77 +++ gforth/history.fs 2012/08/15 00:48:12 1.79 @@ -118,10 +118,11 @@ Variable screenw \ Create lfpad #lf c, : (enter) ( max span addr pos1 -- max span addr pos2 true ) - >r end^ 2@ hist-setpos - 2dup swap history write-line drop ( throw ) \ don't worry about errors - hist-pos 2dup backward^ 2! end^ 2! - r> (ret) ; + >r 2dup swap -trailing nip IF + end^ 2@ hist-setpos + 2dup swap history write-line drop + hist-pos 2dup backward^ 2! end^ 2! + THEN r> (ret) ; : extract-word ( addr len -- addr' len' ) dup >r BEGIN 1- dup 0>= WHILE 2dup + c@ bl = UNTIL THEN 1+ @@ -206,7 +207,8 @@ require utf-8.fs [IFUNDEF] #esc 27 Constant #esc [THEN] -: at-deltaxy ( dx dy -- ) +Defer at-deltaxy +: vt100-at-deltaxy ( dx dy -- ) over 0< over 0= and IF drop abs backspaces EXIT THEN base @ >r decimal ?dup IF @@ -215,6 +217,7 @@ require utf-8.fs ?dup IF #esc emit '[ emit dup abs 0 .r 0< IF 'D ELSE 'C THEN emit THEN r> base ! ; +' vt100-at-deltaxy IS at-deltaxy \ : cygwin? ( -- flag ) s" TERM" getenv s" cygwin" str= ; \ : at-xy? ( -- x y ) @@ -284,10 +287,11 @@ require utf-8.fs rot >r tuck 2dup r> swap /string u8width dup spaces linew +! .all 0 ; : (xenter) ( max span addr pos1 -- max span addr pos2 true ) - >r end^ 2@ hist-setpos - 2dup swap history write-line drop ( throw ) \ don't worry about errors - hist-pos 2dup backward^ 2! end^ 2! - r> .all space true ; + >r 2dup swap -trailing nip IF + end^ 2@ hist-setpos + 2dup swap history write-line drop ( throw ) \ don't worry about errors + hist-pos 2dup backward^ 2! end^ 2! + THEN r> .all space true ; : xkill-expand ( max span addr pos1 -- max span addr pos2 ) prefix-found cell+ @ ?dup IF >r