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

Side by Side Diff: src/preparse-data.cc

Issue 5166006: Untemplated preparser.h and made it depend on virtual types. (Closed)
Patch Set: Created 10 years, 1 month 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
« no previous file with comments | « src/preparse-data.h ('k') | src/preparser.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright 2010 the V8 project authors. All rights reserved.
2 // Redistribution and use in source and binary forms, with or without
3 // modification, are permitted provided that the following conditions are
4 // met:
5 //
6 // * Redistributions of source code must retain the above copyright
7 // notice, this list of conditions and the following disclaimer.
8 // * Redistributions in binary form must reproduce the above
9 // copyright notice, this list of conditions and the following
10 // disclaimer in the documentation and/or other materials provided
11 // with the distribution.
12 // * Neither the name of Google Inc. nor the names of its
13 // contributors may be used to endorse or promote products derived
14 // from this software without specific prior written permission.
15 //
16 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17 // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19 // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20 // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22 // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
28 #include "../include/v8stdint.h"
29 #include "globals.h"
30 #include "checks.h"
31 #include "allocation.h"
32 #include "utils.h"
33 #include "list-inl.h"
34 #include "hashmap.h"
35 #include "preparse-data.h"
36
37 namespace v8 {
38 namespace internal {
39
40 // ----------------------------------------------------------------------------
41 // FunctionLoggingParserRecorder
42
43 FunctionLoggingParserRecorder::FunctionLoggingParserRecorder()
44 : function_store_(0),
45 is_recording_(true),
46 pause_count_(0) {
47 preamble_[PreparseDataConstants::kMagicOffset] =
48 PreparseDataConstants::kMagicNumber;
49 preamble_[PreparseDataConstants::kVersionOffset] =
50 PreparseDataConstants::kCurrentVersion;
51 preamble_[PreparseDataConstants::kHasErrorOffset] = false;
52 preamble_[PreparseDataConstants::kFunctionsSizeOffset] = 0;
53 preamble_[PreparseDataConstants::kSymbolCountOffset] = 0;
54 preamble_[PreparseDataConstants::kSizeOffset] = 0;
55 ASSERT_EQ(6, PreparseDataConstants::kHeaderSize);
56 #ifdef DEBUG
57 prev_start_ = -1;
58 #endif
59 }
60
61
62 void FunctionLoggingParserRecorder::LogMessage(int start_pos,
63 int end_pos,
64 const char* message,
65 const char* arg_opt) {
66 if (has_error()) return;
67 preamble_[PreparseDataConstants::kHasErrorOffset] = true;
68 function_store_.Reset();
69 STATIC_ASSERT(PreparseDataConstants::kMessageStartPos == 0);
70 function_store_.Add(start_pos);
71 STATIC_ASSERT(PreparseDataConstants::kMessageEndPos == 1);
72 function_store_.Add(end_pos);
73 STATIC_ASSERT(PreparseDataConstants::kMessageArgCountPos == 2);
74 function_store_.Add((arg_opt == NULL) ? 0 : 1);
75 STATIC_ASSERT(PreparseDataConstants::kMessageTextPos == 3);
76 WriteString(CStrVector(message));
77 if (arg_opt) WriteString(CStrVector(arg_opt));
78 is_recording_ = false;
79 }
80
81
82 void FunctionLoggingParserRecorder::WriteString(Vector<const char> str) {
83 function_store_.Add(str.length());
84 for (int i = 0; i < str.length(); i++) {
85 function_store_.Add(str[i]);
86 }
87 }
88
89 // ----------------------------------------------------------------------------
90 // PartialParserRecorder - Record both function entries and symbols.
91
92 Vector<unsigned> PartialParserRecorder::ExtractData() {
93 int function_size = function_store_.size();
94 int total_size = PreparseDataConstants::kHeaderSize + function_size;
95 Vector<unsigned> data = Vector<unsigned>::New(total_size);
96 preamble_[PreparseDataConstants::kFunctionsSizeOffset] = function_size;
97 preamble_[PreparseDataConstants::kSymbolCountOffset] = 0;
98 memcpy(data.start(), preamble_, sizeof(preamble_));
99 int symbol_start = PreparseDataConstants::kHeaderSize + function_size;
100 if (function_size > 0) {
101 function_store_.WriteTo(data.SubVector(PreparseDataConstants::kHeaderSize,
102 symbol_start));
103 }
104 return data;
105 }
106
107
108 // ----------------------------------------------------------------------------
109 // CompleteParserRecorder - Record both function entries and symbols.
110
111 CompleteParserRecorder::CompleteParserRecorder()
112 : FunctionLoggingParserRecorder(),
113 symbol_store_(0),
114 symbol_entries_(0),
115 symbol_table_(vector_compare),
116 symbol_id_(0) {
117 }
118
119
120 void CompleteParserRecorder::LogSymbol(
121 int start, const char* literal_chars, int length) {
122 if (!is_recording_) return;
123
124 Vector<const char> literal(literal_chars, length);
125 int hash = vector_hash(literal);
126 HashMap::Entry* entry = symbol_table_.Lookup(&literal, hash, true);
127 int id = static_cast<int>(reinterpret_cast<intptr_t>(entry->value));
128 if (id == 0) {
129 // Put (symbol_id_ + 1) into entry and increment it.
130 id = ++symbol_id_;
131 entry->value = reinterpret_cast<void*>(id);
132 Vector<Vector<const char> > symbol = symbol_entries_.AddBlock(1, literal);
133 entry->key = &symbol[0];
134 }
135 WriteNumber(id - 1);
136 }
137
138
139 Vector<unsigned> CompleteParserRecorder::ExtractData() {
140 int function_size = function_store_.size();
141 // Add terminator to symbols, then pad to unsigned size.
142 int symbol_size = symbol_store_.size();
143 int padding = sizeof(unsigned) - (symbol_size % sizeof(unsigned));
144 symbol_store_.AddBlock(padding, PreparseDataConstants::kNumberTerminator);
145 symbol_size += padding;
146 int total_size = PreparseDataConstants::kHeaderSize + function_size
147 + (symbol_size / sizeof(unsigned));
148 Vector<unsigned> data = Vector<unsigned>::New(total_size);
149 preamble_[PreparseDataConstants::kFunctionsSizeOffset] = function_size;
150 preamble_[PreparseDataConstants::kSymbolCountOffset] = symbol_id_;
151 memcpy(data.start(), preamble_, sizeof(preamble_));
152 int symbol_start = PreparseDataConstants::kHeaderSize + function_size;
153 if (function_size > 0) {
154 function_store_.WriteTo(data.SubVector(PreparseDataConstants::kHeaderSize,
155 symbol_start));
156 }
157 if (!has_error()) {
158 symbol_store_.WriteTo(
159 Vector<byte>::cast(data.SubVector(symbol_start, total_size)));
160 }
161 return data;
162 }
163
164
165 void CompleteParserRecorder::WriteNumber(int number) {
166 ASSERT(number >= 0);
167
168 int mask = (1 << 28) - 1;
169 for (int i = 28; i > 0; i -= 7) {
170 if (number > mask) {
171 symbol_store_.Add(static_cast<byte>(number >> i) | 0x80u);
172 number &= mask;
173 }
174 mask >>= 7;
175 }
176 symbol_store_.Add(static_cast<byte>(number));
177 }
178
179
180 } } // namespace v8::internal.
OLDNEW
« no previous file with comments | « src/preparse-data.h ('k') | src/preparser.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698