! Copyright (C) 2007, 2009 Daniel Ehrenberg.
! See http://factorcode.org/license.txt for BSD license.
-USING: accessors kernel locals words summary slots quotations
-sequences assocs math arrays stack-checker effects continuations
-classes.tuple namespaces make vectors bit-arrays byte-arrays
-strings sbufs math.functions macros sequences.private
-combinators mirrors splitting combinators.smart
-combinators.short-circuit fry words.symbol generalizations
-sequences.generalizations classes ;
+USING: accessors arrays assocs bit-arrays byte-arrays classes
+classes.tuple combinators combinators.short-circuit
+combinators.smart continuations effects generalizations
+kernel make math math.functions namespaces parser
+quotations sbufs sequences sequences.generalizations slots
+splitting stack-checker strings summary vectors words
+words.symbol ;
IN: inverse
ERROR: fail ;
: define-math-inverse ( word quot1 quot2 -- )
pick 1quotation 3array "math-inverse" set-word-prop ;
-: define-pop-inverse ( word n quot -- )
- [ dupd "pop-length" set-word-prop ] dip
- "pop-inverse" set-word-prop ;
+:: define-pop-inverse ( word n quot -- )
+ word n "pop-length" set-word-prop
+ word quot "pop-inverse" set-word-prop ;
ERROR: bad-math-inverse ;
SYMBOL: visited
: flattenable? ( object -- ? )
- { [ word? ] [ primitive? not ] [
- { "inverse" "math-inverse" "pop-inverse" }
- [ word-prop ] with any? not
- ] } 1&& ;
+ {
+ [ word? ]
+ [ primitive? not ]
+ [ explicit-inverse? not ]
+ } 1&& ;
: flatten ( quot -- expanded )
- [
- visited [ over suffix ] change
+ visited get over suffix visited [
[
dup flattenable? [
def>>
bi
] [ 1quotation ] if
] map concat
- ] with-scope ;
+ ] with-variable ;
ERROR: undefined-inverse ;
ERROR: missing-literal ;
: assert-literal ( n -- n )
- dup
- [ word? ] [ symbol? not ] bi and
+ dup { [ word? ] [ symbol? not ] } 1&&
[ missing-literal ] when ;
\ + [ - ] [ - ] define-math-inverse
: recover-fail ( try fail -- )
[ drop call ] [
- [ nip ] dip dup fail?
+ nipd dup fail?
[ drop call ] [ nip throw ] if
] recover ; inline
recover-chain ;
MACRO: switch ( quot-alist -- quot ) [switch] ;
+
+SYNTAX: INVERSE: scan-word parse-definition define-inverse ;
+
+SYNTAX: DUAL: scan-word scan-word define-dual ;