]>
Commit | Line | Data |
---|---|---|
1 | /* | |
2 | * Copyright (C) 1999-2000 Harri Porten (porten@kde.org) | |
3 | * Copyright (C) 2007, 2008, 2009 Apple Inc. All rights reserved. | |
4 | * Copyright (C) 2009 Torch Mobile, Inc. | |
5 | * | |
6 | * This library is free software; you can redistribute it and/or | |
7 | * modify it under the terms of the GNU Lesser General Public | |
8 | * License as published by the Free Software Foundation; either | |
9 | * version 2 of the License, or (at your option) any later version. | |
10 | * | |
11 | * This library is distributed in the hope that it will be useful, | |
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
14 | * Lesser General Public License for more details. | |
15 | * | |
16 | * You should have received a copy of the GNU Lesser General Public | |
17 | * License along with this library; if not, write to the Free Software | |
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |
19 | * | |
20 | */ | |
21 | ||
22 | #ifndef RegExp_h | |
23 | #define RegExp_h | |
24 | ||
25 | #include "ExecutableAllocator.h" | |
26 | #include "MatchResult.h" | |
27 | #include "RegExpKey.h" | |
28 | #include "Structure.h" | |
29 | #include "yarr/Yarr.h" | |
30 | #include <wtf/Forward.h> | |
31 | #include <wtf/RefCounted.h> | |
32 | #include <wtf/text/WTFString.h> | |
33 | ||
34 | #if ENABLE(YARR_JIT) | |
35 | #include "yarr/YarrJIT.h" | |
36 | #endif | |
37 | ||
38 | namespace JSC { | |
39 | ||
40 | struct RegExpRepresentation; | |
41 | class VM; | |
42 | ||
43 | JS_EXPORT_PRIVATE RegExpFlags regExpFlags(const String&); | |
44 | ||
45 | class RegExp : public JSCell { | |
46 | public: | |
47 | typedef JSCell Base; | |
48 | ||
49 | JS_EXPORT_PRIVATE static RegExp* create(VM&, const String& pattern, RegExpFlags); | |
50 | static const bool needsDestruction = true; | |
51 | static const bool hasImmortalStructure = true; | |
52 | static void destroy(JSCell*); | |
53 | ||
54 | bool global() const { return m_flags & FlagGlobal; } | |
55 | bool ignoreCase() const { return m_flags & FlagIgnoreCase; } | |
56 | bool multiline() const { return m_flags & FlagMultiline; } | |
57 | ||
58 | const String& pattern() const { return m_patternString; } | |
59 | ||
60 | bool isValid() const { return !m_constructionError && m_flags != InvalidFlags; } | |
61 | const char* errorMessage() const { return m_constructionError; } | |
62 | ||
63 | JS_EXPORT_PRIVATE int match(VM&, const String&, unsigned startOffset, Vector<int, 32>& ovector); | |
64 | MatchResult match(VM&, const String&, unsigned startOffset); | |
65 | unsigned numSubpatterns() const { return m_numSubpatterns; } | |
66 | ||
67 | bool hasCode() | |
68 | { | |
69 | return m_state != NotCompiled; | |
70 | } | |
71 | ||
72 | void invalidateCode(); | |
73 | ||
74 | #if ENABLE(REGEXP_TRACING) | |
75 | void printTraceData(); | |
76 | #endif | |
77 | ||
78 | static Structure* createStructure(VM& vm, JSGlobalObject* globalObject, JSValue prototype) | |
79 | { | |
80 | return Structure::create(vm, globalObject, prototype, TypeInfo(LeafType, StructureFlags), info()); | |
81 | } | |
82 | ||
83 | DECLARE_INFO; | |
84 | ||
85 | RegExpKey key() { return RegExpKey(m_flags, m_patternString); } | |
86 | ||
87 | protected: | |
88 | static const unsigned StructureFlags = StructureIsImmortal; | |
89 | ||
90 | void finishCreation(VM&); | |
91 | ||
92 | private: | |
93 | friend class RegExpCache; | |
94 | RegExp(VM&, const String&, RegExpFlags); | |
95 | ||
96 | static RegExp* createWithoutCaching(VM&, const String&, RegExpFlags); | |
97 | ||
98 | enum RegExpState { | |
99 | ParseError, | |
100 | JITCode, | |
101 | ByteCode, | |
102 | NotCompiled | |
103 | } m_state; | |
104 | ||
105 | void compile(VM*, Yarr::YarrCharSize); | |
106 | void compileIfNecessary(VM&, Yarr::YarrCharSize); | |
107 | ||
108 | void compileMatchOnly(VM*, Yarr::YarrCharSize); | |
109 | void compileIfNecessaryMatchOnly(VM&, Yarr::YarrCharSize); | |
110 | ||
111 | #if ENABLE(YARR_JIT_DEBUG) | |
112 | void matchCompareWithInterpreter(const String&, int startOffset, int* offsetVector, int jitResult); | |
113 | #endif | |
114 | ||
115 | String m_patternString; | |
116 | RegExpFlags m_flags; | |
117 | const char* m_constructionError; | |
118 | unsigned m_numSubpatterns; | |
119 | #if ENABLE(REGEXP_TRACING) | |
120 | double m_rtMatchOnlyTotalSubjectStringLen; | |
121 | double m_rtMatchTotalSubjectStringLen; | |
122 | unsigned m_rtMatchOnlyCallCount; | |
123 | unsigned m_rtMatchOnlyFoundCount; | |
124 | unsigned m_rtMatchCallCount; | |
125 | unsigned m_rtMatchFoundCount; | |
126 | #endif | |
127 | ||
128 | #if ENABLE(YARR_JIT) | |
129 | Yarr::YarrCodeBlock m_regExpJITCode; | |
130 | #endif | |
131 | OwnPtr<Yarr::BytecodePattern> m_regExpBytecode; | |
132 | }; | |
133 | ||
134 | } // namespace JSC | |
135 | ||
136 | #endif // RegExp_h |