factor/basis/editors/editors.factor

115 lines
2.8 KiB
Factor
Raw Normal View History

! Copyright (C) 2005, 2009 Slava Pestov.
2007-09-20 18:09:08 -04:00
! See http://factorcode.org/license.txt for BSD license.
USING: accessors assocs continuations debugger definitions
help.topics io io.backend io.files io.launcher io.pathnames
kernel lexer math namespaces parser prettyprint sequences
source-files source-files.errors splitting strings summary
tools.crossref vocabs vocabs.files vocabs.hierarchy
vocabs.loader vocabs.metadata calendar threads words ;
FROM: vocabs => vocab-name >vocab-link ;
2007-09-20 18:09:08 -04:00
IN: editors
SYMBOL: editor-class
2007-09-20 18:09:08 -04:00
: available-editors ( -- seq )
2011-10-14 15:31:06 -04:00
"editors" child-vocab-names ;
: editor-restarts ( -- alist )
available-editors
[ [ "Load " prepend ] keep ] { } map>assoc ;
HOOK: editor-command editor-class ( file line -- command )
M: f editor-command
"Select an editor" editor-restarts throw-restarts require
editor-command ;
HOOK: editor-detached? editor-class ( -- ? )
M: object editor-detached? t ;
: run-and-wait-for-editor ( command -- )
<process>
swap >>command
editor-detached? >>detached
run-process
300 milliseconds sleep
dup status>> { 0 f } member?
[ drop ] [ process-failed ] if ;
2007-09-20 18:09:08 -04:00
: edit-location ( file line -- )
[ absolute-path ] dip
editor-command [ run-and-wait-for-editor ] when* ;
2007-09-20 18:09:08 -04:00
ERROR: cannot-find-source definition ;
M: cannot-find-source error.
"Cannot find source for ``" write
definition>> pprint-short
"''" print ;
: edit-file ( path -- )
0 edit-location ;
DEFER: edit
: edit-vocab ( vocab -- )
>vocab-link edit ;
GENERIC: edit ( object -- )
2007-09-20 18:09:08 -04:00
M: object edit
dup where [ first2 edit-location ] [ cannot-find-source ] ?if ;
M: string edit edit-vocab ;
2008-02-24 18:40:28 -05:00
: edit-error ( error -- )
2008-11-24 13:29:24 -05:00
[ error-file ] [ error-line ] bi
over [ 1 or edit-location ] [ 2drop ] if ;
2007-09-20 18:09:08 -04:00
2008-11-24 13:29:24 -05:00
: :edit ( -- )
error get edit-error ;
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 ;
GENERIC: edit-docs ( object -- )
M: object edit-docs vocab-docs-path 1 edit-location ;
M: word edit-docs
dup "help-loc" word-prop
[ nip first2 edit-location ]
[ vocabulary>> edit-docs ]
if* ;
GENERIC: edit-tests ( object -- )
M: object edit-tests vocab-tests-file 1 edit-location ;
M: word edit-tests vocabulary>> edit-tests ;
: edit-platforms ( vocab -- )
dup vocab-platforms-path vocab-append-path 1 edit-location ;
: edit-authors ( vocab -- )
dup vocab-authors-path vocab-append-path 1 edit-location ;
: edit-tags ( vocab -- )
dup vocab-tags-path vocab-append-path 1 edit-location ;
: edit-summary ( vocab -- )
dup vocab-summary-path vocab-append-path 1 edit-location ;