--- gforth/history.fs 2010/01/23 22:19:50 1.73 +++ gforth/history.fs 2012/12/31 15:25:18 1.80 @@ -1,6 +1,6 @@ \ command line edit and history support 16oct94py -\ Copyright (C) 1995,2000,2003,2004,2005,2006,2007,2008 Free Software Foundation, Inc. +\ Copyright (C) 1995,2000,2003,2004,2005,2006,2007,2008,2010,2011,2012 Free Software Foundation, Inc. \ This file is part of Gforth. @@ -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 ) @@ -232,6 +235,8 @@ require utf-8.fs ' xcur-correct IS cur-correct : xback-restore ( u -- ) + dup screenw @ mod 0= IF 1- 0 max THEN + \ correction for line=screenw, no wraparound then! screenw @ /mod negate swap negate swap at-deltaxy ; : .rest ( addr pos1 -- addr pos1 ) linew @ xback-restore 2dup type 2dup cur-correct ; @@ -282,19 +287,22 @@ 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 r@ - >string over r@ + -rot move rot r@ - -rot .all r@ spaces r> back-restore .rest THEN ; +[IFUNDEF] insert : insert ( string length buffer size -- ) rot over min >r r@ - ( left over ) over dup r@ + rot move r> move ; +[THEN] : xtab-expand ( max span addr pos1 -- max span addr pos2 0 ) key? IF #tab (xins) 0 EXIT THEN