X-Git-Url: http://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Foberon-internals.h;h=528842bb6c8b24f0503c85b1b45ca3d0ed9ae551;hb=789adb9354da345b13aa284f3f4f8f1046cadbc4;hp=5dd3582576af7e07980552a59f3763025a098fa8;hpb=72048038b5be32cc940c8452541b8bb3e75958a9;p=dsw-obn.git diff --git a/src/oberon-internals.h b/src/oberon-internals.h index 5dd3582..528842b 100644 --- a/src/oberon-internals.h +++ b/src/oberon-internals.h @@ -36,7 +36,7 @@ struct oberon_scope_t enum oberon_type_kind { - OBERON_TYPE_VOID, + OBERON_TYPE_NOTYPE, OBERON_TYPE_INTEGER, OBERON_TYPE_BOOLEAN, OBERON_TYPE_PROCEDURE, @@ -45,7 +45,11 @@ enum oberon_type_kind OBERON_TYPE_POINTER, OBERON_TYPE_REAL, OBERON_TYPE_CHAR, - OBERON_TYPE_STRING + OBERON_TYPE_STRING, + OBERON_TYPE_SET, + OBERON_TYPE_NIL, + OBERON_TYPE_SYSTEM_BYTE, + OBERON_TYPE_SYSTEM_PTR }; typedef oberon_expr_t * (*GenerateFuncCallback)(oberon_context_t *, int, oberon_expr_t *); @@ -55,6 +59,8 @@ struct oberon_type_t { enum oberon_type_kind class; int size; + oberon_type_t * shorter; + oberon_type_t * longer; int num_decl; oberon_type_t * base; @@ -114,7 +120,8 @@ struct oberon_object_t struct oberon_module_t { char * name; - int ready; + bool ready; + bool intrinsic; oberon_scope_t * decl; @@ -144,8 +151,9 @@ struct oberon_context_t oberon_module_t * mod; /*** END PARSER DATA ***/ - oberon_type_t * void_type; - oberon_type_t * void_ptr_type; + oberon_scope_t * world_scope; + oberon_type_t * notype_type; + oberon_type_t * nil_type; oberon_type_t * bool_type; oberon_type_t * byte_type; oberon_type_t * shortint_type; @@ -155,8 +163,12 @@ struct oberon_context_t oberon_type_t * longreal_type; oberon_type_t * char_type; oberon_type_t * string_type; + oberon_type_t * set_type; + + oberon_module_t * system_module; + oberon_type_t * system_byte_type; + oberon_type_t * system_ptr_type; - oberon_scope_t * world_scope; oberon_module_t * module_list; ModuleImportCallback import_module; gen_context_t * gen_context; @@ -176,24 +188,25 @@ enum oberon_mode_kind MODE_REAL, MODE_CHAR, MODE_STRING, - MODE_TYPE + MODE_TYPE, + MODE_SET, + MODE_LEN, + MODE_SYSBYTE }; enum oberon_operator_kind { OP_UNARY_MINUS, - OP_BITWISE_NOT, OP_LOGIC_NOT, OP_ABS, + OP_CAP, + OP_ENTIER, OP_ADD, OP_SUB, OP_MUL, OP_DIV, OP_MOD, - OP_BITWISE_AND, - OP_BITWISE_XOR, - OP_BITWISE_OR, OP_LOGIC_AND, OP_LOGIC_OR, @@ -205,7 +218,19 @@ enum oberon_operator_kind OP_GEQ, OP_CAST, - OP_IS + OP_IS, + + OP_RANGE, + OP_UNION, + OP_INTERSECTION, + OP_DIFFERENCE, + OP_SYM_DIFFERENCE, + OP_COMPLEMENTATION, + OP_IN, + + OP_ASH, + OP_LSH, + OP_ROT }; struct oberon_item_t @@ -218,7 +243,6 @@ struct oberon_item_t enum oberon_mode_kind mode; long integer; double real; - int boolean; char * string; oberon_object_t * var;