summaryrefslogtreecommitdiffstats
path: root/elaborate.cxx
diff options
context:
space:
mode:
authorStan Cox <scox@redhat.com>2008-05-21 09:22:17 -0400
committerStan Cox <scox@redhat.com>2008-05-21 09:22:17 -0400
commitfcc7aafa64338bdbac356dd509acd20f35563ef5 (patch)
tree452151d41b4978bde87eb133018737821e4c9aec /elaborate.cxx
parentaa215f04d4546c5c810d7accde3ad108e855f397 (diff)
downloadsystemtap-steved-fcc7aafa64338bdbac356dd509acd20f35563ef5.tar.gz
systemtap-steved-fcc7aafa64338bdbac356dd509acd20f35563ef5.tar.xz
systemtap-steved-fcc7aafa64338bdbac356dd509acd20f35563ef5.zip
Optimize compound and binary expression assignments.
Diffstat (limited to 'elaborate.cxx')
-rw-r--r--elaborate.cxx13
1 files changed, 13 insertions, 0 deletions
diff --git a/elaborate.cxx b/elaborate.cxx
index 4bc43832..87deb9cf 100644
--- a/elaborate.cxx
+++ b/elaborate.cxx
@@ -1696,6 +1696,7 @@ struct dead_assignment_remover: public traversing_visitor
// called with null current_expr.
void visit_assignment (assignment* e);
+ void visit_binary_expression (binary_expression* e);
void visit_arrayindex (arrayindex* e);
void visit_functioncall (functioncall* e);
void visit_if_statement (if_statement* e);
@@ -1726,6 +1727,7 @@ dead_assignment_remover::visit_assignment (assignment* e)
{
expression** last_expr = current_expr;
e->left->visit (this);
+ current_expr = &e->right;
e->right->visit (this);
current_expr = last_expr;
if (vut.read.find(leftvar) == vut.read.end()) // var never read?
@@ -1759,6 +1761,17 @@ dead_assignment_remover::visit_assignment (assignment* e)
}
void
+dead_assignment_remover::visit_binary_expression (binary_expression* e)
+{
+ expression** last_expr = current_expr;
+ current_expr = &e->left;
+ e->left->visit (this);
+ current_expr = &e->right;
+ e->right->visit (this);
+ current_expr = last_expr;
+}
+
+void
dead_assignment_remover::visit_arrayindex (arrayindex *e)
{
symbol *array = NULL;