char *vstring;
struct ir_value_s *vpointer;
struct ir_function_s *vfunc;
- quaternion vquat;
- matrix vmat;
} constval;
struct {
int32_t name;
/* filled by the local-allocator */
int32_t local;
+ /* added for members */
+ int32_t addroffset;
} code;
+ /* for acessing vectors */
+ struct ir_value_s *members[3];
+ struct ir_value_s *memberof;
+
/* For the temp allocator */
MEM_VECTOR_MAKE(ir_life_entry_t, life);
} ir_value;
+int32_t ir_value_code_addr(const ir_value*);
+
/* ir_value can be a variable, or created by an operation */
ir_value* ir_value_var(const char *name, int st, int vtype);
/* if a result of an operation: the function should store
ir_value* ir_value_out(struct ir_function_s *owner, const char *name, int st, int vtype);
void ir_value_delete(ir_value*);
void ir_value_set_name(ir_value*, const char *name);
+ir_value* ir_value_vector_member(ir_value*, unsigned int member);
MEM_VECTOR_PROTO_ALL(ir_value, struct ir_instr_s*, reads);
MEM_VECTOR_PROTO_ALL(ir_value, struct ir_instr_s*, writes);
#endif
bool GMQCC_WARN ir_value_set_string(ir_value*, const char *s);
bool GMQCC_WARN ir_value_set_vector(ir_value*, vector v);
+bool GMQCC_WARN ir_value_set_field(ir_value*, ir_value *fld);
/*bool ir_value_set_pointer_v(ir_value*, ir_value* p); */
/*bool ir_value_set_pointer_i(ir_value*, int i); */
-bool GMQCC_WARN ir_value_set_quaternion(ir_value*, quaternion v);
-bool GMQCC_WARN ir_value_set_matrix(ir_value*, matrix v);
MEM_VECTOR_PROTO(ir_value, ir_life_entry_t, life);
/* merge an instruction into the life-range */
lex_ctx context;
+ /* for prototypes - first we generate all the
+ * globals, and we remember teh function-defs
+ * so we can later fill in the entry pos
+ *
+ * remember the ID:
+ */
+ qcint code_function_def;
+
/* for temp allocation */
size_t run_id;
/* This code assumes 32 bit floats while generating binary */
extern int check_int_and_float_size
-[ (sizeof(int32_t) == sizeof(( (ir_value*)(NULL) )->constval.vvec.x)) ? 1 : -1 ];
+[ (sizeof(int32_t) == sizeof(qcfloat)) ? 1 : -1 ];
#endif