i forgot about commas ...

This commit is contained in:
pommicket 2022-01-25 18:28:26 -05:00
parent 47d801cd34
commit fb564812c2
4 changed files with 35 additions and 20 deletions

View file

@ -199,7 +199,8 @@
; char, unsigned char, etc.: TYPE_CHAR, TYPE_UNSIGNED_CHAR, etc. as a single byte
; pointer to type t: TYPE_PTR t
; array of n t's: TYPE_ARRAY {n as 8 bytes} t
; struct/union: TYPE_STRUCT/TYPE_UNION {0 for incomplete types/4-byte pointer to struct/union}
; struct/union: TYPE_STRUCT {8-byte pointer to struct/union data (see structures in main.b)}
; note: incomplete structs/unions are replaced with void.
; function: TYPE_FUNCTION {arg1 type} {arg2 type} ... {argn type} 0 {return type}
; note that enum types are just treated as ints.
#define TYPE_VOID 1
@ -216,7 +217,6 @@
#define TYPE_DOUBLE 12
#define TYPE_POINTER 13
#define TYPE_STRUCT 14
#define TYPE_UNION 15
#define TYPE_ARRAY 16
#define TYPE_FUNCTION 17

View file

@ -30,6 +30,14 @@ global types_bytes_used
global typedefs
; ident list of enum values
global enumerators
; struct/union names
; an ident list of pointers to struct data (see structures below)
global struct_names
; structs and unions
; each struct/union is an ident list of 64-bit values, (type << 32) | offset
; for unions, offset will always be 0.
global structures
global structures_bytes_used
#include util.b
#include idents.b
@ -146,7 +154,8 @@ function main
fill_in_powers_of_10()
typedefs = ident_list_create(100000)
enumerators = ident_list_create(400000)
enumerators = ident_list_create(4000000)
struct_names = ident_list_create(4000000)
dat_banned_objmacros = 255
dat_banned_fmacros = 255
@ -155,6 +164,7 @@ function main
*1file_list = 255
object_macros = malloc(4000000)
function_macros = malloc(4000000)
structures = malloc(40000000)
types = malloc(16000000)
types_init(types, &types_bytes_used)

View file

@ -3,14 +3,4 @@
long double d;
} (*x)(void);
*/
typedef int Foo[(char)((unsigned char)0xff + (unsigned char)0xf02)];
typedef enum {
HELLO,
THERE,
TEST = 1-3,
EEE = TEST+4,
ASDFASDF,
FFF,
HELLO2
} y;
typedef int Bar[FFF];
typedef int Foo(struct Bar { int x, y; }*);

View file

@ -455,9 +455,28 @@ function parse_type_to
*8p_token = suffix_end
return out
:base_type_struct
byte 0xcc ; @TODO
:base_type_union
byte 0xcc ; @TODO
p = prefix + 16
if *1p != TOKEN_IDENTIFIER goto base_type_struct_definition
p += 16
if *1p == SYMBOL_LBRACE goto base_type_struct_definition
p -= 8
c = ident_list_lookup(struct_names, *8p)
if c == 0 goto base_type_incomplete_struct
; e.g. struct Foo x; where struct Foo has been defined
*1out = TYPE_STRUCT
out += 1
*8out = c
out += 8
goto base_type_done
:base_type_incomplete_struct
; e.g. struct Foo *x; where struct Foo hasn't been defined
*1out = TYPE_VOID
out += 1
goto base_type_done
:base_type_struct_definition
if *1p != SYMBOL_LBRACE goto bad_type
byte 0xcc ; @TODO
:base_type_enum
local q
@ -600,7 +619,6 @@ function type_length
return n + 9
:type_length_not_array
if *1p == TYPE_STRUCT goto return_5
if *1p == TYPE_UNION goto return_5
if *1p != TYPE_FUNCTION goto type_length_not_function
local start
start = type
@ -2056,7 +2074,6 @@ function print_type
if c == TYPE_POINTER goto print_type_pointer
if c == TYPE_ARRAY goto print_type_array
if c == TYPE_STRUCT goto print_type_struct
if c == TYPE_UNION goto print_type_union
if c == TYPE_FUNCTION goto print_type_function
fputs(2, .str_bad_print_type)
exit(1)
@ -2100,8 +2117,6 @@ function print_type
goto print_type_top
:print_type_struct
return puts(.str_struct)
:print_type_union
return puts(.str_union)
:print_type_function
type += 1
putc(40)