| compiler.h | | compiler.h | |
|
| /* | | // Copyright 2012 the V8 project authors. All rights reserved. | |
| * Copyright 2012 10gen Inc. | | // Redistribution and use in source and binary forms, with or without | |
| * | | // modification, are permitted provided that the following conditions are | |
| * Licensed under the Apache License, Version 2.0 (the "License"); | | // met: | |
| * you may not use this file except in compliance with the License. | | // | |
| * You may obtain a copy of the License at | | // * Redistributions of source code must retain the above copyright | |
| * | | // notice, this list of conditions and the following disclaimer. | |
| * http://www.apache.org/licenses/LICENSE-2.0 | | // * Redistributions in binary form must reproduce the above | |
| * | | // copyright notice, this list of conditions and the following | |
| * Unless required by applicable law or agreed to in writing, software | | // disclaimer in the documentation and/or other materials provided | |
| * distributed under the License is distributed on an "AS IS" BASIS, | | // with the distribution. | |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | | // * Neither the name of Google Inc. nor the names of its | |
| * See the License for the specific language governing permissions and | | // contributors may be used to endorse or promote products derived | |
| * limitations under the License. | | // from this software without specific prior written permission. | |
| */ | | // | |
| | | // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | |
| #pragma once | | // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | |
| | | // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | |
| /** | | // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | |
| * Include "mongo/platform/compiler.h" to get compiler-targeted macro defin | | // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | |
| itions and utilities. | | // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | |
| * | | // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | |
| * The following macros are provided in all compiler environments: | | // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | |
| * | | // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | |
| * | | // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | |
| * MONGO_COMPILER_NORETURN | | // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |
| * | | | |
| * Instructs the compiler that the decorated function will not return thr | | #ifndef V8_COMPILER_H_ | |
| ough the normal return | | #define V8_COMPILER_H_ | |
| * path. | | | |
| * | | #include "allocation.h" | |
| * Correct: MONGO_COMPILER_NORETURN void myAbortFunction(); | | #include "ast.h" | |
| * | | #include "zone.h" | |
| * | | | |
| * MONGO_COMPILER_VARIABLE_UNUSED | | namespace v8 { | |
| * | | namespace internal { | |
| * Instructs the compiler not to warn if it detects no use of the decorat | | | |
| ed variable. | | class ScriptDataImpl; | |
| * Typically only useful for variables that are always declared but only | | | |
| used in | | // CompilationInfo encapsulates some information known at compile time. It | |
| * conditionally-compiled code. | | // is constructed based on the resources available at compile-time. | |
| * | | class CompilationInfo { | |
| * Correct: MONGO_COMPILER_VARIABLE_UNUSED int ignored; | | public: | |
| * | | CompilationInfo(Handle<Script> script, Zone* zone); | |
| * | | CompilationInfo(Handle<SharedFunctionInfo> shared_info, Zone* zone); | |
| * MONGO_COMPILER_ALIGN_TYPE(ALIGNMENT) | | CompilationInfo(Handle<JSFunction> closure, Zone* zone); | |
| * | | | |
| * Instructs the compiler to use the given minimum alignment for the deco | | virtual ~CompilationInfo(); | |
| rated type. | | | |
| * | | Isolate* isolate() { | |
| * Alignments should probably always be powers of two. Also, note that m | | ASSERT(Isolate::Current() == isolate_); | |
| ost allocators will not | | return isolate_; | |
| * be able to guarantee better than 16- or 32-byte alignment. | | } | |
| * | | Zone* zone() { | |
| * Correct: | | return zone_; | |
| * class MONGO_COMPILER_ALIGN_TYPE(16) MyClass {...}; | | } | |
| * | | bool is_lazy() const { return IsLazy::decode(flags_); } | |
| * Incorrect: | | bool is_eval() const { return IsEval::decode(flags_); } | |
| * MONGO_COMPILER_ALIGN_TYPE(16) class MyClass {...}; | | bool is_global() const { return IsGlobal::decode(flags_); } | |
| * class MyClass{...} MONGO_COMPILER_ALIGN_TYPE(16); | | bool is_classic_mode() const { return language_mode() == CLASSIC_MODE; } | |
| * | | bool is_extended_mode() const { return language_mode() == EXTENDED_MODE; | |
| * | | } | |
| * MONGO_COMPILER_ALIGN_VARIABLE(ALIGNMENT) | | LanguageMode language_mode() const { | |
| * | | return LanguageModeField::decode(flags_); | |
| * Instructs the compiler to use the given minimum alignment for the deco | | } | |
| rated variable. | | bool is_in_loop() const { return IsInLoop::decode(flags_); } | |
| * | | FunctionLiteral* function() const { return function_; } | |
| * Note that most allocators will not allow heap allocated alignments tha | | Scope* scope() const { return scope_; } | |
| t are better than 16- or | | Scope* global_scope() const { return global_scope_; } | |
| * 32-byte aligned. Stack allocators may only guarantee up to the natura | | Handle<Code> code() const { return code_; } | |
| l word length worth of | | Handle<JSFunction> closure() const { return closure_; } | |
| * alignment. | | Handle<SharedFunctionInfo> shared_info() const { return shared_info_; } | |
| * | | Handle<Script> script() const { return script_; } | |
| * Correct: | | v8::Extension* extension() const { return extension_; } | |
| * class MyClass { | | ScriptDataImpl* pre_parse_data() const { return pre_parse_data_; } | |
| * MONGO_COMPILER_ALIGN_VARIABLE(8) char a; | | Handle<Context> calling_context() const { return calling_context_; } | |
| * }; | | int osr_ast_id() const { return osr_ast_id_; } | |
| * | | | |
| * MONGO_COMPILER_ALIGN_VARIABLE(8) class MyClass {...} singletonInstan | | void MarkAsEval() { | |
| ce; | | ASSERT(!is_lazy()); | |
| * | | flags_ |= IsEval::encode(true); | |
| * Incorrect: | | } | |
| * int MONGO_COMPILER_ALIGN_VARIABLE(16) a, b; | | void MarkAsGlobal() { | |
| * | | ASSERT(!is_lazy()); | |
| * | | flags_ |= IsGlobal::encode(true); | |
| * MONGO_COMPILER_API_EXPORT | | } | |
| * | | void SetLanguageMode(LanguageMode language_mode) { | |
| * Instructs the compiler to label the given type, variable or function a | | ASSERT(this->language_mode() == CLASSIC_MODE || | |
| s part of the | | this->language_mode() == language_mode || | |
| * exported interface of the library object under construction. | | language_mode == EXTENDED_MODE); | |
| * | | flags_ = LanguageModeField::update(flags_, language_mode); | |
| * Correct: | | } | |
| * MONGO_COMPILER_API_EXPORT int globalSwitch; | | void MarkAsInLoop() { | |
| * class MONGO_COMPILER_API_EXPORT ExportedType { ... }; | | ASSERT(is_lazy()); | |
| * MONGO_COMPILER_API_EXPORT SomeType exportedFunction(...); | | flags_ |= IsInLoop::encode(true); | |
| * | | } | |
| * NOTE: Rather than using this macro directly, one typically declares an | | void MarkAsNative() { | |
| other macro named for the | | flags_ |= IsNative::encode(true); | |
| * library, which is conditionally defined to either MONGO_COMIPLER_API_E | | } | |
| XPORT or | | bool is_native() const { | |
| * MONGO_COMPILER_API_IMPORT based on whether the compiler is currently b | | return IsNative::decode(flags_); | |
| uilding the library or | | } | |
| * building an object that depends on the library, respectively. For exa | | void SetFunction(FunctionLiteral* literal) { | |
| mple, MONGO_CLIENT_API | | ASSERT(function_ == NULL); | |
| * might be defined to MONGO_COMPILER_API_EXPORT when building the MongoD | | function_ = literal; | |
| B shared library, and to | | } | |
| * MONGO_COMPILER_API_IMPORT when building an application that links agai | | void SetScope(Scope* scope) { | |
| nst the shared library. | | ASSERT(scope_ == NULL); | |
| * | | scope_ = scope; | |
| * | | } | |
| * MONGO_COMPILER_API_IMPORT | | void SetGlobalScope(Scope* global_scope) { | |
| * | | ASSERT(global_scope_ == NULL); | |
| * Instructs the compiler to label the given type, variable or function a | | global_scope_ = global_scope; | |
| s imported | | } | |
| * from another library, and not part of the library object under constru | | void SetCode(Handle<Code> code) { code_ = code; } | |
| ction. | | void SetExtension(v8::Extension* extension) { | |
| * | | ASSERT(!is_lazy()); | |
| * Same correct/incorrect usage as for MONGO_COMPILER_API_EXPORT. | | extension_ = extension; | |
| * | | } | |
| * | | void SetPreParseData(ScriptDataImpl* pre_parse_data) { | |
| * MONGO_COMPILER_API_CALLING_CONVENTION | | ASSERT(!is_lazy()); | |
| * | | pre_parse_data_ = pre_parse_data; | |
| * Explicitly decorates a function declaration the api calling conventio | | } | |
| n used for | | void SetCallingContext(Handle<Context> context) { | |
| * shared libraries. | | ASSERT(is_eval()); | |
| * | | calling_context_ = context; | |
| * Same correct/incorrect usage as for MONGO_COMPILER_API_EXPORT. | | } | |
| */ | | void SetOsrAstId(int osr_ast_id) { | |
| | | ASSERT(IsOptimizing()); | |
| #if defined(_MSC_VER) | | osr_ast_id_ = osr_ast_id; | |
| #include "mongo/platform/compiler_msvc.h" | | } | |
| #elif defined(__GNUC__) | | void MarkCompilingForDebugging(Handle<Code> current_code) { | |
| #include "mongo/platform/compiler_gcc.h" | | ASSERT(mode_ != OPTIMIZE); | |
| #else | | ASSERT(current_code->kind() == Code::FUNCTION); | |
| #error "Unsupported compiler family" | | flags_ |= IsCompilingForDebugging::encode(true); | |
| | | if (current_code->is_compiled_optimizable()) { | |
| | | EnableDeoptimizationSupport(); | |
| | | } else { | |
| | | mode_ = CompilationInfo::NONOPT; | |
| | | } | |
| | | } | |
| | | bool IsCompilingForDebugging() { | |
| | | return IsCompilingForDebugging::decode(flags_); | |
| | | } | |
| | | | |
| | | bool has_global_object() const { | |
| | | return !closure().is_null() && (closure()->context()->global() != NULL) | |
| | | ; | |
| | | } | |
| | | | |
| | | GlobalObject* global_object() const { | |
| | | return has_global_object() ? closure()->context()->global() : NULL; | |
| | | } | |
| | | | |
| | | // Accessors for the different compilation modes. | |
| | | bool IsOptimizing() const { return mode_ == OPTIMIZE; } | |
| | | bool IsOptimizable() const { return mode_ == BASE; } | |
| | | void SetOptimizing(int osr_ast_id) { | |
| | | SetMode(OPTIMIZE); | |
| | | osr_ast_id_ = osr_ast_id; | |
| | | } | |
| | | void DisableOptimization(); | |
| | | | |
| | | // Deoptimization support. | |
| | | bool HasDeoptimizationSupport() const { | |
| | | return SupportsDeoptimization::decode(flags_); | |
| | | } | |
| | | void EnableDeoptimizationSupport() { | |
| | | ASSERT(IsOptimizable()); | |
| | | flags_ |= SupportsDeoptimization::encode(true); | |
| | | } | |
| | | | |
| | | // Determines whether or not to insert a self-optimization header. | |
| | | bool ShouldSelfOptimize(); | |
| | | | |
| | | // Disable all optimization attempts of this info for the rest of the | |
| | | // current compilation pipeline. | |
| | | void AbortOptimization(); | |
| | | | |
| | | void set_deferred_handles(DeferredHandles* deferred_handles) { | |
| | | ASSERT(deferred_handles_ == NULL); | |
| | | deferred_handles_ = deferred_handles; | |
| | | } | |
| | | | |
| | | void SaveHandles() { | |
| | | SaveHandle(&closure_); | |
| | | SaveHandle(&shared_info_); | |
| | | SaveHandle(&calling_context_); | |
| | | SaveHandle(&script_); | |
| | | } | |
| | | | |
| | | private: | |
| | | Isolate* isolate_; | |
| | | | |
| | | // Compilation mode. | |
| | | // BASE is generated by the full codegen, optionally prepared for bailout | |
| | | s. | |
| | | // OPTIMIZE is optimized code generated by the Hydrogen-based backend. | |
| | | // NONOPT is generated by the full codegen and is not prepared for | |
| | | // recompilation/bailouts. These functions are never recompiled. | |
| | | enum Mode { | |
| | | BASE, | |
| | | OPTIMIZE, | |
| | | NONOPT | |
| | | }; | |
| | | | |
| | | void Initialize(Mode mode) { | |
| | | mode_ = V8::UseCrankshaft() ? mode : NONOPT; | |
| | | ASSERT(!script_.is_null()); | |
| | | if (script_->type()->value() == Script::TYPE_NATIVE) { | |
| | | MarkAsNative(); | |
| | | } | |
| | | if (!shared_info_.is_null()) { | |
| | | ASSERT(language_mode() == CLASSIC_MODE); | |
| | | SetLanguageMode(shared_info_->language_mode()); | |
| | | } | |
| | | } | |
| | | | |
| | | void SetMode(Mode mode) { | |
| | | ASSERT(V8::UseCrankshaft()); | |
| | | mode_ = mode; | |
| | | } | |
| | | | |
| | | // Flags using template class BitField<type, start, length>. All are | |
| | | // false by default. | |
| | | // | |
| | | // Compilation is either eager or lazy. | |
| | | class IsLazy: public BitField<bool, 0, 1> {}; | |
| | | // Flags that can be set for eager compilation. | |
| | | class IsEval: public BitField<bool, 1, 1> {}; | |
| | | class IsGlobal: public BitField<bool, 2, 1> {}; | |
| | | // Flags that can be set for lazy compilation. | |
| | | class IsInLoop: public BitField<bool, 3, 1> {}; | |
| | | // Strict mode - used in eager compilation. | |
| | | class LanguageModeField: public BitField<LanguageMode, 4, 2> {}; | |
| | | // Is this a function from our natives. | |
| | | class IsNative: public BitField<bool, 6, 1> {}; | |
| | | // Is this code being compiled with support for deoptimization.. | |
| | | class SupportsDeoptimization: public BitField<bool, 7, 1> {}; | |
| | | // If compiling for debugging produce just full code matching the | |
| | | // initial mode setting. | |
| | | class IsCompilingForDebugging: public BitField<bool, 8, 1> {}; | |
| | | | |
| | | unsigned flags_; | |
| | | | |
| | | // Fields filled in by the compilation pipeline. | |
| | | // AST filled in by the parser. | |
| | | FunctionLiteral* function_; | |
| | | // The scope of the function literal as a convenience. Set to indicate | |
| | | // that scopes have been analyzed. | |
| | | Scope* scope_; | |
| | | // The global scope provided as a convenience. | |
| | | Scope* global_scope_; | |
| | | // The compiled code. | |
| | | Handle<Code> code_; | |
| | | | |
| | | // Possible initial inputs to the compilation process. | |
| | | Handle<JSFunction> closure_; | |
| | | Handle<SharedFunctionInfo> shared_info_; | |
| | | Handle<Script> script_; | |
| | | | |
| | | // Fields possibly needed for eager compilation, NULL by default. | |
| | | v8::Extension* extension_; | |
| | | ScriptDataImpl* pre_parse_data_; | |
| | | | |
| | | // The context of the caller is needed for eval code, and will be a null | |
| | | // handle otherwise. | |
| | | Handle<Context> calling_context_; | |
| | | | |
| | | // Compilation mode flag and whether deoptimization is allowed. | |
| | | Mode mode_; | |
| | | int osr_ast_id_; | |
| | | | |
| | | // The zone from which the compilation pipeline working on this | |
| | | // CompilationInfo allocates. | |
| | | Zone* zone_; | |
| | | | |
| | | DeferredHandles* deferred_handles_; | |
| | | | |
| | | template<typename T> | |
| | | void SaveHandle(Handle<T> *object) { | |
| | | if (!object->is_null()) { | |
| | | Handle<T> handle(*(*object)); | |
| | | *object = handle; | |
| | | } | |
| | | } | |
| | | | |
| | | DISALLOW_COPY_AND_ASSIGN(CompilationInfo); | |
| | | }; | |
| | | | |
| | | // Exactly like a CompilationInfo, except also creates and enters a | |
| | | // Zone on construction and deallocates it on exit. | |
| | | class CompilationInfoWithZone: public CompilationInfo { | |
| | | public: | |
| | | explicit CompilationInfoWithZone(Handle<Script> script) | |
| | | : CompilationInfo(script, &zone_), | |
| | | zone_(script->GetIsolate()), | |
| | | zone_scope_(&zone_, DELETE_ON_EXIT) {} | |
| | | explicit CompilationInfoWithZone(Handle<SharedFunctionInfo> shared_info) | |
| | | : CompilationInfo(shared_info, &zone_), | |
| | | zone_(shared_info->GetIsolate()), | |
| | | zone_scope_(&zone_, DELETE_ON_EXIT) {} | |
| | | explicit CompilationInfoWithZone(Handle<JSFunction> closure) | |
| | | : CompilationInfo(closure, &zone_), | |
| | | zone_(closure->GetIsolate()), | |
| | | zone_scope_(&zone_, DELETE_ON_EXIT) {} | |
| | | | |
| | | private: | |
| | | Zone zone_; | |
| | | ZoneScope zone_scope_; | |
| | | }; | |
| | | | |
| | | // A wrapper around a CompilationInfo that detaches the Handles from | |
| | | // the underlying DeferredHandleScope and stores them in info_ on | |
| | | // destruction. | |
| | | class CompilationHandleScope BASE_EMBEDDED { | |
| | | public: | |
| | | explicit CompilationHandleScope(CompilationInfo* info) | |
| | | : deferred_(info->isolate()), info_(info) {} | |
| | | ~CompilationHandleScope() { | |
| | | info_->set_deferred_handles(deferred_.Detach()); | |
| | | } | |
| | | | |
| | | private: | |
| | | DeferredHandleScope deferred_; | |
| | | CompilationInfo* info_; | |
| | | }; | |
| | | | |
| | | class HGraph; | |
| | | class HGraphBuilder; | |
| | | class LChunk; | |
| | | | |
| | | // A helper class that calls the three compilation phases in | |
| | | // Crankshaft and keeps track of its state. The three phases | |
| | | // CreateGraph, OptimizeGraph and GenerateAndInstallCode can either | |
| | | // fail, bail-out to the full code generator or succeed. Apart from | |
| | | // their return value, the status of the phase last run can be checked | |
| | | // using last_status(). | |
| | | class OptimizingCompiler: public ZoneObject { | |
| | | public: | |
| | | explicit OptimizingCompiler(CompilationInfo* info) | |
| | | : info_(info), | |
| | | oracle_(NULL), | |
| | | graph_builder_(NULL), | |
| | | graph_(NULL), | |
| | | chunk_(NULL), | |
| | | time_taken_to_create_graph_(0), | |
| | | time_taken_to_optimize_(0), | |
| | | time_taken_to_codegen_(0), | |
| | | last_status_(FAILED) { } | |
| | | | |
| | | enum Status { | |
| | | FAILED, BAILED_OUT, SUCCEEDED | |
| | | }; | |
| | | | |
| | | MUST_USE_RESULT Status CreateGraph(); | |
| | | MUST_USE_RESULT Status OptimizeGraph(); | |
| | | MUST_USE_RESULT Status GenerateAndInstallCode(); | |
| | | | |
| | | Status last_status() const { return last_status_; } | |
| | | CompilationInfo* info() const { return info_; } | |
| | | | |
| | | MUST_USE_RESULT Status AbortOptimization() { | |
| | | info_->AbortOptimization(); | |
| | | info_->shared_info()->DisableOptimization(); | |
| | | return SetLastStatus(BAILED_OUT); | |
| | | } | |
| | | | |
| | | private: | |
| | | CompilationInfo* info_; | |
| | | TypeFeedbackOracle* oracle_; | |
| | | HGraphBuilder* graph_builder_; | |
| | | HGraph* graph_; | |
| | | LChunk* chunk_; | |
| | | int64_t time_taken_to_create_graph_; | |
| | | int64_t time_taken_to_optimize_; | |
| | | int64_t time_taken_to_codegen_; | |
| | | Status last_status_; | |
| | | | |
| | | MUST_USE_RESULT Status SetLastStatus(Status status) { | |
| | | last_status_ = status; | |
| | | return last_status_; | |
| | | } | |
| | | void RecordOptimizationStats(); | |
| | | | |
| | | struct Timer { | |
| | | Timer(OptimizingCompiler* compiler, int64_t* location) | |
| | | : compiler_(compiler), | |
| | | start_(OS::Ticks()), | |
| | | location_(location) { } | |
| | | | |
| | | ~Timer() { | |
| | | *location_ += (OS::Ticks() - start_); | |
| | | } | |
| | | | |
| | | OptimizingCompiler* compiler_; | |
| | | int64_t start_; | |
| | | int64_t* location_; | |
| | | }; | |
| | | }; | |
| | | | |
| | | // The V8 compiler | |
| | | // | |
| | | // General strategy: Source code is translated into an anonymous function w | |
| | | /o | |
| | | // parameters which then can be executed. If the source code contains other | |
| | | // functions, they will be compiled and allocated as part of the compilatio | |
| | | n | |
| | | // of the source code. | |
| | | | |
| | | // Please note this interface returns shared function infos. This means yo | |
| | | u | |
| | | // need to call Factory::NewFunctionFromSharedFunctionInfo before you have | |
| | | a | |
| | | // real function with a context. | |
| | | | |
| | | class Compiler : public AllStatic { | |
| | | public: | |
| | | // Default maximum number of function optimization attempts before we | |
| | | // give up. | |
| | | static const int kDefaultMaxOptCount = 10; | |
| | | | |
| | | static const int kMaxInliningLevels = 3; | |
| | | | |
| | | // Call count before primitive functions trigger their own optimization. | |
| | | static const int kCallsUntilPrimitiveOpt = 200; | |
| | | | |
| | | // All routines return a SharedFunctionInfo. | |
| | | // If an error occurs an exception is raised and the return handle | |
| | | // contains NULL. | |
| | | | |
| | | // Compile a String source within a context. | |
| | | static Handle<SharedFunctionInfo> Compile(Handle<String> source, | |
| | | Handle<Object> script_name, | |
| | | int line_offset, | |
| | | int column_offset, | |
| | | v8::Extension* extension, | |
| | | ScriptDataImpl* pre_data, | |
| | | Handle<Object> script_data, | |
| | | NativesFlag is_natives_code); | |
| | | | |
| | | // Compile a String source within a context for Eval. | |
| | | static Handle<SharedFunctionInfo> CompileEval(Handle<String> source, | |
| | | Handle<Context> context, | |
| | | bool is_global, | |
| | | LanguageMode language_mode, | |
| | | int scope_position); | |
| | | | |
| | | // Compile from function info (used for lazy compilation). Returns true o | |
| | | n | |
| | | // success and false if the compilation resulted in a stack overflow. | |
| | | static bool CompileLazy(CompilationInfo* info); | |
| | | | |
| | | static void RecompileParallel(Handle<JSFunction> function); | |
| | | | |
| | | // Compile a shared function info object (the function is possibly lazily | |
| | | // compiled). | |
| | | static Handle<SharedFunctionInfo> BuildFunctionInfo(FunctionLiteral* node | |
| | | , | |
| | | Handle<Script> script | |
| | | ); | |
| | | | |
| | | // Set the function info for a newly compiled function. | |
| | | static void SetFunctionInfo(Handle<SharedFunctionInfo> function_info, | |
| | | FunctionLiteral* lit, | |
| | | bool is_toplevel, | |
| | | Handle<Script> script); | |
| | | | |
| | | static void InstallOptimizedCode(OptimizingCompiler* info); | |
| | | | |
| | | #ifdef ENABLE_DEBUGGER_SUPPORT | |
| | | static bool MakeCodeForLiveEdit(CompilationInfo* info); | |
| #endif | | #endif | |
|
| | | | |
| | | static void RecordFunctionCompilation(Logger::LogEventsAndTags tag, | |
| | | CompilationInfo* info, | |
| | | Handle<SharedFunctionInfo> shared); | |
| | | }; | |
| | | | |
| | | } } // namespace v8::internal | |
| | | | |
| | | #endif // V8_COMPILER_H_ | |
| | | | |
End of changes. 2 change blocks. |
| 135 lines changed or deleted | | 472 lines changed or added | |
|
| pcre.h | | pcre.h | |
| /************************************************* | | /************************************************* | |
| * Perl-Compatible Regular Expressions * | | * Perl-Compatible Regular Expressions * | |
| *************************************************/ | | *************************************************/ | |
| | | | |
| /* This is the public header file for the PCRE library, to be #included by | | /* This is the public header file for the PCRE library, to be #included by | |
| applications that call the PCRE functions. | | applications that call the PCRE functions. | |
| | | | |
|
| Copyright (c) 1997-2012 University of Cambridge | | Copyright (c) 1997-2014 University of Cambridge | |
| | | | |
| ---------------------------------------------------------------------------
-- | | ---------------------------------------------------------------------------
-- | |
| Redistribution and use in source and binary forms, with or without | | Redistribution and use in source and binary forms, with or without | |
| modification, are permitted provided that the following conditions are met: | | modification, are permitted provided that the following conditions are met: | |
| | | | |
| * Redistributions of source code must retain the above copyright notice
, | | * Redistributions of source code must retain the above copyright notice
, | |
| this list of conditions and the following disclaimer. | | this list of conditions and the following disclaimer. | |
| | | | |
| * Redistributions in binary form must reproduce the above copyright | | * Redistributions in binary form must reproduce the above copyright | |
| notice, this list of conditions and the following disclaimer in the | | notice, this list of conditions and the following disclaimer in the | |
| | | | |
| skipping to change at line 45 | | skipping to change at line 45 | |
| POSSIBILITY OF SUCH DAMAGE. | | POSSIBILITY OF SUCH DAMAGE. | |
| ---------------------------------------------------------------------------
-- | | ---------------------------------------------------------------------------
-- | |
| */ | | */ | |
| | | | |
| #ifndef _PCRE_H | | #ifndef _PCRE_H | |
| #define _PCRE_H | | #define _PCRE_H | |
| | | | |
| /* The current PCRE version information. */ | | /* The current PCRE version information. */ | |
| | | | |
| #define PCRE_MAJOR 8 | | #define PCRE_MAJOR 8 | |
|
| #define PCRE_MINOR 30 | | #define PCRE_MINOR 36 | |
| #define PCRE_PRERELEASE | | #define PCRE_PRERELEASE | |
|
| #define PCRE_DATE 2012-02-04 | | #define PCRE_DATE 2014-09-26 | |
| | | | |
| /* When an application links to a PCRE DLL in Windows, the symbols that are | | /* When an application links to a PCRE DLL in Windows, the symbols that are | |
| imported have to be identified as such. When building PCRE, the appropriate | | imported have to be identified as such. When building PCRE, the appropriate | |
| export setting is defined in pcre_internal.h, which includes this file. So
we | | export setting is defined in pcre_internal.h, which includes this file. So
we | |
| don't change existing definitions of PCRE_EXP_DECL and PCRECPP_EXP_DECL. */ | | don't change existing definitions of PCRE_EXP_DECL and PCRECPP_EXP_DECL. */ | |
| | | | |
| #if defined(_WIN32) && !defined(PCRE_STATIC) | | #if defined(_WIN32) && !defined(PCRE_STATIC) | |
| # ifndef PCRE_EXP_DECL | | # ifndef PCRE_EXP_DECL | |
|
| # define PCRE_EXP_DECL extern | | # define PCRE_EXP_DECL extern __declspec(dllimport) | |
| # endif | | # endif | |
| # ifdef __cplusplus | | # ifdef __cplusplus | |
| # ifndef PCRECPP_EXP_DECL | | # ifndef PCRECPP_EXP_DECL | |
|
| # define PCRECPP_EXP_DECL extern | | # define PCRECPP_EXP_DECL extern __declspec(dllimport) | |
| # endif | | # endif | |
| # ifndef PCRECPP_EXP_DEFN | | # ifndef PCRECPP_EXP_DEFN | |
|
| # define PCRECPP_EXP_DEFN | | # define PCRECPP_EXP_DEFN __declspec(dllimport) | |
| # endif | | # endif | |
| # endif | | # endif | |
| #endif | | #endif | |
| | | | |
| /* By default, we use the standard "extern" declarations. */ | | /* By default, we use the standard "extern" declarations. */ | |
| | | | |
| #ifndef PCRE_EXP_DECL | | #ifndef PCRE_EXP_DECL | |
| # ifdef __cplusplus | | # ifdef __cplusplus | |
| # define PCRE_EXP_DECL extern "C" | | # define PCRE_EXP_DECL extern "C" | |
| # else | | # else | |
| | | | |
| skipping to change at line 98 | | skipping to change at line 98 | |
| it is needed here for malloc. */ | | it is needed here for malloc. */ | |
| | | | |
| #include <stdlib.h> | | #include <stdlib.h> | |
| | | | |
| /* Allow for C++ users */ | | /* Allow for C++ users */ | |
| | | | |
| #ifdef __cplusplus | | #ifdef __cplusplus | |
| extern "C" { | | extern "C" { | |
| #endif | | #endif | |
| | | | |
|
| /* Options. Some are compile-time only, some are run-time only, and some ar | | /* Public options. Some are compile-time only, some are run-time only, and | |
| e | | some | |
| both, so we keep them all distinct. However, almost all the bits in the opt | | are both. Most of the compile-time options are saved with the compiled rege | |
| ions | | x so | |
| word are now used. In the long run, we may have to re-use some of the | | that they can be inspected during studying (and therefore JIT compiling). N | |
| compile-time only bits for runtime options, or vice versa. In the comments | | ote | |
| below, "compile", "exec", and "DFA exec" mean that the option is permitted | | that pcre_study() has its own set of options. Originally, all the options | |
| to | | defined here used distinct bits. However, almost all the bits in a 32-bit w | |
| be set for those functions; "used in" means that an option may be set only | | ord | |
| for | | are now used, so in order to conserve them, option bits that were previousl | |
| compile, but is subsequently referenced in exec and/or DFA exec. Any of the | | y | |
| compile-time options may be inspected during studying (and therefore JIT | | only recognized at matching time (i.e. by pcre_exec() or pcre_dfa_exec()) m | |
| compiling). */ | | ay | |
| | | also be used for compile-time options that affect only compiling and are no | |
| #define PCRE_CASELESS 0x00000001 /* Compile */ | | t | |
| #define PCRE_MULTILINE 0x00000002 /* Compile */ | | relevant for studying or JIT compiling. | |
| #define PCRE_DOTALL 0x00000004 /* Compile */ | | | |
| #define PCRE_EXTENDED 0x00000008 /* Compile */ | | Some options for pcre_compile() change its behaviour but do not affect the | |
| #define PCRE_ANCHORED 0x00000010 /* Compile, exec, DFA exec */ | | behaviour of the execution functions. Other options are passed through to t | |
| #define PCRE_DOLLAR_ENDONLY 0x00000020 /* Compile, used in exec, DFA e | | he | |
| xec */ | | execution functions and affect their behaviour, with or without affecting t | |
| #define PCRE_EXTRA 0x00000040 /* Compile */ | | he | |
| #define PCRE_NOTBOL 0x00000080 /* Exec, DFA exec */ | | behaviour of pcre_compile(). | |
| #define PCRE_NOTEOL 0x00000100 /* Exec, DFA exec */ | | | |
| #define PCRE_UNGREEDY 0x00000200 /* Compile */ | | Options that can be passed to pcre_compile() are tagged Cx below, with thes | |
| #define PCRE_NOTEMPTY 0x00000400 /* Exec, DFA exec */ | | e | |
| /* The next two are also used in exec and DFA exec */ | | variants: | |
| #define PCRE_UTF8 0x00000800 /* Compile (same as PCRE_UTF16) | | | |
| */ | | C1 Affects compile only | |
| #define PCRE_UTF16 0x00000800 /* Compile (same as PCRE_UTF8) | | C2 Does not affect compile; affects exec, dfa_exec | |
| */ | | C3 Affects compile, exec, dfa_exec | |
| #define PCRE_NO_AUTO_CAPTURE 0x00001000 /* Compile */ | | C4 Affects compile, exec, dfa_exec, study | |
| /* The next two are also used in exec and DFA exec */ | | C5 Affects compile, exec, study | |
| #define PCRE_NO_UTF8_CHECK 0x00002000 /* Compile (same as PCRE_NO_UTF | | | |
| 16_CHECK) */ | | Options that can be set for pcre_exec() and/or pcre_dfa_exec() are flagged | |
| #define PCRE_NO_UTF16_CHECK 0x00002000 /* Compile (same as PCRE_NO_UTF | | with | |
| 8_CHECK) */ | | E and D, respectively. They take precedence over C3, C4, and C5 settings pa | |
| #define PCRE_AUTO_CALLOUT 0x00004000 /* Compile */ | | ssed | |
| #define PCRE_PARTIAL_SOFT 0x00008000 /* Exec, DFA exec */ | | from pcre_compile(). Those that are compatible with JIT execution are flagg | |
| #define PCRE_PARTIAL 0x00008000 /* Backwards compatible synonym | | ed | |
| */ | | with J. */ | |
| #define PCRE_DFA_SHORTEST 0x00010000 /* DFA exec */ | | | |
| #define PCRE_DFA_RESTART 0x00020000 /* DFA exec */ | | #define PCRE_CASELESS 0x00000001 /* C1 */ | |
| #define PCRE_FIRSTLINE 0x00040000 /* Compile, used in exec, DFA e | | #define PCRE_MULTILINE 0x00000002 /* C1 */ | |
| xec */ | | #define PCRE_DOTALL 0x00000004 /* C1 */ | |
| #define PCRE_DUPNAMES 0x00080000 /* Compile */ | | #define PCRE_EXTENDED 0x00000008 /* C1 */ | |
| #define PCRE_NEWLINE_CR 0x00100000 /* Compile, exec, DFA exec */ | | #define PCRE_ANCHORED 0x00000010 /* C4 E D */ | |
| #define PCRE_NEWLINE_LF 0x00200000 /* Compile, exec, DFA exec */ | | #define PCRE_DOLLAR_ENDONLY 0x00000020 /* C2 */ | |
| #define PCRE_NEWLINE_CRLF 0x00300000 /* Compile, exec, DFA exec */ | | #define PCRE_EXTRA 0x00000040 /* C1 */ | |
| #define PCRE_NEWLINE_ANY 0x00400000 /* Compile, exec, DFA exec */ | | #define PCRE_NOTBOL 0x00000080 /* E D J */ | |
| #define PCRE_NEWLINE_ANYCRLF 0x00500000 /* Compile, exec, DFA exec */ | | #define PCRE_NOTEOL 0x00000100 /* E D J */ | |
| #define PCRE_BSR_ANYCRLF 0x00800000 /* Compile, exec, DFA exec */ | | #define PCRE_UNGREEDY 0x00000200 /* C1 */ | |
| #define PCRE_BSR_UNICODE 0x01000000 /* Compile, exec, DFA exec */ | | #define PCRE_NOTEMPTY 0x00000400 /* E D J */ | |
| #define PCRE_JAVASCRIPT_COMPAT 0x02000000 /* Compile, used in exec */ | | #define PCRE_UTF8 0x00000800 /* C4 ) */ | |
| #define PCRE_NO_START_OPTIMIZE 0x04000000 /* Compile, exec, DFA exec */ | | #define PCRE_UTF16 0x00000800 /* C4 ) Synonyms */ | |
| #define PCRE_NO_START_OPTIMISE 0x04000000 /* Synonym */ | | #define PCRE_UTF32 0x00000800 /* C4 ) */ | |
| #define PCRE_PARTIAL_HARD 0x08000000 /* Exec, DFA exec */ | | #define PCRE_NO_AUTO_CAPTURE 0x00001000 /* C1 */ | |
| #define PCRE_NOTEMPTY_ATSTART 0x10000000 /* Exec, DFA exec */ | | #define PCRE_NO_UTF8_CHECK 0x00002000 /* C1 E D J ) */ | |
| #define PCRE_UCP 0x20000000 /* Compile, used in exec, DFA e | | #define PCRE_NO_UTF16_CHECK 0x00002000 /* C1 E D J ) Synonyms */ | |
| xec */ | | #define PCRE_NO_UTF32_CHECK 0x00002000 /* C1 E D J ) */ | |
| | | #define PCRE_AUTO_CALLOUT 0x00004000 /* C1 */ | |
| | | #define PCRE_PARTIAL_SOFT 0x00008000 /* E D J ) Synonyms */ | |
| | | #define PCRE_PARTIAL 0x00008000 /* E D J ) */ | |
| | | | |
| | | /* This pair use the same bit. */ | |
| | | #define PCRE_NEVER_UTF 0x00010000 /* C1 ) Overlaid */ | |
| | | #define PCRE_DFA_SHORTEST 0x00010000 /* D ) Overlaid */ | |
| | | | |
| | | /* This pair use the same bit. */ | |
| | | #define PCRE_NO_AUTO_POSSESS 0x00020000 /* C1 ) Overlaid */ | |
| | | #define PCRE_DFA_RESTART 0x00020000 /* D ) Overlaid */ | |
| | | | |
| | | #define PCRE_FIRSTLINE 0x00040000 /* C3 */ | |
| | | #define PCRE_DUPNAMES 0x00080000 /* C1 */ | |
| | | #define PCRE_NEWLINE_CR 0x00100000 /* C3 E D */ | |
| | | #define PCRE_NEWLINE_LF 0x00200000 /* C3 E D */ | |
| | | #define PCRE_NEWLINE_CRLF 0x00300000 /* C3 E D */ | |
| | | #define PCRE_NEWLINE_ANY 0x00400000 /* C3 E D */ | |
| | | #define PCRE_NEWLINE_ANYCRLF 0x00500000 /* C3 E D */ | |
| | | #define PCRE_BSR_ANYCRLF 0x00800000 /* C3 E D */ | |
| | | #define PCRE_BSR_UNICODE 0x01000000 /* C3 E D */ | |
| | | #define PCRE_JAVASCRIPT_COMPAT 0x02000000 /* C5 */ | |
| | | #define PCRE_NO_START_OPTIMIZE 0x04000000 /* C2 E D ) Synonyms */ | |
| | | #define PCRE_NO_START_OPTIMISE 0x04000000 /* C2 E D ) */ | |
| | | #define PCRE_PARTIAL_HARD 0x08000000 /* E D J */ | |
| | | #define PCRE_NOTEMPTY_ATSTART 0x10000000 /* E D J */ | |
| | | #define PCRE_UCP 0x20000000 /* C3 */ | |
| | | | |
| /* Exec-time and get/set-time error codes */ | | /* Exec-time and get/set-time error codes */ | |
| | | | |
| #define PCRE_ERROR_NOMATCH (-1) | | #define PCRE_ERROR_NOMATCH (-1) | |
| #define PCRE_ERROR_NULL (-2) | | #define PCRE_ERROR_NULL (-2) | |
| #define PCRE_ERROR_BADOPTION (-3) | | #define PCRE_ERROR_BADOPTION (-3) | |
| #define PCRE_ERROR_BADMAGIC (-4) | | #define PCRE_ERROR_BADMAGIC (-4) | |
| #define PCRE_ERROR_UNKNOWN_OPCODE (-5) | | #define PCRE_ERROR_UNKNOWN_OPCODE (-5) | |
| #define PCRE_ERROR_UNKNOWN_NODE (-5) /* For backward compatibility */ | | #define PCRE_ERROR_UNKNOWN_NODE (-5) /* For backward compatibility */ | |
| #define PCRE_ERROR_NOMEMORY (-6) | | #define PCRE_ERROR_NOMEMORY (-6) | |
| #define PCRE_ERROR_NOSUBSTRING (-7) | | #define PCRE_ERROR_NOSUBSTRING (-7) | |
| #define PCRE_ERROR_MATCHLIMIT (-8) | | #define PCRE_ERROR_MATCHLIMIT (-8) | |
| #define PCRE_ERROR_CALLOUT (-9) /* Never used by PCRE itself */ | | #define PCRE_ERROR_CALLOUT (-9) /* Never used by PCRE itself */ | |
|
| #define PCRE_ERROR_BADUTF8 (-10) /* Same for 8/16 */ | | #define PCRE_ERROR_BADUTF8 (-10) /* Same for 8/16/32 */ | |
| #define PCRE_ERROR_BADUTF16 (-10) /* Same for 8/16 */ | | #define PCRE_ERROR_BADUTF16 (-10) /* Same for 8/16/32 */ | |
| | | #define PCRE_ERROR_BADUTF32 (-10) /* Same for 8/16/32 */ | |
| #define PCRE_ERROR_BADUTF8_OFFSET (-11) /* Same for 8/16 */ | | #define PCRE_ERROR_BADUTF8_OFFSET (-11) /* Same for 8/16 */ | |
| #define PCRE_ERROR_BADUTF16_OFFSET (-11) /* Same for 8/16 */ | | #define PCRE_ERROR_BADUTF16_OFFSET (-11) /* Same for 8/16 */ | |
| #define PCRE_ERROR_PARTIAL (-12) | | #define PCRE_ERROR_PARTIAL (-12) | |
| #define PCRE_ERROR_BADPARTIAL (-13) | | #define PCRE_ERROR_BADPARTIAL (-13) | |
| #define PCRE_ERROR_INTERNAL (-14) | | #define PCRE_ERROR_INTERNAL (-14) | |
| #define PCRE_ERROR_BADCOUNT (-15) | | #define PCRE_ERROR_BADCOUNT (-15) | |
| #define PCRE_ERROR_DFA_UITEM (-16) | | #define PCRE_ERROR_DFA_UITEM (-16) | |
| #define PCRE_ERROR_DFA_UCOND (-17) | | #define PCRE_ERROR_DFA_UCOND (-17) | |
| #define PCRE_ERROR_DFA_UMLIMIT (-18) | | #define PCRE_ERROR_DFA_UMLIMIT (-18) | |
| #define PCRE_ERROR_DFA_WSSIZE (-19) | | #define PCRE_ERROR_DFA_WSSIZE (-19) | |
| | | | |
| skipping to change at line 182 | | skipping to change at line 209 | |
| #define PCRE_ERROR_RECURSIONLIMIT (-21) | | #define PCRE_ERROR_RECURSIONLIMIT (-21) | |
| #define PCRE_ERROR_NULLWSLIMIT (-22) /* No longer actually used */ | | #define PCRE_ERROR_NULLWSLIMIT (-22) /* No longer actually used */ | |
| #define PCRE_ERROR_BADNEWLINE (-23) | | #define PCRE_ERROR_BADNEWLINE (-23) | |
| #define PCRE_ERROR_BADOFFSET (-24) | | #define PCRE_ERROR_BADOFFSET (-24) | |
| #define PCRE_ERROR_SHORTUTF8 (-25) | | #define PCRE_ERROR_SHORTUTF8 (-25) | |
| #define PCRE_ERROR_SHORTUTF16 (-25) /* Same for 8/16 */ | | #define PCRE_ERROR_SHORTUTF16 (-25) /* Same for 8/16 */ | |
| #define PCRE_ERROR_RECURSELOOP (-26) | | #define PCRE_ERROR_RECURSELOOP (-26) | |
| #define PCRE_ERROR_JIT_STACKLIMIT (-27) | | #define PCRE_ERROR_JIT_STACKLIMIT (-27) | |
| #define PCRE_ERROR_BADMODE (-28) | | #define PCRE_ERROR_BADMODE (-28) | |
| #define PCRE_ERROR_BADENDIANNESS (-29) | | #define PCRE_ERROR_BADENDIANNESS (-29) | |
|
| | | #define PCRE_ERROR_DFA_BADRESTART (-30) | |
| | | #define PCRE_ERROR_JIT_BADOPTION (-31) | |
| | | #define PCRE_ERROR_BADLENGTH (-32) | |
| | | #define PCRE_ERROR_UNSET (-33) | |
| | | | |
| /* Specific error codes for UTF-8 validity checks */ | | /* Specific error codes for UTF-8 validity checks */ | |
| | | | |
| #define PCRE_UTF8_ERR0 0 | | #define PCRE_UTF8_ERR0 0 | |
| #define PCRE_UTF8_ERR1 1 | | #define PCRE_UTF8_ERR1 1 | |
| #define PCRE_UTF8_ERR2 2 | | #define PCRE_UTF8_ERR2 2 | |
| #define PCRE_UTF8_ERR3 3 | | #define PCRE_UTF8_ERR3 3 | |
| #define PCRE_UTF8_ERR4 4 | | #define PCRE_UTF8_ERR4 4 | |
| #define PCRE_UTF8_ERR5 5 | | #define PCRE_UTF8_ERR5 5 | |
| #define PCRE_UTF8_ERR6 6 | | #define PCRE_UTF8_ERR6 6 | |
| | | | |
| skipping to change at line 207 | | skipping to change at line 238 | |
| #define PCRE_UTF8_ERR12 12 | | #define PCRE_UTF8_ERR12 12 | |
| #define PCRE_UTF8_ERR13 13 | | #define PCRE_UTF8_ERR13 13 | |
| #define PCRE_UTF8_ERR14 14 | | #define PCRE_UTF8_ERR14 14 | |
| #define PCRE_UTF8_ERR15 15 | | #define PCRE_UTF8_ERR15 15 | |
| #define PCRE_UTF8_ERR16 16 | | #define PCRE_UTF8_ERR16 16 | |
| #define PCRE_UTF8_ERR17 17 | | #define PCRE_UTF8_ERR17 17 | |
| #define PCRE_UTF8_ERR18 18 | | #define PCRE_UTF8_ERR18 18 | |
| #define PCRE_UTF8_ERR19 19 | | #define PCRE_UTF8_ERR19 19 | |
| #define PCRE_UTF8_ERR20 20 | | #define PCRE_UTF8_ERR20 20 | |
| #define PCRE_UTF8_ERR21 21 | | #define PCRE_UTF8_ERR21 21 | |
|
| | | #define PCRE_UTF8_ERR22 22 /* Unused (was non-character) */ | |
| | | | |
| /* Specific error codes for UTF-16 validity checks */ | | /* Specific error codes for UTF-16 validity checks */ | |
| | | | |
| #define PCRE_UTF16_ERR0 0 | | #define PCRE_UTF16_ERR0 0 | |
| #define PCRE_UTF16_ERR1 1 | | #define PCRE_UTF16_ERR1 1 | |
| #define PCRE_UTF16_ERR2 2 | | #define PCRE_UTF16_ERR2 2 | |
| #define PCRE_UTF16_ERR3 3 | | #define PCRE_UTF16_ERR3 3 | |
|
| #define PCRE_UTF16_ERR4 4 | | #define PCRE_UTF16_ERR4 4 /* Unused (was non-character) */ | |
| | | | |
| | | /* Specific error codes for UTF-32 validity checks */ | |
| | | | |
| | | #define PCRE_UTF32_ERR0 0 | |
| | | #define PCRE_UTF32_ERR1 1 | |
| | | #define PCRE_UTF32_ERR2 2 /* Unused (was non-character) */ | |
| | | #define PCRE_UTF32_ERR3 3 | |
| | | | |
| /* Request types for pcre_fullinfo() */ | | /* Request types for pcre_fullinfo() */ | |
| | | | |
| #define PCRE_INFO_OPTIONS 0 | | #define PCRE_INFO_OPTIONS 0 | |
| #define PCRE_INFO_SIZE 1 | | #define PCRE_INFO_SIZE 1 | |
| #define PCRE_INFO_CAPTURECOUNT 2 | | #define PCRE_INFO_CAPTURECOUNT 2 | |
| #define PCRE_INFO_BACKREFMAX 3 | | #define PCRE_INFO_BACKREFMAX 3 | |
| #define PCRE_INFO_FIRSTBYTE 4 | | #define PCRE_INFO_FIRSTBYTE 4 | |
| #define PCRE_INFO_FIRSTCHAR 4 /* For backwards compatibility */ | | #define PCRE_INFO_FIRSTCHAR 4 /* For backwards compatibility */ | |
| #define PCRE_INFO_FIRSTTABLE 5 | | #define PCRE_INFO_FIRSTTABLE 5 | |
| | | | |
| skipping to change at line 237 | | skipping to change at line 276 | |
| #define PCRE_INFO_NAMECOUNT 8 | | #define PCRE_INFO_NAMECOUNT 8 | |
| #define PCRE_INFO_NAMETABLE 9 | | #define PCRE_INFO_NAMETABLE 9 | |
| #define PCRE_INFO_STUDYSIZE 10 | | #define PCRE_INFO_STUDYSIZE 10 | |
| #define PCRE_INFO_DEFAULT_TABLES 11 | | #define PCRE_INFO_DEFAULT_TABLES 11 | |
| #define PCRE_INFO_OKPARTIAL 12 | | #define PCRE_INFO_OKPARTIAL 12 | |
| #define PCRE_INFO_JCHANGED 13 | | #define PCRE_INFO_JCHANGED 13 | |
| #define PCRE_INFO_HASCRORLF 14 | | #define PCRE_INFO_HASCRORLF 14 | |
| #define PCRE_INFO_MINLENGTH 15 | | #define PCRE_INFO_MINLENGTH 15 | |
| #define PCRE_INFO_JIT 16 | | #define PCRE_INFO_JIT 16 | |
| #define PCRE_INFO_JITSIZE 17 | | #define PCRE_INFO_JITSIZE 17 | |
|
| | | #define PCRE_INFO_MAXLOOKBEHIND 18 | |
| | | #define PCRE_INFO_FIRSTCHARACTER 19 | |
| | | #define PCRE_INFO_FIRSTCHARACTERFLAGS 20 | |
| | | #define PCRE_INFO_REQUIREDCHAR 21 | |
| | | #define PCRE_INFO_REQUIREDCHARFLAGS 22 | |
| | | #define PCRE_INFO_MATCHLIMIT 23 | |
| | | #define PCRE_INFO_RECURSIONLIMIT 24 | |
| | | #define PCRE_INFO_MATCH_EMPTY 25 | |
| | | | |
| /* Request types for pcre_config(). Do not re-arrange, in order to remain | | /* Request types for pcre_config(). Do not re-arrange, in order to remain | |
| compatible. */ | | compatible. */ | |
| | | | |
| #define PCRE_CONFIG_UTF8 0 | | #define PCRE_CONFIG_UTF8 0 | |
| #define PCRE_CONFIG_NEWLINE 1 | | #define PCRE_CONFIG_NEWLINE 1 | |
| #define PCRE_CONFIG_LINK_SIZE 2 | | #define PCRE_CONFIG_LINK_SIZE 2 | |
| #define PCRE_CONFIG_POSIX_MALLOC_THRESHOLD 3 | | #define PCRE_CONFIG_POSIX_MALLOC_THRESHOLD 3 | |
| #define PCRE_CONFIG_MATCH_LIMIT 4 | | #define PCRE_CONFIG_MATCH_LIMIT 4 | |
| #define PCRE_CONFIG_STACKRECURSE 5 | | #define PCRE_CONFIG_STACKRECURSE 5 | |
| #define PCRE_CONFIG_UNICODE_PROPERTIES 6 | | #define PCRE_CONFIG_UNICODE_PROPERTIES 6 | |
| #define PCRE_CONFIG_MATCH_LIMIT_RECURSION 7 | | #define PCRE_CONFIG_MATCH_LIMIT_RECURSION 7 | |
| #define PCRE_CONFIG_BSR 8 | | #define PCRE_CONFIG_BSR 8 | |
| #define PCRE_CONFIG_JIT 9 | | #define PCRE_CONFIG_JIT 9 | |
| #define PCRE_CONFIG_UTF16 10 | | #define PCRE_CONFIG_UTF16 10 | |
| #define PCRE_CONFIG_JITTARGET 11 | | #define PCRE_CONFIG_JITTARGET 11 | |
|
| | | #define PCRE_CONFIG_UTF32 12 | |
| | | #define PCRE_CONFIG_PARENS_LIMIT 13 | |
| | | | |
| /* Request types for pcre_study(). Do not re-arrange, in order to remain | | /* Request types for pcre_study(). Do not re-arrange, in order to remain | |
| compatible. */ | | compatible. */ | |
| | | | |
|
| #define PCRE_STUDY_JIT_COMPILE 0x0001 | | #define PCRE_STUDY_JIT_COMPILE 0x0001 | |
| | | #define PCRE_STUDY_JIT_PARTIAL_SOFT_COMPILE 0x0002 | |
| | | #define PCRE_STUDY_JIT_PARTIAL_HARD_COMPILE 0x0004 | |
| | | #define PCRE_STUDY_EXTRA_NEEDED 0x0008 | |
| | | | |
|
| /* Bit flags for the pcre[16]_extra structure. Do not re-arrange or redefin
e | | /* Bit flags for the pcre[16|32]_extra structure. Do not re-arrange or rede
fine | |
| these bits, just add new ones on the end, in order to remain compatible. */ | | these bits, just add new ones on the end, in order to remain compatible. */ | |
| | | | |
| #define PCRE_EXTRA_STUDY_DATA 0x0001 | | #define PCRE_EXTRA_STUDY_DATA 0x0001 | |
| #define PCRE_EXTRA_MATCH_LIMIT 0x0002 | | #define PCRE_EXTRA_MATCH_LIMIT 0x0002 | |
| #define PCRE_EXTRA_CALLOUT_DATA 0x0004 | | #define PCRE_EXTRA_CALLOUT_DATA 0x0004 | |
| #define PCRE_EXTRA_TABLES 0x0008 | | #define PCRE_EXTRA_TABLES 0x0008 | |
| #define PCRE_EXTRA_MATCH_LIMIT_RECURSION 0x0010 | | #define PCRE_EXTRA_MATCH_LIMIT_RECURSION 0x0010 | |
| #define PCRE_EXTRA_MARK 0x0020 | | #define PCRE_EXTRA_MARK 0x0020 | |
| #define PCRE_EXTRA_EXECUTABLE_JIT 0x0040 | | #define PCRE_EXTRA_EXECUTABLE_JIT 0x0040 | |
| | | | |
| /* Types */ | | /* Types */ | |
| | | | |
| struct real_pcre; /* declaration; the definition is private
*/ | | struct real_pcre; /* declaration; the definition is private
*/ | |
| typedef struct real_pcre pcre; | | typedef struct real_pcre pcre; | |
| | | | |
| struct real_pcre16; /* declaration; the definition is private
*/ | | struct real_pcre16; /* declaration; the definition is private
*/ | |
| typedef struct real_pcre16 pcre16; | | typedef struct real_pcre16 pcre16; | |
| | | | |
|
| | | struct real_pcre32; /* declaration; the definition is private | |
| | | */ | |
| | | typedef struct real_pcre32 pcre32; | |
| | | | |
| struct real_pcre_jit_stack; /* declaration; the definition is private
*/ | | struct real_pcre_jit_stack; /* declaration; the definition is private
*/ | |
| typedef struct real_pcre_jit_stack pcre_jit_stack; | | typedef struct real_pcre_jit_stack pcre_jit_stack; | |
| | | | |
| struct real_pcre16_jit_stack; /* declaration; the definition is private
*/ | | struct real_pcre16_jit_stack; /* declaration; the definition is private
*/ | |
| typedef struct real_pcre16_jit_stack pcre16_jit_stack; | | typedef struct real_pcre16_jit_stack pcre16_jit_stack; | |
| | | | |
|
| | | struct real_pcre32_jit_stack; /* declaration; the definition is private | |
| | | */ | |
| | | typedef struct real_pcre32_jit_stack pcre32_jit_stack; | |
| | | | |
| /* If PCRE is compiled with 16 bit character support, PCRE_UCHAR16 must con
tain | | /* If PCRE is compiled with 16 bit character support, PCRE_UCHAR16 must con
tain | |
| a 16 bit wide signed data type. Otherwise it can be a dummy data type since | | a 16 bit wide signed data type. Otherwise it can be a dummy data type since | |
| pcre16 functions are not implemented. There is a check for this in pcre_int
ernal.h. */ | | pcre16 functions are not implemented. There is a check for this in pcre_int
ernal.h. */ | |
| #ifndef PCRE_UCHAR16 | | #ifndef PCRE_UCHAR16 | |
| #define PCRE_UCHAR16 unsigned short | | #define PCRE_UCHAR16 unsigned short | |
| #endif | | #endif | |
| | | | |
| #ifndef PCRE_SPTR16 | | #ifndef PCRE_SPTR16 | |
| #define PCRE_SPTR16 const PCRE_UCHAR16 * | | #define PCRE_SPTR16 const PCRE_UCHAR16 * | |
| #endif | | #endif | |
| | | | |
|
| | | /* If PCRE is compiled with 32 bit character support, PCRE_UCHAR32 must con | |
| | | tain | |
| | | a 32 bit wide signed data type. Otherwise it can be a dummy data type since | |
| | | pcre32 functions are not implemented. There is a check for this in pcre_int | |
| | | ernal.h. */ | |
| | | #ifndef PCRE_UCHAR32 | |
| | | #define PCRE_UCHAR32 unsigned int | |
| | | #endif | |
| | | | |
| | | #ifndef PCRE_SPTR32 | |
| | | #define PCRE_SPTR32 const PCRE_UCHAR32 * | |
| | | #endif | |
| | | | |
| /* When PCRE is compiled as a C++ library, the subject pointer type can be | | /* When PCRE is compiled as a C++ library, the subject pointer type can be | |
| replaced with a custom type. For conventional use, the public interface is
a | | replaced with a custom type. For conventional use, the public interface is
a | |
| const char *. */ | | const char *. */ | |
| | | | |
| #ifndef PCRE_SPTR | | #ifndef PCRE_SPTR | |
| #define PCRE_SPTR const char * | | #define PCRE_SPTR const char * | |
| #endif | | #endif | |
| | | | |
| /* The structure for passing additional data to pcre_exec(). This is define
d in | | /* The structure for passing additional data to pcre_exec(). This is define
d in | |
| such as way as to be extensible. Always add new fields at the end, in order
to | | such as way as to be extensible. Always add new fields at the end, in order
to | |
| | | | |
| skipping to change at line 331 | | skipping to change at line 400 | |
| unsigned long int flags; /* Bits for which fields are set */ | | unsigned long int flags; /* Bits for which fields are set */ | |
| void *study_data; /* Opaque data from pcre_study() */ | | void *study_data; /* Opaque data from pcre_study() */ | |
| unsigned long int match_limit; /* Maximum number of calls to match() */ | | unsigned long int match_limit; /* Maximum number of calls to match() */ | |
| void *callout_data; /* Data passed back in callouts */ | | void *callout_data; /* Data passed back in callouts */ | |
| const unsigned char *tables; /* Pointer to character tables */ | | const unsigned char *tables; /* Pointer to character tables */ | |
| unsigned long int match_limit_recursion; /* Max recursive calls to match(
) */ | | unsigned long int match_limit_recursion; /* Max recursive calls to match(
) */ | |
| PCRE_UCHAR16 **mark; /* For passing back a mark pointer */ | | PCRE_UCHAR16 **mark; /* For passing back a mark pointer */ | |
| void *executable_jit; /* Contains a pointer to a compiled jit c
ode */ | | void *executable_jit; /* Contains a pointer to a compiled jit c
ode */ | |
| } pcre16_extra; | | } pcre16_extra; | |
| | | | |
|
| | | /* Same structure as above, but with 32 bit char pointers. */ | |
| | | | |
| | | typedef struct pcre32_extra { | |
| | | unsigned long int flags; /* Bits for which fields are set */ | |
| | | void *study_data; /* Opaque data from pcre_study() */ | |
| | | unsigned long int match_limit; /* Maximum number of calls to match() */ | |
| | | void *callout_data; /* Data passed back in callouts */ | |
| | | const unsigned char *tables; /* Pointer to character tables */ | |
| | | unsigned long int match_limit_recursion; /* Max recursive calls to match( | |
| | | ) */ | |
| | | PCRE_UCHAR32 **mark; /* For passing back a mark pointer */ | |
| | | void *executable_jit; /* Contains a pointer to a compiled jit c | |
| | | ode */ | |
| | | } pcre32_extra; | |
| | | | |
| /* The structure for passing out data via the pcre_callout_function. We use
a | | /* The structure for passing out data via the pcre_callout_function. We use
a | |
| structure so that new fields can be added on the end in future versions, | | structure so that new fields can be added on the end in future versions, | |
| without changing the API of the function, thereby allowing old clients to w
ork | | without changing the API of the function, thereby allowing old clients to w
ork | |
| without modification. */ | | without modification. */ | |
| | | | |
| typedef struct pcre_callout_block { | | typedef struct pcre_callout_block { | |
| int version; /* Identifies version of block */ | | int version; /* Identifies version of block */ | |
| /* ------------------------ Version 0 ------------------------------- */ | | /* ------------------------ Version 0 ------------------------------- */ | |
| int callout_number; /* Number compiled into pattern */ | | int callout_number; /* Number compiled into pattern */ | |
| int *offset_vector; /* The offset vector */ | | int *offset_vector; /* The offset vector */ | |
| | | | |
| skipping to change at line 378 | | skipping to change at line 460 | |
| int capture_last; /* Most recently closed capture */ | | int capture_last; /* Most recently closed capture */ | |
| void *callout_data; /* Data passed in with the call */ | | void *callout_data; /* Data passed in with the call */ | |
| /* ------------------- Added for Version 1 -------------------------- */ | | /* ------------------- Added for Version 1 -------------------------- */ | |
| int pattern_position; /* Offset to next item in the pattern */ | | int pattern_position; /* Offset to next item in the pattern */ | |
| int next_item_length; /* Length of next item in the pattern */ | | int next_item_length; /* Length of next item in the pattern */ | |
| /* ------------------- Added for Version 2 -------------------------- */ | | /* ------------------- Added for Version 2 -------------------------- */ | |
| const PCRE_UCHAR16 *mark; /* Pointer to current mark or NULL */ | | const PCRE_UCHAR16 *mark; /* Pointer to current mark or NULL */ | |
| /* ------------------------------------------------------------------ */ | | /* ------------------------------------------------------------------ */ | |
| } pcre16_callout_block; | | } pcre16_callout_block; | |
| | | | |
|
| | | /* Same structure as above, but with 32 bit char pointers. */ | |
| | | | |
| | | typedef struct pcre32_callout_block { | |
| | | int version; /* Identifies version of block */ | |
| | | /* ------------------------ Version 0 ------------------------------- */ | |
| | | int callout_number; /* Number compiled into pattern */ | |
| | | int *offset_vector; /* The offset vector */ | |
| | | PCRE_SPTR32 subject; /* The subject being matched */ | |
| | | int subject_length; /* The length of the subject */ | |
| | | int start_match; /* Offset to start of this match attempt | |
| | | */ | |
| | | int current_position; /* Where we currently are in the subject | |
| | | */ | |
| | | int capture_top; /* Max current capture */ | |
| | | int capture_last; /* Most recently closed capture */ | |
| | | void *callout_data; /* Data passed in with the call */ | |
| | | /* ------------------- Added for Version 1 -------------------------- */ | |
| | | int pattern_position; /* Offset to next item in the pattern */ | |
| | | int next_item_length; /* Length of next item in the pattern */ | |
| | | /* ------------------- Added for Version 2 -------------------------- */ | |
| | | const PCRE_UCHAR32 *mark; /* Pointer to current mark or NULL */ | |
| | | /* ------------------------------------------------------------------ */ | |
| | | } pcre32_callout_block; | |
| | | | |
| /* Indirection for store get and free functions. These can be set to | | /* Indirection for store get and free functions. These can be set to | |
| alternative malloc/free functions if required. Special ones are used in the | | alternative malloc/free functions if required. Special ones are used in the | |
| non-recursive case for "frames". There is also an optional callout function | | non-recursive case for "frames". There is also an optional callout function | |
| that is triggered by the (?) regex item. For Virtual Pascal, these definiti
ons | | that is triggered by the (?) regex item. For Virtual Pascal, these definiti
ons | |
| have to take another form. */ | | have to take another form. */ | |
| | | | |
| #ifndef VPCOMPAT | | #ifndef VPCOMPAT | |
| PCRE_EXP_DECL void *(*pcre_malloc)(size_t); | | PCRE_EXP_DECL void *(*pcre_malloc)(size_t); | |
| PCRE_EXP_DECL void (*pcre_free)(void *); | | PCRE_EXP_DECL void (*pcre_free)(void *); | |
| PCRE_EXP_DECL void *(*pcre_stack_malloc)(size_t); | | PCRE_EXP_DECL void *(*pcre_stack_malloc)(size_t); | |
| PCRE_EXP_DECL void (*pcre_stack_free)(void *); | | PCRE_EXP_DECL void (*pcre_stack_free)(void *); | |
| PCRE_EXP_DECL int (*pcre_callout)(pcre_callout_block *); | | PCRE_EXP_DECL int (*pcre_callout)(pcre_callout_block *); | |
|
| | | PCRE_EXP_DECL int (*pcre_stack_guard)(void); | |
| | | | |
| PCRE_EXP_DECL void *(*pcre16_malloc)(size_t); | | PCRE_EXP_DECL void *(*pcre16_malloc)(size_t); | |
| PCRE_EXP_DECL void (*pcre16_free)(void *); | | PCRE_EXP_DECL void (*pcre16_free)(void *); | |
| PCRE_EXP_DECL void *(*pcre16_stack_malloc)(size_t); | | PCRE_EXP_DECL void *(*pcre16_stack_malloc)(size_t); | |
| PCRE_EXP_DECL void (*pcre16_stack_free)(void *); | | PCRE_EXP_DECL void (*pcre16_stack_free)(void *); | |
| PCRE_EXP_DECL int (*pcre16_callout)(pcre16_callout_block *); | | PCRE_EXP_DECL int (*pcre16_callout)(pcre16_callout_block *); | |
|
| | | PCRE_EXP_DECL int (*pcre16_stack_guard)(void); | |
| | | | |
| | | PCRE_EXP_DECL void *(*pcre32_malloc)(size_t); | |
| | | PCRE_EXP_DECL void (*pcre32_free)(void *); | |
| | | PCRE_EXP_DECL void *(*pcre32_stack_malloc)(size_t); | |
| | | PCRE_EXP_DECL void (*pcre32_stack_free)(void *); | |
| | | PCRE_EXP_DECL int (*pcre32_callout)(pcre32_callout_block *); | |
| | | PCRE_EXP_DECL int (*pcre32_stack_guard)(void); | |
| #else /* VPCOMPAT */ | | #else /* VPCOMPAT */ | |
| PCRE_EXP_DECL void *pcre_malloc(size_t); | | PCRE_EXP_DECL void *pcre_malloc(size_t); | |
| PCRE_EXP_DECL void pcre_free(void *); | | PCRE_EXP_DECL void pcre_free(void *); | |
| PCRE_EXP_DECL void *pcre_stack_malloc(size_t); | | PCRE_EXP_DECL void *pcre_stack_malloc(size_t); | |
| PCRE_EXP_DECL void pcre_stack_free(void *); | | PCRE_EXP_DECL void pcre_stack_free(void *); | |
| PCRE_EXP_DECL int pcre_callout(pcre_callout_block *); | | PCRE_EXP_DECL int pcre_callout(pcre_callout_block *); | |
|
| | | PCRE_EXP_DECL int pcre_stack_guard(void); | |
| | | | |
| PCRE_EXP_DECL void *pcre16_malloc(size_t); | | PCRE_EXP_DECL void *pcre16_malloc(size_t); | |
| PCRE_EXP_DECL void pcre16_free(void *); | | PCRE_EXP_DECL void pcre16_free(void *); | |
| PCRE_EXP_DECL void *pcre16_stack_malloc(size_t); | | PCRE_EXP_DECL void *pcre16_stack_malloc(size_t); | |
| PCRE_EXP_DECL void pcre16_stack_free(void *); | | PCRE_EXP_DECL void pcre16_stack_free(void *); | |
| PCRE_EXP_DECL int pcre16_callout(pcre16_callout_block *); | | PCRE_EXP_DECL int pcre16_callout(pcre16_callout_block *); | |
|
| | | PCRE_EXP_DECL int pcre16_stack_guard(void); | |
| | | | |
| | | PCRE_EXP_DECL void *pcre32_malloc(size_t); | |
| | | PCRE_EXP_DECL void pcre32_free(void *); | |
| | | PCRE_EXP_DECL void *pcre32_stack_malloc(size_t); | |
| | | PCRE_EXP_DECL void pcre32_stack_free(void *); | |
| | | PCRE_EXP_DECL int pcre32_callout(pcre32_callout_block *); | |
| | | PCRE_EXP_DECL int pcre32_stack_guard(void); | |
| #endif /* VPCOMPAT */ | | #endif /* VPCOMPAT */ | |
| | | | |
| /* User defined callback which provides a stack just before the match start
s. */ | | /* User defined callback which provides a stack just before the match start
s. */ | |
| | | | |
| typedef pcre_jit_stack *(*pcre_jit_callback)(void *); | | typedef pcre_jit_stack *(*pcre_jit_callback)(void *); | |
| typedef pcre16_jit_stack *(*pcre16_jit_callback)(void *); | | typedef pcre16_jit_stack *(*pcre16_jit_callback)(void *); | |
|
| | | typedef pcre32_jit_stack *(*pcre32_jit_callback)(void *); | |
| | | | |
| /* Exported PCRE functions */ | | /* Exported PCRE functions */ | |
| | | | |
| PCRE_EXP_DECL pcre *pcre_compile(const char *, int, const char **, int *, | | PCRE_EXP_DECL pcre *pcre_compile(const char *, int, const char **, int *, | |
| const unsigned char *); | | const unsigned char *); | |
| PCRE_EXP_DECL pcre16 *pcre16_compile(PCRE_SPTR16, int, const char **, int *
, | | PCRE_EXP_DECL pcre16 *pcre16_compile(PCRE_SPTR16, int, const char **, int *
, | |
| const unsigned char *); | | const unsigned char *); | |
|
| | | PCRE_EXP_DECL pcre32 *pcre32_compile(PCRE_SPTR32, int, const char **, int * | |
| | | , | |
| | | const unsigned char *); | |
| PCRE_EXP_DECL pcre *pcre_compile2(const char *, int, int *, const char **, | | PCRE_EXP_DECL pcre *pcre_compile2(const char *, int, int *, const char **, | |
| int *, const unsigned char *); | | int *, const unsigned char *); | |
| PCRE_EXP_DECL pcre16 *pcre16_compile2(PCRE_SPTR16, int, int *, const char *
*, | | PCRE_EXP_DECL pcre16 *pcre16_compile2(PCRE_SPTR16, int, int *, const char *
*, | |
| int *, const unsigned char *); | | int *, const unsigned char *); | |
|
| | | PCRE_EXP_DECL pcre32 *pcre32_compile2(PCRE_SPTR32, int, int *, const char * | |
| | | *, | |
| | | int *, const unsigned char *); | |
| PCRE_EXP_DECL int pcre_config(int, void *); | | PCRE_EXP_DECL int pcre_config(int, void *); | |
| PCRE_EXP_DECL int pcre16_config(int, void *); | | PCRE_EXP_DECL int pcre16_config(int, void *); | |
|
| | | PCRE_EXP_DECL int pcre32_config(int, void *); | |
| PCRE_EXP_DECL int pcre_copy_named_substring(const pcre *, const char *, | | PCRE_EXP_DECL int pcre_copy_named_substring(const pcre *, const char *, | |
| int *, int, const char *, char *, int); | | int *, int, const char *, char *, int); | |
| PCRE_EXP_DECL int pcre16_copy_named_substring(const pcre16 *, PCRE_SPTR16, | | PCRE_EXP_DECL int pcre16_copy_named_substring(const pcre16 *, PCRE_SPTR16, | |
| int *, int, PCRE_SPTR16, PCRE_UCHAR16 *, int); | | int *, int, PCRE_SPTR16, PCRE_UCHAR16 *, int); | |
|
| | | PCRE_EXP_DECL int pcre32_copy_named_substring(const pcre32 *, PCRE_SPTR32, | |
| | | int *, int, PCRE_SPTR32, PCRE_UCHAR32 *, int); | |
| PCRE_EXP_DECL int pcre_copy_substring(const char *, int *, int, int, | | PCRE_EXP_DECL int pcre_copy_substring(const char *, int *, int, int, | |
| char *, int); | | char *, int); | |
| PCRE_EXP_DECL int pcre16_copy_substring(PCRE_SPTR16, int *, int, int, | | PCRE_EXP_DECL int pcre16_copy_substring(PCRE_SPTR16, int *, int, int, | |
| PCRE_UCHAR16 *, int); | | PCRE_UCHAR16 *, int); | |
|
| | | PCRE_EXP_DECL int pcre32_copy_substring(PCRE_SPTR32, int *, int, int, | |
| | | PCRE_UCHAR32 *, int); | |
| PCRE_EXP_DECL int pcre_dfa_exec(const pcre *, const pcre_extra *, | | PCRE_EXP_DECL int pcre_dfa_exec(const pcre *, const pcre_extra *, | |
| const char *, int, int, int, int *, int , int *, int); | | const char *, int, int, int, int *, int , int *, int); | |
| PCRE_EXP_DECL int pcre16_dfa_exec(const pcre16 *, const pcre16_extra *, | | PCRE_EXP_DECL int pcre16_dfa_exec(const pcre16 *, const pcre16_extra *, | |
| PCRE_SPTR16, int, int, int, int *, int , int *, int); | | PCRE_SPTR16, int, int, int, int *, int , int *, int); | |
|
| | | PCRE_EXP_DECL int pcre32_dfa_exec(const pcre32 *, const pcre32_extra *, | |
| | | PCRE_SPTR32, int, int, int, int *, int , int *, int); | |
| PCRE_EXP_DECL int pcre_exec(const pcre *, const pcre_extra *, PCRE_SPTR, | | PCRE_EXP_DECL int pcre_exec(const pcre *, const pcre_extra *, PCRE_SPTR, | |
| int, int, int, int *, int); | | int, int, int, int *, int); | |
| PCRE_EXP_DECL int pcre16_exec(const pcre16 *, const pcre16_extra *, | | PCRE_EXP_DECL int pcre16_exec(const pcre16 *, const pcre16_extra *, | |
| PCRE_SPTR16, int, int, int, int *, int); | | PCRE_SPTR16, int, int, int, int *, int); | |
|
| | | PCRE_EXP_DECL int pcre32_exec(const pcre32 *, const pcre32_extra *, | |
| | | PCRE_SPTR32, int, int, int, int *, int); | |
| | | PCRE_EXP_DECL int pcre_jit_exec(const pcre *, const pcre_extra *, | |
| | | PCRE_SPTR, int, int, int, int *, int, | |
| | | pcre_jit_stack *); | |
| | | PCRE_EXP_DECL int pcre16_jit_exec(const pcre16 *, const pcre16_extra *, | |
| | | PCRE_SPTR16, int, int, int, int *, int, | |
| | | pcre16_jit_stack *); | |
| | | PCRE_EXP_DECL int pcre32_jit_exec(const pcre32 *, const pcre32_extra *, | |
| | | PCRE_SPTR32, int, int, int, int *, int, | |
| | | pcre32_jit_stack *); | |
| PCRE_EXP_DECL void pcre_free_substring(const char *); | | PCRE_EXP_DECL void pcre_free_substring(const char *); | |
| PCRE_EXP_DECL void pcre16_free_substring(PCRE_SPTR16); | | PCRE_EXP_DECL void pcre16_free_substring(PCRE_SPTR16); | |
|
| | | PCRE_EXP_DECL void pcre32_free_substring(PCRE_SPTR32); | |
| PCRE_EXP_DECL void pcre_free_substring_list(const char **); | | PCRE_EXP_DECL void pcre_free_substring_list(const char **); | |
| PCRE_EXP_DECL void pcre16_free_substring_list(PCRE_SPTR16 *); | | PCRE_EXP_DECL void pcre16_free_substring_list(PCRE_SPTR16 *); | |
|
| | | PCRE_EXP_DECL void pcre32_free_substring_list(PCRE_SPTR32 *); | |
| PCRE_EXP_DECL int pcre_fullinfo(const pcre *, const pcre_extra *, int, | | PCRE_EXP_DECL int pcre_fullinfo(const pcre *, const pcre_extra *, int, | |
| void *); | | void *); | |
| PCRE_EXP_DECL int pcre16_fullinfo(const pcre16 *, const pcre16_extra *, in
t, | | PCRE_EXP_DECL int pcre16_fullinfo(const pcre16 *, const pcre16_extra *, in
t, | |
| void *); | | void *); | |
|
| | | PCRE_EXP_DECL int pcre32_fullinfo(const pcre32 *, const pcre32_extra *, in | |
| | | t, | |
| | | void *); | |
| PCRE_EXP_DECL int pcre_get_named_substring(const pcre *, const char *, | | PCRE_EXP_DECL int pcre_get_named_substring(const pcre *, const char *, | |
| int *, int, const char *, const char **); | | int *, int, const char *, const char **); | |
| PCRE_EXP_DECL int pcre16_get_named_substring(const pcre16 *, PCRE_SPTR16, | | PCRE_EXP_DECL int pcre16_get_named_substring(const pcre16 *, PCRE_SPTR16, | |
| int *, int, PCRE_SPTR16, PCRE_SPTR16 *); | | int *, int, PCRE_SPTR16, PCRE_SPTR16 *); | |
|
| | | PCRE_EXP_DECL int pcre32_get_named_substring(const pcre32 *, PCRE_SPTR32, | |
| | | int *, int, PCRE_SPTR32, PCRE_SPTR32 *); | |
| PCRE_EXP_DECL int pcre_get_stringnumber(const pcre *, const char *); | | PCRE_EXP_DECL int pcre_get_stringnumber(const pcre *, const char *); | |
| PCRE_EXP_DECL int pcre16_get_stringnumber(const pcre16 *, PCRE_SPTR16); | | PCRE_EXP_DECL int pcre16_get_stringnumber(const pcre16 *, PCRE_SPTR16); | |
|
| | | PCRE_EXP_DECL int pcre32_get_stringnumber(const pcre32 *, PCRE_SPTR32); | |
| PCRE_EXP_DECL int pcre_get_stringtable_entries(const pcre *, const char *, | | PCRE_EXP_DECL int pcre_get_stringtable_entries(const pcre *, const char *, | |
| char **, char **); | | char **, char **); | |
| PCRE_EXP_DECL int pcre16_get_stringtable_entries(const pcre16 *, PCRE_SPTR
16, | | PCRE_EXP_DECL int pcre16_get_stringtable_entries(const pcre16 *, PCRE_SPTR
16, | |
| PCRE_UCHAR16 **, PCRE_UCHAR16 **); | | PCRE_UCHAR16 **, PCRE_UCHAR16 **); | |
|
| | | PCRE_EXP_DECL int pcre32_get_stringtable_entries(const pcre32 *, PCRE_SPTR | |
| | | 32, | |
| | | PCRE_UCHAR32 **, PCRE_UCHAR32 **); | |
| PCRE_EXP_DECL int pcre_get_substring(const char *, int *, int, int, | | PCRE_EXP_DECL int pcre_get_substring(const char *, int *, int, int, | |
| const char **); | | const char **); | |
| PCRE_EXP_DECL int pcre16_get_substring(PCRE_SPTR16, int *, int, int, | | PCRE_EXP_DECL int pcre16_get_substring(PCRE_SPTR16, int *, int, int, | |
| PCRE_SPTR16 *); | | PCRE_SPTR16 *); | |
|
| | | PCRE_EXP_DECL int pcre32_get_substring(PCRE_SPTR32, int *, int, int, | |
| | | PCRE_SPTR32 *); | |
| PCRE_EXP_DECL int pcre_get_substring_list(const char *, int *, int, | | PCRE_EXP_DECL int pcre_get_substring_list(const char *, int *, int, | |
| const char ***); | | const char ***); | |
| PCRE_EXP_DECL int pcre16_get_substring_list(PCRE_SPTR16, int *, int, | | PCRE_EXP_DECL int pcre16_get_substring_list(PCRE_SPTR16, int *, int, | |
| PCRE_SPTR16 **); | | PCRE_SPTR16 **); | |
|
| | | PCRE_EXP_DECL int pcre32_get_substring_list(PCRE_SPTR32, int *, int, | |
| | | PCRE_SPTR32 **); | |
| PCRE_EXP_DECL const unsigned char *pcre_maketables(void); | | PCRE_EXP_DECL const unsigned char *pcre_maketables(void); | |
| PCRE_EXP_DECL const unsigned char *pcre16_maketables(void); | | PCRE_EXP_DECL const unsigned char *pcre16_maketables(void); | |
|
| | | PCRE_EXP_DECL const unsigned char *pcre32_maketables(void); | |
| PCRE_EXP_DECL int pcre_refcount(pcre *, int); | | PCRE_EXP_DECL int pcre_refcount(pcre *, int); | |
| PCRE_EXP_DECL int pcre16_refcount(pcre16 *, int); | | PCRE_EXP_DECL int pcre16_refcount(pcre16 *, int); | |
|
| | | PCRE_EXP_DECL int pcre32_refcount(pcre32 *, int); | |
| PCRE_EXP_DECL pcre_extra *pcre_study(const pcre *, int, const char **); | | PCRE_EXP_DECL pcre_extra *pcre_study(const pcre *, int, const char **); | |
| PCRE_EXP_DECL pcre16_extra *pcre16_study(const pcre16 *, int, const char **
); | | PCRE_EXP_DECL pcre16_extra *pcre16_study(const pcre16 *, int, const char **
); | |
|
| | | PCRE_EXP_DECL pcre32_extra *pcre32_study(const pcre32 *, int, const char **
); | |
| PCRE_EXP_DECL void pcre_free_study(pcre_extra *); | | PCRE_EXP_DECL void pcre_free_study(pcre_extra *); | |
| PCRE_EXP_DECL void pcre16_free_study(pcre16_extra *); | | PCRE_EXP_DECL void pcre16_free_study(pcre16_extra *); | |
|
| | | PCRE_EXP_DECL void pcre32_free_study(pcre32_extra *); | |
| PCRE_EXP_DECL const char *pcre_version(void); | | PCRE_EXP_DECL const char *pcre_version(void); | |
| PCRE_EXP_DECL const char *pcre16_version(void); | | PCRE_EXP_DECL const char *pcre16_version(void); | |
|
| | | PCRE_EXP_DECL const char *pcre32_version(void); | |
| | | | |
| /* Utility functions for byte order swaps. */ | | /* Utility functions for byte order swaps. */ | |
| PCRE_EXP_DECL int pcre_pattern_to_host_byte_order(pcre *, pcre_extra *, | | PCRE_EXP_DECL int pcre_pattern_to_host_byte_order(pcre *, pcre_extra *, | |
| const unsigned char *); | | const unsigned char *); | |
| PCRE_EXP_DECL int pcre16_pattern_to_host_byte_order(pcre16 *, pcre16_extra
*, | | PCRE_EXP_DECL int pcre16_pattern_to_host_byte_order(pcre16 *, pcre16_extra
*, | |
| const unsigned char *); | | const unsigned char *); | |
|
| | | PCRE_EXP_DECL int pcre32_pattern_to_host_byte_order(pcre32 *, pcre32_extra | |
| | | *, | |
| | | const unsigned char *); | |
| PCRE_EXP_DECL int pcre16_utf16_to_host_byte_order(PCRE_UCHAR16 *, | | PCRE_EXP_DECL int pcre16_utf16_to_host_byte_order(PCRE_UCHAR16 *, | |
| PCRE_SPTR16, int, int *, int); | | PCRE_SPTR16, int, int *, int); | |
|
| | | PCRE_EXP_DECL int pcre32_utf32_to_host_byte_order(PCRE_UCHAR32 *, | |
| | | PCRE_SPTR32, int, int *, int); | |
| | | | |
| /* JIT compiler related functions. */ | | /* JIT compiler related functions. */ | |
| | | | |
| PCRE_EXP_DECL pcre_jit_stack *pcre_jit_stack_alloc(int, int); | | PCRE_EXP_DECL pcre_jit_stack *pcre_jit_stack_alloc(int, int); | |
| PCRE_EXP_DECL pcre16_jit_stack *pcre16_jit_stack_alloc(int, int); | | PCRE_EXP_DECL pcre16_jit_stack *pcre16_jit_stack_alloc(int, int); | |
|
| | | PCRE_EXP_DECL pcre32_jit_stack *pcre32_jit_stack_alloc(int, int); | |
| PCRE_EXP_DECL void pcre_jit_stack_free(pcre_jit_stack *); | | PCRE_EXP_DECL void pcre_jit_stack_free(pcre_jit_stack *); | |
| PCRE_EXP_DECL void pcre16_jit_stack_free(pcre16_jit_stack *); | | PCRE_EXP_DECL void pcre16_jit_stack_free(pcre16_jit_stack *); | |
|
| | | PCRE_EXP_DECL void pcre32_jit_stack_free(pcre32_jit_stack *); | |
| PCRE_EXP_DECL void pcre_assign_jit_stack(pcre_extra *, | | PCRE_EXP_DECL void pcre_assign_jit_stack(pcre_extra *, | |
| pcre_jit_callback, void *); | | pcre_jit_callback, void *); | |
| PCRE_EXP_DECL void pcre16_assign_jit_stack(pcre16_extra *, | | PCRE_EXP_DECL void pcre16_assign_jit_stack(pcre16_extra *, | |
| pcre16_jit_callback, void *); | | pcre16_jit_callback, void *); | |
|
| | | PCRE_EXP_DECL void pcre32_assign_jit_stack(pcre32_extra *, | |
| | | pcre32_jit_callback, void *); | |
| | | PCRE_EXP_DECL void pcre_jit_free_unused_memory(void); | |
| | | PCRE_EXP_DECL void pcre16_jit_free_unused_memory(void); | |
| | | PCRE_EXP_DECL void pcre32_jit_free_unused_memory(void); | |
| | | | |
| #ifdef __cplusplus | | #ifdef __cplusplus | |
| } /* extern "C" */ | | } /* extern "C" */ | |
| #endif | | #endif | |
| | | | |
| #endif /* End of pcre.h */ | | #endif /* End of pcre.h */ | |
| | | | |
End of changes. 50 change blocks. |
| 71 lines changed or deleted | | 259 lines changed or added | |
|