OLD | NEW |
1 // Copyright 2013 the V8 project authors. All rights reserved. | 1 // Copyright 2013 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef V8_COMPILER_GENERIC_ALGORITHM_INL_H_ | 5 #ifndef V8_COMPILER_GENERIC_ALGORITHM_INL_H_ |
6 #define V8_COMPILER_GENERIC_ALGORITHM_INL_H_ | 6 #define V8_COMPILER_GENERIC_ALGORITHM_INL_H_ |
7 | 7 |
8 #include <vector> | 8 #include <vector> |
9 | 9 |
10 #include "src/compiler/generic-algorithm.h" | 10 #include "src/compiler/generic-algorithm.h" |
11 #include "src/compiler/generic-graph.h" | |
12 #include "src/compiler/generic-node.h" | 11 #include "src/compiler/generic-node.h" |
13 #include "src/compiler/generic-node-inl.h" | 12 #include "src/compiler/generic-node-inl.h" |
| 13 #include "src/compiler/graph.h" |
14 | 14 |
15 namespace v8 { | 15 namespace v8 { |
16 namespace internal { | 16 namespace internal { |
17 namespace compiler { | 17 namespace compiler { |
18 | 18 |
19 template <class N> | 19 template <class N> |
20 class NodeInputIterationTraits { | 20 class NodeInputIterationTraits { |
21 public: | 21 public: |
22 typedef N Node; | 22 typedef N Node; |
23 typedef typename N::Inputs::iterator Iterator; | 23 typedef typename N::Inputs::iterator Iterator; |
24 | 24 |
25 static Iterator begin(Node* node) { return node->inputs().begin(); } | 25 static Iterator begin(Node* node) { return node->inputs().begin(); } |
26 static Iterator end(Node* node) { return node->inputs().end(); } | 26 static Iterator end(Node* node) { return node->inputs().end(); } |
27 static int max_id(GenericGraphBase* graph) { return graph->NodeCount(); } | 27 static int max_id(Graph* graph) { return graph->NodeCount(); } |
28 static Node* to(Iterator iterator) { return *iterator; } | 28 static Node* to(Iterator iterator) { return *iterator; } |
29 static Node* from(Iterator iterator) { return iterator.edge().from(); } | 29 static Node* from(Iterator iterator) { return iterator.edge().from(); } |
30 }; | 30 }; |
31 | 31 |
32 } // namespace compiler | 32 } // namespace compiler |
33 } // namespace internal | 33 } // namespace internal |
34 } // namespace v8 | 34 } // namespace v8 |
35 | 35 |
36 #endif // V8_COMPILER_GENERIC_ALGORITHM_INL_H_ | 36 #endif // V8_COMPILER_GENERIC_ALGORITHM_INL_H_ |
OLD | NEW |