Working on classes

db4
Slava Pestov 2008-03-13 17:20:28 -05:00
parent fc725ce7fa
commit 93ad9cb096
3 changed files with 40 additions and 61 deletions

View File

@ -1,7 +1,7 @@
USING: help.markup help.syntax kernel kernel.private USING: help.markup help.syntax kernel kernel.private
namespaces sequences words arrays layouts help effects math namespaces sequences words arrays layouts help effects math
layouts classes.private classes.union classes.mixin layouts classes.private classes.union classes.mixin
classes.predicate ; classes.predicate quotations ;
IN: classes IN: classes
ARTICLE: "builtin-classes" "Built-in classes" ARTICLE: "builtin-classes" "Built-in classes"
@ -114,24 +114,9 @@ HELP: predicate-word
{ $values { "word" "a word" } { "predicate" "a predicate word" } } { $values { "word" "a word" } { "predicate" "a predicate word" } }
{ $description "Suffixes the word's name with \"?\" and creates a word with that name in the same vocabulary as the word itself." } ; { $description "Suffixes the word's name with \"?\" and creates a word with that name in the same vocabulary as the word itself." } ;
HELP: define-predicate*
{ $values { "class" class } { "predicate" "a predicate word" } { "quot" "a quotation" } }
{ $description
"Defines a predicate word. This is identical to a word definition associating " { $snippet "quot" } " with " { $snippet "predicate" } " with the added perk that three word properties are set:"
{ $list
{ "the class word's " { $snippet "\"predicate\"" } " property is set to a quotation that calls the predicate" }
{ "the predicate word's " { $snippet "\"predicating\"" } " property is set to the class word" }
{ "the predicate word's " { $snippet "\"declared-effect\"" } " word property is set to a descriptive " { $link effect } }
}
"These properties are used by method dispatch and the help system."
}
$low-level-note ;
HELP: define-predicate HELP: define-predicate
{ $values { "class" class } { "quot" "a quotation" } } { $values { "class" class } { "quot" quotation } }
{ $description { $description "Defines a predicate word for a class." }
"Defines a predicate word named " { $snippet "class?" } " with " { $link define-predicate* } "."
}
$low-level-note ; $low-level-note ;
HELP: superclass HELP: superclass

View File

@ -178,39 +178,39 @@ UNION: forget-class-bug-2 forget-class-bug-1 dll ;
[ f ] [ forget-class-bug-2 typemap get values [ memq? ] with contains? ] unit-test [ f ] [ forget-class-bug-2 typemap get values [ memq? ] with contains? ] unit-test
DEFER: mixin-forget-test-g 2 [
[ "mixin-forget-test" forget-source ] with-compilation-unit
[ "mixin-forget-test" forget-source ] with-compilation-unit
[ ] [
[ ] [ {
{ "USING: sequences ;"
"USING: sequences ;" "IN: classes.tests"
"IN: classes.tests" "MIXIN: mixin-forget-test"
"MIXIN: mixin-forget-test" "INSTANCE: sequence mixin-forget-test"
"INSTANCE: sequence mixin-forget-test" "GENERIC: mixin-forget-test-g ( x -- y )"
"GENERIC: mixin-forget-test-g ( x -- y )" "M: mixin-forget-test mixin-forget-test-g ;"
"M: mixin-forget-test mixin-forget-test-g ;" } "\n" join <string-reader> "mixin-forget-test"
} "\n" join <string-reader> "mixin-forget-test" parse-stream drop
parse-stream drop ] unit-test
] unit-test
[ { } ] [ { } "mixin-forget-test-g" "classes.tests" lookup execute ] unit-test
[ { } ] [ { } mixin-forget-test-g ] unit-test [ H{ } "mixin-forget-test-g" "classes.tests" lookup execute ] must-fail
[ H{ } mixin-forget-test-g ] must-fail
[ ] [
[ ] [ {
{ "USING: hashtables ;"
"USING: hashtables ;" "IN: classes.tests"
"IN: classes.tests" "MIXIN: mixin-forget-test"
"MIXIN: mixin-forget-test" "INSTANCE: hashtable mixin-forget-test"
"INSTANCE: hashtable mixin-forget-test" "GENERIC: mixin-forget-test-g ( x -- y )"
"GENERIC: mixin-forget-test-g ( x -- y )" "M: mixin-forget-test mixin-forget-test-g ;"
"M: mixin-forget-test mixin-forget-test-g ;" } "\n" join <string-reader> "mixin-forget-test"
} "\n" join <string-reader> "mixin-forget-test" parse-stream drop
parse-stream drop ] unit-test
] unit-test
[ { } "mixin-forget-test-g" "classes.tests" lookup execute ] must-fail
[ { } mixin-forget-test-g ] must-fail [ H{ } ] [ H{ } "mixin-forget-test-g" "classes.tests" lookup execute ] unit-test
[ H{ } ] [ H{ } mixin-forget-test-g ] unit-test ] times
! Method flattening interfered with mixin update ! Method flattening interfered with mixin update
MIXIN: flat-mx-1 MIXIN: flat-mx-1

View File

@ -31,17 +31,9 @@ PREDICATE: class tuple-class
PREDICATE: word predicate "predicating" word-prop >boolean ; PREDICATE: word predicate "predicating" word-prop >boolean ;
: define-predicate* ( class predicate quot -- )
over [
dupd predicate-effect define-declared
2dup 1quotation "predicate" set-word-prop
swap "predicating" set-word-prop
] [ 3drop ] if ;
: define-predicate ( class quot -- ) : define-predicate ( class quot -- )
over "forgotten" word-prop [ 2drop ] [ >r "predicate" word-prop first
>r dup predicate-word r> define-predicate* r> predicate-effect define-declared ;
] if ;
: superclass ( class -- super ) : superclass ( class -- super )
"superclass" word-prop ; "superclass" word-prop ;
@ -257,6 +249,8 @@ PRIVATE>
over reset-class over reset-class
over deferred? [ over define-symbol ] when over deferred? [ over define-symbol ] when
>r dup word-props r> union over set-word-props >r dup word-props r> union over set-word-props
dup predicate-word 2dup 1quotation "predicate" set-word-prop
over "predicating" set-word-prop
t "class" set-word-prop ; t "class" set-word-prop ;
GENERIC: update-predicate ( class -- ) GENERIC: update-predicate ( class -- )