This commit is contained in:
parent
def1e7349c
commit
ec73905fc4
175
lib/gc.c
175
lib/gc.c
@ -37,30 +37,30 @@ static struct
|
||||
hcl_oow_t offset;
|
||||
} syminfo[] =
|
||||
{
|
||||
{ 3, { 'a','n','d' }, HCL_SYNCODE_AND, HCL_OFFSETOF(hcl_t,_and) },
|
||||
{ 5, { 'b','r','e','a','k' }, HCL_SYNCODE_BREAK, HCL_OFFSETOF(hcl_t,_break) },
|
||||
{ 5, { 'c','a','t','c','h' }, HCL_SYNCODE_CATCH, HCL_OFFSETOF(hcl_t,_catch) },
|
||||
{ 5, { 'c','l','a','s','s' }, HCL_SYNCODE_CLASS, HCL_OFFSETOF(hcl_t,_class) },
|
||||
{ 8, { 'c','o','n','t','i','n','u','e' }, HCL_SYNCODE_CONTINUE, HCL_OFFSETOF(hcl_t,_continue) },
|
||||
{ 8, { 'd','e','f','c','l','a','s','s' }, HCL_SYNCODE_DEFCLASS, HCL_OFFSETOF(hcl_t,_defclass) },
|
||||
{ 5, { 'd','e','f','u','n' }, HCL_SYNCODE_DEFUN, HCL_OFFSETOF(hcl_t,_defun) },
|
||||
{ 2, { 'd','o' }, HCL_SYNCODE_DO, HCL_OFFSETOF(hcl_t,_do) },
|
||||
{ 4, { 'e','l','i','f' }, HCL_SYNCODE_ELIF, HCL_OFFSETOF(hcl_t,_elif) },
|
||||
{ 4, { 'e','l','s','e' }, HCL_SYNCODE_ELSE, HCL_OFFSETOF(hcl_t,_else) },
|
||||
{ 3, { 'f','u','n' }, HCL_SYNCODE_LAMBDA, HCL_OFFSETOF(hcl_t,_fun) }, /* same syncode as lambda */
|
||||
{ 2, { 'i','f' }, HCL_SYNCODE_IF, HCL_OFFSETOF(hcl_t,_if) },
|
||||
{ 6, { 'l','a','m','b','d','a' }, HCL_SYNCODE_LAMBDA, HCL_OFFSETOF(hcl_t,_lambda) },
|
||||
{ 2, { 'o','r' }, HCL_SYNCODE_OR, HCL_OFFSETOF(hcl_t,_or) },
|
||||
{ 4, { 'p','l','u','s' }, HCL_SYNCODE_PLUS, HCL_OFFSETOF(hcl_t,_plus) },
|
||||
{ 6, { 'r','e','t','u','r','n'}, HCL_SYNCODE_RETURN, HCL_OFFSETOF(hcl_t,_return) },
|
||||
{ 3, { 'a','n','d' }, HCL_SYNCODE_AND, HCL_OFFSETOF(hcl_t,s_and) },
|
||||
{ 5, { 'b','r','e','a','k' }, HCL_SYNCODE_BREAK, HCL_OFFSETOF(hcl_t,s_break) },
|
||||
{ 5, { 'c','a','t','c','h' }, HCL_SYNCODE_CATCH, HCL_OFFSETOF(hcl_t,s_catch) },
|
||||
{ 5, { 'c','l','a','s','s' }, HCL_SYNCODE_CLASS, HCL_OFFSETOF(hcl_t,s_class) },
|
||||
{ 8, { 'c','o','n','t','i','n','u','e' }, HCL_SYNCODE_CONTINUE, HCL_OFFSETOF(hcl_t,s_continue) },
|
||||
{ 8, { 'd','e','f','c','l','a','s','s' }, HCL_SYNCODE_DEFCLASS, HCL_OFFSETOF(hcl_t,s_defclass) },
|
||||
{ 5, { 'd','e','f','u','n' }, HCL_SYNCODE_DEFUN, HCL_OFFSETOF(hcl_t,s_defun) },
|
||||
{ 2, { 'd','o' }, HCL_SYNCODE_DO, HCL_OFFSETOF(hcl_t,s_do) },
|
||||
{ 4, { 'e','l','i','f' }, HCL_SYNCODE_ELIF, HCL_OFFSETOF(hcl_t,s_elif) },
|
||||
{ 4, { 'e','l','s','e' }, HCL_SYNCODE_ELSE, HCL_OFFSETOF(hcl_t,s_else) },
|
||||
{ 3, { 'f','u','n' }, HCL_SYNCODE_LAMBDA, HCL_OFFSETOF(hcl_t,s_fun) }, /* same syncode as lambda */
|
||||
{ 2, { 'i','f' }, HCL_SYNCODE_IF, HCL_OFFSETOF(hcl_t,s_if) },
|
||||
{ 6, { 'l','a','m','b','d','a' }, HCL_SYNCODE_LAMBDA, HCL_OFFSETOF(hcl_t,s_lambda) },
|
||||
{ 2, { 'o','r' }, HCL_SYNCODE_OR, HCL_OFFSETOF(hcl_t,s_or) },
|
||||
{ 4, { 'p','l','u','s' }, HCL_SYNCODE_PLUS, HCL_OFFSETOF(hcl_t,s_plus) },
|
||||
{ 6, { 'r','e','t','u','r','n'}, HCL_SYNCODE_RETURN, HCL_OFFSETOF(hcl_t,s_return) },
|
||||
{ 16, { 'r','e','t','u','r','n','-','f','r','o','m','-','h','o','m','e'},
|
||||
HCL_SYNCODE_RETURN_FROM_HOME, HCL_OFFSETOF(hcl_t,_return_from_home) },
|
||||
{ 3, { 's','e','t' }, HCL_SYNCODE_SET, HCL_OFFSETOF(hcl_t,_set) },
|
||||
{ 5, { 's','e','t','-','r' }, HCL_SYNCODE_SET_R, HCL_OFFSETOF(hcl_t,_set_r) },
|
||||
{ 5, { 't','h','r','o','w' }, HCL_SYNCODE_THROW, HCL_OFFSETOF(hcl_t,_throw) },
|
||||
{ 3, { 't','r','y' }, HCL_SYNCODE_TRY, HCL_OFFSETOF(hcl_t,_try_) },
|
||||
{ 5, { 'u','n','t','i','l' }, HCL_SYNCODE_UNTIL, HCL_OFFSETOF(hcl_t,_until) },
|
||||
{ 5, { 'w','h','i','l','e' }, HCL_SYNCODE_WHILE, HCL_OFFSETOF(hcl_t,_while) }
|
||||
HCL_SYNCODE_RETURN_FROM_HOME, HCL_OFFSETOF(hcl_t,s_return_from_home) },
|
||||
{ 3, { 's','e','t' }, HCL_SYNCODE_SET, HCL_OFFSETOF(hcl_t,s_set) },
|
||||
{ 5, { 's','e','t','-','r' }, HCL_SYNCODE_SET_R, HCL_OFFSETOF(hcl_t,s_set_r) },
|
||||
{ 5, { 't','h','r','o','w' }, HCL_SYNCODE_THROW, HCL_OFFSETOF(hcl_t,s_throw) },
|
||||
{ 3, { 't','r','y' }, HCL_SYNCODE_TRY, HCL_OFFSETOF(hcl_t,s_try) },
|
||||
{ 5, { 'u','n','t','i','l' }, HCL_SYNCODE_UNTIL, HCL_OFFSETOF(hcl_t,s_until) },
|
||||
{ 5, { 'w','h','i','l','e' }, HCL_SYNCODE_WHILE, HCL_OFFSETOF(hcl_t,s_while) }
|
||||
};
|
||||
|
||||
/* ========================================================================= */
|
||||
@ -320,6 +320,11 @@ static HCL_INLINE void gc_ms_mark_roots (hcl_t* hcl)
|
||||
gc_ms_mark (hcl, *(hcl_oop_t*)((hcl_uint8_t*)hcl + syminfo[i].offset));
|
||||
}
|
||||
|
||||
for (i = 0; i < HCL_COUNTOF(kernel_classes); i++)
|
||||
{
|
||||
gc_ms_mark (hcl, *(hcl_oop_t*)((hcl_uint8_t*)hcl + kernel_classes[i].offset));
|
||||
}
|
||||
|
||||
gc_ms_mark (hcl, (hcl_oop_t)hcl->sysdic);
|
||||
gc_ms_mark (hcl, (hcl_oop_t)hcl->processor);
|
||||
gc_ms_mark (hcl, (hcl_oop_t)hcl->nil_process);
|
||||
@ -597,6 +602,14 @@ void hcl_gc (hcl_t* hcl)
|
||||
*(hcl_oop_t*)((hcl_uint8_t*)hcl + syminfo[i].offset) = tmp;
|
||||
}
|
||||
|
||||
for (i = 0; i < HCL_COUNTOF(kernel_classes); i++)
|
||||
{
|
||||
hcl_oop_t tmp;
|
||||
tmp = *(hcl_oop_t*)((hcl_uint8_t*)hcl + kernel_classes[i].offset);
|
||||
tmp = hcl_moveoop(hcl, tmp);
|
||||
*(hcl_oop_t*)((hcl_uint8_t*)hcl + kernel_classes[i].offset) = tmp;
|
||||
}
|
||||
|
||||
hcl->sysdic = (hcl_oop_dic_t)hcl_moveoop(hcl, (hcl_oop_t)hcl->sysdic);
|
||||
hcl->processor = (hcl_oop_process_scheduler_t)hcl_moveoop(hcl, (hcl_oop_t)hcl->processor);
|
||||
hcl->nil_process = (hcl_oop_process_t)hcl_moveoop(hcl, (hcl_oop_t)hcl->nil_process);
|
||||
@ -766,57 +779,57 @@ static struct
|
||||
hcl_oow_t ncvars;
|
||||
} kctab[] = {
|
||||
{ "Apex",
|
||||
HCL_OFFSETOF(hcl_t, class_apex),
|
||||
HCL_OFFSETOF(hcl_t, c_apex),
|
||||
HCL_TYPE_MAX(hcl_oow_t),
|
||||
0, 0 },
|
||||
|
||||
{ "Object",
|
||||
HCL_OFFSETOF(hcl_t, class_object),
|
||||
HCL_OFFSETOF(hcl_t, class_apex),
|
||||
HCL_OFFSETOF(hcl_t, c_object),
|
||||
HCL_OFFSETOF(hcl_t, c_apex),
|
||||
0, 0 },
|
||||
|
||||
{ "UndefinedObject",
|
||||
HCL_OFFSETOF(hcl_t, class_undefobj),
|
||||
HCL_OFFSETOF(hcl_t, class_apex),
|
||||
HCL_OFFSETOF(hcl_t, c_undefobj),
|
||||
HCL_OFFSETOF(hcl_t, c_apex),
|
||||
0, 0 },
|
||||
|
||||
{ "Class",
|
||||
HCL_OFFSETOF(hcl_t, class_class),
|
||||
HCL_OFFSETOF(hcl_t, class_object),
|
||||
HCL_OFFSETOF(hcl_t, c_class),
|
||||
HCL_OFFSETOF(hcl_t, c_object),
|
||||
HCL_CLASS_NAMED_INSTVARS, 0 },
|
||||
|
||||
{ "String",
|
||||
HCL_OFFSETOF(hcl_t, class_string),
|
||||
HCL_OFFSETOF(hcl_t, class_object),
|
||||
HCL_OFFSETOF(hcl_t, c_string),
|
||||
HCL_OFFSETOF(hcl_t, c_object),
|
||||
0, 0 },
|
||||
|
||||
{ "Symbol",
|
||||
HCL_OFFSETOF(hcl_t, class_symbol),
|
||||
HCL_OFFSETOF(hcl_t, class_string),
|
||||
HCL_OFFSETOF(hcl_t, c_symbol),
|
||||
HCL_OFFSETOF(hcl_t, c_string),
|
||||
0, 0 },
|
||||
|
||||
{ "Boolean",
|
||||
HCL_OFFSETOF(hcl_t, class_boolean),
|
||||
HCL_OFFSETOF(hcl_t, class_object),
|
||||
HCL_OFFSETOF(hcl_t, c_boolean),
|
||||
HCL_OFFSETOF(hcl_t, c_object),
|
||||
0, 0 },
|
||||
|
||||
{ "True",
|
||||
HCL_OFFSETOF(hcl_t, class_true),
|
||||
HCL_OFFSETOF(hcl_t, class_boolean),
|
||||
HCL_OFFSETOF(hcl_t, c_true),
|
||||
HCL_OFFSETOF(hcl_t, c_boolean),
|
||||
0, 0 },
|
||||
|
||||
{ "False",
|
||||
HCL_OFFSETOF(hcl_t, class_false),
|
||||
HCL_OFFSETOF(hcl_t, class_boolean),
|
||||
HCL_OFFSETOF(hcl_t, c_false),
|
||||
HCL_OFFSETOF(hcl_t, c_boolean),
|
||||
0, 0 },
|
||||
|
||||
{ "System",
|
||||
HCL_OFFSETOF(hcl_t, class_system),
|
||||
HCL_OFFSETOF(hcl_t, class_object),
|
||||
HCL_OFFSETOF(hcl_t, c_system),
|
||||
HCL_OFFSETOF(hcl_t, c_object),
|
||||
0, 0 },
|
||||
};
|
||||
|
||||
#if 0
|
||||
|
||||
/*
|
||||
* Apex......................
|
||||
* ^ ^ ^ : .......
|
||||
@ -895,7 +908,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
0,
|
||||
0,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _apex) },
|
||||
HCL_OFFSETOF(hcl_t, c_apex) },
|
||||
|
||||
{ "UndefinedObject",
|
||||
0,
|
||||
@ -903,7 +916,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
0,
|
||||
0,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _undefined_object) },
|
||||
HCL_OFFSETOF(hcl_t, c_undefobj) },
|
||||
|
||||
#define KCI_CLASS 2 /* index to the Class entry in this table */
|
||||
{ "Class",
|
||||
@ -912,8 +925,9 @@ static kernel_class_info_t kernel_classes[] =
|
||||
HCL_CLASS_NAMED_INSTVARS,
|
||||
HCL_CLASS_SPEC_FLAG_INDEXED | HCL_CLASS_SPEC_FLAG_UNCOPYABLE,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _class) },
|
||||
HCL_OFFSETOF(hcl_t, c_class) },
|
||||
|
||||
#if 0
|
||||
{ "Interface",
|
||||
HCL_CLASS_SELFSPEC_FLAG_LIMITED,
|
||||
0,
|
||||
@ -921,6 +935,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
HCL_CLASS_SPEC_FLAG_INDEXED | HCL_CLASS_SPEC_FLAG_UNCOPYABLE,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _interface) },
|
||||
#endif
|
||||
|
||||
{ "Object",
|
||||
0,
|
||||
@ -928,7 +943,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
0,
|
||||
0,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _object) },
|
||||
HCL_OFFSETOF(hcl_t, c_object) },
|
||||
|
||||
{ "String",
|
||||
0,
|
||||
@ -936,7 +951,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
0,
|
||||
HCL_CLASS_SPEC_FLAG_INDEXED,
|
||||
HCL_OBJ_TYPE_CHAR,
|
||||
HCL_OFFSETOF(hcl_t, _string) },
|
||||
HCL_OFFSETOF(hcl_t, c_string) },
|
||||
|
||||
{ "Symbol",
|
||||
HCL_CLASS_SELFSPEC_FLAG_FINAL | HCL_CLASS_SELFSPEC_FLAG_LIMITED,
|
||||
@ -944,7 +959,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
0,
|
||||
HCL_CLASS_SPEC_FLAG_INDEXED | HCL_CLASS_SPEC_FLAG_IMMUTABLE,
|
||||
HCL_OBJ_TYPE_CHAR,
|
||||
HCL_OFFSETOF(hcl_t, _symbol) },
|
||||
HCL_OFFSETOF(hcl_t, c_symbol) },
|
||||
|
||||
{ "Array",
|
||||
0,
|
||||
@ -952,7 +967,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
0,
|
||||
HCL_CLASS_SPEC_FLAG_INDEXED,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _array) },
|
||||
HCL_OFFSETOF(hcl_t, c_array) },
|
||||
|
||||
{ "ByteArray",
|
||||
0,
|
||||
@ -960,7 +975,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
0,
|
||||
HCL_CLASS_SPEC_FLAG_INDEXED,
|
||||
HCL_OBJ_TYPE_BYTE,
|
||||
HCL_OFFSETOF(hcl_t, _byte_array) },
|
||||
HCL_OFFSETOF(hcl_t, c_byte_array) },
|
||||
|
||||
{ "SymbolTable",
|
||||
0,
|
||||
@ -968,7 +983,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
HCL_DIC_NAMED_INSTVARS,
|
||||
0,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _symbol_table) },
|
||||
HCL_OFFSETOF(hcl_t, c_symbol_table) },
|
||||
|
||||
{ "Dictionary",
|
||||
0,
|
||||
@ -976,7 +991,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
HCL_DIC_NAMED_INSTVARS,
|
||||
0,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _dictionary) },
|
||||
HCL_OFFSETOF(hcl_t, c_dictionary) },
|
||||
|
||||
{ "Association",
|
||||
0,
|
||||
@ -984,15 +999,16 @@ static kernel_class_info_t kernel_classes[] =
|
||||
HCL_ASSOCIATION_NAMED_INSTVARS,
|
||||
0,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _association) },
|
||||
HCL_OFFSETOF(hcl_t, c_association) },
|
||||
|
||||
#if 0
|
||||
{ "Namespace",
|
||||
HCL_CLASS_SELFSPEC_FLAG_LIMITED,
|
||||
0,
|
||||
HCL_NSDIC_NAMED_INSTVARS,
|
||||
0,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _namespace) },
|
||||
HCL_OFFSETOF(hcl_t, c_namespace) },
|
||||
|
||||
{ "PoolDictionary",
|
||||
0,
|
||||
@ -1000,7 +1016,8 @@ static kernel_class_info_t kernel_classes[] =
|
||||
HCL_DIC_NAMED_INSTVARS,
|
||||
0,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _pool_dictionary) },
|
||||
HCL_OFFSETOF(hcl_t, c_pool_dictionary) },
|
||||
#endif
|
||||
|
||||
{ "MethodDictionary",
|
||||
0,
|
||||
@ -1008,7 +1025,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
HCL_DIC_NAMED_INSTVARS,
|
||||
0,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _method_dictionary) },
|
||||
HCL_OFFSETOF(hcl_t, c_method_dictionary) },
|
||||
|
||||
{ "CompiledMethod",
|
||||
0,
|
||||
@ -1016,7 +1033,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
HCL_METHOD_NAMED_INSTVARS,
|
||||
HCL_CLASS_SPEC_FLAG_INDEXED,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _method) },
|
||||
HCL_OFFSETOF(hcl_t, c_method) },
|
||||
|
||||
{ "MethodSignature",
|
||||
0,
|
||||
@ -1024,7 +1041,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
HCL_METHSIG_NAMED_INSTVARS,
|
||||
HCL_CLASS_SPEC_FLAG_INDEXED,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _methsig) },
|
||||
HCL_OFFSETOF(hcl_t, c_methsig) },
|
||||
|
||||
{ "CompiledBlock",
|
||||
0,
|
||||
@ -1032,7 +1049,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
HCL_BLOCK_NAMED_INSTVARS,
|
||||
0,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _block) },
|
||||
HCL_OFFSETOF(hcl_t, c_block) },
|
||||
|
||||
{ "MethodContext",
|
||||
HCL_CLASS_SELFSPEC_FLAG_FINAL | HCL_CLASS_SELFSPEC_FLAG_LIMITED,
|
||||
@ -1040,7 +1057,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
HCL_CONTEXT_NAMED_INSTVARS,
|
||||
HCL_CLASS_SPEC_FLAG_INDEXED,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _method_context) },
|
||||
HCL_OFFSETOF(hcl_t, c_method_context) },
|
||||
|
||||
{ "BlockContext"
|
||||
HCL_CLASS_SELFSPEC_FLAG_FINAL | HCL_CLASS_SELFSPEC_FLAG_LIMITED,
|
||||
@ -1048,7 +1065,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
HCL_CONTEXT_NAMED_INSTVARS,
|
||||
HCL_CLASS_SPEC_FLAG_INDEXED,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _block_context) },
|
||||
HCL_OFFSETOF(hcl_t, c_block_context) },
|
||||
|
||||
{ "Process",
|
||||
HCL_CLASS_SELFSPEC_FLAG_FINAL | HCL_CLASS_SELFSPEC_FLAG_LIMITED,
|
||||
@ -1056,7 +1073,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
HCL_PROCESS_NAMED_INSTVARS,
|
||||
HCL_CLASS_SPEC_FLAG_INDEXED | HCL_CLASS_SPEC_FLAG_UNCOPYABLE,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _process) },
|
||||
HCL_OFFSETOF(hcl_t, c_process) },
|
||||
|
||||
{ "Semaphore",
|
||||
0,
|
||||
@ -1064,7 +1081,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
HCL_SEMAPHORE_NAMED_INSTVARS,
|
||||
HCL_CLASS_SPEC_FLAG_UNCOPYABLE,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _semaphore) },
|
||||
HCL_OFFSETOF(hcl_t, c_semaphore) },
|
||||
|
||||
{ "SemaphoreGroup",
|
||||
0,
|
||||
@ -1072,15 +1089,15 @@ static kernel_class_info_t kernel_classes[] =
|
||||
HCL_SEMAPHORE_GROUP_NAMED_INSTVARS,
|
||||
HCL_CLASS_SPEC_FLAG_UNCOPYABLE,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _semaphore_group) },
|
||||
HCL_OFFSETOF(hcl_t, c_semaphore_group) },
|
||||
|
||||
{ "ProcessScheduler".
|
||||
{ "ProcessScheduler",
|
||||
HCL_CLASS_SELFSPEC_FLAG_FINAL | HCL_CLASS_SELFSPEC_FLAG_LIMITED,
|
||||
0,
|
||||
HCL_PROCESS_SCHEDULER_NAMED_INSTVARS,
|
||||
HCL_CLASS_SPEC_FLAG_UNCOPYABLE,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _process_scheduler) },
|
||||
HCL_OFFSETOF(hcl_t, c_process_scheduler) },
|
||||
|
||||
{ "Error",
|
||||
HCL_CLASS_SELFSPEC_FLAG_LIMITED,
|
||||
@ -1088,7 +1105,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
0,
|
||||
0,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _error_class) },
|
||||
HCL_OFFSETOF(hcl_t, c_error) },
|
||||
|
||||
{ "True",
|
||||
HCL_CLASS_SELFSPEC_FLAG_LIMITED | HCL_CLASS_SELFSPEC_FLAG_FINAL,
|
||||
@ -1096,7 +1113,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
0,
|
||||
0,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _true_class) },
|
||||
HCL_OFFSETOF(hcl_t, c_true) },
|
||||
|
||||
{ "False",
|
||||
HCL_CLASS_SELFSPEC_FLAG_LIMITED | HCL_CLASS_SELFSPEC_FLAG_FINAL,
|
||||
@ -1104,7 +1121,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
0,
|
||||
0,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _false_class) },
|
||||
HCL_OFFSETOF(hcl_t, c_false) },
|
||||
|
||||
/* TOOD: what is a proper spec for Character and SmallInteger?
|
||||
* If the fixed part is 0, its instance must be an object of 0 payload fields.
|
||||
@ -1115,7 +1132,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
0,
|
||||
0,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _character) },
|
||||
HCL_OFFSETOF(hcl_t, c_character) },
|
||||
|
||||
{ "SmallInteger",
|
||||
HCL_CLASS_SELFSPEC_FLAG_LIMITED,
|
||||
@ -1123,7 +1140,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
0,
|
||||
0,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _small_integer) },
|
||||
HCL_OFFSETOF(hcl_t, c_small_integer) },
|
||||
|
||||
{ "LargePositiveInteger",
|
||||
HCL_CLASS_SELFSPEC_FLAG_LIMITED,
|
||||
@ -1131,7 +1148,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
0,
|
||||
HCL_CLASS_SPEC_FLAG_INDEXED | HCL_CLASS_SPEC_FLAG_IMMUTABLE,
|
||||
HCL_OBJ_TYPE_LIWORD,
|
||||
HCL_OFFSETOF(hcl_t, _large_positive_integer) },
|
||||
HCL_OFFSETOF(hcl_t, c_large_positive_integer) },
|
||||
|
||||
{ "LargeNegativeInteger",
|
||||
HCL_CLASS_SELFSPEC_FLAG_LIMITED,
|
||||
@ -1139,7 +1156,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
0,
|
||||
HCL_CLASS_SPEC_FLAG_INDEXED | HCL_CLASS_SPEC_FLAG_IMMUTABLE,
|
||||
HCL_OBJ_TYPE_LIWORD,
|
||||
HCL_OFFSETOF(hcl_t, _large_negative_integer) },
|
||||
HCL_OFFSETOF(hcl_t, c_large_negative_integer) },
|
||||
|
||||
{ "FixedPointDecimal",
|
||||
HCL_CLASS_SELFSPEC_FLAG_LIMITED,
|
||||
@ -1147,7 +1164,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
HCL_FPDEC_NAMED_INSTVARS,
|
||||
HCL_CLASS_SPEC_FLAG_IMMUTABLE,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _fixed_point_decimal) },
|
||||
HCL_OFFSETOF(hcl_t, c_fixed_point_decimal) },
|
||||
|
||||
{ "SmallPointer",
|
||||
HCL_CLASS_SELFSPEC_FLAG_LIMITED,
|
||||
@ -1155,7 +1172,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
0,
|
||||
0,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _small_pointer) },
|
||||
HCL_OFFSETOF(hcl_t, c_small_pointer) },
|
||||
|
||||
{ "LargePointer",
|
||||
HCL_CLASS_SELFSPEC_FLAG_LIMITED,
|
||||
@ -1163,7 +1180,7 @@ static kernel_class_info_t kernel_classes[] =
|
||||
1, /* #word(1) */
|
||||
HCL_CLASS_SPEC_FLAG_IMMUTABLE | HCL_CLASS_SPEC_FLAG_INDEXED,
|
||||
HCL_OBJ_TYPE_WORD,
|
||||
HCL_OFFSETOF(hcl_t, _large_pointer) },
|
||||
HCL_OFFSETOF(hcl_t, c_large_pointer) },
|
||||
|
||||
{ "System",
|
||||
0,
|
||||
@ -1171,10 +1188,12 @@ static kernel_class_info_t kernel_classes[] =
|
||||
0,
|
||||
0,
|
||||
HCL_OBJ_TYPE_OOP,
|
||||
HCL_OFFSETOF(hcl_t, _system) }
|
||||
HCL_OFFSETOF(hcl_t, c_system) }
|
||||
};
|
||||
|
||||
|
||||
#if 0
|
||||
|
||||
static hcl_oow_t move_finalizable_objects (hcl_t* hcl);
|
||||
|
||||
/* -----------------------------------------------------------------------
|
||||
|
106
lib/hcl.h
106
lib/hcl.h
@ -1603,45 +1603,85 @@ struct hcl_t
|
||||
hcl_oop_t _true;
|
||||
hcl_oop_t _false;
|
||||
|
||||
hcl_oop_t _and; /* symbol */
|
||||
hcl_oop_t _break; /* symbol */
|
||||
hcl_oop_t _catch; /* symbol */
|
||||
hcl_oop_t _class; /* symbol */
|
||||
hcl_oop_t _continue; /* symbol */
|
||||
hcl_oop_t _defclass; /* symbol */
|
||||
hcl_oop_t _defun; /* symbol */
|
||||
hcl_oop_t _do; /* symbol */
|
||||
hcl_oop_t _elif; /* symbol */
|
||||
hcl_oop_t _else; /* symbol */
|
||||
hcl_oop_t _fun; /* symbol */
|
||||
hcl_oop_t _if; /* symbol */
|
||||
hcl_oop_t _lambda; /* symbol */
|
||||
hcl_oop_t _or; /* symbol */
|
||||
hcl_oop_t _plus; /* symbol */
|
||||
hcl_oop_t _return; /* symbol */
|
||||
hcl_oop_t _return_from_home; /* symbol */
|
||||
hcl_oop_t _set; /* symbol */
|
||||
hcl_oop_t _set_r; /* symbol */
|
||||
hcl_oop_t _throw; /* symbol */
|
||||
hcl_oop_t _try_; /* symbol */ /* _try is special in MSVC. */
|
||||
hcl_oop_t _until; /* symbol */
|
||||
hcl_oop_t _while; /* symbol */
|
||||
hcl_oop_t s_and; /* symbol */
|
||||
hcl_oop_t s_break; /* symbol */
|
||||
hcl_oop_t s_catch; /* symbol */
|
||||
hcl_oop_t s_class; /* symbol */
|
||||
hcl_oop_t s_continue; /* symbol */
|
||||
hcl_oop_t s_defclass; /* symbol */
|
||||
hcl_oop_t s_defun; /* symbol */
|
||||
hcl_oop_t s_do; /* symbol */
|
||||
hcl_oop_t s_elif; /* symbol */
|
||||
hcl_oop_t s_else; /* symbol */
|
||||
hcl_oop_t s_fun; /* symbol */
|
||||
hcl_oop_t s_if; /* symbol */
|
||||
hcl_oop_t s_lambda; /* symbol */
|
||||
hcl_oop_t s_or; /* symbol */
|
||||
hcl_oop_t s_plus; /* symbol */
|
||||
hcl_oop_t s_return; /* symbol */
|
||||
hcl_oop_t s_return_from_home; /* symbol */
|
||||
hcl_oop_t s_set; /* symbol */
|
||||
hcl_oop_t s_set_r; /* symbol */
|
||||
hcl_oop_t s_throw; /* symbol */
|
||||
hcl_oop_t s_try; /* symbol */ /* _try is special in MSVC. */
|
||||
hcl_oop_t s_until; /* symbol */
|
||||
hcl_oop_t s_while; /* symbol */
|
||||
|
||||
hcl_oop_dic_t symtab; /* system-wide symbol table. */
|
||||
hcl_oop_dic_t sysdic; /* system dictionary. */
|
||||
hcl_oop_process_scheduler_t processor; /* instance of ProcessScheduler */
|
||||
hcl_oop_process_t nil_process; /* instance of Process */
|
||||
|
||||
hcl_oop_class_t class_apex; /* class 'Apex' */
|
||||
hcl_oop_class_t class_object; /* class 'Object' */
|
||||
hcl_oop_class_t class_undefobj; /* class 'UndefinedObject' */
|
||||
hcl_oop_class_t class_class; /* class 'Class' */
|
||||
hcl_oop_class_t class_symbol; /* class 'Symbol' */
|
||||
hcl_oop_class_t class_string; /* class 'String' */
|
||||
hcl_oop_class_t class_boolean; /* class 'String' */
|
||||
hcl_oop_class_t class_true; /* class 'True' */
|
||||
hcl_oop_class_t class_false; /* class 'False' */
|
||||
hcl_oop_class_t class_system; /* class 'System' */
|
||||
/* =============================================================
|
||||
* KERNEL CLASSES
|
||||
* Be sure to Keep these kernel class pointers registered in the
|
||||
* kernel_classes table in gc.c
|
||||
* ============================================================= */
|
||||
hcl_oop_class_t c_apex; /* Apex */
|
||||
hcl_oop_class_t c_undefobj; /* UndefinedObject */
|
||||
hcl_oop_class_t c_class; /* Class */
|
||||
#if 0
|
||||
hcl_oop_class_t c_interface; /* Interface */
|
||||
#endif
|
||||
hcl_oop_class_t c_object; /* Object */
|
||||
|
||||
hcl_oop_class_t c_string; /* String */
|
||||
hcl_oop_class_t c_symbol; /* Symbol */
|
||||
hcl_oop_class_t c_array; /* Array */
|
||||
hcl_oop_class_t c_byte_array; /* ByteArray */
|
||||
hcl_oop_class_t c_symbol_table; /* SymbolTable */
|
||||
hcl_oop_class_t c_dictionary;
|
||||
hcl_oop_class_t c_association; /* Association */
|
||||
|
||||
#if 0
|
||||
hcl_oop_class_t c_namespace; /* Namespace */
|
||||
hcl_oop_class_t c_pool_dictionary; /* PoolDictionary */
|
||||
#endif
|
||||
hcl_oop_class_t c_method_dictionary; /* MethodDictionary */
|
||||
hcl_oop_class_t c_method; /* CompiledMethod */
|
||||
hcl_oop_class_t c_methsig; /* MethodSignature */
|
||||
hcl_oop_class_t c_block; /* CompiledBlock */
|
||||
|
||||
hcl_oop_class_t c_method_context; /* MethodContext */
|
||||
hcl_oop_class_t c_block_context; /* BlockContext */
|
||||
hcl_oop_class_t c_process; /* Process */
|
||||
hcl_oop_class_t c_semaphore; /* Semaphore */
|
||||
hcl_oop_class_t c_semaphore_group; /* SemaphoreGroup */
|
||||
hcl_oop_class_t c_process_scheduler; /* ProcessScheduler */
|
||||
|
||||
hcl_oop_class_t c_error; /* Error */
|
||||
hcl_oop_class_t c_true; /* True */
|
||||
hcl_oop_class_t c_false; /* False */
|
||||
hcl_oop_class_t c_character; /* Character */
|
||||
hcl_oop_class_t c_small_integer; /* SmallInteger */
|
||||
|
||||
hcl_oop_class_t c_large_positive_integer; /* LargePositiveInteger */
|
||||
hcl_oop_class_t c_large_negative_integer; /* LargeNegativeInteger */
|
||||
hcl_oop_class_t c_fixed_point_decimal; /* FixedPointDecimal */
|
||||
|
||||
hcl_oop_class_t c_small_pointer;
|
||||
hcl_oop_class_t c_large_pointer;
|
||||
hcl_oop_class_t c_system;
|
||||
|
||||
/* ============================================================================= */
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user