mirror of
https://git.code.sf.net/p/quake/quakeforge
synced 2024-11-26 14:20:59 +00:00
[qfcc] Update switch tables for compound initializers
Forgot to do a full test build (Machine.r found it)
This commit is contained in:
parent
5d349efe78
commit
e4caf50ee1
3 changed files with 9 additions and 5 deletions
|
@ -371,6 +371,8 @@ init_elements (struct def_s *def, expr_t *eles)
|
||||||
dummy.offset = def->offset + element->offset;
|
dummy.offset = def->offset + element->offset;
|
||||||
g = D_POINTER (pr_type_t, &dummy);
|
g = D_POINTER (pr_type_t, &dummy);
|
||||||
if (c->type == ex_labelref) {
|
if (c->type == ex_labelref) {
|
||||||
|
// reloc_def_* use only the def's offset and space, so dummy
|
||||||
|
// is ok
|
||||||
reloc_def_op (c->e.labelref.label, &dummy);
|
reloc_def_op (c->e.labelref.label, &dummy);
|
||||||
continue;
|
continue;
|
||||||
} else if (c->type == ex_value) {
|
} else if (c->type == ex_value) {
|
||||||
|
|
|
@ -536,7 +536,7 @@ statement_get_targetlist (statement_t *s)
|
||||||
sblock_t **target_list;
|
sblock_t **target_list;
|
||||||
int count = 0, i;
|
int count = 0, i;
|
||||||
def_t *table = 0;
|
def_t *table = 0;
|
||||||
expr_t *e;
|
element_t *e;
|
||||||
|
|
||||||
if (statement_is_cond (s)) {
|
if (statement_is_cond (s)) {
|
||||||
count = 1;
|
count = 1;
|
||||||
|
@ -555,9 +555,9 @@ statement_get_targetlist (statement_t *s)
|
||||||
} else if (statement_is_jumpb (s)) {
|
} else if (statement_is_jumpb (s)) {
|
||||||
if (table->alias)
|
if (table->alias)
|
||||||
internal_error (0, "aliased jump table");
|
internal_error (0, "aliased jump table");
|
||||||
e = table->initializer->e.block.head; //FIXME check!!!
|
e = table->initializer->e.compound.head; //FIXME check!!!
|
||||||
for (i = 0; i < count; e = e->next, i++)
|
for (i = 0; i < count; e = e->next, i++)
|
||||||
target_list[i] = e->e.labelref.label->dest;
|
target_list[i] = e->expr->e.labelref.label->dest;
|
||||||
}
|
}
|
||||||
return target_list;
|
return target_list;
|
||||||
}
|
}
|
||||||
|
|
|
@ -337,11 +337,13 @@ build_switch (expr_t *sw, case_node_t *tree, int op, expr_t *sw_val,
|
||||||
const char *table_name = new_label_name ();
|
const char *table_name = new_label_name ();
|
||||||
int i;
|
int i;
|
||||||
expr_t *range = binary_expr ('-', tree->high, tree->low);
|
expr_t *range = binary_expr ('-', tree->high, tree->low);
|
||||||
|
expr_t *label;
|
||||||
|
|
||||||
table_init = new_block_expr ();
|
table_init = new_compound_init ();
|
||||||
for (i = 0; i <= high - low; i++) {
|
for (i = 0; i <= high - low; i++) {
|
||||||
tree->labels[i]->e.label.used++;
|
tree->labels[i]->e.label.used++;
|
||||||
append_expr (table_init, address_expr (tree->labels[i], 0, 0));
|
label = address_expr (tree->labels[i], 0, 0);
|
||||||
|
append_element (table_init, new_element (label, 0));
|
||||||
}
|
}
|
||||||
table_sym = new_symbol_type (table_name,
|
table_sym = new_symbol_type (table_name,
|
||||||
array_type (&type_integer,
|
array_type (&type_integer,
|
||||||
|
|
Loading…
Reference in a new issue