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

Side by Side Diff: src/bytecodes-irregexp.h

Issue 9854020: RegExp: Add support for table-based character class (Closed) Base URL: http://v8.googlecode.com/svn/branches/bleeding_edge/
Patch Set: Created 8 years, 8 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 2011 the V8 project authors. All rights reserved. 1 // Copyright 2011 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 54 matching lines...) Expand 10 before | Expand all | Expand 10 after
65 V(LOAD_4_CURRENT_CHARS, 21, 8) /* bc8 offset24 addr32 */ \ 65 V(LOAD_4_CURRENT_CHARS, 21, 8) /* bc8 offset24 addr32 */ \
66 V(LOAD_4_CURRENT_CHARS_UNCHECKED, 22, 4) /* bc8 offset24 */ \ 66 V(LOAD_4_CURRENT_CHARS_UNCHECKED, 22, 4) /* bc8 offset24 */ \
67 V(CHECK_4_CHARS, 23, 12) /* bc8 pad24 uint32 addr32 */ \ 67 V(CHECK_4_CHARS, 23, 12) /* bc8 pad24 uint32 addr32 */ \
68 V(CHECK_CHAR, 24, 8) /* bc8 pad8 uint16 addr32 */ \ 68 V(CHECK_CHAR, 24, 8) /* bc8 pad8 uint16 addr32 */ \
69 V(CHECK_NOT_4_CHARS, 25, 12) /* bc8 pad24 uint32 addr32 */ \ 69 V(CHECK_NOT_4_CHARS, 25, 12) /* bc8 pad24 uint32 addr32 */ \
70 V(CHECK_NOT_CHAR, 26, 8) /* bc8 pad8 uint16 addr32 */ \ 70 V(CHECK_NOT_CHAR, 26, 8) /* bc8 pad8 uint16 addr32 */ \
71 V(AND_CHECK_4_CHARS, 27, 16) /* bc8 pad24 uint32 uint32 addr32 */ \ 71 V(AND_CHECK_4_CHARS, 27, 16) /* bc8 pad24 uint32 uint32 addr32 */ \
72 V(AND_CHECK_CHAR, 28, 12) /* bc8 pad8 uint16 uint32 addr32 */ \ 72 V(AND_CHECK_CHAR, 28, 12) /* bc8 pad8 uint16 uint32 addr32 */ \
73 V(AND_CHECK_NOT_4_CHARS, 29, 16) /* bc8 pad24 uint32 uint32 addr32 */ \ 73 V(AND_CHECK_NOT_4_CHARS, 29, 16) /* bc8 pad24 uint32 uint32 addr32 */ \
74 V(AND_CHECK_NOT_CHAR, 30, 12) /* bc8 pad8 uint16 uint32 addr32 */ \ 74 V(AND_CHECK_NOT_CHAR, 30, 12) /* bc8 pad8 uint16 uint32 addr32 */ \
75 V(MINUS_AND_CHECK_NOT_CHAR, 31, 12) /* bc8 pad8 uc16 uc16 addr32 */ \ 75 V(MINUS_AND_CHECK_NOT_CHAR, 31, 12) /* bc8 pad8 uc16 uc16 uc16 addr32 */ \
76 V(CHECK_LT, 32, 8) /* bc8 pad8 uc16 addr32 */ \ 76 V(CHECK_CHAR_IN_RANGE, 32, 12) /* bc8 pad24 uc16 uc16 addr32 */ \
77 V(CHECK_GT, 33, 8) /* bc8 pad8 uc16 addr32 */ \ 77 V(CHECK_CHAR_NOT_IN_RANGE, 33, 12) /* bc8 pad24 uc16 uc16 addr32 */ \
78 V(CHECK_NOT_BACK_REF, 34, 8) /* bc8 reg_idx24 addr32 */ \ 78 V(CHECK_BIT_IN_TABLE, 34, 24) /* bc8 pad24 addr32 bits128 */ \
79 V(CHECK_NOT_BACK_REF_NO_CASE, 35, 8) /* bc8 reg_idx24 addr32 */ \ 79 V(CHECK_LT, 35, 8) /* bc8 pad8 uc16 addr32 */ \
80 V(CHECK_NOT_REGS_EQUAL, 36, 12) /* bc8 regidx24 reg_idx32 addr32 */ \ 80 V(CHECK_GT, 36, 8) /* bc8 pad8 uc16 addr32 */ \
81 V(LOOKUP_MAP1, 37, 12) /* bc8 pad8 start16 bit_map_addr32 addr32 */ \ 81 V(CHECK_NOT_BACK_REF, 37, 8) /* bc8 reg_idx24 addr32 */ \
82 V(LOOKUP_MAP2, 38, 96) /* bc8 pad8 start16 half_nibble_map_addr32* */ \ 82 V(CHECK_NOT_BACK_REF_NO_CASE, 38, 8) /* bc8 reg_idx24 addr32 */ \
83 V(LOOKUP_MAP8, 39, 96) /* bc8 pad8 start16 byte_map addr32* */ \ 83 V(CHECK_NOT_REGS_EQUAL, 39, 12) /* bc8 regidx24 reg_idx32 addr32 */ \
84 V(LOOKUP_HI_MAP8, 40, 96) /* bc8 start24 byte_map_addr32 addr32* */ \ 84 V(CHECK_REGISTER_LT, 40, 12) /* bc8 reg_idx24 value32 addr32 */ \
85 V(CHECK_REGISTER_LT, 41, 12) /* bc8 reg_idx24 value32 addr32 */ \ 85 V(CHECK_REGISTER_GE, 41, 12) /* bc8 reg_idx24 value32 addr32 */ \
86 V(CHECK_REGISTER_GE, 42, 12) /* bc8 reg_idx24 value32 addr32 */ \ 86 V(CHECK_REGISTER_EQ_POS, 42, 8) /* bc8 reg_idx24 addr32 */ \
87 V(CHECK_REGISTER_EQ_POS, 43, 8) /* bc8 reg_idx24 addr32 */ \ 87 V(CHECK_AT_START, 43, 8) /* bc8 pad24 addr32 */ \
88 V(CHECK_AT_START, 44, 8) /* bc8 pad24 addr32 */ \ 88 V(CHECK_NOT_AT_START, 44, 8) /* bc8 pad24 addr32 */ \
89 V(CHECK_NOT_AT_START, 45, 8) /* bc8 pad24 addr32 */ \ 89 V(CHECK_GREEDY, 45, 8) /* bc8 pad24 addr32 */ \
90 V(CHECK_GREEDY, 46, 8) /* bc8 pad24 addr32 */ \ 90 V(ADVANCE_CP_AND_GOTO, 46, 8) /* bc8 offset24 addr32 */ \
91 V(ADVANCE_CP_AND_GOTO, 47, 8) /* bc8 offset24 addr32 */ \ 91 V(SET_CURRENT_POSITION_FROM_END, 47, 4) /* bc8 idx24 */
92 V(SET_CURRENT_POSITION_FROM_END, 48, 4) /* bc8 idx24 */
93 92
94 #define DECLARE_BYTECODES(name, code, length) \ 93 #define DECLARE_BYTECODES(name, code, length) \
95 static const int BC_##name = code; 94 static const int BC_##name = code;
96 BYTECODE_ITERATOR(DECLARE_BYTECODES) 95 BYTECODE_ITERATOR(DECLARE_BYTECODES)
97 #undef DECLARE_BYTECODES 96 #undef DECLARE_BYTECODES
98 97
99 #define DECLARE_BYTECODE_LENGTH(name, code, length) \ 98 #define DECLARE_BYTECODE_LENGTH(name, code, length) \
100 static const int BC_##name##_LENGTH = length; 99 static const int BC_##name##_LENGTH = length;
101 BYTECODE_ITERATOR(DECLARE_BYTECODE_LENGTH) 100 BYTECODE_ITERATOR(DECLARE_BYTECODE_LENGTH)
102 #undef DECLARE_BYTECODE_LENGTH 101 #undef DECLARE_BYTECODE_LENGTH
103 } } 102 } }
104 103
105 #endif // V8_BYTECODES_IRREGEXP_H_ 104 #endif // V8_BYTECODES_IRREGEXP_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698