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_return
*ir
)
140 handle_rvalue(&ir
->value
);;
141 return visit_continue
;
145 ir_rvalue_base_visitor::rvalue_visit(ir_if
*ir
)
147 handle_rvalue(&ir
->condition
);
148 return visit_continue
;
152 ir_rvalue_base_visitor::rvalue_visit(ir_emit_vertex
*ir
)
154 handle_rvalue(&ir
->stream
);
155 return visit_continue
;
159 ir_rvalue_base_visitor::rvalue_visit(ir_end_primitive
*ir
)
161 handle_rvalue(&ir
->stream
);
162 return visit_continue
;
166 ir_rvalue_visitor::visit_leave(ir_expression
*ir
)
168 return rvalue_visit(ir
);
172 ir_rvalue_visitor::visit_leave(ir_texture
*ir
)
174 return rvalue_visit(ir
);
178 ir_rvalue_visitor::visit_leave(ir_swizzle
*ir
)
180 return rvalue_visit(ir
);
184 ir_rvalue_visitor::visit_leave(ir_dereference_array
*ir
)
186 return rvalue_visit(ir
);
190 ir_rvalue_visitor::visit_leave(ir_dereference_record
*ir
)
192 return rvalue_visit(ir
);
196 ir_rvalue_visitor::visit_leave(ir_assignment
*ir
)
198 return rvalue_visit(ir
);
202 ir_rvalue_visitor::visit_leave(ir_call
*ir
)
204 return rvalue_visit(ir
);
208 ir_rvalue_visitor::visit_leave(ir_return
*ir
)
210 return rvalue_visit(ir
);
214 ir_rvalue_visitor::visit_leave(ir_if
*ir
)
216 return rvalue_visit(ir
);
220 ir_rvalue_visitor::visit_leave(ir_emit_vertex
*ir
)
222 return rvalue_visit(ir
);
226 ir_rvalue_visitor::visit_leave(ir_end_primitive
*ir
)
228 return rvalue_visit(ir
);
232 ir_rvalue_enter_visitor::visit_enter(ir_expression
*ir
)
234 return rvalue_visit(ir
);
238 ir_rvalue_enter_visitor::visit_enter(ir_texture
*ir
)
240 return rvalue_visit(ir
);
244 ir_rvalue_enter_visitor::visit_enter(ir_swizzle
*ir
)
246 return rvalue_visit(ir
);
250 ir_rvalue_enter_visitor::visit_enter(ir_dereference_array
*ir
)
252 return rvalue_visit(ir
);
256 ir_rvalue_enter_visitor::visit_enter(ir_dereference_record
*ir
)
258 return rvalue_visit(ir
);
262 ir_rvalue_enter_visitor::visit_enter(ir_assignment
*ir
)
264 return rvalue_visit(ir
);
268 ir_rvalue_enter_visitor::visit_enter(ir_call
*ir
)
270 return rvalue_visit(ir
);
274 ir_rvalue_enter_visitor::visit_enter(ir_return
*ir
)
276 return rvalue_visit(ir
);
280 ir_rvalue_enter_visitor::visit_enter(ir_if
*ir
)
282 return rvalue_visit(ir
);
286 ir_rvalue_enter_visitor::visit_enter(ir_emit_vertex
*ir
)
288 return rvalue_visit(ir
);
292 ir_rvalue_enter_visitor::visit_enter(ir_end_primitive
*ir
)
294 return rvalue_visit(ir
);