DEADSOFTWARE

Добавлены строки в отладочную информацию класса (быстрохак)
[dsw-obn.git] / src / oberon-internals.h
index fa9b5d5280903bf0ea16496170cb3e81fcb69045..d9f311911b94022a2ca7a7a7d6fdb08c869c33f2 100644 (file)
@@ -17,6 +17,8 @@ typedef struct oberon_module_t oberon_module_t;
 typedef struct oberon_context_t oberon_context_t;
 typedef struct oberon_scope_t oberon_scope_t;
 
+typedef struct oberon_location_t oberon_location_t;
+typedef struct oberon_scanner_t oberon_scanner_t;
 typedef struct oberon_item_t oberon_item_t;
 typedef struct oberon_oper_t oberon_oper_t;
 typedef union oberon_expr_t oberon_expr_t;
@@ -36,7 +38,7 @@ struct oberon_scope_t
 
 enum oberon_type_kind
 {
-       OBERON_TYPE_VOID,
+       OBERON_TYPE_NOTYPE,
        OBERON_TYPE_INTEGER,
        OBERON_TYPE_BOOLEAN,
        OBERON_TYPE_PROCEDURE,
@@ -46,7 +48,10 @@ enum oberon_type_kind
        OBERON_TYPE_REAL,
        OBERON_TYPE_CHAR,
        OBERON_TYPE_STRING,
-       OBERON_TYPE_SET
+       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 *);
@@ -56,6 +61,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;
@@ -115,7 +122,8 @@ struct oberon_object_t
 struct oberon_module_t
 {
        char * name;
-       int ready;
+       bool ready;
+       bool intrinsic;
 
        oberon_scope_t * decl;
 
@@ -124,13 +132,28 @@ struct oberon_module_t
        gen_module_t * gen_mod;
 };
 
-typedef const char * (*ModuleImportCallback)(const char * name);
+struct oberon_location_t
+{
+       const char * source;
+       int line;
+       int col;
+};
+
+struct oberon_scanner_t
+{
+       char * source;
+       char * code;
+};
+
+typedef oberon_scanner_t * (*ModuleImportCallback)(const char * name);
 
 struct oberon_context_t
 {
        /*** SCANER DATA ***/
        const char * code;
        int code_index;
+       oberon_location_t loc;
+       oberon_location_t xloc;
 
        char c;
        int token;
@@ -145,8 +168,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;
@@ -158,7 +182,10 @@ struct oberon_context_t
        oberon_type_t * string_type;
        oberon_type_t * set_type;
 
-       oberon_scope_t * world_scope;
+       oberon_module_t * system_module;
+       oberon_type_t * system_byte_type;
+       oberon_type_t * system_ptr_type;
+
        oberon_module_t * module_list;
        ModuleImportCallback import_module;
        gen_context_t * gen_context;
@@ -179,7 +206,10 @@ enum oberon_mode_kind
        MODE_CHAR,
        MODE_STRING,
        MODE_TYPE,
-       MODE_SET
+       MODE_SET,
+       MODE_LEN,
+       MODE_SYSBYTE,
+       MODE_AS
 };
 
 enum oberon_operator_kind
@@ -187,6 +217,8 @@ enum oberon_operator_kind
        OP_UNARY_MINUS,
        OP_LOGIC_NOT,
        OP_ABS,
+       OP_CAP,
+       OP_ENTIER,
 
        OP_ADD,
        OP_SUB,
@@ -204,6 +236,7 @@ enum oberon_operator_kind
        OP_GEQ,
 
        OP_CAST,
+       OP_HARDCAST,
        OP_IS,
 
        OP_RANGE,
@@ -212,7 +245,11 @@ enum oberon_operator_kind
        OP_DIFFERENCE,
        OP_SYM_DIFFERENCE,
        OP_COMPLEMENTATION,
-       OP_IN
+       OP_IN,
+
+       OP_ASH,
+       OP_LSH,
+       OP_ROT
 };
 
 struct oberon_item_t
@@ -259,4 +296,13 @@ union oberon_expr_t
        oberon_oper_t oper;
 };
 
+extern oberon_context_t *
+oberon_create_context(ModuleImportCallback import_module);
+
+extern void
+oberon_destroy_context(oberon_context_t * ctx);
+
+extern oberon_module_t *
+oberon_compile_module(oberon_context_t * ctx, oberon_scanner_t * s);
+
 #endif // OBERON_INTERNALS_H