factor/library/generic/union.factor

26 lines
782 B
Factor
Raw Normal View History

2005-02-18 20:37:01 -05:00
! Copyright (C) 2004, 2005 Slava Pestov.
! See http://factor.sf.net/license.txt for BSD license.
IN: generic
USING: errors hashtables kernel lists namespaces parser
sequences strings words vectors ;
2004-07-16 02:26:21 -04:00
! Union metaclass for dispatch on multiple classes.
SYMBOL: union
2004-07-28 19:02:24 -04:00
: union-predicate ( members -- list )
[
2005-08-22 14:29:43 -04:00
"predicate" word-prop
[ dup ] swap add [ drop t ] cons
] map [ drop f ] swap alist>quot ;
2004-07-16 02:26:21 -04:00
2005-08-14 18:13:16 -04:00
: set-members ( class members -- )
2dup [ types ] map concat "types" set-word-prop
"members" set-word-prop ;
: define-union ( class predicate members -- )
2004-12-23 18:26:04 -05:00
#! We have to turn the f object into the f word, same for t.
2005-08-14 18:13:16 -04:00
3dup nip set-members pick union define-class
union-predicate define-predicate ;
PREDICATE: word union metaclass union = ;