mozilla-yarr-pcre.patch
author Wolfgang Rosenauer <wr@rosenauer.org>
Mon, 16 Jul 2012 21:10:33 +0200
branchfirefox14
changeset 495 8ed13b37e5fb
parent 475 b0df28e752fd
permissions -rw-r--r--
import PPC fixes as provided by Dinar Valeev
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
391
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 386
diff changeset
     1
# HG changeset patch
475
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
     2
# Parent 831eeca7b7cfa9ae2458d9efafe168027259965f
391
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 386
diff changeset
     3
# User Landry Breuil <landry@openbsd.org>
475
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
     4
Bug 691898 - Use YARR regexp interpreter instead of PCRE on platforms where YARR JIT is not supported r=dmandelin
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
     5
PCRE doesn't build anyway.
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
475
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    10
@@ -315,30 +315,33 @@ ifeq (mips, $(findstring mips,$(TARGET_C
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    11
 CPPSRCS +=	TrampolineMIPS.cpp
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    12
 endif
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    13
 #
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    14
 # END enclude sources for the method JIT
386
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    15
 #############################################
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    16
 
475
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    17
 endif
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    18
 
475
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    19
-# For architectures without YARR JIT, PCRE is faster than the YARR
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    20
-# interpreter (bug 684559).
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    21
-
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    22
 ifeq (,$(filter arm% sparc %86 x86_64 mips%,$(TARGET_CPU)))
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    23
 
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    24
-VPATH +=        $(srcdir)/yarr/pcre \
475
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    25
+VPATH +=	$(srcdir)/assembler \
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    26
+		$(srcdir)/assembler/wtf \
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    27
+		$(srcdir)/assembler/jit \
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    28
+		$(srcdir)/yarr \
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    29
 		$(NULL)
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    30
 
475
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    31
-CPPSRCS += \
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    32
-                pcre_compile.cpp \
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    33
-                pcre_exec.cpp \
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    34
-                pcre_tables.cpp \
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    35
-                pcre_xclass.cpp \
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    36
-                pcre_ucp_searchfuncs.cpp \
475
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    37
+CPPSRCS +=	ExecutableAllocator.cpp \
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    38
+		ExecutableAllocatorPosix.cpp \
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    39
+		OSAllocatorOS2.cpp \
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    40
+		OSAllocatorPosix.cpp \
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    41
+		OSAllocatorWin.cpp \
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    42
+		PageBlock.cpp \
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    43
+		YarrInterpreter.cpp \
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    44
+		YarrPattern.cpp \
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    45
+		YarrSyntaxChecker.cpp \
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    46
 		$(NULL)
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    47
 else
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    48
 
386
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    49
 ###############################################
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    50
 # BEGIN include sources for the Nitro assembler
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    51
 #
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    52
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    53
 ENABLE_YARR_JIT = 1
475
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    54
diff --git a/js/src/assembler/jit/ExecutableAllocator.h b/js/src/assembler/jit/ExecutableAllocator.h
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    55
--- a/js/src/assembler/jit/ExecutableAllocator.h
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    56
+++ b/js/src/assembler/jit/ExecutableAllocator.h
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    57
@@ -462,18 +462,16 @@ public:
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    58
             : "r" (code), "r" (reinterpret_cast<char*>(code) + size)
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    59
             : "r0", "r1", "r2");
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    60
     }
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    61
 #elif WTF_CPU_SPARC
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    62
     static void cacheFlush(void* code, size_t size)
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    63
     {
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    64
         sync_instruction_memory((caddr_t)code, size);
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    65
     }
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    66
-#else
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    67
-    #error "The cacheFlush support is missing on this platform."
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    68
 #endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    69
 
475
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    70
 private:
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    71
 
475
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    72
 #if ENABLE_ASSEMBLER_WX_EXCLUSIVE
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    73
     static void reprotectRegion(void*, size_t, ProtectionSetting);
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    74
 #endif
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    75
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    76
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
    77
--- a/js/src/vm/RegExpObject-inl.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    78
+++ b/js/src/vm/RegExpObject-inl.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    79
@@ -132,26 +132,28 @@ RegExpObject::setMultiline(bool enabled)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    80
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    81
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    82
 inline void
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    83
 RegExpObject::setSticky(bool enabled)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    84
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    85
     setSlot(STICKY_FLAG_SLOT, BooleanValue(enabled));
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    86
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    87
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    88
+#if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    89
 /* This function should be deleted once bad Android platforms phase out. See bug 604774. */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    90
 inline bool
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    91
 detail::RegExpCode::isJITRuntimeEnabled(JSContext *cx)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    92
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    93
 #if defined(ANDROID) && defined(JS_METHODJIT)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    94
     return cx->methodJitEnabled;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    95
 #else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    96
     return true;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    97
 #endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    98
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    99
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   100
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   101
 inline bool
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   102
 RegExpToShared(JSContext *cx, JSObject &obj, RegExpGuard *g)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   103
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   104
     JS_ASSERT(ObjectClassIs(obj, ESClass_RegExp, cx));
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   105
     if (obj.isRegExp())
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   106
         return obj.asRegExp().getShared(cx, g);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   107
     return Proxy::regexp_toShared(cx, &obj, g);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   108
diff --git a/js/src/vm/RegExpObject.cpp b/js/src/vm/RegExpObject.cpp
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   109
--- a/js/src/vm/RegExpObject.cpp
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   110
+++ b/js/src/vm/RegExpObject.cpp
475
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
   111
@@ -163,17 +163,16 @@ MatchPairs::checkAgainst(size_t inputLen
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   112
             continue;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   113
         JS_ASSERT(size_t(p.limit) <= inputLength);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   114
     }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   115
 #endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   116
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   117
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   118
 /* detail::RegExpCode */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   119
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   120
-#if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   121
 void
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   122
 RegExpCode::reportYarrError(JSContext *cx, TokenStream *ts, ErrorCode error)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   123
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   124
     switch (error) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   125
       case JSC::Yarr::NoError:
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   126
         JS_NOT_REACHED("Called reportYarrError with value for no error");
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   127
         return;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   128
 #define COMPILE_EMSG(__code, __msg)                                                              \
475
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
   129
@@ -195,73 +194,36 @@ RegExpCode::reportYarrError(JSContext *c
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   130
       COMPILE_EMSG(QuantifierTooLarge, JSMSG_BAD_QUANTIFIER);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   131
       COMPILE_EMSG(EscapeUnterminated, JSMSG_TRAILING_SLASH);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   132
 #undef COMPILE_EMSG
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   133
       default:
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   134
         JS_NOT_REACHED("Unknown Yarr error code");
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   135
     }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   136
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   137
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   138
-#else /* !ENABLE_YARR_JIT */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   139
-
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   140
-void
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   141
-RegExpCode::reportPCREError(JSContext *cx, int error)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   142
-{
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   143
-#define REPORT(msg_) \
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   144
-    JS_ReportErrorFlagsAndNumberUC(cx, JSREPORT_ERROR, js_GetErrorMessage, NULL, msg_); \
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   145
-    return
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   146
-    switch (error) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   147
-      case -2: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   148
-      case 0: JS_NOT_REACHED("Precondition violation: an error must have occurred.");
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   149
-      case 1: REPORT(JSMSG_TRAILING_SLASH);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   150
-      case 2: REPORT(JSMSG_TRAILING_SLASH);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   151
-      case 3: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   152
-      case 4: REPORT(JSMSG_BAD_QUANTIFIER);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   153
-      case 5: REPORT(JSMSG_BAD_QUANTIFIER);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   154
-      case 6: REPORT(JSMSG_BAD_CLASS_RANGE);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   155
-      case 7: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   156
-      case 8: REPORT(JSMSG_BAD_CLASS_RANGE);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   157
-      case 9: REPORT(JSMSG_BAD_QUANTIFIER);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   158
-      case 10: REPORT(JSMSG_UNMATCHED_RIGHT_PAREN);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   159
-      case 11: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   160
-      case 12: REPORT(JSMSG_UNMATCHED_RIGHT_PAREN);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   161
-      case 13: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   162
-      case 14: REPORT(JSMSG_MISSING_PAREN);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   163
-      case 15: REPORT(JSMSG_BAD_BACKREF);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   164
-      case 16: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   165
-      case 17: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   166
-      default:
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   167
-        JS_NOT_REACHED("Precondition violation: unknown PCRE error code.");
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   168
-    }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   169
-#undef REPORT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   170
-}
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   171
-
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   172
-#endif /* ENABLE_YARR_JIT */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   173
-
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   174
 bool
475
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
   175
 RegExpCode::compile(JSContext *cx, JSLinearString &pattern, unsigned *parenCount, RegExpFlag flags)
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   176
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   177
-#if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   178
     /* Parse the pattern. */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   179
     ErrorCode yarrError;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   180
     YarrPattern yarrPattern(pattern, bool(flags & IgnoreCaseFlag), bool(flags & MultilineFlag),
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   181
                             &yarrError);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   182
     if (yarrError) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   183
         reportYarrError(cx, NULL, yarrError);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   184
         return false;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   185
     }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   186
     *parenCount = yarrPattern.m_numSubpatterns;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   187
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   188
     /*
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   189
      * The YARR JIT compiler attempts to compile the parsed pattern. If
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   190
      * it cannot, it informs us via |codeBlock.isFallBack()|, in which
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   191
      * case we have to bytecode compile it.
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   192
      */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   193
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   194
-#ifdef JS_METHODJIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   195
+#if ENABLE_YARR_JIT && defined(JS_METHODJIT)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   196
     if (isJITRuntimeEnabled(cx) && !yarrPattern.m_containsBackreferences) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   197
         JSC::ExecutableAllocator *execAlloc = cx->runtime->getExecutableAllocator(cx);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   198
         if (!execAlloc) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   199
             js_ReportOutOfMemory(cx);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   200
             return false;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   201
         }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   202
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   203
         JSGlobalData globalData(execAlloc);
475
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
   204
@@ -272,58 +234,41 @@ RegExpCode::compile(JSContext *cx, JSLin
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   205
 #endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   206
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   207
     WTF::BumpPointerAllocator *bumpAlloc = cx->runtime->getBumpPointerAllocator(cx);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   208
     if (!bumpAlloc) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   209
         js_ReportOutOfMemory(cx);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   210
         return false;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   211
     }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   212
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   213
+#if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   214
     codeBlock.setFallBack(true);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   215
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   216
     byteCode = byteCompile(yarrPattern, bumpAlloc).get();
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   217
     return true;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   218
-#else /* !defined(ENABLE_YARR_JIT) */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   219
-    int error = 0;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   220
-    compiled = jsRegExpCompile(pattern.chars(), pattern.length(),
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   221
-                  ignoreCase() ? JSRegExpIgnoreCase : JSRegExpDoNotIgnoreCase,
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   222
-                  multiline() ? JSRegExpMultiline : JSRegExpSingleLine,
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   223
-                  parenCount, &error);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   224
-    if (error) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   225
-        reportPCREError(cx, error);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   226
-        return false;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   227
-    }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   228
-    return true;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   229
-#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   230
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   231
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   232
 RegExpRunStatus
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   233
 RegExpCode::execute(JSContext *cx, const jschar *chars, size_t length, size_t start,
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   234
                     int *output, size_t outputCount)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   235
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   236
     int result;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   237
 #if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   238
     (void) cx; /* Unused. */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   239
     if (codeBlock.isFallBack())
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   240
         result = JSC::Yarr::interpret(byteCode, chars, start, length, output);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   241
     else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   242
         result = JSC::Yarr::execute(codeBlock, chars, start, length, output);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   243
 #else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   244
-    result = jsRegExpExecute(cx, compiled, chars, length, start, output, outputCount);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   245
+    result = JSC::Yarr::interpret(byteCode, chars, start, length, output);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   246
 #endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   247
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   248
     if (result == -1)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   249
         return RegExpRunStatus_Success_NotFound;
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
-    if (result < 0) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   253
-        reportPCREError(cx, result);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   254
-        return RegExpRunStatus_Error;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   255
-    }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   256
-#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   257
-
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   258
     JS_ASSERT(result >= 0);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   259
     return RegExpRunStatus_Success;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   260
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   261
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   262
 /* RegExpObject */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   263
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   264
 static void
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   265
 regexp_trace(JSTracer *trc, JSObject *obj)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   266
diff --git a/js/src/vm/RegExpObject.h b/js/src/vm/RegExpObject.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   267
--- a/js/src/vm/RegExpObject.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   268
+++ b/js/src/vm/RegExpObject.h
475
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
   269
@@ -47,20 +47,18 @@
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
   270
 #include "jscntxt.h"
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   271
 #include "jsobj.h"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   272
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   273
 #include "js/TemplateLib.h"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   274
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   275
 #include "yarr/Yarr.h"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   276
 #if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   277
 #include "yarr/YarrJIT.h"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   278
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   279
 #include "yarr/YarrSyntaxChecker.h"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   280
-#else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   281
-#include "yarr/pcre/pcre.h"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   282
-#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   283
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   284
 /*
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   285
  * JavaScript Regular Expressions
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   286
  *
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   287
  * There are several engine concepts associated with a single logical regexp:
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   288
  *
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   289
  *   RegExpObject - The JS-visible object whose .[[Class]] equals "RegExp"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   290
  *
475
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
   291
@@ -108,78 +106,61 @@ class RegExpObjectBuilder
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   292
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   293
 JSObject *
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   294
 CloneRegExpObject(JSContext *cx, JSObject *obj, JSObject *proto);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   295
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   296
 namespace detail {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   297
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   298
 class RegExpCode
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   299
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   300
-#if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   301
     typedef JSC::Yarr::BytecodePattern BytecodePattern;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   302
     typedef JSC::Yarr::ErrorCode ErrorCode;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   303
+    typedef JSC::Yarr::YarrPattern YarrPattern;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   304
+#if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   305
     typedef JSC::Yarr::JSGlobalData JSGlobalData;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   306
     typedef JSC::Yarr::YarrCodeBlock YarrCodeBlock;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   307
-    typedef JSC::Yarr::YarrPattern YarrPattern;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   308
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   309
     /* Note: Native code is valid only if |codeBlock.isFallBack() == false|. */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   310
     YarrCodeBlock   codeBlock;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   311
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   312
     BytecodePattern *byteCode;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   313
-#else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   314
-    JSRegExp        *compiled;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   315
-#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   316
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   317
   public:
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   318
     RegExpCode()
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   319
       :
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   320
 #if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   321
         codeBlock(),
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   322
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   323
         byteCode(NULL)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   324
-#else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   325
-        compiled(NULL)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   326
-#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   327
     { }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   328
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   329
     ~RegExpCode() {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   330
 #if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   331
         codeBlock.release();
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   332
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   333
         if (byteCode)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   334
             Foreground::delete_<BytecodePattern>(byteCode);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   335
-#else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   336
-        if (compiled)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   337
-            jsRegExpFree(compiled);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   338
-#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   339
     }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   340
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   341
     static bool checkSyntax(JSContext *cx, TokenStream *tokenStream, JSLinearString *source) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   342
-#if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   343
         ErrorCode error = JSC::Yarr::checkSyntax(*source);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   344
         if (error == JSC::Yarr::NoError)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   345
             return true;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   346
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   347
         reportYarrError(cx, tokenStream, error);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   348
         return false;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   349
-#else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   350
-# error "Syntax checking not implemented for !ENABLE_YARR_JIT"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   351
-#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   352
     }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   353
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   354
 #if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   355
     static inline bool isJITRuntimeEnabled(JSContext *cx);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   356
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   357
     static void reportYarrError(JSContext *cx, TokenStream *ts, JSC::Yarr::ErrorCode error);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   358
-#else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   359
-    static void reportPCREError(JSContext *cx, int error);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   360
-#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   361
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   362
     static size_t getOutputSize(size_t pairCount) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   363
-#if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   364
         return pairCount * 2;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   365
-#else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   366
-        return pairCount * 3; /* Should be x2, but PCRE has... needs. */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   367
-#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   368
     }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   369
 
475
b0df28e752fd reenabled mozilla-yarr-pcre.patch
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
   370
     bool compile(JSContext *cx, JSLinearString &pattern, unsigned *parenCount, RegExpFlag flags);
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   371
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   372
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   373
     RegExpRunStatus
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   374
     execute(JSContext *cx, const jschar *chars, size_t length, size_t start,
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   375
             int *output, size_t outputCount);
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   376
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
   377
--- a/js/src/yarr/wtfbridge.h
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   378
+++ b/js/src/yarr/wtfbridge.h
386
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   379
@@ -44,19 +44,17 @@
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   380
  * WTF compatibility layer. This file provides various type and data
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   381
  * definitions for use by Yarr.
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   382
  */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   383
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   384
 #include "jsstr.h"
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   385
 #include "jsprvtd.h"
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   386
 #include "vm/String.h"
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   387
 #include "assembler/wtf/Platform.h"
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   388
-#if ENABLE_YARR_JIT
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   389
 #include "assembler/jit/ExecutableAllocator.h"
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   390
-#endif
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   391
 
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   392
 namespace JSC { namespace Yarr {
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   393
 
386
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   394
 /*
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   395
  * Basic type definitions.
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   396
  */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   397
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   398
 typedef jschar UChar;