parrotcode: NameSpace PMC | |
Contents | PMCs |
src/pmc/namespace.pmc - NameSpace PMC
These are the vtable functions for the namespace PMC.
PMC_struct_val ... the hash, bucket->value is a var/sub, a namespace, or a FixedPMCarray of 2 PMCs (namespace, sub/var) slots PMC_pmc_val ... parent namespace PMC_data ... Namespace information struct (name, class/role)
void init()
NameSpace
PMC by calling Hash.init
and clearing other fields.
void mark()
void destroy()
PMC *get_class()
void set_pmc_keyed_str(STRING *key, PMC *value)
*value
as the namespace item for *key
. This is part of the raw interface. If the PMC value
is exactly a NameSpace, SELF
will be set as the parent of that namespace and the name key
of value
is stored too.
void set_pmc_keyed(PMC *key, PMC *value)
key
is a simple key, it works like above. If key
is an array of strings or a chained key, add all components to the namespace.
PMC *get_pmc_keyed(PMC *key)
key
is either an array of strings, or a possibly nested key.
PMC *get_pmc_keyed_str(STRING *key)
PMC *get_pmc_keyed_int(INTVAL key)
void *get_pointer_keyed_str(STRING *key)
void *get_pointer_keyed(PMC *key)
STRING *get_string()
METHOD make_namespace(PMC *key)
key
. If the namespace already exists, only retrieve it.
METHOD add_namespace(STRING *name, PMC *namespace)
namespace
is not a NameSpace PMC or subclass.
METHOD add_sub(STRING *name, PMC *sub)
sub
is not a Sub PMC or subclass.
METHOD add_var(STRING *name, PMC *var)
METHOD get_name()
$P2 = $P3.'get_name'() $S0 = join '::', $P2 # '::Foo::Bar'
METHOD find_namespace(STRING *name)
METHOD find_sub(STRING *name)
METHOD find_var(STRING *name)
METHOD del_namespace(STRING *name)
METHOD del_sub(STRING *name)
METHOD del_var(STRING *name)
METHOD get_sym(STRING *name)
METHOD export_to(PMC *dest, PMC *what)
dest
NameSpace. The items to export are named in what
, which may be an array of strings, a hash, or null. If what
is an array of strings, interpretation of items in an array follows the conventions of the source (exporting) namespace. If what
is a hash, the keys correspond to the names in the source namespace, and the values correspond to the names in the destination namespace. if a hash value is null or an empty string, the name in the hash key is used. A null what
requests the 'default' set of items. Any other type passed in what
throws an exception.NOTE: exporting 'default' set of items is not yet implemented.
METHOD get_parent()
METHOD get_class()
METHOD set_class(PMC *class_or_role)
METHOD get_associated_methods()
METHOD get_associated_vtable_methods()
|