summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ir.cpp24
-rw-r--r--ir.h12
2 files changed, 25 insertions, 11 deletions
diff --git a/ir.cpp b/ir.cpp
index 35fecf7560..d9faac03d4 100644
--- a/ir.cpp
+++ b/ir.cpp
@@ -190,6 +190,30 @@ ir_dereference::ir_dereference(ir_instruction *var,
this->selector.array_index = array_index;
}
+bool
+ir_dereference::is_lvalue()
+{
+ if (var == NULL)
+ return false;
+
+ if (this->type->base_type == GLSL_TYPE_ARRAY ||
+ this->type->base_type == GLSL_TYPE_STRUCT)
+ return false;
+
+ if (mode == ir_reference_variable) {
+ ir_variable *const as_var = var->as_variable();
+ if (as_var == NULL)
+ return false;
+
+ return !as_var->read_only;
+ } else if (mode == ir_reference_array) {
+ /* FINISHME: Walk up the dereference chain and figure out if
+ * FINISHME: the variable is read-only.
+ */
+ }
+
+ return true;
+}
ir_swizzle::ir_swizzle(ir_rvalue *val, unsigned x, unsigned y, unsigned z,
unsigned w, unsigned count)
diff --git a/ir.h b/ir.h
index 381af357b8..64ed881843 100644
--- a/ir.h
+++ b/ir.h
@@ -540,17 +540,7 @@ public:
v->visit(this);
}
- bool is_lvalue()
- {
- if (var == NULL)
- return false;
-
- ir_variable *const as_var = var->as_variable();
- if (as_var == NULL)
- return false;
-
- return !as_var->read_only;
- }
+ bool is_lvalue();
enum {
ir_reference_variable,