Reviewers: danno,

Description:
Add templatized Run() method for Hydrogen phases.

Depends upon https://codereview.chromium.org/17657004

[email protected]
BUG=

Please review this at https://codereview.chromium.org/18034003/

SVN Base: https://v8.googlecode.com/svn/branches/bleeding_edge

Affected files:
  M src/hydrogen.h
  M src/hydrogen.cc


Index: src/hydrogen.cc
diff --git a/src/hydrogen.cc b/src/hydrogen.cc
index 0e6e8681279f4075a4a74430f8a9d759ce775734..04debfadde9524bed82687b48142191ea8d538fc 100644
--- a/src/hydrogen.cc
+++ b/src/hydrogen.cc
@@ -4014,10 +4014,7 @@ bool HGraph::Optimize(SmartArrayPointer<char>* bailout_reason) {

   if (FLAG_use_canonicalizing) Canonicalize();

-  if (FLAG_use_gvn) {
-    HGlobalValueNumberingPhase phase(this);
-    phase.Run();
-  }
+  if (FLAG_use_gvn) Run<HGlobalValueNumberingPhase>();

   if (FLAG_use_range) {
     HRangeAnalysis rangeAnalysis(this);
Index: src/hydrogen.h
diff --git a/src/hydrogen.h b/src/hydrogen.h
index 277448914d2379ff24b638ca516d9925920c116f..97c9a6a21b1ffe9a0fefc8428c9ea1954515294f 100644
--- a/src/hydrogen.h
+++ b/src/hydrogen.h
@@ -427,6 +427,9 @@ class HGraph: public ZoneObject {
   HConstant* GetConstant(SetOncePointer<HConstant>* pointer,
                          int32_t integer_value);

+  template<class Phase>
+  void Run() { Phase phase(this); phase.Run(); }
+
   void MarkLive(HValue* ref, HValue* instr, ZoneList<HValue*>* worklist);
   void MarkLiveInstructions();
   void RemoveDeadInstructions();


--
--
v8-dev mailing list
[email protected]
http://groups.google.com/group/v8-dev
--- You received this message because you are subscribed to the Google Groups "v8-dev" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to [email protected].
For more options, visit https://groups.google.com/groups/opt_out.


Reply via email to