# HG changeset patch # User Pierre-Yves David # Date 1323429251 -3600 # Node ID 7070250bf50de6ddf153ad991c3f5b6fb53d8cbf # Parent b5b0b341467ad87ac42c3f2164f800ea9ec2178e [schema] React to yams improvement of metadata attribute handling. * Change the way RichString is deprecated. * Add documentation about metadata attribute diff -r b5b0b341467a -r 7070250bf50d doc/book/en/devrepo/datamodel/definition.rst --- a/doc/book/en/devrepo/datamodel/definition.rst Thu Dec 08 16:48:00 2011 +0100 +++ b/doc/book/en/devrepo/datamodel/definition.rst Fri Dec 09 12:14:11 2011 +0100 @@ -186,6 +186,9 @@ * `default`: default value of the attribute. In case of date types, the values which could be used correspond to the RQL keywords `TODAY` and `NOW`. +* `metadata`: Is also accepted as an argument of the attribute contructor. It is + not really an attribute property. see `Metadata`_ for details. + Properties for `String` attributes: * `fulltextindexed`: boolean indicating if the attribute is part of @@ -567,17 +570,41 @@ In any case, identifiers starting with "CW" or "cw" are reserved for internal use by the framework. + .. _Metadata: + + Some attribute using the name of another attribute as prefix are considered + metadata. For example, if an EntityType have both a ``data`` and + ``data_format`` attribute, ``data_format`` is view as the ``format`` metadata + of ``data``. Later the :meth:`cw_attr_metadata` method will allow you to fetch + metadata related to an attribute. There are only three valid metadata names: + ``format``, ``encoding`` and ``name``. + The name of the Python attribute corresponds to the name of the attribute or the relation in *CubicWeb* application. An attribute is defined in the schema as follows:: - attr_name = attr_type(properties) + attr_name = AttrType(*properties, metadata={}) + +where + +* `AttrType`: is one of the type listed in EntityType_, + +* `properties`: is a list of the attribute needs to satisfy (see `Properties`_ + for more details), -where `attr_type` is one of the type listed above and `properties` is -a list of the attribute needs to satisfy (see `Properties`_ -for more details). +* `metadata`: is a dictionary of meta attributes related to ``attr_name``. + Dictionary keys are the name of the meta attribute. Dictionary values + attributes objects (like the content of ``AttrType``). For each entry of the + metadata dictionary a ``_ = `` attribute is + automaticaly added to the EntityType. see `Metadata`_ section for details + about valid key. + + + --- + +While building your schema * it is possible to use the attribute `meta` to flag an entity type as a `meta` (e.g. used to describe/categorize other entities) diff -r b5b0b341467a -r 7070250bf50d schema.py --- a/schema.py Thu Dec 08 16:48:00 2011 +0100 +++ b/schema.py Fri Dec 09 12:14:11 2011 +0100 @@ -27,7 +27,7 @@ from logilab.common.decorators import cached, clear_cache, monkeypatch from logilab.common.logging_ext import set_log_methods -from logilab.common.deprecation import deprecated, class_moved +from logilab.common.deprecation import deprecated, class_moved, moved from logilab.common.textutils import splitstrip from logilab.common.graph import get_cycles from logilab.common.compat import any @@ -1241,10 +1241,9 @@ # XXX deprecated -from yams.buildobjs import RichString from yams.constraints import StaticVocabularyConstraint -RichString = class_moved(RichString) +RichString = moved('yams.buildobjs', 'RichString') StaticVocabularyConstraint = class_moved(StaticVocabularyConstraint) FormatConstraint = class_moved(FormatConstraint)