]> git.xonotic.org Git - xonotic/gmqcc.git/blobdiff - ir.h
ast_function gets 'breakblock' and 'continueblock' for break and continue support...
[xonotic/gmqcc.git] / ir.h
diff --git a/ir.h b/ir.h
index cbddf71c40cbe4b46a11320a85198d9e133e50ab..d3ad5b3715ca919ebd83dbc7be280cfe30f4bcbf 100644 (file)
--- a/ir.h
+++ b/ir.h
@@ -157,6 +157,14 @@ bool GMQCC_WARN ir_block_create_storep(ir_block*, ir_value *target, ir_value *wh
 /* field must be of TYPE_FIELD */
 ir_value* ir_block_create_load_from_ent(ir_block*, const char *label, ir_value *ent, ir_value *field, int outype);
 
+ir_value* ir_block_create_fieldaddress(ir_block*, const char *label, ir_value *entity, ir_value *field);
+
+/* This is to create an instruction of the form
+ * <outtype>%label := opcode a, b
+ */
+ir_value* ir_block_create_general_instr(ir_block *self, const char *label,
+                                        int op, ir_value *a, ir_value *b, int outype);
+
 ir_value* ir_block_create_add(ir_block*, const char *label, ir_value *l, ir_value *r);
 ir_value* ir_block_create_sub(ir_block*, const char *label, ir_value *l, ir_value *r);
 ir_value* ir_block_create_mul(ir_block*, const char *label, ir_value *l, ir_value *r);
@@ -168,7 +176,7 @@ bool GMQCC_WARN ir_phi_add(ir_instr*, ir_block *b, ir_value *v);
 bool GMQCC_WARN ir_block_create_return(ir_block*, ir_value *opt_value);
 
 bool GMQCC_WARN ir_block_create_if(ir_block*, ir_value *cond,
-                             ir_block *ontrue, ir_block *onfalse);
+                                   ir_block *ontrue, ir_block *onfalse);
 /* A 'goto' is an actual 'goto' coded in QC, whereas
  * a 'jump' is a virtual construct which simply names the
  * next block to go to.