Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(113)

Side by Side Diff: src/func-name-inferrer.h

Issue 231073002: WIP: Parser: delay string internalization. (Closed) Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
Patch Set: internalizing better Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright 2006-2009 the V8 project authors. All rights reserved. 1 // Copyright 2006-2009 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_FUNC_NAME_INFERRER_H_ 5 #ifndef V8_FUNC_NAME_INFERRER_H_
6 #define V8_FUNC_NAME_INFERRER_H_ 6 #define V8_FUNC_NAME_INFERRER_H_
7 7
8 #include "handles.h" 8 #include "handles.h"
9 #include "parser-symbol-table.h"
9 #include "zone.h" 10 #include "zone.h"
10 11
11 namespace v8 { 12 namespace v8 {
12 namespace internal { 13 namespace internal {
13 14
14 class FunctionLiteral; 15 class FunctionLiteral;
15 class Isolate;
16 16
17 // FuncNameInferrer is a stateful class that is used to perform name 17 // FuncNameInferrer is a stateful class that is used to perform name
18 // inference for anonymous functions during static analysis of source code. 18 // inference for anonymous functions during static analysis of source code.
19 // Inference is performed in cases when an anonymous function is assigned 19 // Inference is performed in cases when an anonymous function is assigned
20 // to a variable or a property (see test-func-name-inference.cc for examples.) 20 // to a variable or a property (see test-func-name-inference.cc for examples.)
21 // 21 //
22 // The basic idea is that during parsing of LHSs of certain expressions 22 // The basic idea is that during parsing of LHSs of certain expressions
23 // (assignments, declarations, object literals) we collect name strings, 23 // (assignments, declarations, object literals) we collect name strings,
24 // and during parsing of the RHS, a function literal can be collected. After 24 // and during parsing of the RHS, a function literal can be collected. After
25 // parsing the RHS we can infer a name for function literals that do not have 25 // parsing the RHS we can infer a name for function literals that do not have
26 // a name. 26 // a name.
27 class FuncNameInferrer : public ZoneObject { 27 class FuncNameInferrer : public ZoneObject {
28 public: 28 public:
29 FuncNameInferrer(Isolate* isolate, Zone* zone); 29 FuncNameInferrer(ParserSymbolTable* symbol_table, Zone* zone);
30 30
31 // Returns whether we have entered name collection state. 31 // Returns whether we have entered name collection state.
32 bool IsOpen() const { return !entries_stack_.is_empty(); } 32 bool IsOpen() const { return !entries_stack_.is_empty(); }
33 33
34 // Pushes an enclosing the name of enclosing function onto names stack. 34 // Pushes an enclosing the name of enclosing function onto names stack.
35 void PushEnclosingName(Handle<String> name); 35 void PushEnclosingName(ParserSymbolTable::Symbol* name);
36 36
37 // Enters name collection state. 37 // Enters name collection state.
38 void Enter() { 38 void Enter() {
39 entries_stack_.Add(names_stack_.length(), zone()); 39 entries_stack_.Add(names_stack_.length(), zone());
40 } 40 }
41 41
42 // Pushes an encountered name onto names stack when in collection state. 42 // Pushes an encountered name onto names stack when in collection state.
43 void PushLiteralName(Handle<String> name); 43 void PushLiteralName(ParserSymbolTable::Symbol* name);
44 44
45 void PushVariableName(Handle<String> name); 45 void PushVariableName(ParserSymbolTable::Symbol* name);
46 46
47 // Adds a function to infer name for. 47 // Adds a function to infer name for.
48 void AddFunction(FunctionLiteral* func_to_infer) { 48 void AddFunction(FunctionLiteral* func_to_infer) {
49 if (IsOpen()) { 49 if (IsOpen()) {
50 funcs_to_infer_.Add(func_to_infer, zone()); 50 funcs_to_infer_.Add(func_to_infer, zone());
51 } 51 }
52 } 52 }
53 53
54 void RemoveLastFunction() { 54 void RemoveLastFunction() {
55 if (IsOpen() && !funcs_to_infer_.is_empty()) { 55 if (IsOpen() && !funcs_to_infer_.is_empty()) {
(...skipping 17 matching lines...) Expand all
73 funcs_to_infer_.Clear(); 73 funcs_to_infer_.Clear();
74 } 74 }
75 75
76 private: 76 private:
77 enum NameType { 77 enum NameType {
78 kEnclosingConstructorName, 78 kEnclosingConstructorName,
79 kLiteralName, 79 kLiteralName,
80 kVariableName 80 kVariableName
81 }; 81 };
82 struct Name { 82 struct Name {
83 Name(Handle<String> name, NameType type) : name(name), type(type) { } 83 Name(ParserSymbolTable::Symbol* name, NameType type)
84 Handle<String> name; 84 : name(name), type(type) {}
85 ParserSymbolTable::Symbol* name;
85 NameType type; 86 NameType type;
86 }; 87 };
87 88
88 Isolate* isolate() { return isolate_; }
89 Zone* zone() const { return zone_; } 89 Zone* zone() const { return zone_; }
90 90
91 // Constructs a full name in dotted notation from gathered names. 91 // Constructs a full name in dotted notation from gathered names.
92 Handle<String> MakeNameFromStack(); 92 ParserSymbolTable::Symbol* MakeNameFromStack();
93
94 // A helper function for MakeNameFromStack.
95 Handle<String> MakeNameFromStackHelper(int pos, Handle<String> prev);
96 93
97 // Performs name inferring for added functions. 94 // Performs name inferring for added functions.
98 void InferFunctionsNames(); 95 void InferFunctionsNames();
99 96
100 Isolate* isolate_; 97 ParserSymbolTable* symbol_table_;
101 ZoneList<int> entries_stack_; 98 ZoneList<int> entries_stack_;
102 ZoneList<Name> names_stack_; 99 ZoneList<Name> names_stack_;
103 ZoneList<FunctionLiteral*> funcs_to_infer_; 100 ZoneList<FunctionLiteral*> funcs_to_infer_;
104 Zone* zone_; 101 Zone* zone_;
105 102
106 DISALLOW_COPY_AND_ASSIGN(FuncNameInferrer); 103 DISALLOW_COPY_AND_ASSIGN(FuncNameInferrer);
107 }; 104 };
108 105
109 106
110 } } // namespace v8::internal 107 } } // namespace v8::internal
111 108
112 #endif // V8_FUNC_NAME_INFERRER_H_ 109 #endif // V8_FUNC_NAME_INFERRER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698