mozilla-yarr-pcre.patch
author Wolfgang Rosenauer <wr@rosenauer.org>
Thu, 15 Mar 2012 10:33:22 +0100
changeset 409 ff30593d2daa
parent 401 aafdccaf5ded
child 445 b8a9179c123d
child 475 b0df28e752fd
permissions -rw-r--r--
switch to 12.0dev
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
391
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 386
diff changeset
     1
# HG changeset patch
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
     2
# Parent 58dd942011a81f3149d9bc34e808806bda099056
391
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 386
diff changeset
     3
# User Landry Breuil <landry@openbsd.org>
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 386
diff changeset
     4
Use YARR interpreter instead of PCRE on platforms where YARR JIT is not
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 386
diff changeset
     5
supported
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
     6
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
     7
diff --git a/js/src/Makefile.in b/js/src/Makefile.in
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
     8
--- a/js/src/Makefile.in
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
     9
+++ b/js/src/Makefile.in
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    10
@@ -335,25 +335,29 @@ CPPSRCS += 	checks.cc \
386
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    11
 # END enclude sources for V8 dtoa
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    12
 #############################################
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    13
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    14
 # For architectures without YARR JIT, PCRE is faster than the YARR
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    15
 # interpreter (bug 684559).
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    16
 
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    17
 ifeq (,$(filter arm% sparc %86 x86_64 mips%,$(TARGET_CPU)))
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    18
 
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    19
-VPATH +=        $(srcdir)/yarr/pcre \
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    20
+VPATH +=        $(srcdir)/assembler \
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    21
+                $(srcdir)/assembler/wtf \
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    22
+                $(srcdir)/yarr \
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    23
 		$(NULL)
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    24
 
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    25
 CPPSRCS += \
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    26
-                pcre_compile.cpp \
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    27
-                pcre_exec.cpp \
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    28
-                pcre_tables.cpp \
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    29
-                pcre_xclass.cpp \
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    30
-                pcre_ucp_searchfuncs.cpp \
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    31
+                OSAllocatorOS2.cpp \
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    32
+                OSAllocatorPosix.cpp \
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    33
+                OSAllocatorWin.cpp \
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    34
+                PageBlock.cpp \
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    35
+                YarrInterpreter.cpp \
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    36
+                YarrPattern.cpp \
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    37
+                YarrSyntaxChecker.cpp \
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    38
 		$(NULL)
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    39
 else
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    40
 
386
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    41
 ###############################################
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    42
 # BEGIN include sources for the Nitro assembler
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    43
 #
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    44
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    45
 ENABLE_YARR_JIT = 1
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    46
@@ -878,20 +882,20 @@ endif
386
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    47
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    48
 ###############################################
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    49
 # BEGIN kludges for the Nitro assembler
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    50
 #
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    51
 
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    52
 # Needed to "configure" it correctly.  Unfortunately these
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    53
 # flags wind up being applied to all code in js/src, not just
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    54
 # the code in js/src/assembler.
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    55
-CXXFLAGS += -DUSE_SYSTEM_MALLOC=1 -DENABLE_ASSEMBLER=1
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    56
+CXXFLAGS += -DUSE_SYSTEM_MALLOC=1
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    57
 
386
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    58
 ifneq (,$(ENABLE_YARR_JIT)$(ENABLE_METHODJIT))
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    59
-CXXFLAGS +=  -DENABLE_JIT=1
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    60
+CXXFLAGS +=  -DENABLE_JIT=1 -DENABLE_ASSEMBLER=1
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    61
 endif
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    62
 
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    63
 INCLUDES +=	-I$(srcdir)/assembler -I$(srcdir)/yarr
386
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    64
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    65
 ifdef ENABLE_METHODJIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    66
 # Build a standalone test program that exercises the assembler
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    67
 # sources a bit.
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    68
 TESTMAIN_OBJS = \
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    69
diff --git a/js/src/jsapi.cpp b/js/src/jsapi.cpp
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    70
--- a/js/src/jsapi.cpp
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    71
+++ b/js/src/jsapi.cpp
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    72
@@ -696,17 +696,19 @@ JS_IsBuiltinFunctionConstructor(JSFuncti
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    73
 static JSBool js_NewRuntimeWasCalled = JS_FALSE;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    74
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    75
 JSRuntime::JSRuntime()
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    76
   : atomsCompartment(NULL),
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    77
 #ifdef JS_THREADSAFE
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    78
     ownerThread_(NULL),
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    79
 #endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    80
     tempLifoAlloc(TEMP_LIFO_ALLOC_PRIMARY_CHUNK_SIZE),
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    81
+#if ENABLE_ASSEMBLER
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    82
     execAlloc_(NULL),
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    83
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    84
     bumpAlloc_(NULL),
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    85
     nativeStackBase(0),
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    86
     nativeStackQuota(0),
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    87
     interpreterFrames(NULL),
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    88
     cxCallback(NULL),
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    89
     compartmentCallback(NULL),
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    90
     activityCallback(NULL),
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    91
     activityCallbackArg(NULL),
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    92
@@ -851,17 +853,19 @@ JSRuntime::init(uint32_t maxbytes)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    93
     nativeStackBase = GetNativeStackBase();
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    94
     return true;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    95
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    96
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    97
 JSRuntime::~JSRuntime()
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    98
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    99
     JS_ASSERT(onOwnerThread());
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   100
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   101
+#if ENABLE_ASSEMBLER
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   102
     delete_<JSC::ExecutableAllocator>(execAlloc_);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   103
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   104
     delete_<WTF::BumpPointerAllocator>(bumpAlloc_);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   105
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   106
 #ifdef DEBUG
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   107
     /* Don't hurt everyone in leaky ol' Mozilla with a fatal JS_ASSERT! */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   108
     if (!JS_CLIST_IS_EMPTY(&contextList)) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   109
         JSContext *cx, *iter = NULL;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   110
         uintN cxcount = 0;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   111
         while ((cx = js_ContextIterator(this, JS_TRUE, &iter)) != NULL) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   112
diff --git a/js/src/jscntxt.cpp b/js/src/jscntxt.cpp
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   113
--- a/js/src/jscntxt.cpp
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   114
+++ b/js/src/jscntxt.cpp
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   115
@@ -100,19 +100,21 @@ JSRuntime::sizeOfExcludingThis(JSMallocS
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   116
     if (normal)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   117
         *normal = mallocSizeOf(dtoaState);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   118
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   119
     if (temporary)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   120
         *temporary = tempLifoAlloc.sizeOfExcludingThis(mallocSizeOf);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   121
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   122
     if (regexpCode) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   123
         size_t method = 0, regexp = 0, unused = 0;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   124
+#if ENABLE_ASSEMBLER
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   125
         if (execAlloc_)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   126
             execAlloc_->sizeOfCode(&method, &regexp, &unused);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   127
         JS_ASSERT(method == 0);     /* this execAlloc is only used for regexp code */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   128
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   129
         *regexpCode = regexp + unused;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   130
     }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   131
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   132
     if (stackCommitted)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   133
         *stackCommitted = stackSpace.sizeOfCommitted();
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   134
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   135
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   136
 JS_FRIEND_API(void)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   137
@@ -124,33 +126,37 @@ JSRuntime::triggerOperationCallback()
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   138
      */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   139
     JS_ATOMIC_SET(&interrupt, 1);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   140
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   141
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   142
 void
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   143
 JSRuntime::setJitHardening(bool enabled)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   144
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   145
     jitHardening = enabled;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   146
+#if ENABLE_ASSEMBLER
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   147
     if (execAlloc_)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   148
         execAlloc_->setRandomize(enabled);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   149
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   150
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   151
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   152
+#if ENABLE_ASSEMBLER
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   153
 JSC::ExecutableAllocator *
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   154
 JSRuntime::createExecutableAllocator(JSContext *cx)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   155
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   156
     JS_ASSERT(!execAlloc_);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   157
     JS_ASSERT(cx->runtime == this);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   158
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   159
     JSC::AllocationBehavior randomize =
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   160
         jitHardening ? JSC::AllocationCanRandomize : JSC::AllocationDeterministic;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   161
     execAlloc_ = new_<JSC::ExecutableAllocator>(randomize);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   162
     if (!execAlloc_)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   163
         js_ReportOutOfMemory(cx);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   164
     return execAlloc_;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   165
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   166
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   167
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   168
 WTF::BumpPointerAllocator *
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   169
 JSRuntime::createBumpPointerAllocator(JSContext *cx)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   170
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   171
     JS_ASSERT(!bumpAlloc_);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   172
     JS_ASSERT(cx->runtime == this);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   173
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   174
     bumpAlloc_ = new_<WTF::BumpPointerAllocator>();
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   175
diff --git a/js/src/jscntxt.h b/js/src/jscntxt.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   176
--- a/js/src/jscntxt.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   177
+++ b/js/src/jscntxt.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   178
@@ -219,26 +219,32 @@ struct JSRuntime : js::RuntimeFriendFiel
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   179
     static const size_t TEMP_LIFO_ALLOC_PRIMARY_CHUNK_SIZE = 1 << 12;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   180
     js::LifoAlloc tempLifoAlloc;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   181
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   182
   private:
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   183
     /*
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   184
      * Both of these allocators are used for regular expression code which is shared at the
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   185
      * thread-data level.
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   186
      */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   187
+#if ENABLE_ASSEMBLER
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   188
     JSC::ExecutableAllocator *execAlloc_;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   189
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   190
     WTF::BumpPointerAllocator *bumpAlloc_;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   191
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   192
+#if ENABLE_ASSEMBLER
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   193
     JSC::ExecutableAllocator *createExecutableAllocator(JSContext *cx);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   194
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   195
     WTF::BumpPointerAllocator *createBumpPointerAllocator(JSContext *cx);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   196
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   197
   public:
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   198
+#if ENABLE_ASSEMBLER
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   199
     JSC::ExecutableAllocator *getExecutableAllocator(JSContext *cx) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   200
         return execAlloc_ ? execAlloc_ : createExecutableAllocator(cx);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   201
     }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   202
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   203
     WTF::BumpPointerAllocator *getBumpPointerAllocator(JSContext *cx) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   204
         return bumpAlloc_ ? bumpAlloc_ : createBumpPointerAllocator(cx);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   205
     }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   206
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   207
     /* Base address of the native stack for the current thread. */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   208
     uintptr_t           nativeStackBase;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   209
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   210
     /* The native stack size limit that runtime should not exceed. */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   211
diff --git a/js/src/jsprvtd.h b/js/src/jsprvtd.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   212
--- a/js/src/jsprvtd.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   213
+++ b/js/src/jsprvtd.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   214
@@ -313,22 +313,23 @@ typedef Handle<BaseShape*>         Handl
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   215
 typedef Handle<types::TypeObject*> HandleTypeObject;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   216
 typedef Handle<JSString*>          HandleString;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   217
 typedef Handle<JSAtom*>            HandleAtom;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   218
 typedef Handle<jsid>               HandleId;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   219
 typedef Handle<Value>              HandleValue;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   220
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   221
 } /* namespace js */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   222
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   223
+#if ENABLE_ASSEMBLER
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   224
 namespace JSC {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   225
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   226
 class ExecutableAllocator;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   227
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   228
 } /* namespace JSC */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   229
-
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   230
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   231
 namespace WTF {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   232
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   233
 class BumpPointerAllocator;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   234
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   235
 } /* namespace WTF */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   236
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   237
 } /* export "C++" */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   238
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   239
diff --git a/js/src/vm/RegExpObject-inl.h b/js/src/vm/RegExpObject-inl.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   240
--- a/js/src/vm/RegExpObject-inl.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   241
+++ b/js/src/vm/RegExpObject-inl.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   242
@@ -132,26 +132,28 @@ RegExpObject::setMultiline(bool enabled)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   243
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   244
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   245
 inline void
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   246
 RegExpObject::setSticky(bool enabled)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   247
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   248
     setSlot(STICKY_FLAG_SLOT, BooleanValue(enabled));
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   249
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   250
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   251
+#if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   252
 /* This function should be deleted once bad Android platforms phase out. See bug 604774. */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   253
 inline bool
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   254
 detail::RegExpCode::isJITRuntimeEnabled(JSContext *cx)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   255
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   256
 #if defined(ANDROID) && defined(JS_METHODJIT)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   257
     return cx->methodJitEnabled;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   258
 #else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   259
     return true;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   260
 #endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   261
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   262
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   263
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   264
 inline bool
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   265
 RegExpToShared(JSContext *cx, JSObject &obj, RegExpGuard *g)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   266
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   267
     JS_ASSERT(ObjectClassIs(obj, ESClass_RegExp, cx));
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   268
     if (obj.isRegExp())
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   269
         return obj.asRegExp().getShared(cx, g);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   270
     return Proxy::regexp_toShared(cx, &obj, g);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   271
diff --git a/js/src/vm/RegExpObject.cpp b/js/src/vm/RegExpObject.cpp
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   272
--- a/js/src/vm/RegExpObject.cpp
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   273
+++ b/js/src/vm/RegExpObject.cpp
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   274
@@ -162,17 +162,16 @@ MatchPairs::checkAgainst(size_t inputLen
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   275
             continue;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   276
         JS_ASSERT(size_t(p.limit) <= inputLength);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   277
     }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   278
 #endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   279
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   280
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   281
 /* detail::RegExpCode */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   282
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   283
-#if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   284
 void
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   285
 RegExpCode::reportYarrError(JSContext *cx, TokenStream *ts, ErrorCode error)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   286
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   287
     switch (error) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   288
       case JSC::Yarr::NoError:
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   289
         JS_NOT_REACHED("Called reportYarrError with value for no error");
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   290
         return;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   291
 #define COMPILE_EMSG(__code, __msg)                                                              \
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   292
@@ -194,73 +193,36 @@ RegExpCode::reportYarrError(JSContext *c
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   293
       COMPILE_EMSG(QuantifierTooLarge, JSMSG_BAD_QUANTIFIER);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   294
       COMPILE_EMSG(EscapeUnterminated, JSMSG_TRAILING_SLASH);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   295
 #undef COMPILE_EMSG
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   296
       default:
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   297
         JS_NOT_REACHED("Unknown Yarr error code");
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   298
     }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   299
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   300
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   301
-#else /* !ENABLE_YARR_JIT */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   302
-
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   303
-void
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   304
-RegExpCode::reportPCREError(JSContext *cx, int error)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   305
-{
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   306
-#define REPORT(msg_) \
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   307
-    JS_ReportErrorFlagsAndNumberUC(cx, JSREPORT_ERROR, js_GetErrorMessage, NULL, msg_); \
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   308
-    return
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   309
-    switch (error) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   310
-      case -2: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   311
-      case 0: JS_NOT_REACHED("Precondition violation: an error must have occurred.");
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   312
-      case 1: REPORT(JSMSG_TRAILING_SLASH);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   313
-      case 2: REPORT(JSMSG_TRAILING_SLASH);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   314
-      case 3: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   315
-      case 4: REPORT(JSMSG_BAD_QUANTIFIER);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   316
-      case 5: REPORT(JSMSG_BAD_QUANTIFIER);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   317
-      case 6: REPORT(JSMSG_BAD_CLASS_RANGE);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   318
-      case 7: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   319
-      case 8: REPORT(JSMSG_BAD_CLASS_RANGE);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   320
-      case 9: REPORT(JSMSG_BAD_QUANTIFIER);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   321
-      case 10: REPORT(JSMSG_UNMATCHED_RIGHT_PAREN);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   322
-      case 11: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   323
-      case 12: REPORT(JSMSG_UNMATCHED_RIGHT_PAREN);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   324
-      case 13: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   325
-      case 14: REPORT(JSMSG_MISSING_PAREN);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   326
-      case 15: REPORT(JSMSG_BAD_BACKREF);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   327
-      case 16: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   328
-      case 17: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   329
-      default:
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   330
-        JS_NOT_REACHED("Precondition violation: unknown PCRE error code.");
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   331
-    }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   332
-#undef REPORT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   333
-}
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   334
-
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   335
-#endif /* ENABLE_YARR_JIT */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   336
-
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   337
 bool
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   338
 RegExpCode::compile(JSContext *cx, JSLinearString &pattern, uintN *parenCount, RegExpFlag flags)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   339
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   340
-#if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   341
     /* Parse the pattern. */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   342
     ErrorCode yarrError;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   343
     YarrPattern yarrPattern(pattern, bool(flags & IgnoreCaseFlag), bool(flags & MultilineFlag),
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   344
                             &yarrError);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   345
     if (yarrError) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   346
         reportYarrError(cx, NULL, yarrError);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   347
         return false;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   348
     }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   349
     *parenCount = yarrPattern.m_numSubpatterns;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   350
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   351
     /*
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   352
      * The YARR JIT compiler attempts to compile the parsed pattern. If
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   353
      * it cannot, it informs us via |codeBlock.isFallBack()|, in which
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   354
      * case we have to bytecode compile it.
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   355
      */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   356
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   357
-#ifdef JS_METHODJIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   358
+#if ENABLE_YARR_JIT && defined(JS_METHODJIT)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   359
     if (isJITRuntimeEnabled(cx) && !yarrPattern.m_containsBackreferences) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   360
         JSC::ExecutableAllocator *execAlloc = cx->runtime->getExecutableAllocator(cx);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   361
         if (!execAlloc) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   362
             js_ReportOutOfMemory(cx);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   363
             return false;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   364
         }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   365
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   366
         JSGlobalData globalData(execAlloc);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   367
@@ -271,58 +233,41 @@ RegExpCode::compile(JSContext *cx, JSLin
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   368
 #endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   369
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   370
     WTF::BumpPointerAllocator *bumpAlloc = cx->runtime->getBumpPointerAllocator(cx);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   371
     if (!bumpAlloc) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   372
         js_ReportOutOfMemory(cx);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   373
         return false;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   374
     }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   375
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   376
+#if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   377
     codeBlock.setFallBack(true);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   378
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   379
     byteCode = byteCompile(yarrPattern, bumpAlloc).get();
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   380
     return true;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   381
-#else /* !defined(ENABLE_YARR_JIT) */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   382
-    int error = 0;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   383
-    compiled = jsRegExpCompile(pattern.chars(), pattern.length(),
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   384
-                  ignoreCase() ? JSRegExpIgnoreCase : JSRegExpDoNotIgnoreCase,
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   385
-                  multiline() ? JSRegExpMultiline : JSRegExpSingleLine,
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   386
-                  parenCount, &error);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   387
-    if (error) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   388
-        reportPCREError(cx, error);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   389
-        return false;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   390
-    }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   391
-    return true;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   392
-#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   393
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   394
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   395
 RegExpRunStatus
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   396
 RegExpCode::execute(JSContext *cx, const jschar *chars, size_t length, size_t start,
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   397
                     int *output, size_t outputCount)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   398
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   399
     int result;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   400
 #if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   401
     (void) cx; /* Unused. */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   402
     if (codeBlock.isFallBack())
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   403
         result = JSC::Yarr::interpret(byteCode, chars, start, length, output);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   404
     else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   405
         result = JSC::Yarr::execute(codeBlock, chars, start, length, output);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   406
 #else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   407
-    result = jsRegExpExecute(cx, compiled, chars, length, start, output, outputCount);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   408
+    result = JSC::Yarr::interpret(byteCode, chars, start, length, output);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   409
 #endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   410
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   411
     if (result == -1)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   412
         return RegExpRunStatus_Success_NotFound;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   413
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   414
-#if !ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   415
-    if (result < 0) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   416
-        reportPCREError(cx, result);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   417
-        return RegExpRunStatus_Error;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   418
-    }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   419
-#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   420
-
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   421
     JS_ASSERT(result >= 0);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   422
     return RegExpRunStatus_Success;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   423
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   424
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   425
 /* RegExpObject */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   426
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   427
 static void
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   428
 regexp_trace(JSTracer *trc, JSObject *obj)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   429
diff --git a/js/src/vm/RegExpObject.h b/js/src/vm/RegExpObject.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   430
--- a/js/src/vm/RegExpObject.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   431
+++ b/js/src/vm/RegExpObject.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   432
@@ -46,20 +46,18 @@
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   433
 #include <stddef.h>
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   434
 #include "jsobj.h"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   435
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   436
 #include "js/TemplateLib.h"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   437
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   438
 #include "yarr/Yarr.h"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   439
 #if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   440
 #include "yarr/YarrJIT.h"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   441
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   442
 #include "yarr/YarrSyntaxChecker.h"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   443
-#else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   444
-#include "yarr/pcre/pcre.h"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   445
-#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   446
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   447
 /*
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   448
  * JavaScript Regular Expressions
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   449
  *
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   450
  * There are several engine concepts associated with a single logical regexp:
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   451
  *
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   452
  *   RegExpObject - The JS-visible object whose .[[Class]] equals "RegExp"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   453
  *
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   454
@@ -107,78 +105,61 @@ class RegExpObjectBuilder
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   455
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   456
 JSObject *
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   457
 CloneRegExpObject(JSContext *cx, JSObject *obj, JSObject *proto);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   458
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   459
 namespace detail {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   460
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   461
 class RegExpCode
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   462
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   463
-#if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   464
     typedef JSC::Yarr::BytecodePattern BytecodePattern;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   465
     typedef JSC::Yarr::ErrorCode ErrorCode;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   466
+    typedef JSC::Yarr::YarrPattern YarrPattern;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   467
+#if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   468
     typedef JSC::Yarr::JSGlobalData JSGlobalData;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   469
     typedef JSC::Yarr::YarrCodeBlock YarrCodeBlock;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   470
-    typedef JSC::Yarr::YarrPattern YarrPattern;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   471
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   472
     /* Note: Native code is valid only if |codeBlock.isFallBack() == false|. */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   473
     YarrCodeBlock   codeBlock;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   474
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   475
     BytecodePattern *byteCode;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   476
-#else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   477
-    JSRegExp        *compiled;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   478
-#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   479
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   480
   public:
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   481
     RegExpCode()
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   482
       :
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   483
 #if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   484
         codeBlock(),
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   485
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   486
         byteCode(NULL)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   487
-#else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   488
-        compiled(NULL)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   489
-#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   490
     { }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   491
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   492
     ~RegExpCode() {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   493
 #if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   494
         codeBlock.release();
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   495
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   496
         if (byteCode)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   497
             Foreground::delete_<BytecodePattern>(byteCode);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   498
-#else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   499
-        if (compiled)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   500
-            jsRegExpFree(compiled);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   501
-#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   502
     }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   503
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   504
     static bool checkSyntax(JSContext *cx, TokenStream *tokenStream, JSLinearString *source) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   505
-#if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   506
         ErrorCode error = JSC::Yarr::checkSyntax(*source);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   507
         if (error == JSC::Yarr::NoError)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   508
             return true;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   509
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   510
         reportYarrError(cx, tokenStream, error);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   511
         return false;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   512
-#else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   513
-# error "Syntax checking not implemented for !ENABLE_YARR_JIT"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   514
-#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   515
     }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   516
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   517
 #if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   518
     static inline bool isJITRuntimeEnabled(JSContext *cx);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   519
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   520
     static void reportYarrError(JSContext *cx, TokenStream *ts, JSC::Yarr::ErrorCode error);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   521
-#else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   522
-    static void reportPCREError(JSContext *cx, int error);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   523
-#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   524
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   525
     static size_t getOutputSize(size_t pairCount) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   526
-#if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   527
         return pairCount * 2;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   528
-#else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   529
-        return pairCount * 3; /* Should be x2, but PCRE has... needs. */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   530
-#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   531
     }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   532
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   533
     bool compile(JSContext *cx, JSLinearString &pattern, uintN *parenCount, RegExpFlag flags);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   534
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   535
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   536
     RegExpRunStatus
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   537
     execute(JSContext *cx, const jschar *chars, size_t length, size_t start,
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   538
             int *output, size_t outputCount);
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   539
diff --git a/js/src/yarr/wtfbridge.h b/js/src/yarr/wtfbridge.h
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   540
--- a/js/src/yarr/wtfbridge.h
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   541
+++ b/js/src/yarr/wtfbridge.h
386
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   542
@@ -44,19 +44,17 @@
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   543
  * WTF compatibility layer. This file provides various type and data
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   544
  * definitions for use by Yarr.
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   545
  */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   546
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   547
 #include "jsstr.h"
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   548
 #include "jsprvtd.h"
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   549
 #include "vm/String.h"
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   550
 #include "assembler/wtf/Platform.h"
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   551
-#if ENABLE_YARR_JIT
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   552
 #include "assembler/jit/ExecutableAllocator.h"
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   553
-#endif
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   554
 
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   555
 namespace JSC { namespace Yarr {
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   556
 
386
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   557
 /*
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   558
  * Basic type definitions.
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   559
  */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   560
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   561
 typedef jschar UChar;