X-Git-Url: https://git.xonotic.org/?a=blobdiff_plain;f=gmqcc.h;h=42a5fc6a166a254493ef178fa1014440acd4661f;hb=8ed6676d0f2c13c895d5129ac07e62219e859cc9;hp=71d3ca92563e9a3a0fe8d3ee1369d30dda6cc791;hpb=77e5807a832ba238a0c114067ce16c63c39d3ae7;p=xonotic%2Fgmqcc.git diff --git a/gmqcc.h b/gmqcc.h index 71d3ca9..42a5fc6 100644 --- a/gmqcc.h +++ b/gmqcc.h @@ -210,7 +210,8 @@ void util_endianswap (void *, int, int); size_t util_strtocmd (const char *, char *, size_t); size_t util_strtononcmd (const char *, char *, size_t); -uint32_t util_crc32(const char *, int, register const short); +uint16_t util_crc16(uint16_t crc, const char *data, size_t len); +uint32_t util_crc32(uint32_t crc, const char *data, size_t len); #ifdef NOTRACK # define mem_a(x) malloc(x) @@ -390,6 +391,10 @@ typedef struct { typedef prog_section_both prog_section_def; typedef prog_section_both prog_section_field; +/* this is ORed to the type */ +#define DEF_SAVEGLOBAL (1<<15) +#define DEF_TYPEMASK ((1<<15)-1) + typedef struct { int32_t entry; /* in statement table for instructions */ uint32_t firstlocal; /* First local in local table */ @@ -410,8 +415,8 @@ enum { INSTR_DONE, INSTR_MUL_F, INSTR_MUL_V, - INSTR_MUL_FV, - INSTR_MUL_VF, + INSTR_MUL_FV, /* NOTE: the float operands must NOT be at the same locations: A != C */ + INSTR_MUL_VF, /* and here: B != C */ INSTR_DIV_F, INSTR_ADD_F, INSTR_ADD_V, @@ -508,6 +513,7 @@ VECTOR_PROT(prog_section_field, code_fields ); VECTOR_PROT(prog_section_function, code_functions ); VECTOR_PROT(int, code_globals ); VECTOR_PROT(char, code_chars ); +extern uint16_t code_crc; typedef float qcfloat; typedef int32_t qcint; @@ -539,7 +545,7 @@ static const struct { { "ADD_F" , 3, 5 }, { "ADD_V" , 3, 5 }, { "SUB_F" , 3, 5 }, - { "DUB_V" , 3, 5 }, + { "SUB_V" , 3, 5 }, { "EQ_F" , 0, 4 }, { "EQ_V" , 0, 4 }, { "EQ_S" , 0, 4 }, @@ -686,22 +692,26 @@ bool GMQCC_WARN Tself##_##mem##_find(Tself *self, Twhat obj, size_t *idx) \ bool GMQCC_WARN Tself##_##mem##_append(Tself *s, Twhat *p, size_t c) \ { \ Twhat *reall; \ - if (s->mem##_count+c >= s->mem##_alloc) { \ + size_t oldalloc; \ + if (s->mem##_count+c > s->mem##_alloc) { \ if (!s->mem##_alloc) { \ s->mem##_alloc = c < 16 ? 16 : c; \ + s->mem = (Twhat*)mem_a(sizeof(Twhat) * s->mem##_alloc); \ } else { \ + oldalloc = s->mem##_alloc; \ s->mem##_alloc *= 2; \ if (s->mem##_count+c >= s->mem##_alloc) { \ s->mem##_alloc = s->mem##_count+c; \ } \ + reall = (Twhat*)mem_a(sizeof(Twhat) * s->mem##_alloc); \ + if (!reall) { \ + s->mem##_alloc = oldalloc; \ + return false; \ + } \ + memcpy(reall, s->mem, sizeof(Twhat) * s->mem##_count); \ + mem_d(s->mem); \ + s->mem = reall; \ } \ - reall = (Twhat*)mem_a(sizeof(Twhat) * s->mem##_alloc); \ - if (!reall) { \ - return false; \ - } \ - memcpy(reall, s->mem, sizeof(Twhat) * s->mem##_count); \ - mem_d(s->mem); \ - s->mem = reall; \ } \ memcpy(&s->mem[s->mem##_count], p, c*sizeof(*p)); \ s->mem##_count += c; \ @@ -729,6 +739,7 @@ bool GMQCC_WARN Tself##_##mem##_resize(Tself *s, size_t c) \ memcpy(reall, s->mem, sizeof(Twhat) * c); \ mem_d(s->mem); \ s->mem = reall; \ + s->mem##_alloc = c; \ } \ return true; \ } @@ -881,6 +892,8 @@ typedef struct qc_program_s { MEM_VECTOR_MAKE(qc_exec_stack, stack); size_t statement; + size_t xflags; + int argc; /* current arg count for debugging */ } qc_program;