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_GRAPH_H_ | 5 #ifndef V8_COMPILER_GRAPH_H_ |
6 #define V8_COMPILER_GRAPH_H_ | 6 #define V8_COMPILER_GRAPH_H_ |
7 | 7 |
8 #include "src/zone.h" | 8 #include "src/zone.h" |
9 #include "src/zone-containers.h" | 9 #include "src/zone-containers.h" |
10 | 10 |
(...skipping 16 matching lines...) Expand all Loading... |
27 // NodeIds are identifying numbers for nodes that can be used to index auxiliary | 27 // NodeIds are identifying numbers for nodes that can be used to index auxiliary |
28 // out-of-line data associated with each node. | 28 // out-of-line data associated with each node. |
29 typedef uint32_t NodeId; | 29 typedef uint32_t NodeId; |
30 | 30 |
31 | 31 |
32 class Graph : public ZoneObject { | 32 class Graph : public ZoneObject { |
33 public: | 33 public: |
34 explicit Graph(Zone* zone); | 34 explicit Graph(Zone* zone); |
35 | 35 |
36 // Base implementation used by all factory methods. | 36 // Base implementation used by all factory methods. |
37 Node* NewNodeUnchecked(const Operator* op, int input_count, Node** inputs, | |
38 bool incomplete = false); | |
39 | |
40 // Factory that checks the input count. | |
41 Node* NewNode(const Operator* op, int input_count, Node** inputs, | 37 Node* NewNode(const Operator* op, int input_count, Node** inputs, |
42 bool incomplete = false); | 38 bool incomplete = false); |
43 | 39 |
44 // Factories for nodes with static input counts. | 40 // Factories for nodes with static input counts. |
45 Node* NewNode(const Operator* op) { | 41 Node* NewNode(const Operator* op) { |
46 return NewNode(op, 0, static_cast<Node**>(nullptr)); | 42 return NewNode(op, 0, static_cast<Node**>(nullptr)); |
47 } | 43 } |
48 Node* NewNode(const Operator* op, Node* n1) { return NewNode(op, 1, &n1); } | 44 Node* NewNode(const Operator* op, Node* n1) { return NewNode(op, 1, &n1); } |
49 Node* NewNode(const Operator* op, Node* n1, Node* n2) { | 45 Node* NewNode(const Operator* op, Node* n1, Node* n2) { |
50 Node* nodes[] = {n1, n2}; | 46 Node* nodes[] = {n1, n2}; |
(...skipping 74 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
125 public: | 121 public: |
126 virtual ~GraphDecorator() {} | 122 virtual ~GraphDecorator() {} |
127 virtual void Decorate(Node* node) = 0; | 123 virtual void Decorate(Node* node) = 0; |
128 }; | 124 }; |
129 | 125 |
130 } // namespace compiler | 126 } // namespace compiler |
131 } // namespace internal | 127 } // namespace internal |
132 } // namespace v8 | 128 } // namespace v8 |
133 | 129 |
134 #endif // V8_COMPILER_GRAPH_H_ | 130 #endif // V8_COMPILER_GRAPH_H_ |
OLD | NEW |