2 * Copyright © 2010 Intel Corporation
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 * and/or sell copies of the Software, and to permit persons to whom the
9 * Software is furnished to do so, subject to the following conditions:
11 * The above copyright notice and this permission notice (including the next
12 * paragraph) shall be included in all copies or substantial portions of the
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
18 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
21 * DEALINGS IN THE SOFTWARE.
25 * \file ir_rvalue_visitor.cpp
27 * Generic class to implement the common pattern we have of wanting to
28 * visit each ir_rvalue * and possibly change that node to a different
33 #include "ir_visitor.h"
34 #include "ir_rvalue_visitor.h"
35 #include "glsl_types.h"
38 ir_rvalue_base_visitor::rvalue_visit(ir_expression
*ir
)
42 for (operand
= 0; operand
< ir
->get_num_operands(); operand
++) {
43 handle_rvalue(&ir
->operands
[operand
]);
46 return visit_continue
;
50 ir_rvalue_base_visitor::rvalue_visit(ir_texture
*ir
)
52 handle_rvalue(&ir
->coordinate
);
53 handle_rvalue(&ir
->projector
);
54 handle_rvalue(&ir
->shadow_comparitor
);
55 handle_rvalue(&ir
->offset
);
63 handle_rvalue(&ir
->lod_info
.bias
);
68 handle_rvalue(&ir
->lod_info
.lod
);
71 handle_rvalue(&ir
->lod_info
.sample_index
);
74 handle_rvalue(&ir
->lod_info
.grad
.dPdx
);
75 handle_rvalue(&ir
->lod_info
.grad
.dPdy
);
78 handle_rvalue(&ir
->lod_info
.component
);
82 return visit_continue
;
86 ir_rvalue_base_visitor::rvalue_visit(ir_swizzle
*ir
)
88 handle_rvalue(&ir
->val
);
89 return visit_continue
;
93 ir_rvalue_base_visitor::rvalue_visit(ir_dereference_array
*ir
)
95 /* The array index is not the target of the assignment, so clear the
96 * 'in_assignee' flag. Restore it after returning from the array index.
98 const bool was_in_assignee
= this->in_assignee
;
99 this->in_assignee
= false;
100 handle_rvalue(&ir
->array_index
);
101 this->in_assignee
= was_in_assignee
;
103 handle_rvalue(&ir
->array
);
104 return visit_continue
;
108 ir_rvalue_base_visitor::rvalue_visit(ir_dereference_record
*ir
)
110 handle_rvalue(&ir
->record
);
111 return visit_continue
;
115 ir_rvalue_base_visitor::rvalue_visit(ir_assignment
*ir
)
117 handle_rvalue(&ir
->rhs
);
118 handle_rvalue(&ir
->condition
);
120 return visit_continue
;
124 ir_rvalue_base_visitor::rvalue_visit(ir_call
*ir
)
126 foreach_in_list_safe(ir_rvalue
, param
, &ir
->actual_parameters
) {
127 ir_rvalue
*new_param
= param
;
128 handle_rvalue(&new_param
);
130 if (new_param
!= param
) {
131 param
->replace_with(new_param
);
134 return visit_continue
;
138 ir_rvalue_base_visitor::rvalue_visit(ir_discard
*ir
)
140 handle_rvalue(&ir
->condition
);
141 return visit_continue
;
145 ir_rvalue_base_visitor::rvalue_visit(ir_return
*ir
)
147 handle_rvalue(&ir
->value
);;
148 return visit_continue
;
152 ir_rvalue_base_visitor::rvalue_visit(ir_if
*ir
)
154 handle_rvalue(&ir
->condition
);
155 return visit_continue
;
159 ir_rvalue_base_visitor::rvalue_visit(ir_emit_vertex
*ir
)
161 handle_rvalue(&ir
->stream
);
162 return visit_continue
;
166 ir_rvalue_base_visitor::rvalue_visit(ir_end_primitive
*ir
)
168 handle_rvalue(&ir
->stream
);
169 return visit_continue
;
173 ir_rvalue_visitor::visit_leave(ir_expression
*ir
)
175 return rvalue_visit(ir
);
179 ir_rvalue_visitor::visit_leave(ir_texture
*ir
)
181 return rvalue_visit(ir
);
185 ir_rvalue_visitor::visit_leave(ir_swizzle
*ir
)
187 return rvalue_visit(ir
);
191 ir_rvalue_visitor::visit_leave(ir_dereference_array
*ir
)
193 return rvalue_visit(ir
);
197 ir_rvalue_visitor::visit_leave(ir_dereference_record
*ir
)
199 return rvalue_visit(ir
);
203 ir_rvalue_visitor::visit_leave(ir_assignment
*ir
)
205 return rvalue_visit(ir
);
209 ir_rvalue_visitor::visit_leave(ir_call
*ir
)
211 return rvalue_visit(ir
);
215 ir_rvalue_visitor::visit_leave(ir_discard
*ir
)
217 return rvalue_visit(ir
);
221 ir_rvalue_visitor::visit_leave(ir_return
*ir
)
223 return rvalue_visit(ir
);
227 ir_rvalue_visitor::visit_leave(ir_if
*ir
)
229 return rvalue_visit(ir
);
233 ir_rvalue_visitor::visit_leave(ir_emit_vertex
*ir
)
235 return rvalue_visit(ir
);
239 ir_rvalue_visitor::visit_leave(ir_end_primitive
*ir
)
241 return rvalue_visit(ir
);
245 ir_rvalue_enter_visitor::visit_enter(ir_expression
*ir
)
247 return rvalue_visit(ir
);
251 ir_rvalue_enter_visitor::visit_enter(ir_texture
*ir
)
253 return rvalue_visit(ir
);
257 ir_rvalue_enter_visitor::visit_enter(ir_swizzle
*ir
)
259 return rvalue_visit(ir
);
263 ir_rvalue_enter_visitor::visit_enter(ir_dereference_array
*ir
)
265 return rvalue_visit(ir
);
269 ir_rvalue_enter_visitor::visit_enter(ir_dereference_record
*ir
)
271 return rvalue_visit(ir
);
275 ir_rvalue_enter_visitor::visit_enter(ir_assignment
*ir
)
277 return rvalue_visit(ir
);
281 ir_rvalue_enter_visitor::visit_enter(ir_call
*ir
)
283 return rvalue_visit(ir
);
287 ir_rvalue_enter_visitor::visit_enter(ir_discard
*ir
)
289 return rvalue_visit(ir
);
293 ir_rvalue_enter_visitor::visit_enter(ir_return
*ir
)
295 return rvalue_visit(ir
);
299 ir_rvalue_enter_visitor::visit_enter(ir_if
*ir
)
301 return rvalue_visit(ir
);
305 ir_rvalue_enter_visitor::visit_enter(ir_emit_vertex
*ir
)
307 return rvalue_visit(ir
);
311 ir_rvalue_enter_visitor::visit_enter(ir_end_primitive
*ir
)
313 return rvalue_visit(ir
);