added some basic code to handle a method dictionary
This commit is contained in:
parent
2e08cca9db
commit
b91cd11561
@ -2451,10 +2451,11 @@ static int make_defined_class (stix_t* stix)
|
|||||||
stix->c->cls.indexed_type);
|
stix->c->cls.indexed_type);
|
||||||
self_spec = STIX_CLASS_SELFSPEC_MAKE(stix->c->cls.var_count[VAR_CLASS], stix->c->cls.var_count[VAR_CLASSINST]);
|
self_spec = STIX_CLASS_SELFSPEC_MAKE(stix->c->cls.var_count[VAR_CLASS], stix->c->cls.var_count[VAR_CLASSINST]);
|
||||||
|
|
||||||
|
#if 0
|
||||||
printf ("MAKING ... ");
|
printf ("MAKING ... ");
|
||||||
print_ucs (&stix->c->cls.name);
|
print_ucs (&stix->c->cls.name);
|
||||||
printf (" instvars %d classvars %d classinstvars %d\n", (int)stix->c->cls.var_count[VAR_INSTANCE], (int)stix->c->cls.var_count[VAR_CLASS], (int)stix->c->cls.var_count[VAR_CLASSINST]);
|
printf (" instvars %d classvars %d classinstvars %d\n", (int)stix->c->cls.var_count[VAR_INSTANCE], (int)stix->c->cls.var_count[VAR_CLASS], (int)stix->c->cls.var_count[VAR_CLASSINST]);
|
||||||
|
#endif
|
||||||
if (stix->c->cls.self_oop)
|
if (stix->c->cls.self_oop)
|
||||||
{
|
{
|
||||||
STIX_ASSERT (STIX_CLASSOF(stix, stix->c->cls.self_oop) == stix->_class);
|
STIX_ASSERT (STIX_CLASSOF(stix, stix->c->cls.self_oop) == stix->_class);
|
||||||
@ -2466,11 +2467,12 @@ printf (" instvars %d classvars %d classinstvars %d\n", (int)stix->c->cls.var_co
|
|||||||
/* it conflicts with internal definition */
|
/* it conflicts with internal definition */
|
||||||
|
|
||||||
|
|
||||||
|
#if 0
|
||||||
printf (" CONFLICTING CLASS DEFINITION %lu %lu %lu %lu\n",
|
printf (" CONFLICTING CLASS DEFINITION %lu %lu %lu %lu\n",
|
||||||
(unsigned long)spec, (unsigned long)self_spec,
|
(unsigned long)spec, (unsigned long)self_spec,
|
||||||
(unsigned long)STIX_OOP_TO_SMINT(stix->c->cls.self_oop->spec), (unsigned long)STIX_OOP_TO_SMINT(stix->c->cls.self_oop->selfspec)
|
(unsigned long)STIX_OOP_TO_SMINT(stix->c->cls.self_oop->spec), (unsigned long)STIX_OOP_TO_SMINT(stix->c->cls.self_oop->selfspec)
|
||||||
);
|
);
|
||||||
|
#endif
|
||||||
set_syntax_error (stix, STIX_SYNERR_CLASSCONTRA, &stix->c->cls.name_loc, &stix->c->cls.name);
|
set_syntax_error (stix, STIX_SYNERR_CLASSCONTRA, &stix->c->cls.name_loc, &stix->c->cls.name);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -2510,7 +2512,10 @@ printf (" CONFLICTING CLASS DEFINITION %lu %lu %lu %lu\n",
|
|||||||
if (!tmp) return -1;
|
if (!tmp) return -1;
|
||||||
stix->c->cls.self_oop->classinstvars = (stix_oop_char_t)tmp;
|
stix->c->cls.self_oop->classinstvars = (stix_oop_char_t)tmp;
|
||||||
|
|
||||||
/* TODO: initialize more fields??? method_dictionary. */
|
tmp = stix_instantiate(stix, stix->_method_dictionary, STIX_NULL, 0);
|
||||||
|
if (!tmp) return -1;
|
||||||
|
stix->c->cls.mthdic_oop = (stix_oop_set_t)tmp;
|
||||||
|
/* TODO: initialize more fields??? whatelse. */
|
||||||
|
|
||||||
if (just_made)
|
if (just_made)
|
||||||
{
|
{
|
||||||
@ -2596,6 +2601,8 @@ static int __compile_class_definition (stix_t* stix)
|
|||||||
|
|
||||||
if (stix->c->tok.type == STIX_IOTOK_LPAREN)
|
if (stix->c->tok.type == STIX_IOTOK_LPAREN)
|
||||||
{
|
{
|
||||||
|
int super_is_nil = 0;
|
||||||
|
|
||||||
printf ("DEFININING..\n");
|
printf ("DEFININING..\n");
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
@ -2605,7 +2612,6 @@ printf ("%c", stix->c->cls.name.ptr[i]);
|
|||||||
}
|
}
|
||||||
printf ("\n");
|
printf ("\n");
|
||||||
}
|
}
|
||||||
int super_is_nil = 0;
|
|
||||||
|
|
||||||
/* superclass is specified. new class defintion.
|
/* superclass is specified. new class defintion.
|
||||||
* for example, #class Class(Stix)
|
* for example, #class Class(Stix)
|
||||||
@ -2799,6 +2805,7 @@ static int compile_class_definition (stix_t* stix)
|
|||||||
|
|
||||||
stix->c->cls.self_oop = STIX_NULL;
|
stix->c->cls.self_oop = STIX_NULL;
|
||||||
stix->c->cls.super_oop = STIX_NULL;
|
stix->c->cls.super_oop = STIX_NULL;
|
||||||
|
stix->c->cls.mthdic_oop = STIX_NULL;
|
||||||
|
|
||||||
/* do main compilation work */
|
/* do main compilation work */
|
||||||
n = __compile_class_definition (stix);
|
n = __compile_class_definition (stix);
|
||||||
@ -2806,6 +2813,7 @@ static int compile_class_definition (stix_t* stix)
|
|||||||
/* reset these oops not to confuse gc_compiler() */
|
/* reset these oops not to confuse gc_compiler() */
|
||||||
stix->c->cls.self_oop = STIX_NULL;
|
stix->c->cls.self_oop = STIX_NULL;
|
||||||
stix->c->cls.super_oop = STIX_NULL;
|
stix->c->cls.super_oop = STIX_NULL;
|
||||||
|
stix->c->cls.mthdic_oop = STIX_NULL;
|
||||||
|
|
||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
|
137
stix/lib/dic.c
137
stix/lib/dic.c
@ -26,23 +26,25 @@
|
|||||||
|
|
||||||
#include "stix-prv.h"
|
#include "stix-prv.h"
|
||||||
|
|
||||||
static stix_oop_oop_t expand_bucket (stix_t* stix, stix_oop_oop_t old_bucket)
|
static stix_oop_oop_t expand_bucket (stix_t* stix, stix_oop_oop_t oldbuc)
|
||||||
{
|
{
|
||||||
stix_oop_oop_t new_bucket;
|
stix_oop_oop_t newbuc;
|
||||||
stix_oow_t oldsz, newsz, index;
|
stix_oow_t oldsz, newsz, index;
|
||||||
stix_oop_association_t ass;
|
stix_oop_association_t ass;
|
||||||
stix_oop_char_t key;
|
stix_oop_char_t key;
|
||||||
|
|
||||||
/* TODO: derive a better growth size */
|
/* TODO: derive a better growth size */
|
||||||
new_bucket = (stix_oop_oop_t)stix_instantiate (stix, stix->_array, STIX_NULL, STIX_OBJ_GET_SIZE(old_bucket) * 2);
|
stix_pushtmp (stix, (stix_oop_t*)&oldbuc);
|
||||||
if (!new_bucket) return STIX_NULL;
|
newbuc = (stix_oop_oop_t)stix_instantiate (stix, stix->_array, STIX_NULL, STIX_OBJ_GET_SIZE(oldbuc) * 2);
|
||||||
|
stix_poptmp (stix);
|
||||||
|
if (!newbuc) return STIX_NULL;
|
||||||
|
|
||||||
oldsz = STIX_OBJ_GET_SIZE(old_bucket);
|
oldsz = STIX_OBJ_GET_SIZE(oldbuc);
|
||||||
newsz = STIX_OBJ_GET_SIZE(new_bucket);
|
newsz = STIX_OBJ_GET_SIZE(newbuc);
|
||||||
|
|
||||||
while (oldsz > 0)
|
while (oldsz > 0)
|
||||||
{
|
{
|
||||||
ass = (stix_oop_association_t)old_bucket->slot[--oldsz];
|
ass = (stix_oop_association_t)oldbuc->slot[--oldsz];
|
||||||
if ((stix_oop_t)ass != stix->_nil)
|
if ((stix_oop_t)ass != stix->_nil)
|
||||||
{
|
{
|
||||||
STIX_ASSERT (STIX_CLASSOF(stix,ass) == stix->_association);
|
STIX_ASSERT (STIX_CLASSOF(stix,ass) == stix->_association);
|
||||||
@ -50,17 +52,16 @@ static stix_oop_oop_t expand_bucket (stix_t* stix, stix_oop_oop_t old_bucket)
|
|||||||
key = (stix_oop_char_t)ass->key;
|
key = (stix_oop_char_t)ass->key;
|
||||||
STIX_ASSERT (STIX_CLASSOF(stix,key) == (stix_oop_t)stix->_symbol);
|
STIX_ASSERT (STIX_CLASSOF(stix,key) == (stix_oop_t)stix->_symbol);
|
||||||
|
|
||||||
index = stix_hashchars (key->slot, STIX_OBJ_GET_SIZE(key)) % newsz;
|
index = stix_hashchars(key->slot, STIX_OBJ_GET_SIZE(key)) % newsz;
|
||||||
while (new_bucket->slot[index] != stix->_nil)
|
while (newbuc->slot[index] != stix->_nil) index = (index + 1) % newsz;
|
||||||
index = (index + 1) % newsz;
|
newbuc->slot[index] = (stix_oop_t)ass;
|
||||||
new_bucket->slot[index] = (stix_oop_t)ass;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return new_bucket;
|
return newbuc;
|
||||||
}
|
}
|
||||||
|
|
||||||
static stix_oop_t find_or_insert (stix_t* stix, stix_oop_char_t key, stix_oop_t value)
|
static stix_oop_t find_or_insert (stix_t* stix, stix_oop_set_t dic, stix_oop_char_t key, stix_oop_t value)
|
||||||
{
|
{
|
||||||
stix_oow_t index, tally;
|
stix_oow_t index, tally;
|
||||||
stix_oop_association_t ass;
|
stix_oop_association_t ass;
|
||||||
@ -69,14 +70,14 @@ static stix_oop_t find_or_insert (stix_t* stix, stix_oop_char_t key, stix_oop_t
|
|||||||
/* the system dictionary is not a generic dictionary.
|
/* the system dictionary is not a generic dictionary.
|
||||||
* it accepts only a symbol as a key. */
|
* it accepts only a symbol as a key. */
|
||||||
STIX_ASSERT (STIX_CLASSOF(stix,key) == stix->_symbol);
|
STIX_ASSERT (STIX_CLASSOF(stix,key) == stix->_symbol);
|
||||||
STIX_ASSERT (STIX_CLASSOF(stix,stix->sysdic->tally) == stix->_small_integer);
|
STIX_ASSERT (STIX_CLASSOF(stix,dic->tally) == stix->_small_integer);
|
||||||
STIX_ASSERT (STIX_CLASSOF(stix,stix->sysdic->bucket) == stix->_array);
|
STIX_ASSERT (STIX_CLASSOF(stix,dic->bucket) == stix->_array);
|
||||||
|
|
||||||
index = stix_hashchars(key->slot, STIX_OBJ_GET_SIZE(key)) % STIX_OBJ_GET_SIZE(stix->sysdic->bucket);
|
index = stix_hashchars(key->slot, STIX_OBJ_GET_SIZE(key)) % STIX_OBJ_GET_SIZE(dic->bucket);
|
||||||
|
|
||||||
while (stix->sysdic->bucket->slot[index] != stix->_nil)
|
while (dic->bucket->slot[index] != stix->_nil)
|
||||||
{
|
{
|
||||||
ass = (stix_oop_association_t)stix->sysdic->bucket->slot[index];
|
ass = (stix_oop_association_t)dic->bucket->slot[index];
|
||||||
|
|
||||||
STIX_ASSERT (STIX_CLASSOF(stix,ass) == stix->_association);
|
STIX_ASSERT (STIX_CLASSOF(stix,ass) == stix->_association);
|
||||||
STIX_ASSERT (STIX_CLASSOF(stix,ass->key) == stix->_symbol);
|
STIX_ASSERT (STIX_CLASSOF(stix,ass->key) == stix->_symbol);
|
||||||
@ -87,7 +88,7 @@ static stix_oop_t find_or_insert (stix_t* stix, stix_oop_char_t key, stix_oop_t
|
|||||||
return (stix_oop_t)ass;
|
return (stix_oop_t)ass;
|
||||||
}
|
}
|
||||||
|
|
||||||
index = (index + 1) % STIX_OBJ_GET_SIZE(stix->sysdic->bucket);
|
index = (index + 1) % STIX_OBJ_GET_SIZE(dic->bucket);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (value == STIX_NULL)
|
if (value == STIX_NULL)
|
||||||
@ -97,11 +98,12 @@ static stix_oop_t find_or_insert (stix_t* stix, stix_oop_char_t key, stix_oop_t
|
|||||||
return STIX_NULL;
|
return STIX_NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
stix_pushtmp (stix, (stix_oop_t*)&dic); tmp_count++;
|
||||||
stix_pushtmp (stix, (stix_oop_t*)&key); tmp_count++;
|
stix_pushtmp (stix, (stix_oop_t*)&key); tmp_count++;
|
||||||
stix_pushtmp (stix, &value); tmp_count++;
|
stix_pushtmp (stix, &value); tmp_count++;
|
||||||
|
|
||||||
tally = STIX_OOP_TO_SMINT(stix->sysdic->tally);
|
tally = STIX_OOP_TO_SMINT(dic->tally);
|
||||||
if (tally + 1 >= STIX_OBJ_GET_SIZE(stix->sysdic->bucket))
|
if (tally + 1 >= STIX_OBJ_GET_SIZE(dic->bucket))
|
||||||
{
|
{
|
||||||
stix_oop_oop_t bucket;
|
stix_oop_oop_t bucket;
|
||||||
|
|
||||||
@ -113,16 +115,16 @@ static stix_oop_t find_or_insert (stix_t* stix, stix_oop_char_t key, stix_oop_t
|
|||||||
* make sure that it has at least one free slot left
|
* make sure that it has at least one free slot left
|
||||||
* after having added a new symbol. this is to help
|
* after having added a new symbol. this is to help
|
||||||
* traversal end at a _nil slot if no entry is found. */
|
* traversal end at a _nil slot if no entry is found. */
|
||||||
bucket = expand_bucket (stix, stix->sysdic->bucket);
|
bucket = expand_bucket (stix, dic->bucket);
|
||||||
if (!bucket) goto oops;
|
if (!bucket) goto oops;
|
||||||
|
|
||||||
stix->sysdic->bucket = bucket;
|
dic->bucket = bucket;
|
||||||
|
|
||||||
/* recalculate the index for the expanded bucket */
|
/* recalculate the index for the expanded bucket */
|
||||||
index = stix_hashchars(key->slot, STIX_OBJ_GET_SIZE(key)) % STIX_OBJ_GET_SIZE(stix->sysdic->bucket);
|
index = stix_hashchars(key->slot, STIX_OBJ_GET_SIZE(key)) % STIX_OBJ_GET_SIZE(dic->bucket);
|
||||||
|
|
||||||
while (stix->sysdic->bucket->slot[index] != stix->_nil)
|
while (dic->bucket->slot[index] != stix->_nil)
|
||||||
index = (index + 1) % STIX_OBJ_GET_SIZE(stix->sysdic->bucket);
|
index = (index + 1) % STIX_OBJ_GET_SIZE(dic->bucket);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* create a new assocation of a key and a value since
|
/* create a new assocation of a key and a value since
|
||||||
@ -133,8 +135,8 @@ static stix_oop_t find_or_insert (stix_t* stix, stix_oop_char_t key, stix_oop_t
|
|||||||
ass->key = (stix_oop_t)key;
|
ass->key = (stix_oop_t)key;
|
||||||
ass->value = value;
|
ass->value = value;
|
||||||
|
|
||||||
stix->sysdic->tally = STIX_OOP_FROM_SMINT(tally + 1);
|
dic->tally = STIX_OOP_FROM_SMINT(tally + 1);
|
||||||
stix->sysdic->bucket->slot[index] = (stix_oop_t)ass;
|
dic->bucket->slot[index] = (stix_oop_t)ass;
|
||||||
|
|
||||||
stix_poptmps (stix, tmp_count);
|
stix_poptmps (stix, tmp_count);
|
||||||
return (stix_oop_t)ass;
|
return (stix_oop_t)ass;
|
||||||
@ -144,19 +146,7 @@ oops:
|
|||||||
return STIX_NULL;
|
return STIX_NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
stix_oop_t stix_putatsysdic (stix_t* stix, stix_oop_t key, stix_oop_t value)
|
static stix_oop_t lookup (stix_t* stix, stix_oop_set_t dic, const stix_ucs_t* name)
|
||||||
{
|
|
||||||
STIX_ASSERT (STIX_CLASSOF(stix,key) == stix->_symbol);
|
|
||||||
return find_or_insert (stix, (stix_oop_char_t)key, value);
|
|
||||||
}
|
|
||||||
|
|
||||||
stix_oop_t stix_getatsysdic (stix_t* stix, stix_oop_t key)
|
|
||||||
{
|
|
||||||
STIX_ASSERT (STIX_CLASSOF(stix,key) == stix->_symbol);
|
|
||||||
return find_or_insert (stix, (stix_oop_char_t)key, STIX_NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
stix_oop_t stix_lookupsysdic (stix_t* stix, const stix_ucs_t* name)
|
|
||||||
{
|
{
|
||||||
/* this is special version of stix_getatsysdic() that performs
|
/* this is special version of stix_getatsysdic() that performs
|
||||||
* lookup using a plain string specified */
|
* lookup using a plain string specified */
|
||||||
@ -164,14 +154,14 @@ stix_oop_t stix_lookupsysdic (stix_t* stix, const stix_ucs_t* name)
|
|||||||
stix_oow_t index;
|
stix_oow_t index;
|
||||||
stix_oop_association_t ass;
|
stix_oop_association_t ass;
|
||||||
|
|
||||||
STIX_ASSERT (STIX_CLASSOF(stix,stix->sysdic->tally) == stix->_small_integer);
|
STIX_ASSERT (STIX_CLASSOF(stix,dic->tally) == stix->_small_integer);
|
||||||
STIX_ASSERT (STIX_CLASSOF(stix,stix->sysdic->bucket) == stix->_array);
|
STIX_ASSERT (STIX_CLASSOF(stix,dic->bucket) == stix->_array);
|
||||||
|
|
||||||
index = stix_hashchars(name->ptr, name->len) % STIX_OBJ_GET_SIZE(stix->sysdic->bucket);
|
index = stix_hashchars(name->ptr, name->len) % STIX_OBJ_GET_SIZE(dic->bucket);
|
||||||
|
|
||||||
while (stix->sysdic->bucket->slot[index] != stix->_nil)
|
while (dic->bucket->slot[index] != stix->_nil)
|
||||||
{
|
{
|
||||||
ass = (stix_oop_association_t)stix->sysdic->bucket->slot[index];
|
ass = (stix_oop_association_t)dic->bucket->slot[index];
|
||||||
|
|
||||||
STIX_ASSERT (STIX_CLASSOF(stix,ass) == stix->_association);
|
STIX_ASSERT (STIX_CLASSOF(stix,ass) == stix->_association);
|
||||||
STIX_ASSERT (STIX_CLASSOF(stix,ass->key) == stix->_symbol);
|
STIX_ASSERT (STIX_CLASSOF(stix,ass->key) == stix->_symbol);
|
||||||
@ -182,10 +172,63 @@ stix_oop_t stix_lookupsysdic (stix_t* stix, const stix_ucs_t* name)
|
|||||||
return (stix_oop_t)ass;
|
return (stix_oop_t)ass;
|
||||||
}
|
}
|
||||||
|
|
||||||
index = (index + 1) % STIX_OBJ_GET_SIZE(stix->sysdic->bucket);
|
index = (index + 1) % STIX_OBJ_GET_SIZE(dic->bucket);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* when value is STIX_NULL, perform no insertion */
|
/* when value is STIX_NULL, perform no insertion */
|
||||||
stix->errnum = STIX_ENOENT;
|
stix->errnum = STIX_ENOENT;
|
||||||
return STIX_NULL;
|
return STIX_NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
stix_oop_t stix_putatsysdic (stix_t* stix, stix_oop_t key, stix_oop_t value)
|
||||||
|
{
|
||||||
|
STIX_ASSERT (STIX_CLASSOF(stix,key) == stix->_symbol);
|
||||||
|
return find_or_insert (stix, stix->sysdic, (stix_oop_char_t)key, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
stix_oop_t stix_getatsysdic (stix_t* stix, stix_oop_t key)
|
||||||
|
{
|
||||||
|
STIX_ASSERT (STIX_CLASSOF(stix,key) == stix->_symbol);
|
||||||
|
return find_or_insert (stix, stix->sysdic, (stix_oop_char_t)key, STIX_NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
stix_oop_t stix_lookupsysdic (stix_t* stix, const stix_ucs_t* name)
|
||||||
|
{
|
||||||
|
return lookup (stix, stix->sysdic, name);
|
||||||
|
}
|
||||||
|
|
||||||
|
stix_oop_t stix_putatdic (stix_t* stix, stix_oop_set_t dic, stix_oop_t key, stix_oop_t value)
|
||||||
|
{
|
||||||
|
STIX_ASSERT (STIX_CLASSOF(stix,key) == stix->_symbol);
|
||||||
|
return find_or_insert (stix, stix->sysdic, (stix_oop_char_t)key, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
stix_oop_t stix_getatdic (stix_t* stix, stix_oop_set_t dic, stix_oop_t key)
|
||||||
|
{
|
||||||
|
STIX_ASSERT (STIX_CLASSOF(stix,key) == stix->_symbol);
|
||||||
|
return find_or_insert (stix, dic, (stix_oop_char_t)key, STIX_NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
stix_oop_t stix_lookupdic (stix_t* stix, stix_oop_set_t dic, const stix_ucs_t* name)
|
||||||
|
{
|
||||||
|
return lookup (stix, dic, name);
|
||||||
|
}
|
||||||
|
|
||||||
|
stix_oop_set_t stix_makedic (stix_t* stix, stix_oop_t cls, stix_oow_t size)
|
||||||
|
{
|
||||||
|
stix_oop_set_t dic;
|
||||||
|
stix_oop_t tmp;
|
||||||
|
|
||||||
|
dic = (stix_oop_set_t)stix_instantiate (stix, cls, STIX_NULL, 0);
|
||||||
|
if (!dic) return STIX_NULL;
|
||||||
|
|
||||||
|
dic->tally = STIX_OOP_FROM_SMINT(0);
|
||||||
|
|
||||||
|
stix_pushtmp (stix, (stix_oop_t*)&dic);
|
||||||
|
tmp = stix_instantiate (stix, stix->_array, STIX_NULL, size);
|
||||||
|
stix_poptmp (stix);
|
||||||
|
if (!tmp) return STIX_NULL;
|
||||||
|
|
||||||
|
dic->bucket = (stix_oop_oop_t)tmp;
|
||||||
|
return dic;
|
||||||
|
}
|
||||||
|
@ -209,6 +209,7 @@ printf ("STARTING GC curheap base %p ptr %p newheap base %p ptr %p\n",
|
|||||||
stix->_symbol = stix_moveoop (stix, stix->_symbol);
|
stix->_symbol = stix_moveoop (stix, stix->_symbol);
|
||||||
stix->_symbol_set = stix_moveoop (stix, stix->_symbol_set);
|
stix->_symbol_set = stix_moveoop (stix, stix->_symbol_set);
|
||||||
stix->_system_dictionary = stix_moveoop (stix, stix->_system_dictionary);
|
stix->_system_dictionary = stix_moveoop (stix, stix->_system_dictionary);
|
||||||
|
stix->_method_dictionary = stix_moveoop (stix, stix->_method_dictionary);
|
||||||
stix->_association = stix_moveoop (stix, stix->_association);
|
stix->_association = stix_moveoop (stix, stix->_association);
|
||||||
stix->_true_class = stix_moveoop (stix, stix->_true_class);
|
stix->_true_class = stix_moveoop (stix, stix->_true_class);
|
||||||
stix->_false_class = stix_moveoop (stix, stix->_false_class);
|
stix->_false_class = stix_moveoop (stix, stix->_false_class);
|
||||||
|
@ -122,6 +122,7 @@ static int ignite_1 (stix_t* stix)
|
|||||||
stix->_symbol = alloc_kernel_class (stix, 0, STIX_CLASS_SPEC_MAKE(0, 1, STIX_OBJ_TYPE_CHAR));
|
stix->_symbol = alloc_kernel_class (stix, 0, STIX_CLASS_SPEC_MAKE(0, 1, STIX_OBJ_TYPE_CHAR));
|
||||||
stix->_symbol_set = alloc_kernel_class (stix, 0, STIX_CLASS_SPEC_MAKE(STIX_SET_NAMED_INSTVARS, 0, STIX_OBJ_TYPE_OOP));
|
stix->_symbol_set = alloc_kernel_class (stix, 0, STIX_CLASS_SPEC_MAKE(STIX_SET_NAMED_INSTVARS, 0, STIX_OBJ_TYPE_OOP));
|
||||||
stix->_system_dictionary = alloc_kernel_class (stix, 0, STIX_CLASS_SPEC_MAKE(STIX_SET_NAMED_INSTVARS, 0, STIX_OBJ_TYPE_OOP));
|
stix->_system_dictionary = alloc_kernel_class (stix, 0, STIX_CLASS_SPEC_MAKE(STIX_SET_NAMED_INSTVARS, 0, STIX_OBJ_TYPE_OOP));
|
||||||
|
stix->_method_dictionary = alloc_kernel_class (stix, 0, STIX_CLASS_SPEC_MAKE(STIX_SET_NAMED_INSTVARS, 0, STIX_OBJ_TYPE_OOP));
|
||||||
stix->_association = alloc_kernel_class (stix, 0, STIX_CLASS_SPEC_MAKE(STIX_ASSOCIATION_NAMED_INSTVARS, 0, STIX_OBJ_TYPE_OOP));
|
stix->_association = alloc_kernel_class (stix, 0, STIX_CLASS_SPEC_MAKE(STIX_ASSOCIATION_NAMED_INSTVARS, 0, STIX_OBJ_TYPE_OOP));
|
||||||
stix->_true_class = alloc_kernel_class (stix, 0, STIX_CLASS_SPEC_MAKE(0, 0, STIX_OBJ_TYPE_OOP));
|
stix->_true_class = alloc_kernel_class (stix, 0, STIX_CLASS_SPEC_MAKE(0, 0, STIX_OBJ_TYPE_OOP));
|
||||||
stix->_false_class = alloc_kernel_class (stix, 0, STIX_CLASS_SPEC_MAKE(0, 0, STIX_OBJ_TYPE_OOP));
|
stix->_false_class = alloc_kernel_class (stix, 0, STIX_CLASS_SPEC_MAKE(0, 0, STIX_OBJ_TYPE_OOP));
|
||||||
@ -134,8 +135,8 @@ static int ignite_1 (stix_t* stix)
|
|||||||
|
|
||||||
if (!stix->_stix || !stix->_nil_object || !stix->_object ||
|
if (!stix->_stix || !stix->_nil_object || !stix->_object ||
|
||||||
!stix->_array || !stix->_string || !stix->_symbol ||
|
!stix->_array || !stix->_string || !stix->_symbol ||
|
||||||
!stix->_symbol_set || !stix->_system_dictionary || !stix->_association ||
|
!stix->_symbol_set || !stix->_system_dictionary || !stix->_method_dictionary ||
|
||||||
!stix->_true_class || !stix->_false_class ||
|
!stix->_association || !stix->_true_class || !stix->_false_class ||
|
||||||
!stix->_character || !stix->_small_integer) return -1;
|
!stix->_character || !stix->_small_integer) return -1;
|
||||||
STIX_OBJ_SET_CLASS (stix->_nil, stix->_nil_object);
|
STIX_OBJ_SET_CLASS (stix->_nil, stix->_nil_object);
|
||||||
return 0;
|
return 0;
|
||||||
@ -143,7 +144,7 @@ static int ignite_1 (stix_t* stix)
|
|||||||
|
|
||||||
static int ignite_2 (stix_t* stix)
|
static int ignite_2 (stix_t* stix)
|
||||||
{
|
{
|
||||||
stix_oop_oop_t arr;
|
stix_oop_t tmp;
|
||||||
|
|
||||||
/* Create 'true' and 'false objects */
|
/* Create 'true' and 'false objects */
|
||||||
stix->_true = stix_instantiate (stix, stix->_true_class, STIX_NULL, 0);
|
stix->_true = stix_instantiate (stix, stix->_true_class, STIX_NULL, 0);
|
||||||
@ -151,8 +152,9 @@ static int ignite_2 (stix_t* stix)
|
|||||||
if (!stix->_true || !stix->_false) return -1;
|
if (!stix->_true || !stix->_false) return -1;
|
||||||
|
|
||||||
/* Create the symbol table */
|
/* Create the symbol table */
|
||||||
stix->symtab = (stix_oop_set_t)stix_instantiate (stix, stix->_symbol_set, STIX_NULL, 0);
|
tmp = stix_instantiate (stix, stix->_symbol_set, STIX_NULL, 0);
|
||||||
if (!stix->symtab) return -1;
|
if (!tmp) return -1;
|
||||||
|
stix->symtab = (stix_oop_set_t)tmp;
|
||||||
|
|
||||||
stix->symtab->tally = STIX_OOP_FROM_SMINT(0);
|
stix->symtab->tally = STIX_OOP_FROM_SMINT(0);
|
||||||
/* It's important to assign the result of stix_instantiate() to a temporary
|
/* It's important to assign the result of stix_instantiate() to a temporary
|
||||||
@ -160,18 +162,19 @@ static int ignite_2 (stix_t* stix)
|
|||||||
* The pointer 'stix->symtab; can change in stix_instantiate() and the
|
* The pointer 'stix->symtab; can change in stix_instantiate() and the
|
||||||
* target address of assignment may get set before stix_instantiate()
|
* target address of assignment may get set before stix_instantiate()
|
||||||
* is called. */
|
* is called. */
|
||||||
arr = (stix_oop_oop_t)stix_instantiate (stix, stix->_array, STIX_NULL, stix->option.dfl_symtab_size);
|
tmp = stix_instantiate (stix, stix->_array, STIX_NULL, stix->option.dfl_symtab_size);
|
||||||
if (!arr) return -1;
|
if (!tmp) return -1;
|
||||||
stix->symtab->bucket = arr;
|
stix->symtab->bucket = (stix_oop_oop_t)tmp;
|
||||||
|
|
||||||
/* Create the system dictionary */
|
/* Create the system dictionary */
|
||||||
stix->sysdic = (stix_oop_set_t)stix_instantiate (stix, stix->_system_dictionary, STIX_NULL, 0);
|
tmp = stix_instantiate (stix, stix->_system_dictionary, STIX_NULL, 0);
|
||||||
if (!stix->sysdic) return -1;
|
if (!tmp) return -1;
|
||||||
|
stix->sysdic = (stix_oop_set_t)tmp;
|
||||||
|
|
||||||
stix->sysdic->tally = STIX_OOP_FROM_SMINT(0);
|
stix->sysdic->tally = STIX_OOP_FROM_SMINT(0);
|
||||||
arr = (stix_oop_oop_t)stix_instantiate (stix, stix->_array, STIX_NULL, stix->option.dfl_sysdic_size);
|
tmp = stix_instantiate (stix, stix->_array, STIX_NULL, stix->option.dfl_sysdic_size);
|
||||||
if (!arr) return -1;
|
if (!tmp) return -1;
|
||||||
stix->sysdic->bucket = arr;
|
stix->sysdic->bucket = (stix_oop_oop_t)tmp;
|
||||||
|
|
||||||
/* Export the system dictionary via the first class variable of the Stix class */
|
/* Export the system dictionary via the first class variable of the Stix class */
|
||||||
((stix_oop_class_t)stix->_stix)->classvar[0] = (stix_oop_t)stix->sysdic;
|
((stix_oop_class_t)stix->_stix)->classvar[0] = (stix_oop_t)stix->sysdic;
|
||||||
@ -197,6 +200,7 @@ static int ignite_3 (stix_t* stix)
|
|||||||
{ 5, { 'A','r','r','a','y' } },
|
{ 5, { 'A','r','r','a','y' } },
|
||||||
{ 9, { 'S','y','m','b','o','l','S','e','t' } },
|
{ 9, { 'S','y','m','b','o','l','S','e','t' } },
|
||||||
{ 16, { 'S','y','s','t','e','m','D','i','c','t','i','o','n','a','r','y' } },
|
{ 16, { 'S','y','s','t','e','m','D','i','c','t','i','o','n','a','r','y' } },
|
||||||
|
{ 16, { 'M','e','t','h','o','d','D','i','c','t','i','o','n','a','r','y' } },
|
||||||
{ 11, { 'A','s','s','o','c','i','a','t','i','o','n' } },
|
{ 11, { 'A','s','s','o','c','i','a','t','i','o','n' } },
|
||||||
{ 4, { 'T','r','u','e' } },
|
{ 4, { 'T','r','u','e' } },
|
||||||
{ 5, { 'F','a','l','s','e' } },
|
{ 5, { 'F','a','l','s','e' } },
|
||||||
|
@ -255,11 +255,13 @@ int main (int argc, char* argv[])
|
|||||||
(unsigned long int)STIX_MAX_CLASSINSTVARS);
|
(unsigned long int)STIX_MAX_CLASSINSTVARS);
|
||||||
|
|
||||||
|
|
||||||
|
#if !defined(macintosh)
|
||||||
if (argc != 2)
|
if (argc != 2)
|
||||||
{
|
{
|
||||||
fprintf (stderr, "Usage: %s filename\n", argv[0]);
|
fprintf (stderr, "Usage: %s filename\n", argv[0]);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
{
|
{
|
||||||
stix_oow_t x;
|
stix_oow_t x;
|
||||||
@ -280,9 +282,12 @@ int main (int argc, char* argv[])
|
|||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
stix_oow_t symtab_size = 5000;
|
stix_oow_t tab_size;
|
||||||
stix_setoption (stix, STIX_DFL_SYMTAB_SIZE, &symtab_size);
|
|
||||||
stix_setoption (stix, STIX_DFL_SYSDIC_SIZE, &symtab_size);
|
tab_size = 5000;
|
||||||
|
stix_setoption (stix, STIX_DFL_SYMTAB_SIZE, &tab_size);
|
||||||
|
tab_size = 5000;
|
||||||
|
stix_setoption (stix, STIX_DFL_SYSDIC_SIZE, &tab_size);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (stix_ignite(stix) <= -1)
|
if (stix_ignite(stix) <= -1)
|
||||||
@ -316,7 +321,11 @@ printf ("%p\n", a);
|
|||||||
}
|
}
|
||||||
|
|
||||||
xtn = stix_getxtn (stix);
|
xtn = stix_getxtn (stix);
|
||||||
|
#if !defined(macintosh)
|
||||||
xtn->source_path = argv[1];
|
xtn->source_path = argv[1];
|
||||||
|
#else
|
||||||
|
xtn->source_path = "test.st";
|
||||||
|
#endif
|
||||||
if (stix_compile (stix, input_handler) <= -1)
|
if (stix_compile (stix, input_handler) <= -1)
|
||||||
{
|
{
|
||||||
if (stix->errnum == STIX_ESYNTAX)
|
if (stix->errnum == STIX_ESYNTAX)
|
||||||
|
@ -121,7 +121,6 @@ stix_oop_t stix_alloccharobj (stix_t* stix, const stix_uch_t* ptr, stix_oow_t le
|
|||||||
|
|
||||||
stix_oop_t stix_allocbyteobj (stix_t* stix, const stix_byte_t* ptr, stix_oow_t len)
|
stix_oop_t stix_allocbyteobj (stix_t* stix, const stix_byte_t* ptr, stix_oow_t len)
|
||||||
{
|
{
|
||||||
|
|
||||||
return alloc_numeric_array (stix, ptr, len, STIX_OBJ_TYPE_BYTE, STIX_SIZEOF(stix_byte_t), 0);
|
return alloc_numeric_array (stix, ptr, len, STIX_OBJ_TYPE_BYTE, STIX_SIZEOF(stix_byte_t), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -515,6 +515,7 @@ struct stix_compiler_t
|
|||||||
|
|
||||||
stix_oop_class_t self_oop;
|
stix_oop_class_t self_oop;
|
||||||
stix_oop_t super_oop; /* this may be nil. so the type is stix_oop_t */
|
stix_oop_t super_oop; /* this may be nil. so the type is stix_oop_t */
|
||||||
|
stix_oop_set_t mthdic_oop;
|
||||||
|
|
||||||
stix_ucs_t name;
|
stix_ucs_t name;
|
||||||
stix_size_t name_capa;
|
stix_size_t name_capa;
|
||||||
@ -659,21 +660,15 @@ stix_oop_t stix_alloccharobj (
|
|||||||
stix_oow_t len
|
stix_oow_t len
|
||||||
);
|
);
|
||||||
|
|
||||||
stix_oop_t stix_allocuint8obj (
|
stix_oop_t stix_allocbyteobj (
|
||||||
stix_t* stix,
|
stix_t* stix,
|
||||||
const stix_uint8_t* ptr,
|
const stix_byte_t* ptr,
|
||||||
stix_oow_t len
|
stix_oow_t len
|
||||||
);
|
);
|
||||||
|
|
||||||
stix_oop_t stix_allocuint16obj (
|
stix_oop_t stix_allocwordobj (
|
||||||
stix_t* stix,
|
stix_t* stix,
|
||||||
const stix_uint16_t* ptr,
|
const stix_oow_t* ptr,
|
||||||
stix_oow_t len
|
|
||||||
);
|
|
||||||
|
|
||||||
stix_oop_t stix_allocuint32obj (
|
|
||||||
stix_t* stix,
|
|
||||||
const stix_uint32_t* ptr,
|
|
||||||
stix_oow_t len
|
stix_oow_t len
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -717,6 +712,31 @@ stix_oop_t stix_lookupsysdic (
|
|||||||
const stix_ucs_t* name
|
const stix_ucs_t* name
|
||||||
);
|
);
|
||||||
|
|
||||||
|
stix_oop_t stix_putatdic (
|
||||||
|
stix_t* stix,
|
||||||
|
stix_oop_set_t dic,
|
||||||
|
stix_oop_t key,
|
||||||
|
stix_oop_t value
|
||||||
|
);
|
||||||
|
|
||||||
|
stix_oop_t stix_getatdic (
|
||||||
|
stix_t* stix,
|
||||||
|
stix_oop_set_t dic,
|
||||||
|
stix_oop_t key
|
||||||
|
);
|
||||||
|
|
||||||
|
stix_oop_t stix_lookupdic (
|
||||||
|
stix_t* stix,
|
||||||
|
stix_oop_set_t dic,
|
||||||
|
const stix_ucs_t* name
|
||||||
|
);
|
||||||
|
|
||||||
|
stix_oop_set_t stix_makedic (
|
||||||
|
stix_t* stix,
|
||||||
|
stix_oop_t cls,
|
||||||
|
stix_oow_t size
|
||||||
|
);
|
||||||
|
|
||||||
/* ========================================================================= */
|
/* ========================================================================= */
|
||||||
/* utf8.c */
|
/* utf8.c */
|
||||||
/* ========================================================================= */
|
/* ========================================================================= */
|
||||||
|
@ -620,6 +620,7 @@ struct stix_t
|
|||||||
stix_oop_t _array; /* Array */
|
stix_oop_t _array; /* Array */
|
||||||
stix_oop_t _symbol_set; /* SymbolSet */
|
stix_oop_t _symbol_set; /* SymbolSet */
|
||||||
stix_oop_t _system_dictionary; /* SystemDictionary */
|
stix_oop_t _system_dictionary; /* SystemDictionary */
|
||||||
|
stix_oop_t _method_dictionary; /* MethodDictionary */
|
||||||
stix_oop_t _association; /* Association */
|
stix_oop_t _association; /* Association */
|
||||||
stix_oop_t _true_class; /* True */
|
stix_oop_t _true_class; /* True */
|
||||||
stix_oop_t _false_class; /* False */
|
stix_oop_t _false_class; /* False */
|
||||||
@ -630,7 +631,7 @@ struct stix_t
|
|||||||
stix_oop_set_t symtab; /* system-wide symbol table. instance of SymbolSet */
|
stix_oop_set_t symtab; /* system-wide symbol table. instance of SymbolSet */
|
||||||
stix_oop_set_t sysdic; /* system dictionary. instance of SystemDictionary */
|
stix_oop_set_t sysdic; /* system dictionary. instance of SystemDictionary */
|
||||||
|
|
||||||
stix_oop_t* tmp_stack[100]; /* stack for temporaries */
|
stix_oop_t* tmp_stack[256]; /* stack for temporaries */
|
||||||
stix_oow_t tmp_count;
|
stix_oow_t tmp_count;
|
||||||
|
|
||||||
#if defined(STIX_INCLUDE_COMPILER)
|
#if defined(STIX_INCLUDE_COMPILER)
|
||||||
|
@ -26,35 +26,36 @@
|
|||||||
|
|
||||||
#include "stix-prv.h"
|
#include "stix-prv.h"
|
||||||
|
|
||||||
static stix_oop_oop_t expand_bucket (stix_t* stix, stix_oop_oop_t old_bucket)
|
static stix_oop_oop_t expand_bucket (stix_t* stix, stix_oop_oop_t oldbuc)
|
||||||
{
|
{
|
||||||
stix_oop_oop_t new_bucket;
|
stix_oop_oop_t newbuc;
|
||||||
stix_oow_t oldsz, newsz, index;
|
stix_oow_t oldsz, newsz, index;
|
||||||
stix_oop_char_t symbol;
|
stix_oop_char_t symbol;
|
||||||
|
|
||||||
/* TODO: derive a better growth size */
|
/* TODO: derive a better growth size */
|
||||||
new_bucket = (stix_oop_oop_t)stix_instantiate (stix, stix->_array, STIX_NULL, STIX_OBJ_GET_SIZE(old_bucket) * 2);
|
stix_pushtmp (stix, (stix_oop_t*)&oldbuc);
|
||||||
if (!new_bucket) return STIX_NULL;
|
newbuc = (stix_oop_oop_t)stix_instantiate (stix, stix->_array, STIX_NULL, STIX_OBJ_GET_SIZE(oldbuc) * 2);
|
||||||
|
stix_poptmp (stix);
|
||||||
|
if (!newbuc) return STIX_NULL;
|
||||||
|
|
||||||
oldsz = STIX_OBJ_GET_SIZE(old_bucket);
|
oldsz = STIX_OBJ_GET_SIZE(oldbuc);
|
||||||
newsz = STIX_OBJ_GET_SIZE(new_bucket);
|
newsz = STIX_OBJ_GET_SIZE(newbuc);
|
||||||
|
|
||||||
while (oldsz > 0)
|
while (oldsz > 0)
|
||||||
{
|
{
|
||||||
symbol = (stix_oop_char_t)old_bucket->slot[--oldsz];
|
symbol = (stix_oop_char_t)oldbuc->slot[--oldsz];
|
||||||
if ((stix_oop_t)symbol != stix->_nil)
|
if ((stix_oop_t)symbol != stix->_nil)
|
||||||
{
|
{
|
||||||
STIX_ASSERT (STIX_CLASSOF(stix,symbol) == stix->_symbol);
|
STIX_ASSERT (STIX_CLASSOF(stix,symbol) == stix->_symbol);
|
||||||
/*STIX_ASSERT (sym->size > 0);*/
|
/*STIX_ASSERT (sym->size > 0);*/
|
||||||
|
|
||||||
index = stix_hashchars(symbol->slot, STIX_OBJ_GET_SIZE(symbol)) % newsz;
|
index = stix_hashchars(symbol->slot, STIX_OBJ_GET_SIZE(symbol)) % newsz;
|
||||||
while (new_bucket->slot[index] != stix->_nil)
|
while (newbuc->slot[index] != stix->_nil) index = (index + 1) % newsz;
|
||||||
index = (index + 1) % newsz;
|
newbuc->slot[index] = (stix_oop_t)symbol;
|
||||||
new_bucket->slot[index] = (stix_oop_t)symbol;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return new_bucket;
|
return newbuc;
|
||||||
}
|
}
|
||||||
|
|
||||||
static stix_oop_t find_or_make_symbol (stix_t* stix, const stix_uch_t* ptr, stix_oow_t len, int create)
|
static stix_oop_t find_or_make_symbol (stix_t* stix, const stix_uch_t* ptr, stix_oow_t len, int create)
|
||||||
|
62
stix/lib/syntax.txt
Normal file
62
stix/lib/syntax.txt
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
|
||||||
|
literal := number-literal | string-literal | character-literal | symbol-literal
|
||||||
|
|
||||||
|
string-literal := single-quote string-character* single-quote
|
||||||
|
string-character := normal-character | (single-quote single-quote)
|
||||||
|
single-quote := "'"
|
||||||
|
normal-character := character-except-single-quote
|
||||||
|
|
||||||
|
character-literal := "$" character
|
||||||
|
character := normal-character | "'"
|
||||||
|
|
||||||
|
symbol-literal := "#" symbol-body
|
||||||
|
symbol-body := identifier | keyword+ | binary-selector | string
|
||||||
|
|
||||||
|
unary-selector := identifier
|
||||||
|
binary-selector := binary-selector-character+
|
||||||
|
binary-selector-character := "+" | "/" | "\" | ...
|
||||||
|
selector-argument := identifier
|
||||||
|
|
||||||
|
identifier := alpha-char (alpha-char | digit-char)*
|
||||||
|
keyword := identifier ":"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class-definition := #class class-modifier? "{" class-body "}"
|
||||||
|
class-modifier := "(" (#byte | #character | #word | #pointer)? ")"
|
||||||
|
class-body := variable-definition* method-definition*
|
||||||
|
|
||||||
|
variable-definition := (#dcl | #declare) variable-modifier? variable-list "."
|
||||||
|
variable-modifier := "(" (#class | #classinst)? ")"
|
||||||
|
variable-list := identifier*
|
||||||
|
|
||||||
|
method-definition := (#mth | #method) method-modifier? method-actual-definition
|
||||||
|
method-modifier := "(" (#class | #instance) ")"
|
||||||
|
method-actual-definition := method-name "{" method-tempraries? method-primitive? method-statements* "}"
|
||||||
|
|
||||||
|
method-name := unary-method-name | binary-method-name | keyword-method-name
|
||||||
|
unary-method-name := unary-selector
|
||||||
|
binary-method-name := binary-selector selector-argument
|
||||||
|
keyword-method-name := (keyword selector-argument)+
|
||||||
|
|
||||||
|
method-temporaries := "|" variable-list "|"
|
||||||
|
method-primitive := "<" "primitive:" integer ">"
|
||||||
|
method-statements := method-statement ("." | ("." method-statements))*
|
||||||
|
method-statement := method-return | method-expression
|
||||||
|
method-return := "^" method-expression
|
||||||
|
|
||||||
|
|
||||||
|
method-expression := assignment-expression | basic-expression
|
||||||
|
assignment-expression := identifier ":=" method-expression
|
||||||
|
basic-expression := expression-primary (message cascaded-message)?
|
||||||
|
|
||||||
|
----------------------------------------------------------
|
||||||
|
|
||||||
|
#include '....'.
|
||||||
|
|
||||||
|
#class Test(Object)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
#main
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user