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

Side by Side Diff: src/regexp-macro-assembler.h

Issue 17378: Capture register clearing on loop iteration (Closed)
Patch Set: Created 11 years, 11 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
OLDNEW
1 // Copyright 2008 the V8 project authors. All rights reserved. 1 // Copyright 2008 the V8 project authors. All rights reserved.
2 // Redistribution and use in source and binary forms, with or without 2 // Redistribution and use in source and binary forms, with or without
3 // modification, are permitted provided that the following conditions are 3 // modification, are permitted provided that the following conditions are
4 // met: 4 // met:
5 // 5 //
6 // * Redistributions of source code must retain the above copyright 6 // * Redistributions of source code must retain the above copyright
7 // notice, this list of conditions and the following disclaimer. 7 // notice, this list of conditions and the following disclaimer.
8 // * Redistributions in binary form must reproduce the above 8 // * Redistributions in binary form must reproduce the above
9 // copyright notice, this list of conditions and the following 9 // copyright notice, this list of conditions and the following
10 // disclaimer in the documentation and/or other materials provided 10 // disclaimer in the documentation and/or other materials provided
(...skipping 149 matching lines...) Expand 10 before | Expand all | Expand 10 after
160 // will go to this label. Always checks the backtrack stack limit. 160 // will go to this label. Always checks the backtrack stack limit.
161 virtual void PushBacktrack(Label* label) = 0; 161 virtual void PushBacktrack(Label* label) = 0;
162 virtual void PushCurrentPosition() = 0; 162 virtual void PushCurrentPosition() = 0;
163 virtual void PushRegister(int register_index, 163 virtual void PushRegister(int register_index,
164 StackCheckFlag check_stack_limit) = 0; 164 StackCheckFlag check_stack_limit) = 0;
165 virtual void ReadCurrentPositionFromRegister(int reg) = 0; 165 virtual void ReadCurrentPositionFromRegister(int reg) = 0;
166 virtual void ReadStackPointerFromRegister(int reg) = 0; 166 virtual void ReadStackPointerFromRegister(int reg) = 0;
167 virtual void SetRegister(int register_index, int to) = 0; 167 virtual void SetRegister(int register_index, int to) = 0;
168 virtual void Succeed() = 0; 168 virtual void Succeed() = 0;
169 virtual void WriteCurrentPositionToRegister(int reg, int cp_offset) = 0; 169 virtual void WriteCurrentPositionToRegister(int reg, int cp_offset) = 0;
170 virtual void ClearRegister(int reg) = 0;
170 virtual void WriteStackPointerToRegister(int reg) = 0; 171 virtual void WriteStackPointerToRegister(int reg) = 0;
171 172
172 private: 173 private:
173 }; 174 };
174 175
175 176
176 struct ArraySlice { 177 struct ArraySlice {
177 public: 178 public:
178 ArraySlice(Handle<ByteArray> array, size_t offset) 179 ArraySlice(Handle<ByteArray> array, size_t offset)
179 : array_(array), offset_(offset) {} 180 : array_(array), offset_(offset) {}
(...skipping 29 matching lines...) Expand all
209 ArraySlice GetBuffer(Vector<T> values); 210 ArraySlice GetBuffer(Vector<T> values);
210 private: 211 private:
211 size_t byte_array_size_; 212 size_t byte_array_size_;
212 Handle<ByteArray> current_byte_array_; 213 Handle<ByteArray> current_byte_array_;
213 int current_byte_array_free_offset_; 214 int current_byte_array_free_offset_;
214 }; 215 };
215 216
216 } } // namespace v8::internal 217 } } // namespace v8::internal
217 218
218 #endif // V8_REGEXP_MACRO_ASSEMBLER_H_ 219 #endif // V8_REGEXP_MACRO_ASSEMBLER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698