mozilla-yarr-pcre.patch
author Wolfgang Rosenauer <wr@rosenauer.org>
Mon, 25 Jun 2012 11:08:07 +0200
branchfirefox13
changeset 489 f5ef195f348b
parent 445 b8a9179c123d
permissions -rw-r--r--
13.0.2 with adopted mozilla-prefer_plugin_pref.patch
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
     1
diff --git a/js/src/Makefile.in b/js/src/Makefile.in
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
     2
--- a/js/src/Makefile.in
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
     3
+++ b/js/src/Makefile.in
445
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
     4
@@ -332,30 +332,33 @@ CPPSRCS += 	checks.cc \
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
     5
 		platform.cc \
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
     6
 		utils.cc \
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
     7
 		$(NONE)
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
     8
 
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
     9
 #
386
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    10
 # END enclude sources for V8 dtoa
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    11
 #############################################
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    12
 
445
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    13
-# For architectures without YARR JIT, PCRE is faster than the YARR
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    14
-# interpreter (bug 684559).
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    15
-
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    16
 ifeq (,$(filter arm% sparc %86 x86_64 mips%,$(TARGET_CPU)))
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    17
 
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    18
-VPATH +=        $(srcdir)/yarr/pcre \
445
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    19
+VPATH +=	$(srcdir)/assembler \
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    20
+		$(srcdir)/assembler/wtf \
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    21
+		$(srcdir)/assembler/jit \
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
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
 
445
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    25
-CPPSRCS += \
378
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 \
445
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    31
+CPPSRCS +=	ExecutableAllocator.cpp \
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    32
+		ExecutableAllocatorPosix.cpp \
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    33
+		OSAllocatorOS2.cpp \
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    34
+		OSAllocatorPosix.cpp \
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    35
+		OSAllocatorWin.cpp \
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    36
+		PageBlock.cpp \
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    37
+		YarrInterpreter.cpp \
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    38
+		YarrPattern.cpp \
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    39
+		YarrSyntaxChecker.cpp \
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    40
 		$(NULL)
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    41
 else
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
    42
 
386
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    43
 ###############################################
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    44
 # BEGIN include sources for the Nitro assembler
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    45
 #
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    46
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
    47
 ENABLE_YARR_JIT = 1
445
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    48
diff --git a/js/src/assembler/jit/ExecutableAllocator.h b/js/src/assembler/jit/ExecutableAllocator.h
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    49
--- a/js/src/assembler/jit/ExecutableAllocator.h
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    50
+++ b/js/src/assembler/jit/ExecutableAllocator.h
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    51
@@ -462,18 +462,16 @@ public:
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    52
             : "r" (code), "r" (reinterpret_cast<char*>(code) + size)
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    53
             : "r0", "r1", "r2");
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    54
     }
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    55
 #elif WTF_CPU_SPARC
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    56
     static void cacheFlush(void* code, size_t size)
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    57
     {
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    58
         sync_instruction_memory((caddr_t)code, size);
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    59
     }
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    60
-#else
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    61
-    #error "The cacheFlush support is missing on this platform."
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    62
 #endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    63
 
445
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    64
 private:
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    65
 
445
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    66
 #if ENABLE_ASSEMBLER_WX_EXCLUSIVE
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    67
     static void reprotectRegion(void*, size_t, ProtectionSetting);
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    68
 #endif
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    69
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    70
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
    71
--- a/js/src/vm/RegExpObject-inl.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    72
+++ b/js/src/vm/RegExpObject-inl.h
445
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
    73
@@ -132,16 +132,17 @@ RegExpObject::setMultiline(bool enabled)
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    74
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    75
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    76
 inline void
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    77
 RegExpObject::setSticky(bool enabled)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    78
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    79
     setSlot(STICKY_FLAG_SLOT, BooleanValue(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
+#if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    83
 /* This function should be deleted once bad Android platforms phase out. See bug 604774. */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    84
 inline bool
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    85
 detail::RegExpCode::isJITRuntimeEnabled(JSContext *cx)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    86
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    87
 #if defined(ANDROID) && defined(JS_METHODJIT)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    88
     return cx->methodJitEnabled;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    89
 #else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    90
     return true;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    91
diff --git a/js/src/vm/RegExpObject.cpp b/js/src/vm/RegExpObject.cpp
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    92
--- a/js/src/vm/RegExpObject.cpp
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    93
+++ b/js/src/vm/RegExpObject.cpp
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    94
@@ -162,17 +162,16 @@ MatchPairs::checkAgainst(size_t inputLen
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    95
             continue;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    96
         JS_ASSERT(size_t(p.limit) <= inputLength);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    97
     }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    98
 #endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
    99
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   100
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   101
 /* detail::RegExpCode */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   102
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   103
-#if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   104
 void
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   105
 RegExpCode::reportYarrError(JSContext *cx, TokenStream *ts, ErrorCode error)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   106
 {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   107
     switch (error) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   108
       case JSC::Yarr::NoError:
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   109
         JS_NOT_REACHED("Called reportYarrError with value for no error");
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   110
         return;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   111
 #define COMPILE_EMSG(__code, __msg)                                                              \
445
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
   112
@@ -194,52 +193,16 @@ RegExpCode::reportYarrError(JSContext *c
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   113
       COMPILE_EMSG(QuantifierTooLarge, JSMSG_BAD_QUANTIFIER);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   114
       COMPILE_EMSG(EscapeUnterminated, JSMSG_TRAILING_SLASH);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   115
 #undef COMPILE_EMSG
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   116
       default:
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   117
         JS_NOT_REACHED("Unknown Yarr error code");
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   118
     }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   119
 }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   120
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   121
-#else /* !ENABLE_YARR_JIT */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   122
-
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   123
-void
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   124
-RegExpCode::reportPCREError(JSContext *cx, int error)
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   125
-{
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   126
-#define REPORT(msg_) \
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   127
-    JS_ReportErrorFlagsAndNumberUC(cx, JSREPORT_ERROR, js_GetErrorMessage, NULL, msg_); \
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   128
-    return
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   129
-    switch (error) {
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   130
-      case -2: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   131
-      case 0: JS_NOT_REACHED("Precondition violation: an error must have occurred.");
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   132
-      case 1: REPORT(JSMSG_TRAILING_SLASH);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   133
-      case 2: REPORT(JSMSG_TRAILING_SLASH);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   134
-      case 3: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   135
-      case 4: REPORT(JSMSG_BAD_QUANTIFIER);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   136
-      case 5: REPORT(JSMSG_BAD_QUANTIFIER);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   137
-      case 6: REPORT(JSMSG_BAD_CLASS_RANGE);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   138
-      case 7: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   139
-      case 8: REPORT(JSMSG_BAD_CLASS_RANGE);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   140
-      case 9: REPORT(JSMSG_BAD_QUANTIFIER);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   141
-      case 10: REPORT(JSMSG_UNMATCHED_RIGHT_PAREN);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   142
-      case 11: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   143
-      case 12: REPORT(JSMSG_UNMATCHED_RIGHT_PAREN);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   144
-      case 13: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   145
-      case 14: REPORT(JSMSG_MISSING_PAREN);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   146
-      case 15: REPORT(JSMSG_BAD_BACKREF);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   147
-      case 16: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   148
-      case 17: REPORT(JSMSG_REGEXP_TOO_COMPLEX);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   149
-      default:
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   150
-        JS_NOT_REACHED("Precondition violation: unknown PCRE error code.");
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   151
-    }
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   152
-#undef REPORT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   153
-}
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   154
-
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   155
-#endif /* ENABLE_YARR_JIT */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   156
-
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   157
 bool
445
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
   158
 RegExpCode::compile(JSContext *cx, JSLinearString &pattern, unsigned *parenCount, RegExpFlag flags)
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   159
 {
445
b8a9179c123d - 13.0b3
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 401
diff changeset
   160
 #if ENABLE_YARR_JIT
401
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   161
     /* Parse the pattern. */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   162
     ErrorCode yarrError;
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   163
     YarrPattern yarrPattern(pattern, bool(flags & IgnoreCaseFlag), bool(flags & MultilineFlag),
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   164
                             &yarrError);
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   165
diff --git a/js/src/vm/RegExpObject.h b/js/src/vm/RegExpObject.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   166
--- a/js/src/vm/RegExpObject.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   167
+++ b/js/src/vm/RegExpObject.h
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   168
@@ -46,20 +46,18 @@
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   169
 #include <stddef.h>
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   170
 #include "jsobj.h"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   171
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   172
 #include "js/TemplateLib.h"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   173
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   174
 #include "yarr/Yarr.h"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   175
 #if ENABLE_YARR_JIT
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   176
 #include "yarr/YarrJIT.h"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   177
+#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   178
 #include "yarr/YarrSyntaxChecker.h"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   179
-#else
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   180
-#include "yarr/pcre/pcre.h"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   181
-#endif
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   182
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   183
 /*
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   184
  * JavaScript Regular Expressions
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   185
  *
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   186
  * There are several engine concepts associated with a single logical regexp:
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   187
  *
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   188
  *   RegExpObject - The JS-visible object whose .[[Class]] equals "RegExp"
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 391
diff changeset
   189
  *
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   190
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
   191
--- a/js/src/yarr/wtfbridge.h
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   192
+++ b/js/src/yarr/wtfbridge.h
386
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   193
@@ -44,19 +44,17 @@
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   194
  * WTF compatibility layer. This file provides various type and data
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   195
  * definitions for use by Yarr.
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   196
  */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   197
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   198
 #include "jsstr.h"
378
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   199
 #include "jsprvtd.h"
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   200
 #include "vm/String.h"
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   201
 #include "assembler/wtf/Platform.h"
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   202
-#if ENABLE_YARR_JIT
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   203
 #include "assembler/jit/ExecutableAllocator.h"
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   204
-#endif
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   205
 
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   206
 namespace JSC { namespace Yarr {
dfb824794771 import upstream patches to fix PPC64
Dinar Valeev
parents:
diff changeset
   207
 
386
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   208
 /*
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   209
  * Basic type definitions.
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   210
  */
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   211
 
Wolfgang Rosenauer <wr@rosenauer.org>
parents: 378
diff changeset
   212
 typedef jschar UChar;