DEADSOFTWARE

Добавлена конструкция FOR
[dsw-obn.git] / src / oberon-internals.h
index c28cfa5b80761a1d42992a32ffa5d49fa31dce76..f0a6bed23e96fa8ec6b70d9cafc3a133713485ba 100644 (file)
@@ -8,7 +8,7 @@ typedef struct gen_module_t gen_module_t;
 typedef struct gen_proc_t gen_proc_t;
 typedef struct gen_type_t gen_type_t;
 typedef struct gen_var_t gen_var_t;
-typedef struct gen_block_t gen_block_t;
+typedef struct gen_label_t gen_label_t;
 typedef struct gen_context_t gen_context_t;
 
 typedef struct oberon_type_t oberon_type_t;
@@ -32,7 +32,7 @@ struct oberon_scope_t
        oberon_type_t * parent_type;
 };
 
-enum
+enum oberon_type_kind
 {
        OBERON_TYPE_VOID,
        OBERON_TYPE_INTEGER,
@@ -41,7 +41,9 @@ enum
        OBERON_TYPE_ARRAY,
        OBERON_TYPE_RECORD,
        OBERON_TYPE_POINTER,
-       OBERON_TYPE_REAL
+       OBERON_TYPE_REAL,
+       OBERON_TYPE_CHAR,
+       OBERON_TYPE_STRING
 };
 
 typedef oberon_expr_t * (*GenerateFuncCallback)(oberon_context_t *, int, oberon_expr_t *);
@@ -49,7 +51,7 @@ typedef void (*GenerateProcCallback)(oberon_context_t *, int, oberon_expr_t *);
 
 struct oberon_type_t
 {
-       int class;
+       enum oberon_type_kind class;
        int size;
 
        int num_decl;
@@ -68,7 +70,7 @@ struct oberon_type_t
        gen_type_t * gen_type;
 };
 
-enum
+enum oberon_object_kind
 {
        OBERON_CLASS_VAR,
        OBERON_CLASS_TYPE,
@@ -83,7 +85,7 @@ enum
 struct oberon_object_t
 {
        char * name;
-       int class;
+       enum oberon_object_kind class;
        int export;
        int read_only;
 
@@ -140,6 +142,8 @@ struct oberon_context_t
        oberon_module_t * mod;
        /*** END PARSER DATA ***/
 
+       oberon_type_t * void_type;
+       oberon_type_t * void_ptr_type;
        oberon_type_t * bool_type;
        oberon_type_t * byte_type;
        oberon_type_t * shortint_type;
@@ -147,8 +151,8 @@ struct oberon_context_t
        oberon_type_t * longint_type;
        oberon_type_t * real_type;
        oberon_type_t * longreal_type;
-       oberon_type_t * void_type;
-       oberon_type_t * void_ptr_type;
+       oberon_type_t * char_type;
+       oberon_type_t * string_type;
 
        oberon_scope_t * world_scope;
        oberon_module_t * module_list;
@@ -156,7 +160,7 @@ struct oberon_context_t
        gen_context_t * gen_context;
 };
 
-enum
+enum oberon_mode_kind
 {
        MODE_VAR,
        MODE_INTEGER,
@@ -168,9 +172,11 @@ enum
        MODE_NIL,
        MODE_NEW,
        MODE_REAL,
+       MODE_CHAR,
+       MODE_STRING
 };
 
-enum
+enum oberon_operator_kind
 {
        OP_UNARY_MINUS,
        OP_BITWISE_NOT,
@@ -200,15 +206,16 @@ enum
 
 struct oberon_item_t
 {
-       int is_item; // == 1
+       bool is_item; // == 1
        oberon_type_t * result;
        oberon_expr_t * next;
-       int read_only;
+       bool read_only;
 
-       int mode;
+       enum oberon_mode_kind mode;
        long integer;
        double real;
        int boolean;
+       char * string;
        oberon_object_t * var;
 
        oberon_item_t * parent;
@@ -219,12 +226,12 @@ struct oberon_item_t
 
 struct oberon_oper_t
 {
-       int is_item; // == 0
+       bool is_item; // == 0
        oberon_type_t * result;
        oberon_expr_t * next;
-       int read_only;
+       bool read_only;
 
-       int op;
+       enum oberon_operator_kind op;
        oberon_expr_t * left;
        oberon_expr_t * right;
 };
@@ -232,10 +239,10 @@ struct oberon_oper_t
 union oberon_expr_t
 {
        struct {
-               int is_item;
+               bool is_item;
                oberon_type_t * result;
                oberon_expr_t * next;
-               int read_only;
+               bool read_only;
        };
 
        oberon_item_t item;