Re: [Xotcl] -type of Attributes
Created by hypermail2xowiki importer, last modified by Stefan Sobernig 02 Jan 2017, at 11:15 PM
Date: Fri, 02 May 2008 21:04:21 +0200
Eckhard Lehmann schrieb:
> Hi,
>
> two questions on the -type field of the Attribute class:
>
> 1)
> There is obviously no documentation on the available types? I needed to
> force an error on a wrong -type that told me all the available types
>
The type-checking is implemented in Tcl and is not hardcoded.
The logic is defined in the method mk_type_checker of the
class ::xotcl::Attribute and behaves as follows:
a) if the specified "-type" of an ::xotcl::Attribute is an XOTcl class,
the specified values have to be instances of the class
In the example below, the attribute tasks of a Workflow
has to be filled with instances of Task.
#=======
xotcl::Class Task
xotcl::Class create Workflow -slots {
Attribute tasks -multivalued true -type Task
Attribute name -default ""
}
=======
The full example is in
http://groups.google.at/group/comp.lang.tcl/browse_frm/thread/eccb038ec48236bb/cfe350d1283b6c70?lnk=st&q=xotcl+workflow#cfe350d1283b6c70
b) if the specified "-type" of an ::xotcl::Attribute consists of a
single word,
the single word is interpeted as a string-class of Tcl's
"string is STRING-CLASS value"
c) "-type" of an ::xotcl::Attribute consists of a single word, it is
interpreted as a method call in XOTcl.
See for example:
=======
Class Person -slots {
...
Attribute sex -type "my sex" -proc sex {value} {
switch -glob $value {
m* {my uplevel {$obj set $var m}; return 1}
f* {my uplevel {$obj set $var f}; return 1}
default {return 0}
}
}
}
=========
http://media.wu-wien.ac.at/doc/tutorial.html#slot-experimental
So, the potential range of permissable values is quite large, since it
includes
all STRING-CLASSES from Tcl, all classes from XOTcl
(::xotcl::Class info instances -closure) and potentially, all methods
that can be defined in XOTcl.
> 2)
> Is there a -type that denotes a string? There is alnum and alpha, but I
> mean ordinary strings that can contain arbitrary (utf-8, ISO-8859-1
> etc.) characters? Or alternatively, are the types extensible?
>
All types are extensible, actually in multiple dimensions: one can define
different checking methods, and one can as well define new types
of ::xotcl::Attributes via subclassing. The latter ensures reusability.
> Background of this question: The -type of an attribute seems to be a
> useful invention for an automated persistency framework for databases.
> The problem with that automation is currently that you can not really
> generate SQL automatically for XOTcl attributes, because you don't know
> their exact storage types from looking at the classes.
> If it was possible to assign the proper -type to attributes (e.g.
> "text", "date", "bytea" ...), then I could see two cool possibilities
> for a persistency framework:
>
Sure. In the OpenACS framework, xotcl-core contains definitions for
subclassing ::xotcl::Attribute with ::xo::db::Attribute, which are
persistent
attributes containing e.g. the column_name or the sql-type. Note that
these
types might be different depending on the used database m management
system.
see for example slide 28ff in
http://alice.wu-wien.ac.at:8000/s5-xotcl-core-tutorial/download/file/xotcl-core.pdf
> a) create XOTcl classes automatically using meta information of the
> database, and -type as validator
> b) create CRUD and select statements automatically from XOTcl classes,
> using -type for the proper quoting/format that the database expects
>
This can be achieved in various ways.
Certainly, one can keep the meta-data in XOTcl, and create just
the tables in SQL (see e.g. slide 38ff), where the definitions
are used to create the tables and the CRUD methods.
In OpenACS exits already a rich meta-data catalog, stored in
the database (e.g. acs_object_types, acs_attributes, ...).
The xotcl-componets use there the pre-existing catalog and can generate
on the fly XOTcl classes from this. The appropriate method is
"get_class_from_db", see slide 45 above.
It is certainly a question, whether the xotcl-type checker is the best
instrument, since one would like to check e.g. referential integrity,
or as some other value constraints. Furthermore, the database
has sometimes other understanding of permissable values to
certain types than tcl (e.g. for boolean values). In come cases,
the xotcl-core layer provides value constraints for table definitions.
The next major release of XOTcl will have several improvements
in this area. For example, it will use the same type checking mechanisms
for non-positional arguments and slot values and clean up some
legacy stuff (i have this - and many more improvements - in my
leading edge branch, not sure, how much of this will make it
into the next release).
best regards
-gustaf neumann



