factor/extra/smalltalk/selectors/selectors.factor

29 lines
897 B
Factor
Raw Normal View History

2010-01-14 10:10:13 -05:00
! Copyright (C) 2009, 2010 Slava Pestov.
2009-03-30 06:31:50 -04:00
! See http://factorcode.org/license.txt for BSD license.
2010-01-14 10:10:13 -05:00
USING: arrays combinators effects generic generic.standard
kernel sequences words lexer ;
2009-03-30 06:31:50 -04:00
IN: smalltalk.selectors
SYMBOLS: unary binary keyword ;
: selector-type ( selector -- type )
{
{ [ dup [ "~!@%&*-+=|\\<>,?/" member? ] all? ] [ binary ] }
2009-03-30 06:31:50 -04:00
{ [ CHAR: : over member? ] [ keyword ] }
[ unary ]
} cond nip ;
: selector>effect ( selector -- effect )
dup selector-type {
2010-01-14 10:10:13 -05:00
{ unary [ drop { } ] }
{ binary [ drop { "x" } ] }
{ keyword [ [ CHAR: : = ] count "x" <array> ] }
2009-03-30 06:31:50 -04:00
} case "receiver" suffix { "result" } <effect> ;
: selector>generic ( selector -- generic )
[ "selector-" prepend "smalltalk.selectors" create dup ]
[ selector>effect ]
bi define-simple-generic ;
SYNTAX: SELECTOR: scan-token selector>generic drop ;