| \ command line edit and history support 16oct94py |
\ command line edit and history support 16oct94py |
| |
|
| \ Copyright (C) 1995,2000,2003,2004,2005,2006,2007 Free Software Foundation, Inc. |
\ Copyright (C) 1995,2000,2003,2004,2005,2006,2007,2008,2010,2011 Free Software Foundation, Inc. |
| |
|
| \ This file is part of Gforth. |
\ This file is part of Gforth. |
| |
|
| |
|
| [IFUNDEF] #esc 27 Constant #esc [THEN] |
[IFUNDEF] #esc 27 Constant #esc [THEN] |
| |
|
| : at-deltaxy ( dx dy -- ) base @ >r decimal |
: at-deltaxy ( dx dy -- ) |
| |
over 0< over 0= and IF drop abs backspaces EXIT THEN |
| |
base @ >r decimal |
| ?dup IF |
?dup IF |
| #esc emit '[ emit dup abs 0 .r 0< IF 'A ELSE 'B THEN emit |
#esc emit '[ emit dup abs 0 .r 0< IF 'A ELSE 'B THEN emit |
| THEN |
THEN |
| ' xcur-correct IS cur-correct |
' xcur-correct IS cur-correct |
| |
|
| : xback-restore ( u -- ) |
: 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 ; |
screenw @ /mod negate swap negate swap at-deltaxy ; |
| : .rest ( addr pos1 -- addr pos1 ) |
: .rest ( addr pos1 -- addr pos1 ) |
| linew @ xback-restore 2dup type 2dup cur-correct ; |
linew @ xback-restore 2dup type 2dup cur-correct ; |
| : xend-pos ( max span addr pos1 -- max span addr span 0 ) |
: xend-pos ( max span addr pos1 -- max span addr span 0 ) |
| drop over .all 0 ; |
drop over .all 0 ; |
| |
|
| |
: xclear-rest ( max span addr pos -- max pos addr pos false ) |
| : xclear-line ( max span addr pos1 -- max addr ) |
rot >r tuck 2dup r> swap /string u8width dup spaces linew +! .all 0 ; |
| 2dup x-width dup xback-restore dup spaces xback-restore drop nip ; |
|
| : xclear-tib ( max span addr pos -- max 0 addr 0 false ) |
|
| xclear-line 0 tuck dup ; |
|
| |
|
| : (xenter) ( max span addr pos1 -- max span addr pos2 true ) |
: (xenter) ( max span addr pos1 -- max span addr pos2 true ) |
| >r end^ 2@ hist-setpos |
>r end^ 2@ hist-setpos |
| r@ - >string over r@ + -rot move |
r@ - >string over r@ + -rot move |
| rot r@ - -rot .all r@ spaces r> back-restore .rest THEN ; |
rot r@ - -rot .all r@ spaces r> back-restore .rest THEN ; |
| |
|
| |
[IFUNDEF] insert |
| : insert ( string length buffer size -- ) |
: insert ( string length buffer size -- ) |
| rot over min >r r@ - ( left over ) |
rot over min >r r@ - ( left over ) |
| over dup r@ + rot move r> move ; |
over dup r@ + rot move r> move ; |
| |
[THEN] |
| |
|
| : xtab-expand ( max span addr pos1 -- max span addr pos2 0 ) |
: xtab-expand ( max span addr pos1 -- max span addr pos2 0 ) |
| key? IF #tab (xins) 0 EXIT THEN |
key? IF #tab (xins) 0 EXIT THEN |
| ['] ?xdel ctrl H bindkey |
['] ?xdel ctrl H bindkey |
| ['] xeof ctrl D bindkey |
['] xeof ctrl D bindkey |
| ['] <xdel> ctrl X bindkey |
['] <xdel> ctrl X bindkey |
| ['] xclear-tib ctrl K bindkey |
['] xclear-rest ctrl K bindkey |
| ['] xfirst-pos ctrl A bindkey |
['] xfirst-pos ctrl A bindkey |
| ['] xend-pos ctrl E bindkey |
['] xend-pos ctrl E bindkey |
| ['] xretype ctrl L bindkey |
['] xretype ctrl L bindkey |