Chromium Code Reviews| Index: runtime/vm/raw_object.h |
| diff --git a/runtime/vm/raw_object.h b/runtime/vm/raw_object.h |
| index 9e48fac0af64fcdb95096cdfdd6d3ce973a789c2..1b446d189d702b0bf0f65c1162f512156f3dfc40 100644 |
| --- a/runtime/vm/raw_object.h |
| +++ b/runtime/vm/raw_object.h |
| @@ -631,6 +631,7 @@ class RawFunction : public RawObject { |
| kMethodExtractor, // converts method into implicit closure on the receiver. |
| kNoSuchMethodDispatcher, // invokes noSuchMethod. |
| kInvokeFieldDispatcher, // invokes a field as a closure. |
| + kIrregexpFunction, // represents a generated irregexp matcher function. |
| }; |
| enum AsyncModifier { |
| @@ -673,6 +674,7 @@ class RawFunction : public RawObject { |
| int16_t num_fixed_parameters_; |
| int16_t num_optional_parameters_; // > 0: positional; < 0: named. |
| int16_t deoptimization_counter_; |
| + int16_t regexp_cid_; |
|
Ivan Posva
2014/10/10 06:35:54
Would an int8_t do? Or a uint8_t?
Generally it is
Vyacheslav Egorov (Google)
2014/10/10 08:08:08
We were indeed concerned about the size of the Fun
jgruber1
2014/10/10 09:29:44
Added snapshotting of regexp_cid_.
|
| uint32_t kind_tag_; // See Function::KindTagBits. |
| uint16_t optimized_instruction_count_; |
| uint16_t optimized_call_site_count_; |
| @@ -1768,8 +1770,12 @@ class RawJSRegExp : public RawInstance { |
| RawSmi* data_length_; |
| RawSmi* num_bracket_expressions_; |
| RawString* pattern_; // Pattern to be used for matching. |
| + RawFunction* one_byte_function_; |
| + RawFunction* two_byte_function_; |
| + RawFunction* external_one_byte_function_; |
| + RawFunction* external_two_byte_function_; |
| RawObject** to() { |
| - return reinterpret_cast<RawObject**>(&ptr()->pattern_); |
| + return reinterpret_cast<RawObject**>(&ptr()->external_two_byte_function_); |
| } |
| // A bitfield with two fields: |