factor/basis/editors/editors.factor

85 lines
2.0 KiB
Factor
Raw Normal View History

2008-03-26 15:55:04 -04:00
! Copyright (C) 2005, 2008 Slava Pestov.
2007-09-20 18:09:08 -04:00
! See http://factorcode.org/license.txt for BSD license.
2008-06-25 04:25:08 -04:00
USING: parser lexer kernel namespaces sequences definitions
2008-07-02 01:20:01 -04:00
io.files summary continuations tools.crossref tools.vocabs io
2008-06-25 04:25:08 -04:00
prettyprint source-files assocs vocabs vocabs.loader io.backend
splitting accessors ;
2007-09-20 18:09:08 -04:00
IN: editors
TUPLE: no-edit-hook ;
M: no-edit-hook summary
drop "You must load one of the below vocabularies before using editor integration:" ;
2007-09-20 18:09:08 -04:00
SYMBOL: edit-hook
: available-editors ( -- seq )
2008-03-13 04:35:54 -04:00
"editors" all-child-vocabs-seq [ vocab-name ] map ;
: editor-restarts ( -- alist )
available-editors
[ [ "Load " prepend ] keep ] { } map>assoc ;
: no-edit-hook ( -- )
\ no-edit-hook new
editor-restarts throw-restarts
require ;
2007-09-20 18:09:08 -04:00
: edit-location ( file line -- )
>r (normalize-path) r>
2008-03-27 19:00:55 -04:00
edit-hook get [ call ] [ no-edit-hook edit-location ] if* ;
2007-09-20 18:09:08 -04:00
: edit ( defspec -- )
where [ first2 edit-location ] when* ;
2008-02-24 18:40:28 -05:00
: edit-vocab ( name -- )
vocab-source-path 1 edit-location ;
2008-06-25 04:25:08 -04:00
GENERIC: error-file ( error -- file )
2008-06-25 04:25:08 -04:00
GENERIC: error-line ( error -- line )
2008-06-26 21:46:59 -04:00
M: lexer-error error-file
error>> error-file ;
2008-06-26 21:46:59 -04:00
M: lexer-error error-line
[ error>> error-line ] [ line>> ] bi or ;
2008-06-25 04:25:08 -04:00
2008-06-26 21:46:59 -04:00
M: source-file-error error-file
[ error>> error-file ] [ file>> path>> ] bi or ;
2008-06-25 04:25:08 -04:00
2008-06-26 21:46:59 -04:00
M: source-file-error error-line
error>> error-line ;
2008-06-25 04:25:08 -04:00
2008-06-26 21:46:59 -04:00
M: condition error-file
error>> error-file ;
2008-06-25 04:25:08 -04:00
2008-06-26 21:46:59 -04:00
M: condition error-line
error>> error-line ;
2008-06-25 04:25:08 -04:00
2008-06-26 21:46:59 -04:00
M: object error-file
drop f ;
M: object error-line
drop f ;
2007-09-20 18:09:08 -04:00
: :edit ( -- )
2008-06-25 04:25:08 -04:00
error get [ error-file ] [ error-line ] bi
2dup and [ edit-location ] [ 2drop ] if ;
2007-09-20 18:09:08 -04:00
2008-06-08 16:32:55 -04:00
: edit-each ( seq -- )
[
[ "Editing " write . ]
[
"RETURN moves on to the next usage, C+d stops." print
flush
edit
readln
] bi
2007-09-20 18:09:08 -04:00
] all? drop ;
2008-06-08 16:32:55 -04:00
: fix ( word -- )
[ "Fixing " write pprint " and all usages..." print nl ]
[ [ smart-usage ] keep prefix ] bi
edit-each ;