| 2008-08-10 Jan Michael Alonzo <jmalonzo@webkit.org> |
| |
| Reviewed (and updated) by Alp Toker. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=16620 |
| [GTK] Autotools make dist and make check support |
| |
| Get make dist working. |
| |
| Note that not all possible configurations have been tested yet. |
| |
| * GNUmakefile.am: |
| |
| 2008-08-09 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Sam Weinig. |
| |
| Added same heap debug checks to more code paths. |
| |
| * kjs/JSActivation.cpp: |
| (KJS::JSActivation::put): |
| (KJS::JSActivation::putWithAttributes): |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::putWithAttributes): |
| * kjs/JSObject.h: |
| (KJS::JSObject::putDirect): |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::symbolTablePut): |
| (KJS::JSVariableObject::symbolTablePutWithAttributes): |
| |
| 2008-08-09 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Fix some style issues in the sampling tool. |
| |
| * VM/SamplingTool.cpp: |
| (KJS::sleepForMicroseconds): |
| (KJS::SamplingTool::dump): |
| |
| 2008-08-09 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Revision 35651, despite being a rather trivial change, introduced a |
| large regression on the regexp-dna SunSpider test. This regression |
| stemmed from an increase in the size of CodeBlock::dump(). There is |
| no reason for this method (and several related methods) to be compiled |
| in non-debug builds with the sampling tool disabled. This patch |
| conditionally compiles them, reversing the regression on SunSpider. |
| |
| * JavaScriptCore.exp: |
| * VM/CodeBlock.cpp: |
| * VM/CodeBlock.h: |
| * VM/Machine.cpp: |
| |
| 2008-08-08 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Bug 20330: JSCore crash loading any filehurricane media page |
| <https://bugs.webkit.org/show_bug.cgi?id=20330> |
| |
| Fix a typo in the constant loading patch. Also, add a case for |
| op_unexpected_load to CodeBlock::dump(). |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::addUnexpectedConstant): |
| |
| 2008-08-08 Matt Lilek <webkit@mattlilek.com> |
| |
| Not reviewed, build fix. |
| |
| * JavaScriptCore.exp: |
| |
| 2008-08-08 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Cameron Zwarich. |
| |
| Improve performance of arithmetic operators |
| |
| Added a fast (non-virtual) mechanism to determine if a non-immediate JSValue* |
| is a JSNumberCell. We then use this to allow improved specialisation in many |
| arithmetic operators. SunSpider reports a 2.5% progression overall, with greater |
| than 10% progressions on a number of arithmetic heavy tests. |
| |
| * VM/Machine.cpp: |
| (KJS::fastIsNumber): |
| (KJS::fastToInt32): |
| (KJS::fastToUInt32): |
| (KJS::jsLess): |
| (KJS::jsLessEq): |
| (KJS::jsAdd): |
| (KJS::Machine::privateExecute): |
| * kjs/JSNumberCell.h: |
| (KJS::JSNumberCell::fastToInt32): |
| (KJS::JSNumberCell::fastToUInt32): |
| * kjs/collector.cpp: |
| (KJS::allocateBlock): |
| (KJS::Heap::heapAllocate): |
| * kjs/collector.h: |
| (KJS::Heap::fastIsNumber): |
| |
| 2008-08-06 Adam Roben <aroben@apple.com> |
| |
| Try to fix the Windows build bots |
| |
| * API/JSBase.cpp: Touch this to force JSC to rebuild and re-copy the |
| WTF headers. |
| |
| 2008-08-06 Tor Arne Vestbø <tavestbo@trolltech.com> |
| |
| Revert change 35595. |
| |
| * wtf/RetainPtr.h: |
| |
| 2008-08-06 Ariya Hidayat <ariya.hidayat@trolltech.com> |
| |
| Fix non-Mac build. |
| |
| * wtf/RetainPtr.h: CoreFoundation only for PLATFORM(MAC) |
| |
| 2008-08-06 Ariya Hidayat <ariya.hidayat@trolltech.com> |
| |
| Fix non-Mac build. |
| |
| * wtf/RetainPtr.h: CoreFoundation only for PLATFORM(MAC) |
| |
| 2008-08-06 Csaba Osztrogonac <oszi@inf.u-szeged.hu> |
| |
| Reviewed by Darin. Landed by Cameron. |
| |
| Bug 20272: typo in JavaScriptCore |
| <https://bugs.webkit.org/show_bug.cgi?id=20272> |
| |
| Correct the documentation for op_not. (typo) |
| Fix #undef. (typo) |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-08-06 Cameron Zwarich <cwzwarich@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Bug 20286: Load constants all at once instead of using op_load |
| <https://bugs.webkit.org/show_bug.cgi?id=20286> |
| |
| Load constants all at once into temporary registers instead of using |
| individual instances of op_load. |
| |
| This is a 2.6% speedup on SunSpider. |
| |
| * JavaScriptCore.exp: |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| (KJS::CodeBlock::mark): |
| * VM/CodeBlock.h: |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::CodeGenerator): |
| (KJS::CodeGenerator::newTemporary): |
| (KJS::CodeGenerator::addConstant): |
| (KJS::CodeGenerator::addUnexpectedConstant): |
| (KJS::CodeGenerator::emitLoad): |
| (KJS::CodeGenerator::emitUnexpectedLoad): |
| (KJS::CodeGenerator::emitNewError): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::slideRegisterWindowForCall): |
| (KJS::Machine::unwindCallFrame): |
| (KJS::Machine::throwException): |
| (KJS::Machine::execute): |
| (KJS::Machine::privateExecute): |
| * VM/Machine.h: |
| * VM/Opcode.h: |
| * VM/RegisterID.h: |
| (KJS::RegisterID::RegisterID): |
| (KJS::RegisterID::makeConstant): |
| (KJS::RegisterID::isTemporary): |
| * kjs/NodeInfo.h: |
| * kjs/Parser.cpp: |
| (KJS::Parser::didFinishParsing): |
| * kjs/Parser.h: |
| (KJS::Parser::parse): |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::NullNode::emitCode): |
| (KJS::BooleanNode::emitCode): |
| (KJS::NumberNode::emitCode): |
| (KJS::StringNode::emitCode): |
| (KJS::ArrayNode::emitCode): |
| (KJS::DeleteResolveNode::emitCode): |
| (KJS::DeleteValueNode::emitCode): |
| (KJS::VoidNode::emitCode): |
| (KJS::ConstDeclNode::emitCodeSingle): |
| (KJS::ReturnNode::emitCode): |
| (KJS::ScopeNode::ScopeNode): |
| (KJS::ProgramNode::ProgramNode): |
| (KJS::ProgramNode::create): |
| (KJS::EvalNode::EvalNode): |
| (KJS::EvalNode::create): |
| (KJS::FunctionBodyNode::FunctionBodyNode): |
| (KJS::FunctionBodyNode::create): |
| (KJS::FunctionBodyNode::emitCode): |
| * kjs/nodes.h: |
| (KJS::ScopeNode::neededConstants): |
| |
| 2008-08-05 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Cameron. |
| |
| - add fast path for immediates to % operator, as we have for many other math ops |
| |
| This fixes handling for a 0 divisor relative to the last patch. Only an 0.2% speedup on SunSpider but |
| still a 1.4x win on Oliver's prime test. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-08-05 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Darin. |
| |
| Bug 20293: Crash in JavaScript codegen for eval("const a;") |
| <https://bugs.webkit.org/show_bug.cgi?id=20293> |
| |
| Correctly handle constant declarations in eval code with no initializer. |
| |
| * kjs/nodes.cpp: |
| (KJS::ConstDeclNode::emitCodeSingle): |
| |
| 2008-08-05 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Roll out r35555 because of correctness issues. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-08-05 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - add fast path for immediates to % operator, as we have for many other math ops |
| |
| 0.6% speedup on SunSpider. 1.4x speedup on a prime testing torture test that Oliver whipped up. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-07-31 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Cameron Zwarich. |
| |
| Bug 19359: JavaScriptCore behaves differently from FF2/3 and IE when handling context in catch statement |
| <https://bugs.webkit.org/show_bug.cgi?id=19359> |
| |
| Make our catch behave like Firefox and IE, we do this by using a StaticScopeObject |
| instead of a generic JSObject for the scope node. We still don't make use of the |
| fact that we have a static scope inside the catch block, so the internal performance |
| of the catch block is not improved, even though technically it would be possible to |
| do so. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitPushNewScope): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::createExceptionScope): |
| (KJS::Machine::privateExecute): |
| * VM/Machine.h: |
| * VM/Opcode.h: |
| * kjs/JSStaticScopeObject.cpp: |
| (KJS::JSStaticScopeObject::toThisObject): |
| (KJS::JSStaticScopeObject::put): |
| * kjs/JSStaticScopeObject.h: |
| * kjs/nodes.cpp: |
| (KJS::TryNode::emitCode): |
| |
| 2008-08-02 Rob Gowin <robg@gowin.net> |
| |
| Reviewed by Eric Seidel. |
| |
| Added JavaScriptCore/API/WebKitAvailability to list of files in |
| javascriptcore_h_api. |
| |
| * GNUmakefile.am: |
| |
| 2008-08-01 Alexey Proskuryakov <ap@webkit.org> |
| |
| Rubber-stamped by Maciej. |
| |
| Remove JSGlobalData::DataInstance. It was only needed when we had per-thread JSGlobalData |
| instances. |
| |
| * kjs/JSGlobalData.h: |
| |
| 2008-07-31 Kevin Ollivier <kevino@theolliviers.com> |
| |
| Second attempt at Windows/wx build fix. Instead of avoiding inclusion of windows.h, |
| use defines, etc. to avoid conflicts in each affected file. Also, change PLATFORM(WIN) |
| to PLATFORM(WIN_OS) so that other ports using Windows headers get the right impls. |
| |
| * VM/SamplingTool.cpp: |
| * wtf/Threading.h: |
| |
| 2008-07-31 Anders Carlsson <andersca@apple.com> |
| |
| Reviewed by Adam. |
| |
| Fix Windows build. |
| |
| * kjs/collector.h: |
| * wtf/FastMalloc.cpp: |
| |
| 2008-07-31 Csaba Osztrogonac <oszi@inf.u-szeged.hu> |
| |
| Reviewed by Simon. |
| |
| Bug 20170: [Qt] missing namespace defines in JavaScriptCore.pro |
| <https://bugs.webkit.org/show_bug.cgi?id=20170> |
| |
| * JavaScriptCore.pro: Added missing define. |
| |
| 2008-07-31 Alexey Proskuryakov <ap@webkit.org> |
| |
| Rubber-stamped by Maciej. |
| |
| Eliminate JSLock (it was already disabled, removing the stub implementaion and all |
| call sites now). |
| |
| * API/JSBase.cpp: |
| (JSEvaluateScript): |
| (JSCheckScriptSyntax): |
| (JSGarbageCollect): |
| * API/JSCallbackConstructor.cpp: |
| (KJS::constructJSCallback): |
| * API/JSCallbackFunction.cpp: |
| (KJS::JSCallbackFunction::call): |
| * API/JSCallbackObjectFunctions.h: |
| (KJS::::init): |
| (KJS::::getOwnPropertySlot): |
| (KJS::::put): |
| (KJS::::deleteProperty): |
| (KJS::::construct): |
| (KJS::::hasInstance): |
| (KJS::::call): |
| (KJS::::getPropertyNames): |
| (KJS::::toNumber): |
| (KJS::::toString): |
| (KJS::::staticValueGetter): |
| (KJS::::callbackGetter): |
| * API/JSContextRef.cpp: |
| (JSGlobalContextCreateInGroup): |
| (JSGlobalContextRetain): |
| (JSGlobalContextRelease): |
| * API/JSObjectRef.cpp: |
| (JSObjectMake): |
| (JSObjectMakeFunctionWithCallback): |
| (JSObjectMakeConstructor): |
| (JSObjectMakeFunction): |
| (JSObjectHasProperty): |
| (JSObjectGetProperty): |
| (JSObjectSetProperty): |
| (JSObjectGetPropertyAtIndex): |
| (JSObjectSetPropertyAtIndex): |
| (JSObjectDeleteProperty): |
| (JSObjectCallAsFunction): |
| (JSObjectCallAsConstructor): |
| (JSObjectCopyPropertyNames): |
| (JSPropertyNameArrayRelease): |
| (JSPropertyNameAccumulatorAddName): |
| * API/JSStringRef.cpp: |
| (JSStringRelease): |
| * API/JSValueRef.cpp: |
| (JSValueIsEqual): |
| (JSValueIsInstanceOfConstructor): |
| (JSValueMakeNumber): |
| (JSValueMakeString): |
| (JSValueToNumber): |
| (JSValueToStringCopy): |
| (JSValueToObject): |
| (JSValueProtect): |
| (JSValueUnprotect): |
| * ForwardingHeaders/JavaScriptCore/JSLock.h: Removed. |
| * GNUmakefile.am: |
| * JavaScriptCore.exp: |
| * JavaScriptCore.order: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * kjs/AllInOneFile.cpp: |
| * kjs/JSGlobalData.cpp: |
| (KJS::JSGlobalData::JSGlobalData): |
| * kjs/JSGlobalData.h: |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::~JSGlobalObject): |
| (KJS::JSGlobalObject::init): |
| * kjs/JSLock.cpp: Removed. |
| * kjs/JSLock.h: Removed. |
| * kjs/Shell.cpp: |
| (functionGC): |
| (jscmain): |
| * kjs/collector.cpp: |
| (KJS::Heap::~Heap): |
| (KJS::Heap::heapAllocate): |
| (KJS::Heap::setGCProtectNeedsLocking): |
| (KJS::Heap::protect): |
| (KJS::Heap::unprotect): |
| (KJS::Heap::collect): |
| * kjs/identifier.cpp: |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::checkSyntax): |
| (KJS::Interpreter::evaluate): |
| |
| 2008-07-31 Alexey Proskuryakov <ap@webkit.org> |
| |
| Rubber-stamped by Oliver Hunt. |
| |
| Fix the Mac project to not display "test/" as part of file name for tests. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2008-07-31 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Alexey Proskuryakov. |
| |
| Rename USE(MULTIPLE_THREADS) to ENABLE(JSC_MULTIPLE_THREADS) |
| to better match the use/enable pattern (and better describe |
| the usage of the feature in question.) |
| |
| I also fixed a couple other ENABLE_ macros to be pre-processor |
| definition override-able to match the rest of the ENABLE_ macros |
| since it seems to be our convention that build systems can set |
| ENABLE_ macros in Makefiles. |
| |
| * kjs/InitializeThreading.cpp: |
| (KJS::initializeThreadingOnce): |
| * kjs/JSGlobalData.cpp: |
| (KJS::JSGlobalData::JSGlobalData): |
| (KJS::JSGlobalData::~JSGlobalData): |
| * kjs/MathObject.cpp: |
| * kjs/collector.cpp: |
| (KJS::Heap::Heap): |
| (KJS::Heap::~Heap): |
| (KJS::allocateBlock): |
| (KJS::Heap::markStackObjectsConservatively): |
| * kjs/collector.h: |
| * kjs/dtoa.cpp: |
| (KJS::pow5mult): |
| (KJS::rv_alloc): |
| (KJS::freedtoa): |
| (KJS::dtoa): |
| * wtf/FastMalloc.cpp: |
| * wtf/Platform.h: |
| * wtf/RefCountedLeakCounter.cpp: |
| |
| 2008-07-30 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Mark Rowe. |
| |
| Try to clean up our usage of USE(MULTIPLE_THREADS) vs. USE(PTHREADS) a little. |
| It looks like JSC assumes that if MULTIPLE_THREADS is defined, then pthreads will always be available |
| I'm not sure that's always the case for gtk, certainly not for Windows. We should eventually go back |
| and fix wtf/Threading.h to cover all these cases some day. |
| |
| * kjs/JSLock.cpp: |
| * kjs/collector.h: |
| * wtf/Platform.h: |
| |
| 2008-07-30 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Oliver. |
| |
| MSVC warns when structs are called classes or vice versa. |
| Make all the source refer to JSGlobalData as a class. |
| |
| * kjs/CommonIdentifiers.h: |
| * kjs/JSGlobalData.h: |
| * kjs/Parser.h: |
| * kjs/lexer.h: |
| |
| 2008-07-30 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Geoff Garen. |
| |
| Add consistency checks to UString to document and enforce its design. |
| |
| * kjs/ustring.cpp: |
| (KJS::UString::Rep::create): |
| (KJS::UString::Rep::destroy): |
| (KJS::UString::Rep::checkConsistency): |
| (KJS::UString::expandCapacity): |
| (KJS::UString::expandPreCapacity): |
| (KJS::UString::UString): |
| (KJS::UString::spliceSubstringsWithSeparators): |
| (KJS::UString::append): |
| * kjs/ustring.h: |
| (KJS::UString::Rep::checkConsistency): |
| |
| 2008-07-30 Gavin Barraclough <barraclough@apple.com> |
| |
| Reviewed by Geoff Garen. |
| |
| Fixes for Windows and non-AllInOne file build with SamplingTool, plus review fixes. |
| |
| * GNUmakefile.am: Adding SamplingTool.cpp to build. |
| * JavaScriptCore.exp: Export hooks to init & control SamplingTool. |
| * JavaScriptCore.pri: Adding SamplingTool.cpp to build. |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Adding SamplingTool.cpp to build. |
| * JavaScriptCore.xcodeproj/project.pbxproj: Adding SamplingTool.cpp to build. |
| * JavaScriptCoreSources.bkl: Adding SamplingTool.cpp to build. |
| * VM/Machine.cpp: MACHINE_SAMPLING_callingNativeFunction renamed MACHINE_SAMPLING_callingHostFunction |
| * VM/Machine.h: |
| * VM/Opcode.cpp: SamplingTool moved to SamplingTool.cpp/.h, opcodeNames generated from FOR_EACH_OPCODE_ID. |
| * VM/Opcode.h: |
| * VM/SamplingTool.cpp: Added .cpp/.h for SamplingTool. |
| * VM/SamplingTool.h: |
| * kjs/Shell.cpp: Switched SAMPLING_TOOL_ENABLED to ENABLE_SAMPLING_TOOL. |
| * wtf/Platform.h: Added ENABLE_SAMPLING_TOOL config option. |
| * kjs/nodes.cpp: Header include to fix non-AllInOne builds. |
| |
| 2008-07-30 Ariya Hidayat <ariya.hidayat@trolltech.com> |
| |
| Reviewed by Alexey Proskuryakov. |
| |
| Fix compilation without multi-threading support. |
| |
| * kjs/collector.cpp: |
| (KJS::Heap::Heap): |
| |
| 2008-07-30 Anders Carlsson <andersca@apple.com> |
| |
| Add WebKitAvailability.h forwarding header. |
| |
| * ForwardingHeaders/JavaScriptCore/WebKitAvailability.h: Added. |
| |
| 2008-07-30 Anders Carlsson <andersca@apple.com> |
| |
| Fix the else. |
| |
| * API/WebKitAvailability.h: |
| |
| 2008-07-30 Anders Carlsson <andersca@apple.com> |
| |
| * API/WebKitAvailability.h: |
| Fix Windows (and other non-Mac builds). |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| Add WebKitAvailability.h to the project. |
| |
| 2008-07-30 Anders Carlsson <andersca@apple.com> |
| |
| One step closer towards fixing the Windows build. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCoreGenerated.make: |
| Make sure to copy WebKitAvailability.h |
| |
| 2008-07-29 Gavin Barraclough <barraclough@apple.com> |
| |
| Reviewed by Geoff Garen. |
| |
| Bug 20209: Atomize constant strings |
| <https://bugs.webkit.org/show_bug.cgi?id=20209> |
| |
| Prevents significant performance degradation seen when a script contains multiple |
| identical strings that are used as keys to identify properties on objects. |
| |
| No performance change on SunSpider. |
| |
| * kjs/nodes.cpp: Atomize constant strings. |
| |
| 2008-07-30 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Alexey Proskuryakov. |
| |
| <rdar://problem/6111648> JavaScript exceptions fail if the scope chain includes the global object |
| |
| In an attempt to remove the branch I just added to KJS::depth I |
| used the existence of a Variable Object at a point in the scope |
| chain as an indicator of function or global scope activation. |
| However this assumption results in incorrect behaviour if the |
| global object is injected into the scope chain with 'with'. |
| |
| * VM/Machine.cpp: |
| (KJS::depth): |
| |
| 2008-07-30 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Geoff Garen. |
| |
| Don't call JSGarbageCollect() on a released context. |
| |
| * API/testapi.c: (main): |
| |
| 2008-07-29 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Geoff Garen. |
| |
| Implement JSContextGroup APIs to make concurrent execution possible for |
| JavaScriptCore clients. |
| |
| This changes the behavior of JSGlobalContextCreate(), so that it now uses a private context |
| group for each context, making JSlock implicit locking unnecessary. |
| |
| * API/JSContextRef.h: |
| * API/JSContextRef.cpp: |
| (JSContextGroupCreate): |
| (JSContextGroupRetain): |
| (JSContextGroupRelease): |
| (JSGlobalContextCreate): |
| (JSGlobalContextCreateInGroup): |
| (JSGlobalContextRelease): |
| (JSContextGetGroup): |
| Added new methods. JSGlobalContextCreate() calls JSGlobalContextCreateInGroup() now. |
| |
| * API/APICast.h: (toJS): (toRef): Added converters for JSContextGroupRef. |
| * API/JSBase.cpp: (JSGarbageCollect): JSGarbageCollect(0) is now a no-op, and the passed in |
| context is actually used. |
| |
| * API/JSBase.h: Aded a typedef for JSContextGroupRef. Updated documentation for |
| JSGarbageCollect(). |
| |
| * JavaScriptCore.exp: Removed JSGlobalData::sharedInstance(). |
| |
| * kjs/JSGlobalData.cpp: |
| * kjs/JSGlobalData.h: |
| Removed support for JSGlobalData shared instance. JSGlobalData::isSharedInstance member |
| variable still remains, to be deleted in a followup patch. |
| |
| * kjs/JSLock.cpp: (KJS::JSLock::JSLock): Disabled JSLock, to be deleted in a follow-up patch. |
| |
| * kjs/collector.cpp: |
| (KJS::Heap::markOtherThreadConservatively): Removed an assertion that referenced |
| JSGlobalData::sharedInstance. |
| |
| * kjs/collector.h: Made Heap destructor public, so that JSContextRelease can use it. |
| |
| 2008-07-29 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Geoff Garen. |
| |
| Fix a leak of ThreadRegistrar objects. |
| |
| As the heap is usually deleted when registered threads still exist, ThreadSpecific doesn't |
| have a chance to clean up per-thread object. Switched to native pthread calls, storing a |
| plain pointer that doesn't require cleanup. |
| |
| * kjs/collector.cpp: |
| (KJS::PlatformThread::PlatformThread): |
| (KJS::Heap::Thread::Thread): |
| (KJS::Heap::Heap): |
| (KJS::Heap::~Heap): |
| (KJS::Heap::registerThread): |
| (KJS::Heap::unregisterThread): |
| * kjs/collector.h: |
| |
| 2008-07-29 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Sam Weinig. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=20169 |
| Memory allocated with fastMalloc is freed with delete |
| |
| * VM/JSPropertyNameIterator.cpp: |
| (KJS::JSPropertyNameIterator::invalidate): Free the array properly. |
| (KJS::JSPropertyNameIterator::~JSPropertyNameIterator): Delete the array by calling |
| invalidate(). |
| |
| 2008-07-29 Mark Rowe <mrowe@apple.com> |
| |
| Attempt to fix the Qt build. |
| |
| * wtf/ThreadingQt.cpp: Add the extra argument to createThread. |
| |
| 2008-07-29 Adam Roben <aroben@apple.com> |
| |
| Change Vector::find to return an index instead of an iterator |
| |
| Indices are more natural than iterators when working with Vector. |
| |
| Reviewed by John Sullivan. |
| |
| * wtf/Vector.h: |
| (WTF::Vector::find): Changed to iterate the Vector manually and return |
| the index of the found item, rather than an iterator. When the item |
| could not be found, we return WTF::notFound. |
| |
| 2008-07-29 Adam Roben <aroben@apple.com> |
| |
| Windows build fix |
| |
| * wtf/ThreadingWin.cpp: |
| (WTF::setThreadName): Move a misplaced assertion to here... |
| (WTF::createThread): ...from here. |
| |
| 2008-07-29 Adam Roben <aroben@apple.com> |
| |
| Add support for setting thread names on Windows |
| |
| These thread names make it much easier to identify particular threads |
| in Visual Studio's Threads panel. |
| |
| WTF::createThread now takes a const char* representing the thread's |
| name. On Windows, we throw a special exception to set this string as |
| the thread's name. Other platforms do nothing with this name for now. |
| |
| Reviewed by Anders Carlsson. |
| |
| * JavaScriptCore.exp: Export the new version of createThread that |
| takes 3 arguments (the old one continues to be exported for backward |
| compatibility). |
| * wtf/Threading.h: Add a threadName argument to createThread. |
| |
| * wtf/ThreadingGtk.cpp: |
| (WTF::createThread): |
| * wtf/ThreadingNone.cpp: |
| (WTF::createThread): |
| Updated for function signature change. |
| |
| * wtf/ThreadingPthreads.cpp: |
| (WTF::createThread): Updated for function signature change. We keep |
| around the old 2-argument version of createThread for backward |
| compatibility. |
| |
| * wtf/ThreadingWin.cpp: |
| (WTF::setThreadName): Added. This function's implementation came from |
| MSDN. |
| (WTF::initializeThreading): Set the name of the main thread. |
| (WTF::createThread): Call setThreadName. We keep around the old |
| 2-argument version of createThread for backward compatibility. |
| |
| 2008-07-29 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Oliver Hunt. |
| |
| Store UString::Rep::isStatic bit in identifierTable pointer instead of reportedCost for |
| slightly nicer code and a 0.5% SunSpider improvement. |
| |
| * API/JSClassRef.cpp: |
| (OpaqueJSClass::~OpaqueJSClass): |
| (OpaqueJSClassContextData::OpaqueJSClassContextData): |
| * API/JSStringRef.cpp: |
| (JSStringRelease): |
| * kjs/PropertyNameArray.cpp: |
| (KJS::PropertyNameArray::add): |
| * kjs/identifier.cpp: |
| (KJS::IdentifierTable::~IdentifierTable): |
| (KJS::IdentifierTable::add): |
| (KJS::Identifier::addSlowCase): |
| (KJS::Identifier::remove): |
| * kjs/identifier.h: |
| (KJS::Identifier::add): |
| * kjs/ustring.cpp: |
| (KJS::): |
| (KJS::UString::Rep::create): |
| (KJS::UString::Rep::destroy): |
| * kjs/ustring.h: |
| (KJS::UString::Rep::identifierTable): |
| (KJS::UString::Rep::setIdentifierTable): |
| (KJS::UString::Rep::isStatic): |
| (KJS::UString::Rep::setStatic): |
| (KJS::UString::cost): |
| |
| 2008-07-28 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Renamed "ConstructTypeNative" => "ConstructTypeHost". |
| |
| 2008-07-26 Mark Rowe <mrowe@apple.com> |
| |
| Speculative fix for the wx build. |
| |
| * JavaScriptCoreSources.bkl: Add JSStaticScopeObject.cpp to the list of source files. |
| |
| 2008-07-25 Oliver Hunt <oliver@apple.com> |
| |
| RS=Cameron Zwarich. |
| |
| Whoops, forgot to save style correction. |
| |
| * kjs/JSStaticScopeObject.h: |
| |
| 2008-07-25 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Cameron Zwarich. |
| |
| Bug 19718: Named anonymous functions are slow accessing global variables |
| <https://bugs.webkit.org/show_bug.cgi?id=19718> |
| |
| To fix this we switch over to an activation-like scope object for |
| on which we attach the function name property, and add logic to |
| prevent cross scope assignment to read only properties. |
| |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::findScopedProperty): |
| (KJS::CodeGenerator::emitResolve): |
| * VM/CodeGenerator.h: |
| * kjs/AllInOneFile.cpp: |
| * kjs/JSStaticScopeObject.cpp: Added. |
| (KJS::JSStaticScopeObject::putWithAttributes): |
| (KJS::JSStaticScopeObject::isDynamicScope): |
| (KJS::JSStaticScopeObject::~JSStaticScopeObject): |
| (KJS::JSStaticScopeObject::getOwnPropertySlot): |
| * kjs/JSStaticScopeObject.h: Added. |
| (KJS::JSStaticScopeObject::JSStaticScopeObjectData::JSStaticScopeObjectData): |
| (KJS::JSStaticScopeObject::JSStaticScopeObject): |
| * kjs/nodes.cpp: |
| (KJS::FunctionCallResolveNode::emitCode): |
| (KJS::PostfixResolveNode::emitCode): |
| (KJS::PrefixResolveNode::emitCode): |
| (KJS::ReadModifyResolveNode::emitCode): |
| (KJS::AssignResolveNode::emitCode): |
| (KJS::FuncExprNode::makeFunction): |
| |
| 2008-07-25 kevino <kevino@theolliviers.com> |
| |
| wx build fix for Win. |
| |
| On wx/Win, including windows.h in Threading.h causes multiply-defined symbol errors |
| for libjpeg and wx, and also wx needs to include windows.h itself first for wx |
| includes to work right. So until we can find a better solution to this problem, |
| on wx, we work around the need to include windows.h here. |
| |
| * wtf/Threading.h: |
| |
| 2008-07-25 Adam Roben <aroben@apple.com> |
| |
| Windows build fix |
| |
| * JavaScriptCore.vcproj/testapi/testapi.vcproj: Add API/ to the |
| include path. |
| |
| 2008-07-25 Simon Hausmann <hausmann@webkit.org> |
| |
| Fix the build of jsc on Qt/Windows, make sure os-win32 is in the |
| include search path (added by WebKit.pri). |
| |
| * kjs/jsc.pro: |
| |
| 2008-07-25 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Simon Hausmann. |
| |
| Move JavaScriptCore API tests into a subdirectory of their own to avoid header name |
| conflicts and developer confusion. |
| |
| * API/JSNode.c: Removed. |
| * API/JSNode.h: Removed. |
| * API/JSNodeList.c: Removed. |
| * API/JSNodeList.h: Removed. |
| * API/Node.c: Removed. |
| * API/Node.h: Removed. |
| * API/NodeList.c: Removed. |
| * API/NodeList.h: Removed. |
| * API/minidom.c: Removed. |
| * API/minidom.html: Removed. |
| * API/minidom.js: Removed. |
| * API/testapi.c: Removed. |
| * API/testapi.js: Removed. |
| * API/tests: Added. |
| * API/tests/JSNode.c: Copied from JavaScriptCore/API/JSNode.c. |
| * API/tests/JSNode.h: Copied from JavaScriptCore/API/JSNode.h. |
| * API/tests/JSNodeList.c: Copied from JavaScriptCore/API/JSNodeList.c. |
| * API/tests/JSNodeList.h: Copied from JavaScriptCore/API/JSNodeList.h. |
| * API/tests/Node.c: Copied from JavaScriptCore/API/Node.c. |
| * API/tests/Node.h: Copied from JavaScriptCore/API/Node.h. |
| * API/tests/NodeList.c: Copied from JavaScriptCore/API/NodeList.c. |
| * API/tests/NodeList.h: Copied from JavaScriptCore/API/NodeList.h. |
| * API/tests/minidom.c: Copied from JavaScriptCore/API/minidom.c. |
| * API/tests/minidom.html: Copied from JavaScriptCore/API/minidom.html. |
| * API/tests/minidom.js: Copied from JavaScriptCore/API/minidom.js. |
| * API/tests/testapi.c: Copied from JavaScriptCore/API/testapi.c. |
| * API/tests/testapi.js: Copied from JavaScriptCore/API/testapi.js. |
| * GNUmakefile.am: |
| * JavaScriptCore.vcproj/testapi/testapi.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2008-07-25 Simon Hausmann <hausmann@webkit.org> |
| |
| Prospective WX build fix, add JavaScriptCore/API to the include search |
| path. |
| |
| * jscore.bkl: |
| |
| 2008-07-25 Simon Hausmann <hausmann@webkit.org> |
| |
| Rubber-stamped by Lars. |
| |
| Fix the build on Windows. operator new for ArgList is implemented using fastMalloc() |
| but operator delete was not implemented. Unfortunately MSVC decides to call/reference |
| the function, so a simple implementation using fastFree() fixes the build. |
| |
| * kjs/ArgList.h: |
| (KJS::ArgList::operator delete): |
| |
| 2008-07-25 Simon Hausmann <hausmann@webkit.org> |
| |
| Discussed with and rubber-stamped by Lars. |
| |
| Fix the build system for the Qt port. |
| |
| Recent JavaScriptCore changes require the addition of JavaScriptCore/API to the |
| include search path. With a build process that combines JavaScriptCore and |
| WebCore in one build process/Makefile the existance of |
| JavaScriptCore/API/Node.h and WebCore/dom/Node.h causes include conflicts. |
| |
| This commit solves this by introducing a separate build of JavaScriptCore into |
| a static library. |
| |
| As a result of the split-up a race-condition due to broken dependencies of |
| regular source files to header files of generated sources showed up very |
| frequently when doing parallel builds (which the buildbot does). This commit at |
| the same time tries to address the dependency problem by making the |
| addExtraCompiler() function also generate a pseudo extra compiler that |
| represents the header file output, so that qmake is aware of the creation of |
| the header file for dependency calculation. |
| |
| At the same time I removed a lot of cruft from the pro files to ease maintenance. |
| |
| * JavaScriptCore.pri: |
| * JavaScriptCore.pro: Added. |
| * kjs/jsc.pro: |
| |
| 2008-07-24 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Fixed a strict aliasing violation, which caused hash tables with floating |
| point keys not to find items that were indeed in the tables |
| (intermittently, and only in release builds, of course). |
| |
| SunSpider reports no change. |
| |
| This bug doesn't seem to affect any existing code, but it causes obvious |
| crashes in some new code I'm working on. |
| |
| * wtf/HashFunctions.h: |
| (WTF::FloatHash::hash): Use a union when punning between a float / double |
| and an unsigned (bucket of bits). With strict aliasing enabled, unions |
| are the only safe way to do this kind of type punning. |
| |
| * wtf/HashTable.h: When rehashing, ASSERT that the item we just added to |
| the table is indeed in the table. In the buggy case described above, this |
| ASSERT fires. |
| |
| 2008-07-24 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Alexey Proskuryakov. |
| |
| Bug 20142: REGRESSION(r35245): /=/ weirdness |
| <https://bugs.webkit.org/show_bug.cgi?id=20142> |
| |
| When adding all the meta data needed for exception error messages |
| I accidentally clobbered the handling of regex beginning with /=. |
| |
| * kjs/grammar.y: |
| |
| 2008-07-23 Alp Toker <alp@nuanti.com> |
| |
| Build fix after r35293: Add API/ to the include path. |
| |
| * GNUmakefile.am: |
| |
| 2008-07-23 Adam Roben <aroben@apple.com> |
| |
| Windows build fixes |
| |
| Build fix after r35293: |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Add API/ |
| to the include path. |
| |
| Build fix after r35305: |
| |
| * VM/Machine.cpp: |
| * VM/Machine.h: |
| * VM/Opcode.cpp: |
| * VM/Opcode.h: |
| Completely compile out all sampler-related code when |
| SAMPLING_TOOL_ENABLED is 0. The sampler code can't be compiled 1) on |
| non-AllInOne configurations due to circular header dependencies, and |
| 2) on platforms that don't have a usleep() function, such as Windows. |
| |
| 2008-07-23 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff Garen and Sam Weinig. |
| |
| Improve switch performance. |
| |
| Improve switch performance by converting to a hashmap based jump |
| table to avoid the sequence of dispatches that would otherwise be |
| needed. This results in a 9-19x performance win for string switches |
| based on ad hoc testing, and a 6x improvement for integer switch |
| statements. SunSpider reports a 1.2% progression. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| (KJS::SimpleJumpTable::offsetForValue): |
| * VM/CodeBlock.h: |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::beginSwitch): |
| (KJS::prepareJumpTableForImmediateSwitch): |
| (KJS::prepareJumpTableForCharacterSwitch): |
| (KJS::prepareJumpTableForStringSwitch): |
| (KJS::CodeGenerator::endSwitch): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::offsetForStringSwitch): |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.cpp: |
| (KJS::): |
| * VM/Opcode.h: |
| * kjs/JSImmediate.h: |
| * kjs/nodes.cpp: |
| (KJS::): |
| (KJS::processClauseList): |
| (KJS::CaseBlockNode::tryOptimisedSwitch): |
| (KJS::CaseBlockNode::emitCodeForBlock): |
| * kjs/nodes.h: |
| (KJS::SwitchInfo::): |
| |
| 2008-07-23 Gavin Barraclough <barraclough@apple.com> |
| |
| Reviewed by Geoff Garen. |
| |
| Sampling tool to analyze cost of instruction execution and identify hot regions of JS code. |
| Enable Switches by setting SAMPLING_TOOL_ENABLED in Opcode.h. |
| |
| * JavaScriptCore.exp: Export symbols for Shell.cpp. |
| * VM/Machine.cpp: Added sampling hooks. |
| * VM/Machine.h: Machine contains a pointer to a sampler, when sampling. |
| * VM/Opcode.cpp: Tool implementation. |
| * VM/Opcode.h: Tool declaration. |
| * kjs/Shell.cpp: Initialize the sampler, if enabled. |
| * kjs/nodes.cpp: Added sampling hooks. |
| |
| 2008-07-23 Gabor Loki <loki@inf.u-szeged.hu> |
| |
| Bug 20097: [Qt] 20% Sunspider slow-down |
| |
| <https://bugs.webkit.org/show_bug.cgi?id=20097> |
| |
| Reviewed by Simon Hausmann. |
| |
| * kjs/jsc.pro: Added missing NDEBUG define for release builds. |
| |
| 2008-07-23 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Geoff Garen. |
| |
| JSClassRef is created context-free, but gets infatuated with the first context it sees. |
| |
| The implicit API contract is that JSClassRef can be used with any context on any thread. |
| This no longer worked, because UStrings in the class were turned into per-context |
| identifiers, and the cached JSObject prototype was tied to JSGlobalData, too. |
| |
| * API/JSClassRef.h: Made a separate struct for context-dependent parts of OpaqueJSClass. |
| * API/JSClassRef.cpp: |
| (OpaqueJSClass::OpaqueJSClass): Updated for renames and changed member variable order. |
| (OpaqueJSClass::~OpaqueJSClass): Assert that string members are not identifiers. |
| (clearReferenceToPrototype): Update for the new reference location. |
| (OpaqueJSClassContextData::OpaqueJSClassContextData): Make a deep copy of all strings. |
| (OpaqueJSClass::contextData): Added a function that finds the per-context part of |
| OpaqueJSClass in JSGlobalData, or creates it if not found. |
| (OpaqueJSClass::className): Always make a deep copy. Callers of this function do not have |
| a way to access JSGlobalData, so a per-context copy could not be made. |
| (OpaqueJSClass::staticValues): Updated for new data location. |
| (OpaqueJSClass::staticFunctions): Ditto. |
| (OpaqueJSClass::prototype): Changed to take an internal type for consistency. |
| |
| * kjs/JSGlobalData.cpp: |
| (KJS::JSGlobalData::JSGlobalData): |
| (KJS::JSGlobalData::~JSGlobalData): |
| * kjs/JSGlobalData.h: |
| Keep a HashMap to access per-context JSClass data given a pointr to the shared part. |
| |
| * API/JSCallbackObjectFunctions.h: |
| (KJS::::className): |
| (KJS::::getOwnPropertySlot): |
| (KJS::::put): |
| (KJS::::deleteProperty): |
| (KJS::::getPropertyNames): |
| (KJS::::staticValueGetter): |
| (KJS::::staticFunctionGetter):j |
| Use function accessors instead of accessing OpaqueJSClass members directly. |
| |
| * API/JSContextRef.cpp: (JSGlobalContextCreate): Updated for the change in |
| OpaqueJSClass::prototype() argument type. |
| |
| * API/JSObjectRef.cpp: |
| (JSObjectMake): Updated for the change in OpaqueJSClass::prototype() argument type. |
| (JSObjectMakeConstructor): Ditto. |
| |
| 2008-07-23 Alexey Proskuryakov <ap@webkit.org> |
| |
| Build fix. |
| |
| * kjs/ArgList.h: (KJS::ArgList::operator new): removed an extraneous "ArgList::" inside the |
| class definition. |
| |
| 2008-07-22 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt and Sam Weinig. |
| |
| Next step toward putting doubles in registers: Prepare the Register class |
| and its clients for registers that don't contain JSValue*s. |
| |
| This means a few things: |
| |
| 1. Register::jsValue() clients, including ArgList clients, must now supply |
| an ExecState* when accessing an entry in an ArgList, in case the entry |
| will need to create a JSValue* on the fly. |
| |
| 2. Register clients that definitely don't want to create a JSValue* on |
| the fly now use different APIs: getJSValue() for clients that know |
| the register contains a JSValue*, and v() for clients who just want a |
| void*. |
| |
| 3. I had to change some headers around in order to resolve dependency |
| problems created by using a Register in the ArgList header. |
| |
| SunSpider reports no change. |
| |
| 2008-07-22 Gavin Barraclough <barraclough@apple.com> |
| |
| Reviewed by Alexey Proskuryakov. |
| |
| Prevent integer overflow when reallocating storage vector for arrays. |
| |
| Sunspider reports 1.005x as fast (no change expected). |
| |
| * kjs/JSArray.cpp: |
| |
| 2008-07-21 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| <rdar://problem/6091287> Revamp the handling of CFBundleShortVersionString to be fixed at the major component of the version number. |
| |
| * Configurations/Version.xcconfig: |
| * Info.plist: |
| |
| 2008-07-21 Adam Roben <aroben@apple.com> |
| |
| Add Vector::find |
| |
| This is a convenience wrapper around std::find. |
| |
| Reviewed by Anders Carlsson. |
| |
| * wtf/Vector.h: |
| |
| 2008-07-19 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Cameron Zwarich. |
| |
| Bug 20104: Exception in tables/mozilla_expected_failures/bugs/bug92868_1.html includes the equals operator in the quoted expression |
| <https://bugs.webkit.org/show_bug.cgi?id=20104> |
| |
| To make this correct we make the dot and bracket assign nodes emit the information to indicate |
| the failure range is the dot/bracket accessor. |
| |
| * kjs/grammar.y: |
| |
| 2008-07-18 Steve Falkenburg <sfalken@apple.com> |
| |
| Windows build fix. |
| |
| * kjs/JSGlobalObjectFunctions.cpp: |
| (KJS::isStrWhiteSpace): |
| |
| 2008-07-18 Steve Falkenburg <sfalken@apple.com> |
| |
| Windows build fix. |
| |
| * kjs/nodes.h: |
| (KJS::ThrowableExpressionData::ThrowableExpressionData): |
| |
| 2008-07-18 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Cameron Zwarich. |
| |
| Bug 18774: SQUIRRELFISH: print meaningful error messages <https://bugs.webkit.org/show_bug.cgi?id=18774> |
| <rdar://problem/5769353> SQUIRRELFISH: JavaScript error messages are missing informative text |
| |
| Add support for decent error messages in JavaScript. This patch achieves this by providing |
| ensuring the common errors and exceptions have messages that provide the text of expression |
| that trigger the exception. In addition it attaches a number of properties to the exception |
| object detailing where in the source the expression came from. |
| |
| * JavaScriptCore.exp: |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::lineNumberForVPC): |
| (KJS::CodeBlock::expressionRangeForVPC): |
| Function to recover the expression range for an instruction |
| that triggered an exception. |
| * VM/CodeBlock.h: |
| (KJS::ExpressionRangeInfo::): |
| (KJS::CodeBlock::CodeBlock): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitCall): |
| (KJS::CodeGenerator::emitCallEval): |
| Emit call needed to be modified so to place the expression range info internally, |
| as the CodeGenerator emits the arguments nodes itself, rather than the various call |
| nodes. |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::emitExpressionInfo): |
| Record the expression range info. |
| * VM/ExceptionHelpers.cpp: |
| (KJS::createErrorMessage): |
| (KJS::createInvalidParamError): |
| (KJS::createUndefinedVariableError): |
| (KJS::createNotAConstructorError): |
| (KJS::createNotAFunctionError): |
| (KJS::createNotAnObjectErrorStub): |
| (KJS::createNotAnObjectError): |
| Rewrite all the code for the error messages so that they make use of the newly available |
| information. |
| * VM/ExceptionHelpers.h: |
| * VM/Machine.cpp: |
| (KJS::isNotObject): Now needs vPC and codeBlock |
| (KJS::Machine::throwException): |
| New logic to handle the NotAnObjectErrorStub and to handle the absurd "no default value" edge case |
| (KJS::Machine::privateExecute): |
| * VM/Machine.h: |
| * kjs/DebuggerCallFrame.cpp: |
| (KJS::DebuggerCallFrame::evaluate): |
| * kjs/Error.cpp: |
| (KJS::Error::create): |
| * kjs/Error.h: |
| * kjs/JSGlobalObjectFunctions.cpp: |
| * kjs/JSImmediate.cpp: |
| (KJS::JSImmediate::toObject): |
| (KJS::JSImmediate::prototype): |
| My changes to the JSNotAnObject constructor needed to be handled here. |
| * kjs/JSNotAnObject.h: |
| (KJS::JSNotAnObjectErrorStub::JSNotAnObjectErrorStub): |
| (KJS::JSNotAnObjectErrorStub::isNull): |
| (KJS::JSNotAnObjectErrorStub::isNotAnObjectErrorStub): |
| Added a JSNotAnObjectErrorStub class to ease the handling of toObject failure exceptions, |
| and potentially allow even more detailed error messages in future. |
| * kjs/JSObject.h: |
| * kjs/Parser.h: |
| (KJS::Parser::parse): |
| * kjs/SourceRange.h: |
| * kjs/grammar.y: |
| Large amounts of position propagation. |
| * kjs/lexer.cpp: |
| (KJS::Lexer::Lexer): |
| (KJS::Lexer::shift): |
| (KJS::Lexer::lex): |
| The lexer needed a few changes to be able to correctly track token character positions. |
| * kjs/lexer.h: |
| * kjs/nodes.cpp: |
| (KJS::ThrowableExpressionData::emitThrowError): |
| (KJS::StatementNode::StatementNode): |
| (KJS::ResolveNode::emitCode): |
| (KJS::BracketAccessorNode::emitCode): |
| (KJS::DotAccessorNode::emitCode): |
| (KJS::NewExprNode::emitCode): |
| (KJS::EvalFunctionCallNode::emitCode): |
| (KJS::FunctionCallValueNode::emitCode): |
| (KJS::FunctionCallResolveNode::emitCode): |
| (KJS::FunctionCallBracketNode::emitCode): |
| (KJS::FunctionCallDotNode::emitCode): |
| (KJS::PostfixResolveNode::emitCode): |
| (KJS::PostfixBracketNode::emitCode): |
| (KJS::PostfixDotNode::emitCode): |
| (KJS::DeleteResolveNode::emitCode): |
| (KJS::DeleteBracketNode::emitCode): |
| (KJS::DeleteDotNode::emitCode): |
| (KJS::PrefixResolveNode::emitCode): |
| (KJS::PrefixBracketNode::emitCode): |
| (KJS::PrefixDotNode::emitCode): |
| (KJS::ThrowableBinaryOpNode::emitCode): |
| (KJS::ReadModifyResolveNode::emitCode): |
| (KJS::AssignResolveNode::emitCode): |
| (KJS::AssignDotNode::emitCode): |
| (KJS::ReadModifyDotNode::emitCode): |
| (KJS::AssignBracketNode::emitCode): |
| (KJS::ReadModifyBracketNode::emitCode): |
| (KJS::ForInNode::ForInNode): |
| (KJS::ForInNode::emitCode): |
| (KJS::WithNode::emitCode): |
| (KJS::LabelNode::emitCode): |
| (KJS::ThrowNode::emitCode): |
| (KJS::ProgramNode::ProgramNode): |
| (KJS::ProgramNode::create): |
| (KJS::EvalNode::generateCode): |
| (KJS::FunctionBodyNode::create): |
| (KJS::FunctionBodyNode::generateCode): |
| (KJS::ProgramNode::generateCode): |
| All of these methods were handling the position information. |
| Constructors and create methods were modified to store the information. |
| All the emitCall implementations listed needed to be updated to actually |
| record the position information we have so carefully collected. |
| * kjs/nodes.h: |
| (KJS::ThrowableExpressionData::ThrowableExpressionData): |
| (KJS::ThrowableExpressionData::setExceptionSourceRange): |
| (KJS::ThrowableExpressionData::divot): |
| (KJS::ThrowableExpressionData::startOffset): |
| (KJS::ThrowableExpressionData::endOffset): |
| (KJS::ThrowableSubExpressionData::ThrowableSubExpressionData): |
| (KJS::ThrowableSubExpressionData::setSubexpressionInfo): |
| (KJS::ThrowablePrefixedSubExpressionData::ThrowablePrefixedSubExpressionData): |
| (KJS::ThrowablePrefixedSubExpressionData::setSubexpressionInfo): |
| ThrowableExpressionData is just a uniform mechanism for storing the position |
| information. |
| (KJS::ResolveNode::): |
| (KJS::PrePostResolveNode::): |
| (KJS::ThrowableBinaryOpNode::): |
| (KJS::WithNode::): |
| |
| 2008-07-18 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Cameron Zwarich. |
| |
| Three renames: |
| |
| "CallTypeNative" => "CallTypeHost" |
| "code" => "byteCode" |
| "generatedCode" => "generatedByteCode" |
| |
| 2008-07-18 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Optimized <= for immediate number cases. |
| |
| SunSpider reports no overall change, but a 10% speedup on access-nsieve. |
| |
| 2008-07-18 Mark Rowe <mrowe@apple.com> |
| |
| Rubber-stamped by Sam Weinig. |
| |
| Fix some casts added in a previous build fix to match the style used |
| throughout WebKit. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::initializeCallFrame): |
| * VM/Register.h: |
| (KJS::Register::Register): |
| |
| 2008-07-18 Landry Breuil <landry@openbsd.org> |
| |
| Bug 19975: [OpenBSD] Patches to enable build of WebKit |
| |
| <https://bugs.webkit.org/show_bug.cgi?id=19975> |
| |
| Reviewed by David Kilzer. |
| |
| Support for OpenBSD, mostly threading and libm tweaks. |
| |
| * kjs/collector.cpp: #include <pthread.h> |
| (KJS::currentThreadStackBase): use pthread_stackseg_np() to get stack base |
| * kjs/config.h: OpenBSD also provides <pthread_np.h> |
| * wtf/MathExtras.h: #include <sys/types.h> and <machine/ieee.h> |
| (isfinite), (signbit): as long as we don't have those functions provide fallback implementations |
| * wtf/Platform.h: Add support for PLATFORM(OPENBSD) and PLATFORM(SPARC64) macro |
| |
| 2008-07-17 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Next step toward putting doubles in registers: Store constant pool |
| entries as registers, not JSValue*s. |
| |
| SunSpider reports no change. |
| |
| 2008-07-17 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by John Sullivan and Oliver Hunt. |
| |
| A tiny bit of tidying in function call register allocation. |
| |
| This patch saves one register when invoking a function expression and/or |
| a new expression that is stored in a temporary. |
| |
| Since it's just one register, I can't make a testcase for it. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitCall): No need to ref the function we're calling |
| or its base. We'd like the call frame to overlap with them, if possible. |
| op_call will read the function and its base before writing the call frame, |
| so this is safe. |
| |
| * kjs/nodes.cpp: |
| (KJS::NewExprNode::emitCode): No need to ref the function we're new-ing, |
| for the same reasons stated above. |
| |
| (KJS::FunctionCallValueNode::emitCode): ditto |
| |
| 2008-07-17 Steve Falkenburg <sfalken@apple.com> |
| |
| Build fix. |
| |
| * kjs/InternalFunction.cpp: |
| |
| 2008-07-17 Sam Weinig <sam@webkit.org> |
| |
| Roll out r35199 as it is causing failures on the PPC build. |
| |
| 2008-07-17 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by David Kilzer. |
| |
| Fixed https://bugs.webkit.org/show_bug.cgi?id=20067 |
| Support function.name (Firefox extension) |
| |
| Pretty straight-forward. |
| |
| 2008-07-17 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fixed <rdar://problem/6081636> Functions calls use more temporary |
| registers than necessary |
| |
| Holding a reference to the last statement result register caused each |
| successive statement to output its result to an even higher register. |
| |
| Happily, statements don't actually need to return a result register |
| at all. I hope to make this clearer in a future cleanup patch, |
| but this change will fix the major bug for now. |
| |
| * kjs/nodes.cpp: |
| (KJS::statementListEmitCode): |
| |
| 2008-07-17 Gavin Barraclough <barraclough@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Merge pre&post dot nodes to simplify the parse tree. |
| Sunspider results show 0.6% progression (no performance change expected). |
| |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| * kjs/nodes.h: |
| * kjs/nodes2string.cpp: |
| |
| 2008-07-17 Gavin Barraclough <barraclough@apple.com> |
| |
| Reviewed by Cameron Zwarich. |
| |
| Merge pre&post resolve nodes to simplify the parse tree. |
| Sunspider results show no performance change. |
| |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| * kjs/nodes.h: |
| * kjs/nodes2string.cpp: |
| |
| 2008-07-17 Gavin Barraclough <barraclough@apple.com> |
| |
| Reviewed by Cameron Zwarich. |
| |
| Merge logical nodes to simplify the parse tree. |
| Sunspider results show 0.6% progression (no performance change expected). |
| |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| * kjs/nodes.h: |
| * kjs/nodes2string.cpp: |
| |
| 2008-07-17 Ariya Hidayat <ariya.hidayat@trolltech.com> |
| |
| Reviewed by Simon. |
| |
| Fix MinGW build (broken in r35198) and simplify getLocalTime(). |
| |
| * kjs/DateMath.cpp: |
| (KJS::getLocalTime): |
| |
| 2008-07-17 Gavin Barraclough <barraclough@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Merge pre&post bracket nodes to simplify the parse tree. |
| Sunspider results show no performance change. |
| |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| * kjs/nodes.h: |
| * kjs/nodes2string.cpp: |
| |
| 2008-07-17 Ariya Hidayat <ariya.hidayat@trolltech.com> |
| |
| Reviewed by Simon. |
| |
| Fix the 32-bit gcc builds, conversion from "long int" to Register is |
| ambiguous. Explicitly choose the intptr_t constructor. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::initializeCallFrame): |
| * VM/Register.h: |
| (KJS::Register::Register): |
| |
| 2008-07-16 Mark Rowe <mrowe@apple.com> |
| |
| Rubber-stamped by Geoff Garen. |
| |
| Fix JavaScript in 64-bit by using a pointer-sized integer |
| type in the Register union. Also includes a rename of |
| the intType constant to IntType. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::initializeCallFrame): |
| * VM/Register.h: |
| (KJS::Register::): |
| (KJS::Register::Register): |
| |
| 2008-07-17 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| First step toward putting doubles in registers: Turned Register into a |
| proper abstraction layer. It is no longer possible to cast a Register |
| to a JSValue*, or a Register& to a JSValue*&, or to access the union |
| inside a Register directly. |
| |
| SunSpider reports no change. |
| |
| In support of this change, I had to make the following mechanical changes |
| in a lot of places: |
| |
| 1. Clients now use explicit accessors to read data out of Registers, and |
| implicit copy constructors to write data into registers. |
| |
| So, assignment that used to look like |
| |
| x.u.jsValue = y; |
| |
| now looks like |
| |
| x = y; |
| |
| And access that used to look like |
| |
| x = y.u.jsValue; |
| |
| now looks like |
| |
| x = y.jsValue(); |
| |
| 2. I made generic flow control specific in opcodes that made their flow |
| control generic by treating a Register& as a JSValue*&. This had the |
| added benefit of removing some exception checking branches from immediate |
| number code. |
| |
| 3. I beefed up PropertySlot to support storing a Register* in a property |
| slot. For now, only JSVariableObject's symbolTableGet and symbolTablePut |
| use this functionality, but I expect more clients to use it in the future. |
| |
| 4. I changed ArgList to be a buffer of Registers, not JSValue*'s, and I |
| changed ArgList iterator clients to iterate Registers, not JSValue*'s. |
| |
| 2008-07-16 Ada Chan <adachan@apple.com> |
| |
| Fixed build. |
| |
| * kjs/JSGlobalObject.cpp: |
| |
| 2008-07-16 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Sam and Geoff. |
| |
| <rdar://problem/5958840> Navigating to another page while profiler is |
| attached results in slow JavaScript for all time. |
| |
| - The UNLIKELY keeps this from being a sunspider performance regression. |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::~JSGlobalObject): Stop the profiler associated |
| with this exec state. |
| |
| 2008-07-16 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Steve Falkenburg. |
| |
| Replace adopting UString constructor in favor of explicit |
| static adopt method. |
| |
| * API/JSStringRefCF.cpp: |
| (JSStringCreateWithCFString): |
| * kjs/StringConstructor.cpp: |
| (KJS::stringFromCharCode): |
| * kjs/StringPrototype.cpp: |
| (KJS::stringProtoFuncToLowerCase): |
| (KJS::stringProtoFuncToUpperCase): |
| (KJS::stringProtoFuncToLocaleLowerCase): |
| (KJS::stringProtoFuncToLocaleUpperCase): |
| * kjs/ustring.cpp: |
| (KJS::UString::adopt): |
| * kjs/ustring.h: |
| (KJS::UString::UString): |
| (KJS::UString::~UString): |
| |
| 2008-07-16 Ariya Hidayat <ariya.hidayat@trolltech.com> |
| |
| Reviewed by Simon. |
| |
| http://trolltech.com/developer/task-tracker/index_html?method=entry&id=216179 |
| Fix potential crash (on Qt for Windows port) when performing JavaScript date |
| conversion. |
| |
| * kjs/DateMath.cpp: |
| (KJS::getLocalTime): For the Qt port, prefer to use Windows code, i.e. |
| localtime_s() instead of localtime() since the latter might crash (on Windows) |
| given a non-sensible, e.g. NaN, argument. |
| |
| 2008-07-16 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Anders and Geoff. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=20023 |
| Failed assertion in PropertyNameArray.cpp |
| |
| This is already tested by testapi. |
| |
| * API/JSObjectRef.cpp: (JSPropertyNameAccumulatorAddName): Add the string to identifier |
| table to appease PropertyNameArray. |
| |
| 2008-07-16 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Geoff. |
| |
| Dereference identifiers when deleting a hash table (fixes leaks with private JSGlobalData |
| objects). |
| |
| * kjs/JSGlobalData.cpp: (KJS::JSGlobalData::~JSGlobalData): |
| * kjs/lookup.cpp: (KJS::HashTable::deleteTable): |
| * kjs/lookup.h: |
| * kjs/lexer.cpp: (KJS::Lexer::~Lexer) |
| HashTable cannot have a destructor, because check-for-global-initializers complains about |
| having a global constructor then. |
| |
| 2008-07-16 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Geoff. |
| |
| Check pthread_key_create return value. |
| |
| This check was helpful when debugging a crash in run-webkit-tests --threaded that happened |
| because JSGlobalData objects were not deleted, and we were running out of pthread keys soon. |
| It also looks useful for production builds. |
| |
| * wtf/ThreadSpecific.h: (WTF::::ThreadSpecific): |
| |
| 2008-07-15 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Rename pageGroupIdentifier to profileGroup to keep mention of a |
| pageGroup out of JavaScriptCore. |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::init): |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::setProfileGroup): |
| (KJS::JSGlobalObject::profileGroup): |
| * profiler/ProfileGenerator.cpp: |
| (KJS::ProfileGenerator::create): |
| (KJS::ProfileGenerator::ProfileGenerator): |
| * profiler/ProfileGenerator.h: |
| (KJS::ProfileGenerator::profileGroup): |
| * profiler/Profiler.cpp: |
| (KJS::Profiler::startProfiling): |
| (KJS::dispatchFunctionToProfiles): |
| (KJS::Profiler::willExecute): |
| (KJS::Profiler::didExecute): |
| |
| 2008-07-14 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Fix https://bugs.webkit.org/show_bug.cgi?id=20037 |
| Bug 20037: GCC 4.2 build broken due to strict aliasing violation. |
| |
| * kjs/ustring.cpp: |
| (KJS::UString::Rep::computeHash): Add a version of computeHash that takes a char* and explicit length. |
| * kjs/ustring.h: |
| * profiler/CallIdentifier.h: |
| (WTF::): Use new version of computeHash that takes a char* and explicit length to avoid unsafe aliasing. |
| |
| 2008-07-14 David Hyatt <hyatt@apple.com> |
| |
| Fix a crashing bug in ListHashSet's -- operator. Make sure that end() can be -- by special-casing the null |
| position. |
| |
| Reviewed by Maciej |
| |
| * wtf/ListHashSet.h: |
| (WTF::ListHashSetConstIterator::operator--): |
| |
| 2008-07-14 David Hyatt <hyatt@apple.com> |
| |
| Buidl fix. Make sure the second insertBefore method returns a value. |
| |
| * wtf/ListHashSet.h: |
| (WTF::::insertBefore): |
| |
| 2008-07-14 Adam Roben <aroben@apple.com> |
| |
| Windows build fix |
| |
| * JavaScriptCore.vcproj/jsc/jsc.vcproj: Added include/pthreads to the |
| include path. |
| |
| 2008-07-14 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Kevin McCullough. |
| |
| Make JSGlobalData refcounted in preparation to adding a way to create contexts that share |
| global data. |
| |
| * JavaScriptCore.exp: |
| * kjs/JSGlobalData.cpp: |
| (KJS::JSGlobalData::create): |
| * kjs/JSGlobalData.h: |
| Made contructor private, and added a static create() method. Made the class inherit from |
| RefCounted. |
| |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::globalData): |
| JSGlobalData is now owned by JSGlobalObject (except for the shared one, and the common |
| WebCore one, which are never deleted). |
| |
| * kjs/Shell.cpp: (main): Create JSGlobalData with create() method. |
| |
| 2008-07-14 Simon Hausmann <hausmann@webkit.org> |
| |
| Fix the single-threaded build. |
| |
| * kjs/JSLock.cpp: Removed undeclared registerThread() function. |
| * kjs/collector.cpp: |
| (KJS::Heap::registerThread): Added dummy implementation. |
| |
| 2008-07-14 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Geoff Garen. |
| |
| Eliminate per-thread JavaScript global data instance support and make arbitrary |
| global data/global object combinations possible. |
| |
| * kjs/collector.cpp: |
| (KJS::Heap::Heap): Store a JSGlobalData pointer instead of multiple pointers to its members. |
| This allows for going from any JS object to its associated global data, currently used in |
| JSGlobalObject constructor to initialize its JSGlobalData pointer. |
| (KJS::Heap::registerThread): Changed thread registration data to be per-heap. Previously, |
| only the shared heap could be used from multiple threads, so it was the only one that needed |
| thread registration, but now this can happen to any heap. |
| (KJS::Heap::unregisterThread): Ditto. |
| (KJS::Heap::markStackObjectsConservatively): Adapt for the above changes. |
| (KJS::Heap::setGCProtectNeedsLocking): Ditto. |
| (KJS::Heap::protect): Ditto. |
| (KJS::Heap::unprotect): Ditto. |
| (KJS::Heap::collect): Ditto. |
| (KJS::Heap::globalObjectCount): Use global object list associated with the current heap, |
| not the late per-thread one. |
| (KJS::Heap::protectedGlobalObjectCount): Ditto. |
| |
| * kjs/collector.h: |
| (KJS::Heap::ThreadRegistrar): Added a helper object that unregisters a thread when it is |
| destroyed. |
| |
| * kjs/JSLock.cpp: |
| (KJS::JSLock::JSLock): |
| * kjs/JSLock.h: |
| (KJS::JSLock::JSLock): |
| Don't use JSLock to implicitly register threads. I've added registerThread() calls to most |
| places that use JSLock - we cannot guarantee absolute safety unless we always mark all |
| threads in the process, but these implicit registration calls should cover reasonable usage |
| scenarios, I hope. |
| |
| * API/JSBase.cpp: |
| (JSEvaluateScript): Explicitly register the current thread. |
| (JSCheckScriptSyntax): Explicitly register the current thread. |
| (JSGarbageCollect): Changed to use the passed in context. Unfortunately, this creates a race |
| condition for clients that pass an already released context to JSGarbageCollect - but it is |
| unlikely to create real life problems. |
| To maintain compatibility, the shared heap is collected if NULL is passed. |
| |
| * API/JSContextRef.cpp: |
| (JSGlobalContextCreate): Use a new syntax for JSGlobalObject allocation. |
| (JSGlobalContextRetain): Register the thread. |
| (JSContextGetGlobalObject): Register the thread. |
| |
| * API/JSObjectRef.cpp: |
| (JSObjectMake): |
| (JSObjectMakeFunctionWithCallback): |
| (JSObjectMakeConstructor): |
| (JSObjectMakeFunction): |
| (JSObjectHasProperty): |
| (JSObjectGetProperty): |
| (JSObjectSetProperty): |
| (JSObjectGetPropertyAtIndex): |
| (JSObjectSetPropertyAtIndex): |
| (JSObjectDeleteProperty): |
| (JSObjectCallAsFunction): |
| (JSObjectCallAsConstructor): |
| (JSObjectCopyPropertyNames): |
| (JSPropertyNameAccumulatorAddName): |
| * API/JSValueRef.cpp: |
| (JSValueIsEqual): |
| (JSValueIsInstanceOfConstructor): |
| (JSValueMakeNumber): |
| (JSValueMakeString): |
| (JSValueToNumber): |
| (JSValueToStringCopy): |
| (JSValueToObject): |
| (JSValueProtect): |
| (JSValueUnprotect): |
| Register the thread. |
| |
| * API/JSStringRef.cpp: (JSStringRelease): Changed a comment to not mention per-thread contexts. |
| |
| * API/JSStringRefCF.cpp: Removed an unnecessary include of JSLock.h. |
| |
| * JavaScriptCore.exp: Export JSGlobalData constructor/destructor, now that anyone can have |
| their own instances. Adapt to other changes, too. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: Made ThreadSpecific.h private, as it is now |
| included by collector.h and is thus needed in other projects. |
| |
| * kjs/InitializeThreading.cpp: (KJS::initializeThreadingOnce): Don't initialize per-thread |
| global data, as it no longer exists. |
| |
| * kjs/JSGlobalData.cpp: |
| (KJS::JSGlobalData::JSGlobalData): |
| (KJS::JSGlobalData::~JSGlobalData): |
| * kjs/JSGlobalData.h: |
| Removed support for per-thread instance. Made constructor and destructor public. |
| |
| * kjs/JSGlobalObject.cpp: (KJS::JSGlobalObject::init): Get to now arbitrary JSGlobalData |
| via the heap. |
| (KJS::JSGlobalObject::operator new): Changed ot take JSGlobalDatra pointer. |
| * kjs/JSGlobalObject.h: |
| |
| * kjs/Shell.cpp: |
| (main): |
| (jscmain): |
| Changed to maintain a custom JSGlobalData pointer instead of a per-thread one. |
| |
| 2008-07-13 Ada Chan <adachan@apple.com> |
| |
| Windows build fix: Add wtf/RefCountedLeakCounter to the project. |
| |
| * JavaScriptCore.vcproj/WTF/WTF.vcproj: |
| |
| 2008-07-12 Jan Michael Alonzo <jmalonzo@webkit.org> |
| |
| Gtk, Qt and Wx build fix: Add wtf/RefCountedLeakCounter in the |
| build scripts |
| |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| * JavaScriptCoreSources.bkl: |
| |
| 2008-07-11 Stephanie Lewis <slewis@apple.com> |
| |
| Reviewed by Darin Adler and Oliver Hunt. |
| |
| Refactor RefCounting Leak counting code into a common class. |
| |
| In order to export the symbols I needed to put the debug defines inside the function names |
| |
| Before we had a separate channel for each Logging each Leak type. Since the leak channels were only used in one location, and only at quit for simplicity I combined them all into one leak channel. |
| |
| * JavaScriptCore.exp: |
| * JavaScriptCore.xcodeproj/project.pbxproj: add new class |
| * kjs/nodes.cpp: remove old leak counting code |
| * wtf/RefCountedLeakCounter.cpp: Added. create a common leak counting class |
| * wtf/RefCountedLeakCounter.h: Added. |
| |
| 2008-07-11 David Hyatt <hyatt@apple.com> |
| |
| Add an insertBefore method to ListHashSet to allow for insertions in the middle of the list (rather than just |
| at the end). |
| |
| Reviewed by Anders |
| |
| * wtf/ListHashSet.h: |
| (WTF::::insertBefore): |
| (WTF::::insertNodeBefore): |
| |
| 2008-07-11 Sam Weinig <sam@webkit.org> |
| |
| Rubber-stamped by Darin Adler. |
| |
| Move call function to CallData.cpp and construct to ConstructData.cpp. |
| |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * kjs/AllInOneFile.cpp: |
| * kjs/CallData.cpp: Copied from kjs/JSValue.cpp. |
| * kjs/ConstructData.cpp: Copied from kjs/JSValue.cpp. |
| * kjs/JSValue.cpp: |
| |
| 2008-07-10 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Define WEBKIT_VERSION_MIN_REQUIRED=WEBKIT_VERSION_LATEST when building WebKit to ensure that no symbols end up with the weak_import attribute. |
| |
| * Configurations/Base.xcconfig: |
| |
| 2008-07-10 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Fix the Tiger build by omitting annotations from methods declared in categories when using old versions of GCC. |
| |
| * API/WebKitAvailability.h: |
| |
| 2008-07-10 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Darin. |
| |
| -Minor cleanup. Renamed callTree() to head() and no longer use m_head |
| directly but instead keep it private and access via a method(). |
| |
| * profiler/HeavyProfile.cpp: |
| (KJS::HeavyProfile::HeavyProfile): |
| (KJS::HeavyProfile::generateHeavyStructure): |
| (KJS::HeavyProfile::addNode): |
| * profiler/Profile.h: |
| (KJS::Profile::head): |
| * profiler/ProfileGenerator.cpp: |
| (KJS::ProfileGenerator::ProfileGenerator): |
| |
| 2008-07-10 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Mark Rowe. |
| |
| Eliminate CollectorHeapIntrospector. |
| |
| CollectorHeapIntrospector was added primarily in the hopes to improve leaks tool output, |
| a result that it didn't deliver. Also, it helped by labeling JSC heap regions as reported by |
| vmmap tool, but at the same time, it made them mislabeled as malloc'd ones - the correct |
| way to label mapped regions is to use a VM tag. |
| |
| So, it makes more sense to remove it completely than to make it work with multiple heaps. |
| |
| * JavaScriptCore.exp: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/AllInOneFile.cpp: |
| * kjs/InitializeThreading.cpp: |
| (KJS::initializeThreading): |
| * kjs/collector.cpp: |
| * kjs/collector.h: |
| * kjs/CollectorHeapIntrospector.cpp: Removed. |
| * kjs/CollectorHeapIntrospector.h: Removed. |
| |
| 2008-07-09 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Darin. |
| |
| <rdar://problem/5951532> JSProfiler: Implement heavy (or bottom-up) |
| view (19228) |
| - Implemented the time and call count portionof heavy. Now all that we |
| need is some UI. |
| |
| * profiler/CallIdentifier.h: Removed an unused constructor. |
| * profiler/HeavyProfile.cpp: |
| (KJS::HeavyProfile::HeavyProfile): Set the initial time of the head |
| node so that percentages work correctly. |
| (KJS::HeavyProfile::mergeProfiles): Sum the times and call count of |
| nodes being merged. |
| * profiler/ProfileNode.cpp: Set the intital values of time and call |
| count when copying ProfileNodes. |
| (KJS::ProfileNode::ProfileNode): |
| |
| 2008-07-10 Jan Michael Alonzo <jmalonzo@webkit.org> |
| |
| Gtk build fix. |
| |
| * GNUmakefile.am: Add HeavyProfile.cpp |
| |
| 2008-07-09 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Geoff Garen. |
| |
| Don't warn about deprecated functions in production builds. |
| |
| * Configurations/Base.xcconfig: |
| * Configurations/DebugRelease.xcconfig: |
| |
| 2008-07-09 Darin Adler <darin@apple.com> |
| |
| * JavaScriptCore.pri: Fix Qt build by adding HeavyProfile.cpp. |
| |
| 2008-07-09 Kevin Ollivier <kevino@theolliviers.com> |
| |
| wx biuld fix. Add HeavyProfile.cpp to build files. |
| |
| * JavaScriptCoreSources.bkl: |
| |
| 2008-07-09 Kevin McCullough <kmccullough@apple.com> |
| |
| - Windows build fix. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| |
| 2008-07-09 Kevin McCullough <kmccullough@apple.com> |
| |
| - Build fix. |
| |
| * profiler/HeavyProfile.cpp: |
| (KJS::HeavyProfile::mergeProfiles): |
| |
| 2008-07-09 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Geoff and Adam. |
| |
| <rdar://problem/5951532> JSProfiler: Implement Bottom-Up view (19228) |
| - This is the plumbing for bottom-up, but does not include calculating |
| time, mostly because I'm still undclear about what the end result should |
| look like. |
| - This, obviously, does not include the UI to expose this in the |
| inspector yet. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * profiler/CallIdentifier.h: |
| (KJS::CallIdentifier::CallIdentifier): |
| (WTF::): Added HashTraits for CallIdentifiers to be used by a HashMap. |
| * profiler/HeavyProfile.cpp: Added. |
| (KJS::HeavyProfile::HeavyProfile): |
| (KJS::HeavyProfile::generateHeavyStructure): |
| (KJS::HeavyProfile::addNode): |
| (KJS::HeavyProfile::mergeProfiles): |
| (KJS::HeavyProfile::addAncestorsAsChildren): |
| * profiler/HeavyProfile.h: Added. |
| (KJS::HeavyProfile::create): |
| (KJS::HeavyProfile::heavyProfile): |
| (KJS::HeavyProfile::treeProfile): |
| * profiler/Profile.cpp: Removed old commented out includes. |
| * profiler/Profile.h: The m_head is needed by the HeavyProfile so it |
| is now protected as opposed to private. |
| * profiler/ProfileNode.cpp: |
| (KJS::ProfileNode::ProfileNode): Created a constructor to copy |
| ProfileNodes. |
| (KJS::ProfileNode::findChild): Added a null check to make HeavyProfile |
| children finding easier and avoid a potential crasher. |
| * profiler/ProfileNode.h: Mostly moved things around but also added some |
| functionality needed by HeavyProfile. |
| (KJS::ProfileNode::create): |
| (KJS::ProfileNode::functionName): |
| (KJS::ProfileNode::url): |
| (KJS::ProfileNode::lineNumber): |
| (KJS::ProfileNode::head): |
| (KJS::ProfileNode::setHead): |
| (KJS::ProfileNode::setNextSibling): |
| (KJS::ProfileNode::actualTotalTime): |
| (KJS::ProfileNode::actualSelfTime): |
| * profiler/TreeProfile.cpp: Implemented the ability to get a |
| HeavyProfile. |
| (KJS::TreeProfile::heavyProfile): |
| * profiler/TreeProfile.h: |
| |
| 2008-07-08 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Added support for checking if an object has custom properties in its |
| property map. WebCore uses this to optimize marking DOM wrappers. |
| |
| 2008-07-08 Simon Hausmann <hausmann@webkit.org> |
| |
| Prospective Gtk/Wx build fixes, add ProfileGenerator.cpp to the build. |
| |
| * GNUmakefile.am: |
| * JavaScriptCoreSources.bkl: |
| |
| 2008-07-08 Simon Hausmann <hausmann@webkit.org> |
| |
| Fix the Qt build, add ProfileGenerator.cpp to the build. |
| |
| * JavaScriptCore.pri: |
| |
| 2008-07-07 David Kilzer <ddkilzer@apple.com> |
| |
| releaseFastMallocFreeMemory() should always be defined |
| |
| Reviewed by Darin. |
| |
| * JavaScriptCore.exp: Changed to export C++ binding for |
| WTF::releaseFastMallocFreeMemory() instead of C binding for |
| releaseFastMallocFreeMemory(). |
| * wtf/FastMalloc.cpp: Moved definitions of |
| releaseFastMallocFreeMemory() to be in the WTF namespace |
| regardless whether FORCE_SYSTEM_MALLOC is defined. |
| * wtf/FastMalloc.h: Moved releaseFastMallocFreeMemory() from |
| extern "C" binding to WTF::releaseFastMallocFreeMemory(). |
| |
| 2008-07-07 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Geoff. |
| |
| Bug 19926: URL causes crash within a minute |
| <https://bugs.webkit.org/show_bug.cgi?id=19926> |
| |
| Add a check that lastGlobalObject is non-null in Machine::execute() |
| before copying its globals to the current register file. |
| |
| In theory, it is possible to make a test case for this, but it will |
| take a while to get it right. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): |
| |
| 2008-07-07 Darin Adler <darin@apple.com> |
| |
| Rubber stamped by Adele. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): Fix a typo in a comment. |
| |
| 2008-07-07 Steve Falkenburg <sfalken@apple.com> |
| |
| Build fixes. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.vcproj/testapi/testapi.vcproj: |
| |
| 2008-07-07 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Darin. |
| |
| When the profiler is running it gathers information and creates a |
| Profile. After it finishes the Profile can be sorted and have other |
| data refinements run over it. Both of these were done in the same class |
| before. Now I split the gathering operations into a new class called |
| ProfileGenerator. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * profiler/Profile.cpp: Removed code related to the gather stage of a |
| Profile's creation. |
| (KJS::Profile::create): |
| (KJS::Profile::Profile): |
| * profiler/Profile.h: Ditto. |
| (KJS::Profile::title): |
| (KJS::Profile::callTree): |
| (KJS::Profile::setHead): |
| * profiler/ProfileGenerator.cpp: Added. This is the class that will |
| handle the stage of creating a Profile. Once the Profile is finished |
| being created, this class goes away. |
| (KJS::ProfileGenerator::create): |
| (KJS::ProfileGenerator::ProfileGenerator): |
| (KJS::ProfileGenerator::title): |
| (KJS::ProfileGenerator::willExecute): |
| (KJS::ProfileGenerator::didExecute): |
| (KJS::ProfileGenerator::stopProfiling): |
| (KJS::ProfileGenerator::didFinishAllExecution): |
| (KJS::ProfileGenerator::removeProfileStart): |
| (KJS::ProfileGenerator::removeProfileEnd): |
| * profiler/ProfileGenerator.h: Added. |
| (KJS::ProfileGenerator::profile): |
| (KJS::ProfileGenerator::originatingGlobalExec): |
| (KJS::ProfileGenerator::pageGroupIdentifier): |
| (KJS::ProfileGenerator::client): |
| (KJS::ProfileGenerator::stoppedProfiling): |
| * profiler/Profiler.cpp: Now operates with the ProfileGenerator instead |
| of the Profile. |
| (KJS::Profiler::startProfiling): |
| (KJS::Profiler::stopProfiling): |
| (KJS::Profiler::didFinishAllExecution): It is here that the Profile is |
| handed off to its client and the Profile Generator is no longer needed. |
| (KJS::dispatchFunctionToProfiles): |
| (KJS::Profiler::willExecute): |
| (KJS::Profiler::didExecute): |
| * profiler/Profiler.h: Cleaned up the includes and subsequently the |
| forward declarations. Also use the new ProfileGenerator. |
| (KJS::ProfilerClient::~ProfilerClient): |
| (KJS::Profiler::currentProfiles): |
| * profiler/TreeProfile.cpp: Use Profile's new interface. |
| (KJS::TreeProfile::create): |
| (KJS::TreeProfile::TreeProfile): |
| * profiler/TreeProfile.h: |
| |
| 2008-07-07 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Cameron Zwarich. |
| |
| Third step in broad cleanup effort. |
| |
| [ File list elided ] |
| |
| 2008-07-06 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Cameron Zwarich. |
| |
| Second step in broad cleanup effort. |
| |
| [ File list elided ] |
| |
| 2008-07-05 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Cameron Zwarich. |
| |
| First step in broad cleanup effort. |
| |
| [ File list elided ] |
| |
| 2008-07-05 Sam Weinig <sam@webkit.org> |
| |
| Rubber-stamped by Cameron Zwarich. |
| |
| Rename list.h/cpp to ArgList.h/cpp. |
| |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * VM/Machine.h: |
| * kjs/AllInOneFile.cpp: |
| * kjs/ArgList.cpp: Copied from JavaScriptCore/kjs/list.cpp. |
| * kjs/ArgList.h: Copied from JavaScriptCore/kjs/list.h. |
| * kjs/IndexToNameMap.cpp: |
| * kjs/JSGlobalData.cpp: |
| * kjs/JSGlobalData.h: |
| * kjs/JSObject.h: |
| * kjs/collector.cpp: |
| * kjs/list.cpp: Removed. |
| * kjs/list.h: Removed. |
| |
| 2008-07-05 Sam Weinig <sam@webkit.org> |
| |
| Fix non-AllInOne builds again. |
| |
| * kjs/BooleanPrototype.cpp: |
| * kjs/ErrorPrototype.cpp: |
| * kjs/FunctionPrototype.cpp: |
| * kjs/NumberPrototype.cpp: |
| * kjs/ObjectPrototype.cpp: |
| |
| 2008-07-05 Sam Weinig <sam@webkit.org> |
| |
| Fix build on case-sensitive build systems. |
| |
| * kjs/IndexToNameMap.cpp: |
| |
| 2008-07-05 Sam Weinig <sam@webkit.org> |
| |
| Fix build. |
| |
| * kjs/Arguments.cpp: |
| * kjs/BooleanPrototype.cpp: |
| * kjs/DateConstructor.cpp: |
| * kjs/ErrorPrototype.cpp: |
| * kjs/FunctionPrototype.cpp: |
| * kjs/NumberPrototype.cpp: |
| * kjs/ObjectPrototype.cpp: |
| * kjs/RegExpPrototype.cpp: |
| * kjs/StringConstructor.cpp: |
| * kjs/lookup.cpp: |
| |
| 2008-07-05 Sam Weinig <sam@webkit.org> |
| |
| Fix non-AllInOne build. |
| |
| * kjs/JSGlobalObject.cpp: |
| |
| 2008-07-05 Sam Weinig <sam@webkit.org> |
| |
| Rubber-stamped by Cameron Zwarich. |
| |
| Split Arguments, IndexToNameMap, PrototypeFunction, GlobalEvalFunction and |
| the functions on the global object out of JSFunction.h/cpp. |
| |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * VM/Machine.cpp: |
| * kjs/AllInOneFile.cpp: |
| * kjs/Arguments.cpp: Copied from JavaScriptCore/kjs/JSFunction.cpp. |
| * kjs/Arguments.h: Copied from JavaScriptCore/kjs/JSFunction.h. |
| * kjs/GlobalEvalFunction.cpp: Copied from JavaScriptCore/kjs/JSFunction.cpp. |
| * kjs/GlobalEvalFunction.h: Copied from JavaScriptCore/kjs/JSFunction.h. |
| * kjs/IndexToNameMap.cpp: Copied from JavaScriptCore/kjs/JSFunction.cpp. |
| * kjs/IndexToNameMap.h: Copied from JavaScriptCore/kjs/JSFunction.h. |
| * kjs/JSActivation.cpp: |
| * kjs/JSFunction.cpp: |
| * kjs/JSFunction.h: |
| * kjs/JSGlobalObject.cpp: |
| * kjs/JSGlobalObjectFunctions.cpp: Copied from JavaScriptCore/kjs/JSFunction.cpp. |
| * kjs/JSGlobalObjectFunctions.h: Copied from JavaScriptCore/kjs/JSFunction.h. |
| The functions on the global object should be in JSGlobalObject.cpp, but putting them there |
| was a 0.5% regression. |
| |
| * kjs/PrototypeFunction.cpp: Copied from JavaScriptCore/kjs/JSFunction.cpp. |
| * kjs/PrototypeFunction.h: Copied from JavaScriptCore/kjs/JSFunction.h. |
| * kjs/Shell.cpp: |
| * kjs/lexer.cpp: |
| * kjs/ustring.cpp: |
| |
| 2008-07-04 Sam Weinig <sam@webkit.org> |
| |
| Really fix the mac build. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2008-07-04 Sam Weinig <sam@webkit.org> |
| |
| Fix mac build. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2008-07-04 Sam Weinig <sam@webkit.org> |
| |
| Fix non-AllInOne builds. |
| |
| * kjs/Error.cpp: |
| * kjs/GetterSetter.cpp: |
| * kjs/JSImmediate.cpp: |
| * kjs/operations.cpp: |
| |
| 2008-07-04 Sam Weinig <sam@webkit.org> |
| |
| Rubber-stamped by Dan Bernstein. |
| |
| Split Error and GetterSetter out of JSObject.h. |
| |
| * API/JSCallbackObjectFunctions.h: |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * kjs/AllInOneFile.cpp: |
| * kjs/ClassInfo.h: Copied from JavaScriptCore/kjs/JSObject.h. |
| * kjs/Error.cpp: Copied from JavaScriptCore/kjs/JSObject.cpp. |
| * kjs/Error.h: Copied from JavaScriptCore/kjs/JSObject.h. |
| * kjs/GetterSetter.cpp: |
| * kjs/GetterSetter.h: Copied from JavaScriptCore/kjs/JSObject.h. |
| * kjs/JSObject.cpp: |
| * kjs/JSObject.h: |
| * kjs/nodes.h: |
| |
| 2008-07-04 Simon Hausmann <hausmann@webkit.org> |
| |
| Fix the Wx build, added TreeProfile.cpp to the build. |
| |
| * JavaScriptCoreSources.bkl: |
| |
| 2008-07-03 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fix output path of recently-added script phase to reference the correct file. |
| This prevents Xcode from running the script phase unnecessarily, which caused |
| the generated header to be recreated and lead to AllInOneFile.cpp rebuilding. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2008-07-03 Mark Rowe <mrowe@apple.com> |
| |
| Follow-up to the 64-bit build fix. Use intptr_t rather than ssize_t as |
| the latter is non-standard and does not exist on Windows. |
| |
| * kjs/JSLock.cpp: |
| (KJS::JSLock::lockCount): |
| (KJS::JSLock::lock): |
| (KJS::JSLock::unlock): |
| (KJS::JSLock::DropAllLocks::DropAllLocks): |
| * kjs/JSLock.h: |
| |
| 2008-07-02 Mark Rowe <mrowe@apple.com> |
| |
| Fix the 64-bit build. pthread_getspecific works with pointer-sized values, |
| so use ssize_t rather than int to track the lock count to avoid warnings about |
| truncating the result of pthread_getspecific. |
| |
| * kjs/JSLock.cpp: |
| (KJS::JSLock::lockCount): |
| (KJS::JSLock::lock): |
| (KJS::JSLock::unlock): |
| (KJS::JSLock::DropAllLocks::DropAllLocks): |
| * kjs/JSLock.h: |
| |
| 2008-07-03 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Removed checking for the array get/put fast case from the array code. |
| Callers who want the fast case should call getIndex and/or setIndex |
| instead. (get_by_val and put_by_val already do this.) |
| |
| SunSpider reports no change overall, but a 1.4% speedup on fannkuch and |
| a 3.6% speedup on nsieve. |
| |
| 2008-07-03 Dan Bernstein <mitz@apple.com> |
| |
| - Windows build fix |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Added TreeProfile.{h,cpp}. |
| |
| 2008-07-03 Dan Bernstein <mitz@apple.com> |
| |
| Reviewed by Anders Carlsson. |
| |
| - Windows build fix |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::Machine): |
| |
| 2008-07-03 Simon Hausmann <hausmann@webkit.org> |
| |
| Reviewed by Alexey Proskuryakov. |
| |
| Fix the non-threaded build. |
| |
| * kjs/JSGlobalData.cpp: |
| (KJS::JSGlobalData::threadInstanceInternal): |
| |
| 2008-07-03 Simon Hausmann <hausmann@webkit.org> |
| |
| Fix the Qt build, added TreeProfile to the build. |
| |
| * JavaScriptCore.pri: |
| |
| 2008-07-02 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Geoff. |
| |
| Don't create unnecessary JSGlobalData instances. |
| |
| * kjs/JSGlobalData.h: |
| * kjs/JSGlobalData.cpp: |
| (KJS::JSGlobalData::threadInstanceExists): |
| (KJS::JSGlobalData::sharedInstanceExists): |
| (KJS::JSGlobalData::threadInstance): |
| (KJS::JSGlobalData::sharedInstance): |
| (KJS::JSGlobalData::threadInstanceInternal): |
| (KJS::JSGlobalData::sharedInstanceInternal): |
| Added methods to query instance existence. |
| |
| * kjs/InitializeThreading.cpp: |
| (KJS::initializeThreadingOnce): |
| Initialize thread instance static in a new way. |
| |
| * API/JSBase.cpp: |
| (JSGarbageCollect): |
| * kjs/collector.cpp: |
| (KJS::Heap::collect): |
| Check for instance existence before accessing it. |
| |
| 2008-07-02 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Cameron Zwarich. |
| |
| Fixed https://bugs.webkit.org/show_bug.cgi?id=19862 |
| REGRESSION (r34907): Gmail crashes in JavaScriptCore code while editing drafts |
| |
| I was never able to reproduce this issue, but Cameron could, and he says |
| that this patch fixes it. |
| |
| The crash seems tied to a timer or event handler callback. In such a case, |
| the sole reference to the global object may be in the current call frame, |
| so we can't depend on the global object to mark the call frame area in |
| the register file. |
| |
| The new GC marking rule is: the global object is not responsible for |
| marking the whole register file -- it's just responsible for the globals |
| section it's tied to. The heap is responsible for marking the call frame area. |
| |
| 2008-07-02 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Add the ability to trace JavaScriptCore garabge collections using dtrace. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: Generate the dtrace probe header |
| file when building on a new enough version of Mac OS X. |
| * JavaScriptCorePrefix.h: Add our standard Mac OS X version detection macros. |
| * kjs/Tracing.d: Declare three dtrace probes. |
| * kjs/Tracing.h: Include the generated dtrace macros if dtrace is available, |
| otherwise provide versions that do nothing. |
| * kjs/collector.cpp: |
| (KJS::Heap::collect): Fire dtrace probes when starting a collection, after the |
| mark phase has completed, and when the collection is complete. |
| * wtf/Platform.h: Define HAVE_DTRACE when building on a new enough version of Mac OS X. |
| |
| 2008-07-02 Geoffrey Garen <ggaren@apple.com> |
| |
| Rubber stamped by Oliver Hunt. |
| |
| Reduced the max register file size from 8MB to 2MB. |
| |
| We still allow about 20,000 levels of recursion. |
| |
| 2008-07-02 Alp Toker <alp@nuanti.com> |
| |
| Build fix for r34960. Add TreeProfile.cpp to build. |
| |
| * GNUmakefile.am: |
| |
| 2008-07-02 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Optimized a[n] get for cases when a is an array or a string. When a is |
| an array, we optimize both get and put. When a is a string, we only |
| optimize get, since you can't put to a string. |
| |
| SunSpider says 3.4% faster. |
| |
| 2008-07-02 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Darin. |
| |
| -Small cleanup in preparation for implementing Bottom-up. |
| |
| * profiler/CallIdentifier.h: Rename debug function to make it clear of |
| its output and intention to be debug only. |
| (KJS::CallIdentifier::operator const char* ): Implement in terms of |
| c_str. |
| (KJS::CallIdentifier::c_str): |
| * profiler/ProfileNode.cpp: Impelment findChild() which will be needed |
| by the bottom-up implementation. |
| (KJS::ProfileNode::findChild): |
| * profiler/ProfileNode.h: Added comments to make the collections of |
| functions more clear. |
| (KJS::ProfileNode::operator==): |
| (KJS::ProfileNode::c_str): |
| |
| 2008-07-02 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Darin. |
| |
| Bug 19776: Number.toExponential() is incorrect for numbers between 0.1 and 1 |
| <https://bugs.webkit.org/show_bug.cgi?id=19776> |
| |
| Perform the sign check for the exponent on the actual exponent value, |
| which is 1 less than the value of decimalPoint, instead of on the value |
| of decimalPoint itself. |
| |
| * kjs/NumberPrototype.cpp: |
| (KJS::exponentialPartToString): |
| |
| 2008-07-02 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Darin. |
| |
| <rdar://problem/5951532> JSProfiler: Implement Bottom-Up view (19228) |
| - Subclass TreeProfile as I prepare for a HeavyProfile to be comming |
| later. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * profiler/Profile.cpp: By default we create a TreeProfile. |
| (KJS::Profile::create): |
| * profiler/Profile.h: Changes to the Profile class to make it amenable |
| to be inherited from. |
| (KJS::Profile::~Profile): |
| * profiler/TreeProfile.cpp: Added. |
| (KJS::TreeProfile::create): |
| (KJS::TreeProfile::TreeProfile): |
| (KJS::TreeProfile::heavyProfile): |
| * profiler/TreeProfile.h: Added. |
| (KJS::TreeProfile::treeProfile): |
| |
| 2008-07-02 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Dan. |
| |
| Broke CallIdentifier out into its own file. I did this because it's |
| going to grow a lot soon and I wanted this to be a separate patch. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * profiler/CallIdentifier.h: Added. |
| (KJS::CallIdentifier::CallIdentifier): |
| (KJS::CallIdentifier::operator==): |
| (KJS::CallIdentifier::operator!=): |
| (KJS::CallIdentifier::operator const char* ): |
| (KJS::CallIdentifier::toString): |
| * profiler/ProfileNode.h: |
| |
| 2008-07-02 Simon Hausmann <hausmann@webkit.org> |
| |
| Build fix. Implemented missing functions for single-threaded build. |
| |
| * kjs/JSLock.cpp: |
| (KJS::JSLock::JSLock): |
| (KJS::JSLock::lock): |
| (KJS::JSLock::unlock): |
| (KJS::JSLock::DropAllLocks::DropAllLocks): |
| |
| 2008-07-02 Alexey Proskuryakov <ap@webkit.org> |
| |
| Another non-AllInOne build fix. |
| |
| * kjs/JSGlobalObject.cpp: Include JSLock.h here, too. |
| |
| 2008-07-02 Alexey Proskuryakov <ap@webkit.org> |
| |
| Non-AllInOne build fix. |
| |
| * kjs/interpreter.cpp: Include JSLock.h. |
| |
| 2008-06-30 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Disable JSLock for per-thread contexts. |
| |
| No change on SunSpider. |
| |
| * kjs/JSGlobalData.h: |
| * kjs/JSGlobalData.cpp: |
| (KJS::JSGlobalData::JSGlobalData): |
| (KJS::JSGlobalData::sharedInstance): |
| Added isSharedInstance as a better way to tell whether the instance is shared (legacy). |
| |
| * kjs/JSLock.cpp: |
| (KJS::createJSLockCount): |
| (KJS::JSLock::lockCount): |
| (KJS::setLockCount): |
| (KJS::JSLock::JSLock): |
| (KJS::JSLock::lock): |
| (KJS::JSLock::unlock): |
| (KJS::JSLock::currentThreadIsHoldingLock): |
| (KJS::JSLock::DropAllLocks::DropAllLocks): |
| (KJS::JSLock::DropAllLocks::~DropAllLocks): |
| * kjs/JSLock.h: |
| (KJS::JSLock::JSLock): |
| (KJS::JSLock::~JSLock): |
| Made JSLock and JSLock::DropAllLocks constructors take a parameter to decide whether to |
| actually lock a mutex, or only to increment recursion count. We cannot turn it into no-op |
| if we want to keep existing assertions working. |
| Made recursion count per-thread, now that locks may not lock. |
| |
| * API/JSBase.cpp: |
| (JSEvaluateScript): Take JSLock after casting JSContextRef to ExecState* (which doesn't need |
| locking in any case), so that a decision whether to actually lock can be made. |
| (JSCheckScriptSyntax): Ditto. |
| (JSGarbageCollect): Only lock while collecting the shared heap, not the per-thread one. |
| |
| * API/JSObjectRef.cpp: |
| (JSClassCreate): Don't lock, as there is no reason to. |
| (JSClassRetain): Ditto. |
| (JSClassRelease): Ditto. |
| (JSPropertyNameArrayRetain): Ditto. |
| (JSPropertyNameArrayRelease): Only lock while deleting the array, as that may touch |
| identifier table. |
| (JSPropertyNameAccumulatorAddName): Adding a string also involves an identifier table |
| lookup, and possibly modification. |
| |
| * API/JSStringRef.cpp: |
| (JSStringCreateWithCharacters): |
| (JSStringCreateWithUTF8CString): |
| (JSStringRetain): |
| (JSStringRelease): |
| (JSStringGetUTF8CString): |
| (JSStringIsEqual): |
| * API/JSStringRefCF.cpp: |
| (JSStringCreateWithCFString): |
| JSStringRef operations other than releasing do not need locking. |
| |
| * VM/Machine.cpp: Don't include unused JSLock.h. |
| |
| * kjs/CollectorHeapIntrospector.cpp: (KJS::CollectorHeapIntrospector::statistics): |
| Don't take the lock for real, as heap introspection pauses the process anyway. It seems that |
| the existing code could cause deadlocks. |
| |
| * kjs/Shell.cpp: |
| (functionGC): |
| (main): |
| (jscmain): |
| The test tool uses a per-thread context, so no real locking is required. |
| |
| * kjs/collector.h: |
| (KJS::Heap::setGCProtectNeedsLocking): Optionally protect m_protectedValues access with a |
| per-heap mutex. This is only needed for WebCore Database code, which violates the "no data |
| migration between threads" by using ProtectedPtr on a background thread. |
| (KJS::Heap::isShared): Keep a shared flag here, as well. |
| |
| * kjs/protect.h: |
| (KJS::::ProtectedPtr): |
| (KJS::::~ProtectedPtr): |
| (KJS::::operator): |
| (KJS::operator==): |
| (KJS::operator!=): |
| ProtectedPtr is ony used from WebCore, so it doesn't need to take JSLock. An assertion in |
| Heap::protect/unprotect guards agains possible future unlocked uses of ProtectedPtr in JSC. |
| |
| * kjs/collector.cpp: |
| (KJS::Heap::Heap): Initialize m_isShared. |
| (KJS::Heap::~Heap): No need to lock for real during destruction, but must keep assertions |
| in sweep() working. |
| (KJS::destroyRegisteredThread): Registered thread list is only accessed for shared heap, |
| so locking is always needed here. |
| (KJS::Heap::registerThread): Ditto. |
| (KJS::Heap::markStackObjectsConservatively): Use m_isShared instead of comparing to a shared |
| instance for a small speedup. |
| (KJS::Heap::setGCProtectNeedsLocking): Create m_protectedValuesMutex. There is currently no |
| way to undo this - and ideally, Database code will be fixed to lo longer require this quirk. |
| (KJS::Heap::protect): Take m_protectedValuesMutex (if it exists) while accessing |
| m_protectedValues. |
| (KJS::Heap::unprotect): Ditto. |
| (KJS::Heap::markProtectedObjects): Ditto. |
| (KJS::Heap::protectedGlobalObjectCount): Ditto. |
| (KJS::Heap::protectedObjectCount): Ditto. |
| (KJS::Heap::protectedObjectTypeCounts): Ditto. |
| |
| * kjs/ustring.cpp: |
| * kjs/ustring.h: |
| Don't include JSLock.h, which is no longer used here. As a result, an explicit include had |
| to be added to many files in JavaScriptGlue, WebCore and WebKit. |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::init): |
| * API/JSCallbackConstructor.cpp: |
| (KJS::constructJSCallback): |
| * API/JSCallbackFunction.cpp: |
| (KJS::JSCallbackFunction::call): |
| * API/JSCallbackObjectFunctions.h: |
| (KJS::::init): |
| (KJS::::getOwnPropertySlot): |
| (KJS::::put): |
| (KJS::::deleteProperty): |
| (KJS::::construct): |
| (KJS::::hasInstance): |
| (KJS::::call): |
| (KJS::::getPropertyNames): |
| (KJS::::toNumber): |
| (KJS::::toString): |
| (KJS::::staticValueGetter): |
| (KJS::::callbackGetter): |
| * API/JSContextRef.cpp: |
| (JSGlobalContextCreate): |
| (JSGlobalContextRetain): |
| (JSGlobalContextRelease): |
| * API/JSValueRef.cpp: |
| (JSValueIsEqual): |
| (JSValueIsStrictEqual): |
| (JSValueIsInstanceOfConstructor): |
| (JSValueMakeNumber): |
| (JSValueMakeString): |
| (JSValueToNumber): |
| (JSValueToStringCopy): |
| (JSValueToObject): |
| (JSValueProtect): |
| (JSValueUnprotect): |
| * JavaScriptCore.exp: |
| * kjs/PropertyNameArray.h: |
| (KJS::PropertyNameArray::globalData): |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::checkSyntax): |
| (KJS::Interpreter::evaluate): |
| Pass a parameter to JSLock/JSLock::DropAllLocks to decide whether the lock needs to be taken. |
| |
| 2008-07-01 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=19834 |
| Failed assertion in JavaScriptCore/VM/SegmentedVector.h:82 |
| |
| Creating a global object with a custom prototype resets it twice (wasteful!). |
| So, addStaticGlobals() was called twice, but JSGlobalObject::reset() didn't reset |
| the register array. |
| |
| * kjs/JSGlobalObject.cpp: (KJS::JSGlobalObject::reset): Call setRegisterArray(0, 0). |
| |
| * kjs/JSVariableObject.h: Changed registerArray to OwnArrayPtr. Also, added private copy |
| constructor and operator= to ensure that no one attempts to copy this object (for whatever |
| reason, I couldn't make Noncopyable work). |
| |
| * kjs/JSGlobalObject.h: (KJS::JSGlobalObject::addStaticGlobals): Allocate registerArray |
| with new[]. |
| |
| * kjs/JSVariableObject.cpp: |
| (KJS::JSVariableObject::copyRegisterArray): Allocate registerArray with new[]. |
| (KJS::JSVariableObject::setRegisterArray): Avoid hitting an assertion in OwnArrayPtr when |
| "changing" the value from 0 to 0. |
| |
| 2008-07-01 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Removed and/or reordered exception checks in array-style a[n] access. |
| |
| SunSpider says 1.4% faster. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): No need to check for exceptions before |
| calling toString, toNumber and/or get. If the call ends up being observable |
| through toString, valueOf, or a getter, we short-circuit it there, instead. |
| In the op_del_by_val case, I removed the incorrect comment without actually |
| removing the code, since I didn't want to tempt the GCC fates! |
| |
| * kjs/JSObject.cpp: |
| (KJS::callDefaultValueFunction): Added exception check to prevent |
| toString and valueOf functions from observing execution after an exception |
| has been thrown. This removes some of the burden of exception checking |
| from the machine. |
| |
| (KJS::JSObject::defaultValue): Removed redundant exception check here. |
| |
| * kjs/PropertySlot.cpp: |
| (KJS::PropertySlot::functionGetter): Added exception check to prevent |
| getter functions from observing execution after an exception has been |
| thrown. This removes some of the burden of exception checking from the |
| machine. |
| |
| 2008-07-01 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Optimized a[n] get and put for cases where n is an immediate unsigned |
| value. |
| |
| SunSpider says 3.5% faster. |
| |
| 2008-07-01 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Darin. |
| |
| Bug 19844: JavaScript Switch statement modifies "this" |
| <https://bugs.webkit.org/show_bug.cgi?id=19844> |
| |
| Use a temporary when generating code for switch clauses to avoid |
| overwriting 'this' or a local variable. |
| |
| * kjs/nodes.cpp: |
| (KJS::CaseBlockNode::emitCodeForBlock): |
| |
| 2008-07-01 Christian Dywan <christian@twotoasts.de> |
| |
| Gtk+ build fix. |
| |
| * kjs/list.cpp: Include "JSCell.h" |
| |
| 2008-07-01 Kevin McCullough <kmccullough@apple.com> |
| |
| Build fix. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2008-07-01 Dan Bernstein <mitz@apple.com> |
| |
| Reviewed by Anders Carlsson. |
| |
| - Mac release build fix |
| |
| * JavaScriptCore.exp: |
| |
| 2008-07-01 Sam Weinig <sam@webkit.org> |
| |
| Try and fix mac builds. |
| |
| * JavaScriptCore.exp: |
| |
| 2008-07-01 Sam Weinig <sam@webkit.org> |
| |
| Fix non-AllInOne builds. |
| |
| * kjs/DateMath.cpp: |
| |
| 2008-07-01 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Darin Adler. |
| |
| Split JSCell and JSNumberCell class declarations out of JSValue.h |
| |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * VM/JSPropertyNameIterator.h: |
| * kjs/AllInOneFile.cpp: |
| * kjs/JSCell.cpp: Copied from JavaScriptCore/kjs/JSValue.cpp. |
| * kjs/JSCell.h: Copied from JavaScriptCore/kjs/JSValue.h. |
| (KJS::JSValue::getJSNumber): |
| * kjs/JSNumberCell.cpp: |
| * kjs/JSNumberCell.h: Copied from JavaScriptCore/kjs/JSValue.h. |
| * kjs/JSObject.h: |
| * kjs/JSString.cpp: |
| (KJS::jsString): |
| (KJS::jsOwnedString): |
| * kjs/JSString.h: |
| (KJS::JSValue::toThisJSString): |
| * kjs/JSValue.cpp: |
| * kjs/JSValue.h: |
| |
| 2008-07-01 Anders Carlsson <andersca@apple.com> |
| |
| Build fixes. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::addStaticGlobals): |
| |
| 2008-07-01 Simon Hausmann <hausmann@webkit.org> |
| |
| Build fix, include OwnPtr.h. |
| |
| * kjs/RegExpConstructor.h: |
| |
| 2008-06-30 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fixed a global object leak caused by the switch to one register file. |
| |
| Don't unconditionally mark the register file, since that logically |
| makes all global variables GC roots, even when their global object is |
| no longer reachable. |
| |
| Instead, make the global object associated with the register file |
| responsible for marking the register file. |
| |
| 2008-06-30 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Removed the "registerBase" abstraction. Since the register file never |
| reallocates, we can keep direct pointers into it, instead of |
| <registerBase, offset> tuples. |
| |
| SunSpider says 0.8% faster. |
| |
| 2008-06-30 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by NOBODY (build fix). |
| |
| Fix build by adding all (hopefully) the missing includes. |
| |
| * kjs/BooleanPrototype.cpp: |
| * kjs/DateConstructor.cpp: |
| * kjs/ErrorPrototype.cpp: |
| * kjs/FunctionPrototype.cpp: |
| * kjs/NativeErrorConstructor.cpp: |
| * kjs/NumberPrototype.cpp: |
| * kjs/ObjectPrototype.cpp: |
| * kjs/RegExpConstructor.cpp: |
| * kjs/StringConstructor.cpp: |
| * kjs/StringPrototype.cpp: |
| |
| 2008-06-30 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Bug 19830: REGRESSION (r34883): Google Reader doesn't show up feed list on sidebar |
| <https://bugs.webkit.org/show_bug.cgi?id=19830> |
| |
| Ensure that we do not eliminate a write to a local register when doing |
| peephole optimizations. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitJumpIfTrue): |
| (KJS::CodeGenerator::emitJumpIfFalse): |
| |
| 2008-06-30 Sam Weinig <sam@webkit.org> |
| |
| Rubber-stamped by Darin Alder. |
| |
| Split InternalFunction into its own header file. |
| |
| * API/JSCallbackFunction.h: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/ArrayConstructor.h: |
| * kjs/BooleanConstructor.h: |
| * kjs/DateConstructor.h: |
| * kjs/ErrorConstructor.h: |
| * kjs/FunctionConstructor.h: |
| * kjs/FunctionPrototype.h: |
| * kjs/InternalFunction.h: Copied from kjs/JSFunction.h. |
| * kjs/JSFunction.h: |
| * kjs/NativeErrorConstructor.h: |
| * kjs/NumberConstructor.h: |
| * kjs/ObjectConstructor.h: |
| * kjs/RegExpConstructor.h: |
| * kjs/StringConstructor.h: |
| * profiler/Profiler.cpp: |
| |
| 2008-06-30 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Kevin McCullough. |
| |
| Remove empty files Instruction.cpp, LabelID.cpp, Register.cpp and RegisterID.cpp. |
| |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * VM/Instruction.cpp: Removed. |
| * VM/LabelID.cpp: Removed. |
| * VM/Register.cpp: Removed. |
| * VM/RegisterID.cpp: Removed. |
| |
| 2008-06-30 Sam Weinig <sam@webkit.org> |
| |
| Rubber-stamped (reluctantly) by Kevin McCullough. |
| |
| Rename date_object.h/cpp to DateInstance.h/cpp |
| |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * kjs/AllInOneFile.cpp: |
| * kjs/DateConstructor.cpp: |
| * kjs/DateInstance.cpp: Copied from kjs/date_object.cpp. |
| * kjs/DateInstance.h: Copied from kjs/date_object.h. |
| * kjs/DatePrototype.cpp: |
| * kjs/DatePrototype.h: |
| * kjs/date_object.cpp: Removed. |
| * kjs/date_object.h: Removed. |
| |
| 2008-06-30 Sam Weinig <sam@webkit.org> |
| |
| Rubber-stamped by Darin Adler. |
| |
| Remove internal.cpp and move its contents to there own .cpp files. |
| |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * kjs/AllInOneFile.cpp: |
| * kjs/GetterSetter.cpp: Copied from kjs/internal.cpp. |
| * kjs/InternalFunction.cpp: Copied from kjs/internal.cpp. |
| * kjs/JSNumberCell.cpp: Copied from kjs/internal.cpp. |
| * kjs/JSString.cpp: Copied from kjs/internal.cpp. |
| * kjs/JSString.h: |
| * kjs/LabelStack.cpp: Copied from kjs/internal.cpp. |
| * kjs/NumberConstructor.cpp: |
| * kjs/NumberObject.cpp: |
| (KJS::constructNumber): |
| (KJS::constructNumberFromImmediateNumber): |
| * kjs/internal.cpp: Removed. |
| |
| 2008-06-30 Adam Roben <aroben@apple.com> |
| |
| Fix <rdar://5954749> Assertion failure due to HashTable's use of |
| operator& |
| |
| HashTable was passing &value to constructDeletedValue, which in |
| classes like WebCore::COMPtr would cause an assertion. We now pass |
| value by reference instead of by address so that the HashTraits |
| implementations have more flexibility in constructing the deleted |
| value. |
| |
| Reviewed by Ada Chan. |
| |
| * VM/CodeGenerator.h: Updated for changes to HashTraits. |
| * wtf/HashTable.h: |
| (WTF::::deleteBucket): Changed to pass bucket by reference instead of |
| by address. |
| (WTF::::checkKey): Ditto. |
| * wtf/HashTraits.h: |
| (WTF::): Updated HashTraits for HashTable change. |
| |
| 2008-07-01 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Cameron Zwarich. |
| |
| Make RegisterFile really unmap memory on destruction. |
| |
| This fixes run-webkit-tests --threaded, which ran out of address space in a few seconds. |
| |
| * VM/RegisterFile.cpp: (KJS::RegisterFile::~RegisterFile): Unmap all the memory, not just |
| 1/4 of it. |
| |
| * kjs/JSGlobalObject.h: Don't include RegisterFile.h, so that changes to it don't make |
| half of WebCore rebuild. |
| |
| * VM/Machine.h: Don't forward declare RegisterFile, as RegisterFile.h is included already. |
| |
| * VM/RegisterFile.h: (KJS::RegisterFile::RegisterFile): Assert that the allocation succeeded. |
| |
| 2008-06-30 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Rubber-stamped by Oliver. |
| |
| Correct the documentation for op_put_by_index. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-06-29 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Bug 19821: Merge the instruction pair (less, jfalse) |
| <https://bugs.webkit.org/show_bug.cgi?id=19821> |
| |
| This is a 2.4% win on SunSpider. I needed to add an ALWAYS_INLINE |
| intrinisc to CodeGenerator::rewindBinaryOp() to avoid a massive |
| regression in regexp-dna. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::rewindBinaryOp): |
| (KJS::CodeGenerator::emitJumpIfFalse): |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.cpp: |
| (KJS::): |
| * VM/Opcode.h: |
| |
| 2008-06-29 Sam Weinig <sam@webkit.org> |
| |
| Fix non-AllInOne builds. |
| |
| * kjs/JSObject.cpp: |
| * kjs/JSValue.cpp: |
| |
| 2008-06-29 Sam Weinig <sam@webkit.org> |
| |
| Build fix for Qt. |
| |
| * kjs/DateMath.cpp: |
| * kjs/DatePrototype.cpp: |
| |
| 2008-06-29 Sam Weinig <sam@webkit.org> |
| |
| Rubber-stamped by Cameron Zwarich. |
| |
| Splits ErrorConstructor, ErrorPrototype, NativeErrorConstructor and |
| NativeErrorPrototype out of error_object.h/cpp and renames it ErrorInstance. |
| |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * kjs/AllInOneFile.cpp: |
| * kjs/ArrayConstructor.cpp: |
| * kjs/ArrayPrototype.cpp: |
| * kjs/BooleanPrototype.cpp: |
| * kjs/DatePrototype.cpp: |
| * kjs/ErrorConstructor.cpp: Copied from kjs/error_object.cpp. |
| * kjs/ErrorConstructor.h: Copied from kjs/error_object.h. |
| * kjs/ErrorInstance.cpp: Copied from kjs/error_object.cpp. |
| * kjs/ErrorInstance.h: Copied from kjs/error_object.h. |
| * kjs/ErrorPrototype.cpp: Copied from kjs/error_object.cpp. |
| * kjs/ErrorPrototype.h: Copied from kjs/error_object.h. |
| * kjs/JSGlobalObject.cpp: |
| * kjs/JSObject.cpp: |
| * kjs/JSValue.cpp: |
| * kjs/NativeErrorConstructor.cpp: Copied from kjs/error_object.cpp. |
| * kjs/NativeErrorConstructor.h: Copied from kjs/error_object.h. |
| * kjs/NativeErrorPrototype.cpp: Copied from kjs/error_object.cpp. |
| * kjs/NativeErrorPrototype.h: Copied from kjs/error_object.h. |
| * kjs/NumberPrototype.cpp: |
| * kjs/RegExpConstructor.cpp: |
| * kjs/RegExpObject.cpp: |
| * kjs/RegExpPrototype.cpp: |
| * kjs/StringPrototype.cpp: |
| * kjs/error_object.cpp: Removed. |
| * kjs/error_object.h: Removed. |
| * kjs/internal.cpp: |
| |
| 2008-06-29 Sam Weinig <sam@webkit.org> |
| |
| Fix non-AllInOne build. |
| |
| * kjs/DateConstructor.cpp: |
| * kjs/DateMath.cpp: |
| * kjs/JSObject.cpp: |
| |
| 2008-06-29 Sam Weinig <sam@webkit.org> |
| |
| Rubber-stamped by Oliver Hunt. |
| |
| Splits DateConstructor and DatePrototype out of date_object.h/cpp |
| Moves shared Date code into DateMath. |
| |
| * DerivedSources.make: |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * kjs/AllInOneFile.cpp: |
| * kjs/DateConstructor.cpp: Copied from kjs/date_object.cpp. |
| * kjs/DateConstructor.h: Copied from kjs/date_object.h. |
| * kjs/DateMath.cpp: |
| (KJS::ymdhmsToSeconds): |
| (KJS::): |
| (KJS::skipSpacesAndComments): |
| (KJS::findMonth): |
| (KJS::parseDate): |
| (KJS::timeClip): |
| (KJS::formatDate): |
| (KJS::formatDateUTCVariant): |
| (KJS::formatTime): |
| * kjs/DateMath.h: |
| (KJS::gmtoffset): |
| * kjs/DatePrototype.cpp: Copied from kjs/date_object.cpp. |
| * kjs/DatePrototype.h: Copied from kjs/date_object.h. |
| * kjs/JSGlobalObject.cpp: |
| * kjs/JSObject.cpp: |
| * kjs/date_object.cpp: |
| * kjs/date_object.h: |
| * kjs/internal.cpp: |
| |
| 2008-06-29 Jan Michael Alonzo <jmalonzo@webkit.org> |
| |
| Rubber-stamped by Cameron Zwarich |
| |
| Fix Gtk non-AllInOne build |
| |
| * GNUmakefile.am: include JSVariableObject.cpp |
| * kjs/RegExpConstructor.cpp: include RegExpObject.h |
| * kjs/RegExpObject.h: forward declare RegExpPrototype |
| |
| 2008-06-28 Darin Adler <darin@apple.com> |
| |
| Reviewed by Sam and Cameron. |
| |
| - fix https://bugs.webkit.org/show_bug.cgi?id=19805 |
| Array.concat turns missing array elements into "undefined" |
| |
| Test: fast/js/array-holes.html |
| |
| * JavaScriptCore.exp: No longer export JSArray::getItem. |
| |
| * kjs/ArrayPrototype.cpp: |
| (KJS::arrayProtoFuncConcat): Changed to use getProperty instead of |
| JSArray::getItem -- need to handle properties from the prototype chain |
| instead of ignoring them. |
| |
| * kjs/JSArray.cpp: Removed getItem. |
| * kjs/JSArray.h: Ditto. |
| |
| 2008-06-28 Darin Adler <darin@apple.com> |
| |
| Reviewed by Cameron. |
| |
| - https://bugs.webkit.org/show_bug.cgi?id=19804 |
| optimize access to arrays without "holes" |
| |
| SunSpider says 1.8% faster. |
| |
| * kjs/JSArray.cpp: |
| (KJS::JSArray::JSArray): Initialize m_fastAccessCutoff when creating |
| arrays. Also updated for new location of m_vectorLength. |
| (KJS::JSArray::getItem): Updated for new location of m_vectorLength. |
| (KJS::JSArray::getSlowCase): Added. Broke out the non-hot parts of |
| getOwnPropertySlot to make the hot part faster. |
| (KJS::JSArray::getOwnPropertySlot): Added a new faster case for |
| indices lower than m_fastAccessCutoff. We can do theese with no |
| additional checks or branches. |
| (KJS::JSArray::put): Added a new faster case for indices lower than |
| m_fastAccessCutoff. We can do theese with no additional checks or |
| branches. Moved the maxArrayIndex handling out of this function. |
| Added code to set m_fastAccessCutoff when the very last hole in |
| an array is filled; this is how the cutoff gets set for most arrays. |
| (KJS::JSArray::putSlowCase): Moved the rest of the put function logic |
| in here, to make the hot part of the put function faster. |
| (KJS::JSArray::deleteProperty): Added code to lower m_fastAccessCutoff |
| when a delete makes a new hole in the array. |
| (KJS::JSArray::getPropertyNames): Updated for new location of |
| m_vectorLength. |
| (KJS::JSArray::increaseVectorLength): Ditto. |
| (KJS::JSArray::setLength): Added code to lower m_fastAccessCutoff |
| when setLength makes the array smaller. |
| (KJS::JSArray::mark): Updated for new location of m_vectorLength. |
| (KJS::JSArray::sort): Ditto. Set m_fastAccessCutoff after moving |
| all the holes to the end of the array. |
| (KJS::JSArray::compactForSorting): Ditto. |
| (KJS::JSArray::checkConsistency): Added consistency checks fro |
| m_fastAccessCutoff and updated for the new location of m_vectorLength. |
| |
| * kjs/JSArray.h: Added declarations for slow case functions. |
| Replaced m_vectorLength with m_fastAccessCutoff. |
| |
| 2008-06-28 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Sam. |
| |
| When executing a native call, check for an exception before writing the |
| return value. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-06-28 Mark Rowe <mrowe@apple.com> |
| |
| Build fix. Flag headers as private or public as is appropriate. |
| These settings were accidentally removed during some project file cleanup. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2008-06-28 Sam Weinig <sam@webkit.org> |
| |
| Rubber-stamped by Darin Adler. |
| |
| Splits RegExpConstructor and RegExpPrototype out of RegExpObject.h/cpp |
| |
| * DerivedSources.make: |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * VM/Machine.cpp: |
| * kjs/AllInOneFile.cpp: |
| * kjs/JSGlobalObject.cpp: |
| * kjs/RegExpConstructor.cpp: Copied from kjs/RegExpObject.cpp. |
| * kjs/RegExpConstructor.h: Copied from kjs/RegExpObject.h. |
| * kjs/RegExpObject.cpp: |
| * kjs/RegExpObject.h: |
| * kjs/RegExpPrototype.cpp: Copied from kjs/RegExpObject.cpp. |
| * kjs/RegExpPrototype.h: Copied from kjs/RegExpObject.h. |
| * kjs/StringPrototype.cpp: |
| * kjs/internal.cpp: |
| |
| 2008-06-28 Sam Weinig <sam@webkit.org> |
| |
| Fix non-AllInOne builds. |
| |
| * kjs/StringConstructor.cpp: |
| |
| 2008-06-28 Sam Weinig <sam@webkit.org> |
| |
| Rubber-stamped by Darin Adler. |
| |
| Rename string_object.h/cpp to StringObject.h/cpp and split out StringObjectThatMasqueradesAsUndefined, |
| StringConstructor and StringPrototype. |
| |
| * DerivedSources.make: |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * kjs/AllInOneFile.cpp: |
| * kjs/JSGlobalObject.cpp: |
| * kjs/StringConstructor.cpp: Copied from JavaScriptCore/kjs/string_object.cpp. |
| * kjs/StringConstructor.h: Copied from JavaScriptCore/kjs/string_object.h. |
| * kjs/StringObject.cpp: Copied from JavaScriptCore/kjs/string_object.cpp. |
| * kjs/StringObject.h: Copied from JavaScriptCore/kjs/string_object.h. |
| * kjs/StringObjectThatMasqueradesAsUndefined.h: Copied from JavaScriptCore/kjs/string_object.h. |
| * kjs/StringPrototype.cpp: Copied from JavaScriptCore/kjs/string_object.cpp. |
| * kjs/StringPrototype.h: Copied from JavaScriptCore/kjs/string_object.h. |
| * kjs/internal.cpp: |
| * kjs/string_object.cpp: Removed. |
| * kjs/string_object.h: Removed. |
| |
| 2008-06-28 Jan Michael Alonzo <jmalonzo@webkit.org> |
| |
| Gtk build fix: JSVariableObject is now part of AllInOne |
| |
| * GNUmakefile.am: |
| |
| 2008-06-28 Darin Adler <darin@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - https://bugs.webkit.org/show_bug.cgi?id=19801 |
| add a feature so we can tell what regular expressions are taking time |
| |
| * pcre/pcre_compile.cpp: |
| (jsRegExpCompile): Compile in the string if REGEXP_HISTOGRAM is on. |
| |
| * pcre/pcre_exec.cpp: |
| (jsRegExpExecute): Add hook to time execution. |
| (Histogram::~Histogram): Print a sorted list of what took time. |
| (Histogram::add): Accumulate records of what took time. |
| (HistogramTimeLogger::~HistogramTimeLogger): Hook that calls |
| Histogram::add at the right moment and creates the global histogram |
| object. |
| |
| * pcre/pcre_internal.h: Define REGEXP_HISTOGRAM. |
| |
| * pcre/pcre_tables.cpp: Added missing include of "config.h". Not needed |
| any more, but an omissions an earlier version of this patch detected. |
| * pcre/pcre_ucp_searchfuncs.cpp: Ditto. |
| * pcre/pcre_xclass.cpp: Ditto. |
| |
| 2008-06-28 Sam Weinig <sam@webkit.org> |
| |
| Try and fix the Windows build again. |
| |
| * kjs/RegExpObject.cpp: |
| * kjs/date_object.cpp: |
| * kjs/error_object.cpp: |
| |
| 2008-06-28 Sam Weinig <sam@webkit.org> |
| |
| Rubber-stamped by Darin Adler. |
| |
| Remove unused StringConstructorFunction class. |
| |
| * kjs/string_object.h: |
| |
| 2008-06-28 Sam Weinig <sam@webkit.org> |
| |
| Fix windows build. |
| |
| * kjs/ArrayPrototype.cpp: |
| * kjs/BooleanPrototype.cpp: |
| * kjs/BooleanPrototype.h: |
| * kjs/FunctionPrototype.cpp: |
| * kjs/JSImmediate.cpp: |
| * kjs/JSObject.cpp: |
| * kjs/MathObject.cpp: |
| * kjs/NumberPrototype.cpp: |
| * kjs/NumberPrototype.h: |
| * kjs/ObjectConstructor.cpp: |
| * kjs/RegExpObject.h: |
| * kjs/error_object.h: |
| * kjs/string_object.cpp: |
| |
| 2008-06-28 Sam Weinig <sam@webkit.org> |
| |
| Rubber-stamped by Oliver Hunt. |
| |
| Splits FunctionConstructor out of FunctionPrototype.h/cpp |
| Splits NumberConstructor and NumberPrototype out of NumberObject.h/cpp |
| Rename object_object.h/cpp to ObjectPrototype.h/cpp and split out ObjectConstructor. |
| |
| * API/JSCallbackConstructor.cpp: |
| * API/JSClassRef.cpp: |
| * API/JSObjectRef.cpp: |
| * DerivedSources.make: |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * VM/Machine.cpp: |
| * kjs/AllInOneFile.cpp: |
| * kjs/ArrayConstructor.cpp: |
| * kjs/ArrayConstructor.h: |
| * kjs/FunctionConstructor.cpp: Copied from JavaScriptCore/kjs/FunctionPrototype.cpp. |
| * kjs/FunctionConstructor.h: Copied from JavaScriptCore/kjs/FunctionPrototype.h. |
| * kjs/FunctionPrototype.cpp: |
| * kjs/FunctionPrototype.h: |
| * kjs/JSFunction.cpp: |
| * kjs/JSGlobalObject.cpp: |
| * kjs/JSImmediate.cpp: |
| * kjs/MathObject.h: |
| * kjs/NumberConstructor.cpp: Copied from JavaScriptCore/kjs/NumberObject.cpp. |
| * kjs/NumberConstructor.h: Copied from JavaScriptCore/kjs/NumberObject.h. |
| * kjs/NumberObject.cpp: |
| * kjs/NumberObject.h: |
| * kjs/NumberPrototype.cpp: Copied from JavaScriptCore/kjs/NumberObject.cpp. |
| * kjs/NumberPrototype.h: Copied from JavaScriptCore/kjs/NumberObject.h. |
| * kjs/ObjectConstructor.cpp: Copied from JavaScriptCore/kjs/object_object.cpp. |
| * kjs/ObjectConstructor.h: Copied from JavaScriptCore/kjs/object_object.h. |
| * kjs/ObjectPrototype.cpp: Copied from JavaScriptCore/kjs/object_object.cpp. |
| * kjs/ObjectPrototype.h: Copied from JavaScriptCore/kjs/object_object.h. |
| * kjs/RegExpObject.h: |
| * kjs/Shell.cpp: |
| * kjs/error_object.h: |
| * kjs/internal.cpp: |
| * kjs/nodes.cpp: |
| * kjs/object_object.cpp: Removed. |
| * kjs/object_object.h: Removed. |
| * kjs/string_object.h: |
| |
| 2008-06-28 Darin Adler <darin@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fix https://bugs.webkit.org/show_bug.cgi?id=19796 |
| optimize expressions with ignored results (especially post-increment) |
| |
| SunSpider says 0.9% faster. |
| |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::tempDestination): Create a new temporary for |
| ignoredResult() too, just as we would for 0. |
| (KJS::CodeGenerator::finalDestination): Use the temporary if the |
| register passed in is ignoredResult() too, just as we would for 0. |
| (KJS::CodeGenerator::destinationForAssignResult): Return 0 if the |
| passed in register is ignoredResult(), just as we would for 0. |
| (KJS::CodeGenerator::moveToDestinationIfNeeded): Return 0 if the |
| register passed in is ignoredResult(). What matters is that we |
| don't want to emit a move. The return value won't be looked at. |
| (KJS::CodeGenerator::emitNode): Allow ignoredResult() and pass it |
| through to the node's emitCode function. |
| |
| * VM/RegisterID.h: |
| (KJS::ignoredResult): Added. Special value to indicate the result of |
| a node will be ignored and need not be put in any register. |
| |
| * kjs/nodes.cpp: |
| (KJS::NullNode::emitCode): Do nothing if dst == ignoredResult(). |
| (KJS::BooleanNode::emitCode): Ditto. |
| (KJS::NumberNode::emitCode): Ditto. |
| (KJS::StringNode::emitCode): Ditto. |
| (KJS::RegExpNode::emitCode): Ditto. |
| (KJS::ThisNode::emitCode): Ditto. |
| (KJS::ResolveNode::emitCode): Do nothing if dst == ignoredResult() and |
| the identifier resolves to a local variable. |
| (KJS::ObjectLiteralNode::emitCode): Do nothing if dst == ignoredResult() |
| and the object is empty. |
| (KJS::PostIncResolveNode::emitCode): If dst == ignoredResult(), then do |
| nothing for the local constant case, and do a pre-increment in all the |
| other cases. |
| (KJS::PostDecResolveNode::emitCode): Ditto. |
| (KJS::PostIncBracketNode::emitCode): Ditto. |
| (KJS::PostDecBracketNode::emitCode): Ditto. |
| (KJS::PostIncDotNode::emitCode): Ditto. |
| (KJS::PostDecDotNode::emitCode): Ditto. |
| (KJS::DeleteValueNode::emitCode): Pass ignoredResult() when evaluating |
| the expression. |
| (KJS::VoidNode::emitCode): Ditto. |
| (KJS::TypeOfResolveNode::emitCode): If dst == ignoredResult(), do nothing |
| if the identifier resolves to a local variable, and don't bother generating |
| a typeof opcode in the other case. |
| (KJS::TypeOfValueNode::emitCode): Ditto. |
| (KJS::PreIncResolveNode::emitCode): Do nothing if dst == ignoredResult() and |
| the identifier resolves to a local constant. |
| (KJS::PreDecResolveNode::emitCode): Ditto. |
| (KJS::AssignResolveNode::emitCode): Turn ignoredResult() into 0 in a couple |
| places, because we need to put the result into a register so we can assign |
| it. At other sites this is taken care of by functions like finalDestination. |
| (KJS::CommaNode::emitCode): Pass ignoredResult() when evaluating the first |
| expression. |
| (KJS::ForNode::emitCode): Pass ignoredResult() when evaluating the first and |
| third expressions. |
| (KJS::ForInNode::emitCode): Pass ignoredResult() when evaluating the first |
| expression. |
| |
| 2008-06-28 Darin Adler <darin@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - https://bugs.webkit.org/show_bug.cgi?id=19787 |
| create most arrays from values in registers rather than with multiple put operations |
| |
| SunSpider says 0.8% faster. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): Added argv and argc parameters to new_array. |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): Ditto. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitNewArray): Added. |
| * VM/CodeGenerator.h: Added ElementNode* argument to emitNewArray. |
| |
| * kjs/nodes.cpp: |
| (KJS::ArrayNode::emitCode): Pass the ElementNode to emitNewArray so it can be |
| initialized with as many elements as possible. If the array doesn't have any |
| holes in it, that's all that's needed. If there are holes, then emit some separate |
| put operations for the other values in the array and for the length as needed. |
| |
| * kjs/nodes.h: Added some accessors to ElementNode so the code generator can |
| iterate through elements and generate code to evaluate them. Now ArrayNode does |
| not need to be a friend. Also took out some unused PlacementNewAdoptType |
| constructors. |
| |
| 2008-06-28 Darin Adler <darin@apple.com> |
| |
| Reviewed by Oliver. |
| |
| * kjs/nodes.h: Remove obsolete PlacementNewAdopt constructors. |
| We no longer mutate the AST in place. |
| |
| 2008-06-28 Jan Michael Alonzo <jmalonzo@webkit.org> |
| |
| Reviewed by Oliver Hunt. |
| |
| Build fix |
| |
| * VM/Machine.cpp: include stdio.h for printf |
| |
| 2008-06-27 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fix platforms that don't use AllInOne.cpp |
| |
| * kjs/BooleanConstructor.h: |
| * kjs/BooleanPrototype.h: |
| * kjs/FunctionPrototype.cpp: |
| |
| 2008-06-27 Sam Weinig <sam@webkit.org> |
| |
| Rubber-stamped by Oliver Hunt. |
| |
| Splits ArrayConstructor out of ArrayPrototype.h/cpp |
| Splits BooleanConstructor and BooleanPrototype out of BooleanObject.h/cpp |
| |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * VM/Machine.cpp: |
| * kjs/AllInOneFile.cpp: |
| * kjs/ArrayConstructor.cpp: Copied from kjs/ArrayPrototype.cpp. |
| * kjs/ArrayConstructor.h: Copied from kjs/ArrayPrototype.h. |
| * kjs/ArrayPrototype.cpp: |
| * kjs/ArrayPrototype.h: |
| * kjs/BooleanConstructor.cpp: Copied from kjs/BooleanObject.cpp. |
| * kjs/BooleanConstructor.h: Copied from kjs/BooleanObject.h. |
| * kjs/BooleanObject.cpp: |
| * kjs/BooleanObject.h: |
| * kjs/BooleanPrototype.cpp: Copied from kjs/BooleanObject.cpp. |
| * kjs/BooleanPrototype.h: Copied from kjs/BooleanObject.h. |
| * kjs/CommonIdentifiers.h: |
| * kjs/FunctionPrototype.cpp: |
| * kjs/JSArray.cpp: |
| * kjs/JSGlobalObject.cpp: |
| * kjs/JSImmediate.cpp: |
| * kjs/Shell.cpp: |
| * kjs/internal.cpp: |
| * kjs/nodes.cpp: |
| * kjs/string_object.cpp: |
| |
| 2008-06-27 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Sam. |
| |
| Bug 18626: SQUIRRELFISH: support the "slow script" dialog <https://bugs.webkit.org/show_bug.cgi?id=18626> |
| <rdar://problem/5973931> Slow script dialog needs to be reimplemented for squirrelfish |
| |
| Adds support for the slow script dialog in squirrelfish. This requires the addition |
| of three new op codes, op_loop, op_loop_if_true, and op_loop_if_less which have the |
| same behaviour as their simple jump equivalents but have an additional time out check. |
| |
| Additional assertions were added to other jump instructions to prevent accidentally |
| creating loops with jump types that do not support time out checks. |
| |
| Sunspider does not report a regression, however this appears very sensitive to code |
| layout and hardware, so i would expect up to a 1% regression on other systems. |
| |
| Part of this required moving the old timeout logic from JSGlobalObject and into Machine |
| which is the cause of a number of the larger diff blocks. |
| |
| * JavaScriptCore.exp: |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitJumpIfTrue): |
| (KJS::CodeGenerator::emitJumpScopes): |
| * VM/ExceptionHelpers.cpp: |
| (KJS::InterruptedExecutionError::isWatchdogException): |
| (KJS::createInterruptedExecutionException): |
| * VM/ExceptionHelpers.h: |
| * VM/LabelID.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::Machine): |
| (KJS::Machine::throwException): |
| (KJS::Machine::resetTimeoutCheck): |
| (KJS::getCurrentTime): |
| (KJS::Machine::checkTimeout): |
| (KJS::Machine::privateExecute): |
| * VM/Machine.h: |
| (KJS::Machine::setTimeoutTime): |
| (KJS::Machine::startTimeoutCheck): |
| (KJS::Machine::stopTimeoutCheck): |
| (KJS::Machine::initTimeout): |
| * VM/Opcode.cpp: |
| (KJS::): |
| * VM/Opcode.h: |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::init): |
| (KJS::JSGlobalObject::setTimeoutTime): |
| (KJS::JSGlobalObject::startTimeoutCheck): |
| * kjs/JSGlobalObject.h: |
| * kjs/JSObject.h: |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::evaluate): |
| |
| 2008-06-27 Jan Michael Alonzo <jmalonzo@webkit.org> |
| |
| Gtk and Qt build fix: Remove RegisterFileStack from the build |
| scripts. |
| |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| |
| 2008-06-27 Adele Peterson <adele@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Build fixes. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * VM/RegisterFile.h: |
| (KJS::RegisterFile::RegisterFile): |
| * kjs/JSGlobalObject.cpp: |
| * kjs/collector.cpp: |
| |
| 2008-06-27 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| One RegisterFile to rule them all! |
| |
| SunSpider reports a 0.2% speedup. |
| |
| This patch removes the RegisterFileStack abstraction and replaces it with |
| a single register file that |
| |
| (a) allocates a fixed storage area, including a fixed area for global |
| vars, so that no operation may cause the register file to reallocate |
| |
| and |
| |
| (b) swaps between global storage areas when executing code in different |
| global objects. |
| |
| This patch also changes the layout of the register file so that all call |
| frames, including call frames for global code, get a header. This is |
| required to support re-entrant global code. It also just makes things simpler. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::addGlobalVar): New function. Differs from addVar in |
| that |
| |
| (a) global vars don't contribute to a CodeBlock's numLocals count, since |
| global storage is fixed and allocated at startup |
| |
| and |
| |
| (b) references to global vars get shifted to elide intermediate stack |
| between "r" and the global storage area. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::dumpRegisters): Updated this function to match the new |
| register file layout, and added the ability to dump exact identifiers |
| for the different parts of a call frame. |
| |
| (KJS::Machine::unwindCallFrame): Updated this function to match the new |
| register file layout. |
| |
| (KJS::Machine::execute): Updated this function to initialize a call frame |
| header for global code, and to swap global storage areas when switching |
| to execution in a new global object. |
| |
| (KJS::Machine::privateExecute): Got rid of "safeForReentry" and re-reading |
| of registerBase because the register file is always safe for reentry now, |
| and registerBase never changes. |
| |
| * VM/Machine.h: Moved the call frame header enum from Machine to RegisterFile, |
| to resolve a header dependency problem (a good sign that the enum belonged |
| in RegisterFile all along!) |
| |
| * VM/RegisterFile.cpp: |
| * VM/RegisterFile.h: Changed RegisterFile to mmap a fixed size register |
| area. This allows us to avoid re-allocting the register file later on. |
| Instead, we rely on the OS to allocate physical pages to the register |
| file as necessary. |
| |
| * VM/RegisterFileStack.cpp: Removed. Tada! |
| * VM/RegisterFileStack.h: Removed. Tada! |
| |
| * kjs/DebuggerCallFrame.cpp: Updated this class to match the new |
| register file layout, greatly simplifying it in the process. |
| |
| * kjs/JSActivation.h: |
| * kjs/JSActivation.cpp: Moved some of this logic up to JSVariableObject, |
| since the global object now needs to be able to tear off its registers |
| just like the activation object. |
| |
| * kjs/JSFunction.cpp: No need to fiddle with the register file anymore. |
| |
| * kjs/JSGlobalObject.h: |
| * kjs/JSGlobalObject.cpp: Updated JSGlobalObject to support moving its |
| global storage area into and out of the register file. |
| |
| * kjs/PropertySlot.cpp: No need to fiddle with the register file anymore. |
| |
| * kjs/collector.cpp: Renamed markStackObjectConservatively to |
| markConservatively, since we don't just mark stack objects this way. |
| |
| Also, added code to mark the machine's register file. |
| |
| * kjs/config.h: Moved some platforms #defines from here... |
| * wtf/Platform.h: ...to here, to support mmap/VirtualAlloc detection |
| in RegisterFile.h. |
| |
| 2008-06-26 Mark Rowe <mrowe@apple.com> |
| |
| Speculative fix for the Windows build. |
| |
| * kjs/JSImmediate.cpp: |
| |
| 2008-06-26 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Darin Adler and Geoff Garen. |
| |
| Fix the malloc zone introspection functions so that malloc_zone_statistics does not give |
| bogus output in an application that uses JavaScriptCore. |
| |
| * kjs/CollectorHeapIntrospector.cpp: |
| (KJS::CollectorHeapIntrospector::statistics): Return statistics about memory allocated by the collector. |
| * kjs/CollectorHeapIntrospector.h: |
| * wtf/FastMalloc.cpp: Zero out the statistics. FastMalloc doesn't track this information at present. |
| Returning zero for all values is preferable to returning bogus data. |
| |
| 2008-06-26 Darin Adler <darin@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - https://bugs.webkit.org/show_bug.cgi?id=19721 |
| speed up JavaScriptCore by not wrapping strings in objects just |
| to call functions on them |
| |
| - optimize UString append and the replace function a bit |
| |
| SunSpider says 1.8% faster. |
| |
| * JavaScriptCore.exp: Updated. |
| |
| * VM/JSPropertyNameIterator.cpp: Added include of JSString.h, now needed |
| because jsString returns a JSString*. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): Removed the toObject call from native |
| function calls. Also removed code to put the this value into a register. |
| |
| * kjs/BooleanObject.cpp: |
| (KJS::booleanProtoFuncToString): Rewrite to handle false and true |
| separately. |
| |
| * kjs/FunctionPrototype.cpp: |
| (KJS::constructFunction): Use single-character append rather than building |
| a string for each character. |
| * kjs/JSFunction.cpp: |
| (KJS::globalFuncUnescape): Ditto. |
| |
| * kjs/JSImmediate.cpp: |
| (KJS::JSImmediate::prototype): Added. Gets the appropriate prototype for |
| use with an immediate value. To be used instead of toObject when doing a |
| get on an immediate value. |
| * kjs/JSImmediate.h: Added prototype. |
| |
| * kjs/JSObject.cpp: |
| (KJS::JSObject::toString): Tweaked formatting. |
| |
| * kjs/JSObject.h: |
| (KJS::JSValue::get): Use prototype instead of toObject to avoid creating |
| an object wrapper just to search for properties. This also saves an |
| unnecessary hash table lookup since the object wrappers themselves don't |
| have any properties. |
| |
| * kjs/JSString.h: Added toThisString and toThisJSString. |
| |
| * kjs/JSValue.cpp: |
| (KJS::JSCell::toThisString): Added. |
| (KJS::JSCell::toThisJSString): Added. |
| (KJS::JSCell::getJSNumber): Added. |
| (KJS::jsString): Changed return type to JSString*. |
| (KJS::jsOwnedString): Ditto. |
| |
| * kjs/JSValue.h: |
| (KJS::JSValue::toThisString): Added. |
| (KJS::JSValue::toThisJSString): Added. |
| (KJS::JSValue::getJSNumber): Added. |
| |
| * kjs/NumberObject.cpp: |
| (KJS::NumberObject::getJSNumber): Added. |
| (KJS::integer_part_noexp): Append C string directly rather than first |
| turning it into a UString. |
| (KJS::numberProtoFuncToString): Use getJSNumber to check if the value |
| is a number rather than isObject(&NumberObject::info). This works for |
| immediate numbers, number cells, and NumberObject instances. |
| (KJS::numberProtoFuncToLocaleString): Ditto. |
| (KJS::numberProtoFuncValueOf): Ditto. |
| (KJS::numberProtoFuncToFixed): Ditto. |
| (KJS::numberProtoFuncToExponential): Ditto. |
| (KJS::numberProtoFuncToPrecision): Ditto. |
| * kjs/NumberObject.h: Added getJSNumber. |
| |
| * kjs/PropertySlot.cpp: Tweaked comment. |
| |
| * kjs/internal.cpp: |
| (KJS::JSString::toThisString): Added. |
| (KJS::JSString::toThisJSString): Added. |
| (KJS::JSString::getOwnPropertySlot): Changed code that searches the |
| prototype chain to start with the string prototype and not create a |
| string object. |
| (KJS::JSNumberCell::toThisString): Added. |
| (KJS::JSNumberCell::getJSNumber): Added. |
| |
| * kjs/lookup.cpp: |
| (KJS::staticFunctionGetter): Moved here, because there's no point in |
| having a function that's only used for a function pointer be inline. |
| (KJS::setUpStaticFunctionSlot): New function for getStaticFunctionSlot. |
| |
| * kjs/lookup.h: |
| (KJS::staticValueGetter): Don't mark this inline. It doesn't make sense |
| to have a function that's only used for a function pointer be inline. |
| (KJS::getStaticFunctionSlot): Changed to get properties from the parent |
| first before doing any handling of functions. This is the fastest way |
| to return the function once the initial setup is done. |
| |
| * kjs/string_object.cpp: |
| (KJS::StringObject::getPropertyNames): Call value() instead of getString(), |
| avoiding an unnecessary virtual function call (the call to the type() |
| function in the implementation of the isString() function). |
| (KJS::StringObject::toString): Added. |
| (KJS::StringObject::toThisString): Added. |
| (KJS::StringObject::toThisJSString): Added. |
| (KJS::substituteBackreferences): Rewrote to use a appending algorithm |
| instead of a the old one that tried to replace in place. |
| (KJS::stringProtoFuncReplace): Merged this function and the replace function. |
| Replaced the hand-rolled dynamic arrays for source ranges and replacements |
| with Vector. |
| (KJS::stringProtoFuncToString): Handle JSString as well as StringObject. |
| Removed the separate valueOf implementation, since it can just share this. |
| (KJS::stringProtoFuncCharAt): Use toThisString, which handles JSString as |
| well as StringObject, and is slightly more efficient than the old code too. |
| (KJS::stringProtoFuncCharCodeAt): Ditto. |
| (KJS::stringProtoFuncConcat): Ditto. |
| (KJS::stringProtoFuncIndexOf): Ditto. |
| (KJS::stringProtoFuncLastIndexOf): Ditto. |
| (KJS::stringProtoFuncMatch): Ditto. |
| (KJS::stringProtoFuncSearch): Ditto. |
| (KJS::stringProtoFuncSlice): Ditto. |
| (KJS::stringProtoFuncSplit): Ditto. |
| (KJS::stringProtoFuncSubstr): Ditto. |
| (KJS::stringProtoFuncSubstring): Ditto. |
| (KJS::stringProtoFuncToLowerCase): Use toThisJSString. |
| (KJS::stringProtoFuncToUpperCase): Ditto. |
| (KJS::stringProtoFuncToLocaleLowerCase): Ditto. |
| (KJS::stringProtoFuncToLocaleUpperCase): Ditto. |
| (KJS::stringProtoFuncLocaleCompare): Ditto. |
| (KJS::stringProtoFuncBig): Use toThisString. |
| (KJS::stringProtoFuncSmall): Ditto. |
| (KJS::stringProtoFuncBlink): Ditto. |
| (KJS::stringProtoFuncBold): Ditto. |
| (KJS::stringProtoFuncFixed): Ditto. |
| (KJS::stringProtoFuncItalics): Ditto. |
| (KJS::stringProtoFuncStrike): Ditto. |
| (KJS::stringProtoFuncSub): Ditto. |
| (KJS::stringProtoFuncSup): Ditto. |
| (KJS::stringProtoFuncFontcolor): Ditto. |
| (KJS::stringProtoFuncFontsize): Ditto. |
| (KJS::stringProtoFuncAnchor): Ditto. |
| (KJS::stringProtoFuncLink): Ditto. |
| |
| * kjs/string_object.h: Added toString, toThisString, and toThisJSString. |
| |
| * kjs/ustring.cpp: |
| (KJS::UString::append): Added a version that takes a character pointer and |
| size, so we don't have to create a UString just to append to another UString. |
| * kjs/ustring.h: |
| |
| 2008-06-26 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Make JSGlobalData per-thread. |
| |
| No change on SunSpider total. |
| |
| * wtf/ThreadSpecific.h: Re-enabled the actual implementation. |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::~JSGlobalObject): Re-added a JSLock-related assertion. We'll probably |
| want to preserve these somehow to keep legacy behavior in working condition. |
| (KJS::JSGlobalObject::init): Initialize globalData pointer earlier, so that it is ready |
| when updating JSGlobalObject linked list. |
| |
| * kjs/JSGlobalObject.h: (KJS::JSGlobalObject::head): Changed head() to be non-static, and |
| to use JSGlobalData associated with the current object. |
| |
| * kjs/InitializeThreading.cpp: (KJS::initializeThreadingOnce): Removed a no longer needed |
| Heap::registerAsMainThread() call. |
| |
| * kjs/JSGlobalData.h: Removed a lying lie comment - parserObjectExtraRefCounts is not |
| transient, and while newParserObjects may conceptually be such, there is still some node |
| manipulation going on outside Parser::parse which touches it. |
| |
| * kjs/JSGlobalData.cpp: |
| (KJS::JSGlobalData::~JSGlobalData): Delete recently added members. |
| (KJS::JSGlobalData::sharedInstance): Actually use a separate instance. |
| |
| * kjs/collector.cpp: |
| (KJS::Heap::Heap): |
| (KJS::Heap::~Heap): Added a destructor, which unconditionally deletes everything. |
| (KJS::Heap::sweep): Removed code related to "collect on main thread only" logic. |
| (KJS::Heap::collect): Ditto. |
| (KJS::Heap::globalObjectCount): Explicitly use per-thread instance of JSGlobalObject linked |
| list now that JSGlobalObject::head() is not static. Curently, WebCoreStatistics methods only |
| work with the main thread currently anyway. |
| (KJS::Heap::protectedGlobalObjectCount): Ditto. |
| |
| * kjs/collector.h: Removed code related to "collect on main thread only" logic. |
| |
| * JavaScriptCore.exp: Removed Heap::collectOnMainThreadOnly. |
| |
| 2008-06-26 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=19767 |
| REGRESSION: Crash in sort() when visiting http://www.onnyturf.com/subway/ |
| |
| * kjs/JSArray.cpp: (KJS::AVLTreeAbstractorForArrayCompare::set_balance_factor): |
| Made changing balance factor from -1 to +1 work correctly. |
| |
| * wtf/AVLTree.h: (KJS::AVLTreeDefaultBSet::operator[]): Added an assertion that catches |
| this slightly earlier. |
| |
| 2008-06-25 Timothy Hatcher <timothy@apple.com> |
| |
| Fixes an ASSERT in the profiler when starting multiple profiles |
| with the same name inside the same function/program. |
| |
| Reviewed by Kevin McCullough. |
| |
| * profiler/Profile.cpp: |
| (KJS::Profile::Profile): Initialize m_stoppedCallDepth to zero. |
| (KJS::Profile::stopProfiling): Set the current node to the parent, |
| because we are in a call that will not get a didExecute call. |
| (KJS::Profile::removeProfile): Increment m_stoppedCallDepth to |
| account for didExecute not being called for profile. |
| (KJS::Profile::willExecute): Increment m_stoppedCallDepth if stopped. |
| (KJS::Profile::didExecute): Decrement m_stoppedCallDepth if stopped and |
| greater than zero, and return early. |
| * profiler/Profile.h: Added stoppedProfiling(). |
| * profiler/Profiler.cpp: |
| (KJS::Profiler::findProfile): Removed. |
| (KJS::Profiler::startProfiling): Don't return early for stopped profiles. |
| (KJS::Profiler::stopProfiling): Skipp stopped profiles. |
| (KJS::Profiler::didFinishAllExecution): Code clean-up. |
| * profiler/Profiler.h: Removed findProfile. |
| |
| 2008-06-25 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Alexey Proskuryakov. |
| |
| Attempt to fix Windows debug build. The compiler gives a warning when |
| Structured Exception Handling and destructors are used in the same |
| function. Using manual locking and unlocking instead of constructors |
| and destructors should fix the warning. |
| |
| * kjs/Shell.cpp: |
| (main): |
| |
| 2008-06-25 Alexey Proskuryakov <ap@webkit.org> |
| |
| Forgot to address a review comment about better names for tracked objects, doing it now. |
| |
| * kjs/JSGlobalData.cpp: |
| (KJS::JSGlobalData::JSGlobalData): |
| * kjs/JSGlobalData.h: |
| * kjs/nodes.cpp: |
| (KJS::ParserRefCounted::ParserRefCounted): |
| (KJS::ParserRefCounted::ref): |
| (KJS::ParserRefCounted::deref): |
| (KJS::ParserRefCounted::hasOneRef): |
| (KJS::ParserRefCounted::deleteNewObjects): |
| |
| 2008-06-25 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Geoff. |
| |
| Remove more threadInstance() calls. |
| |
| * kjs/JSFunction.cpp: |
| (KJS::JSFunction::getParameterName): |
| (KJS::IndexToNameMap::unMap): |
| (KJS::Arguments::deleteProperty): |
| * kjs/JSFunction.h: |
| Access nullIdentifier without going to thread specific storage. |
| |
| * JavaScriptCore.exp: |
| * kjs/JSGlobalData.cpp: |
| (KJS::JSGlobalData::JSGlobalData): |
| * kjs/JSGlobalData.h: |
| * kjs/Parser.cpp: |
| (KJS::Parser::parse): |
| * kjs/Parser.h: |
| (KJS::ParserRefCountedData::ParserRefCountedData): |
| (KJS::Parser::parse): |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::ParserRefCounted::ParserRefCounted): |
| (KJS::ParserRefCounted::ref): |
| (KJS::ParserRefCounted::deref): |
| (KJS::ParserRefCounted::hasOneRef): |
| (KJS::ParserRefCounted::deleteNewObjects): |
| (KJS::Node::Node): |
| (KJS::StatementNode::StatementNode): |
| (KJS::BreakpointCheckStatement::BreakpointCheckStatement): |
| (KJS::ConstDeclNode::ConstDeclNode): |
| (KJS::BlockNode::BlockNode): |
| (KJS::ForInNode::ForInNode): |
| (KJS::ScopeNode::ScopeNode): |
| (KJS::ProgramNode::ProgramNode): |
| (KJS::ProgramNode::create): |
| (KJS::EvalNode::EvalNode): |
| (KJS::EvalNode::create): |
| (KJS::FunctionBodyNode::FunctionBodyNode): |
| (KJS::FunctionBodyNode::create): |
| * kjs/nodes.h: |
| (KJS::ExpressionNode::): |
| (KJS::NullNode::): |
| (KJS::BooleanNode::): |
| (KJS::NumberNode::): |
| (KJS::ImmediateNumberNode::): |
| (KJS::StringNode::): |
| (KJS::RegExpNode::): |
| (KJS::ThisNode::): |
| (KJS::ResolveNode::): |
| (KJS::ElementNode::): |
| (KJS::ArrayNode::): |
| (KJS::PropertyNode::): |
| (KJS::PropertyListNode::): |
| (KJS::ObjectLiteralNode::): |
| (KJS::BracketAccessorNode::): |
| (KJS::DotAccessorNode::): |
| (KJS::ArgumentListNode::): |
| (KJS::ArgumentsNode::): |
| (KJS::NewExprNode::): |
| (KJS::EvalFunctionCallNode::): |
| (KJS::FunctionCallValueNode::): |
| (KJS::FunctionCallResolveNode::): |
| (KJS::FunctionCallBracketNode::): |
| (KJS::FunctionCallDotNode::): |
| (KJS::PrePostResolveNode::): |
| (KJS::PostIncResolveNode::): |
| (KJS::PostDecResolveNode::): |
| (KJS::PostfixBracketNode::): |
| (KJS::PostIncBracketNode::): |
| (KJS::PostDecBracketNode::): |
| (KJS::PostfixDotNode::): |
| (KJS::PostIncDotNode::): |
| (KJS::PostDecDotNode::): |
| (KJS::PostfixErrorNode::): |
| (KJS::DeleteResolveNode::): |
| (KJS::DeleteBracketNode::): |
| (KJS::DeleteDotNode::): |
| (KJS::DeleteValueNode::): |
| (KJS::VoidNode::): |
| (KJS::TypeOfResolveNode::): |
| (KJS::TypeOfValueNode::): |
| (KJS::PreIncResolveNode::): |
| (KJS::PreDecResolveNode::): |
| (KJS::PrefixBracketNode::): |
| (KJS::PreIncBracketNode::): |
| (KJS::PreDecBracketNode::): |
| (KJS::PrefixDotNode::): |
| (KJS::PreIncDotNode::): |
| (KJS::PreDecDotNode::): |
| (KJS::PrefixErrorNode::): |
| (KJS::UnaryOpNode::UnaryOpNode): |
| (KJS::UnaryPlusNode::): |
| (KJS::NegateNode::): |
| (KJS::BitwiseNotNode::): |
| (KJS::LogicalNotNode::): |
| (KJS::BinaryOpNode::BinaryOpNode): |
| (KJS::ReverseBinaryOpNode::ReverseBinaryOpNode): |
| (KJS::MultNode::): |
| (KJS::DivNode::): |
| (KJS::ModNode::): |
| (KJS::AddNode::): |
| (KJS::SubNode::): |
| (KJS::LeftShiftNode::): |
| (KJS::RightShiftNode::): |
| (KJS::UnsignedRightShiftNode::): |
| (KJS::LessNode::): |
| (KJS::GreaterNode::): |
| (KJS::LessEqNode::): |
| (KJS::GreaterEqNode::): |
| (KJS::InstanceOfNode::): |
| (KJS::InNode::): |
| (KJS::EqualNode::): |
| (KJS::NotEqualNode::): |
| (KJS::StrictEqualNode::): |
| (KJS::NotStrictEqualNode::): |
| (KJS::BitAndNode::): |
| (KJS::BitOrNode::): |
| (KJS::BitXOrNode::): |
| (KJS::LogicalAndNode::): |
| (KJS::LogicalOrNode::): |
| (KJS::ConditionalNode::): |
| (KJS::ReadModifyResolveNode::): |
| (KJS::AssignResolveNode::): |
| (KJS::ReadModifyBracketNode::): |
| (KJS::AssignBracketNode::): |
| (KJS::AssignDotNode::): |
| (KJS::ReadModifyDotNode::): |
| (KJS::AssignErrorNode::): |
| (KJS::CommaNode::): |
| (KJS::VarDeclCommaNode::): |
| (KJS::ConstStatementNode::): |
| (KJS::SourceElements::SourceElements): |
| (KJS::EmptyStatementNode::): |
| (KJS::DebuggerStatementNode::): |
| (KJS::ExprStatementNode::): |
| (KJS::VarStatementNode::): |
| (KJS::IfNode::): |
| (KJS::IfElseNode::): |
| (KJS::DoWhileNode::): |
| (KJS::WhileNode::): |
| (KJS::ForNode::): |
| (KJS::ContinueNode::): |
| (KJS::BreakNode::): |
| (KJS::ReturnNode::): |
| (KJS::WithNode::): |
| (KJS::LabelNode::): |
| (KJS::ThrowNode::): |
| (KJS::TryNode::): |
| (KJS::ParameterNode::): |
| (KJS::FuncExprNode::): |
| (KJS::FuncDeclNode::): |
| (KJS::CaseClauseNode::): |
| (KJS::ClauseListNode::): |
| (KJS::CaseBlockNode::): |
| (KJS::SwitchNode::): |
| Changed ParserRefCounted to hold a JSGlobalData pointer, and used it to replace |
| threadInstance calls. |
| |
| 2008-06-24 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Alexey Proskuryakov. |
| |
| Make the JavaScript shell collect the heap from main() instead of |
| jscmain() to suppress leak messages in debug builds. |
| |
| * kjs/Shell.cpp: |
| (main): |
| (jscmain): |
| |
| 2008-06-24 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Make the conversion of the pair (less, jtrue) to jless use register |
| reference counting information for safety instead of requiring callers |
| to decide whether it is safe. |
| |
| No changes on SunSpider codegen. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitJumpIfTrue): |
| * VM/CodeGenerator.h: |
| * kjs/nodes.cpp: |
| (KJS::DoWhileNode::emitCode): |
| (KJS::WhileNode::emitCode): |
| (KJS::ForNode::emitCode): |
| (KJS::CaseBlockNode::emitCodeForBlock): |
| |
| 2008-06-24 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Tim. |
| |
| <rdar://problem/6031594> JSProfiler: Profiler goes into an infinite |
| loop sometimes. |
| <rdar://problem/6031603> JSProfiler: Profiler asserts in debug and |
| give the wrong times in release |
| |
| Fixed two issues found by Tim in the same test. |
| |
| * profiler/Profile.cpp: |
| (KJS::Profile::removeProfileStart): No longer take profile's time from |
| all ancestors, but instead attribute it to its parent. Also add an |
| Assert to ensure we only delete the child we mean to. |
| (KJS::Profile::removeProfileEnd): Ditto for profileEnd. |
| (KJS::Profile::didExecute): Cleaned up the execution order and correctly |
| attribute all of the parent's time to the new node. |
| * profiler/ProfileNode.cpp: If this node does not have a startTime it |
| should not get a giant total time, but instead be 0. |
| (KJS::ProfileNode::endAndRecordCall): |
| * profiler/ProfileNode.h: |
| (KJS::ProfileNode::removeChild): Should reset the sibling pointers since |
| one of them has been removed. |
| |
| 2008-06-24 Darin Adler <darin@apple.com> |
| |
| Reviewed by Cameron. |
| |
| - fix https://bugs.webkit.org/show_bug.cgi?id=19739 |
| REGRESSION: fast/js/property-getters-and-setters.html fails |
| |
| * kjs/JSObject.cpp: |
| (KJS::JSObject::put): Remove an untested optimization I checked in by accident. |
| The two loops up the prototype chain both need to start from this; instead the |
| second loop was starting where the first loop left off. |
| |
| 2008-06-24 Steve Falkenburg <sfalken@apple.com> |
| |
| Build fix. |
| |
| * kjs/nodes.cpp: |
| |
| 2008-06-24 Joerg Bornemann <joerg.bornemann@trolltech.com> |
| |
| Reviewed by Simon. |
| |
| For the Qt build on Windows don't depend on the presence of GNU CPP |
| but use MSVC's preprocessor instead. |
| dftables accepts a --preprocessor option which is set in pcre.pri for MSVC platforms. |
| |
| * pcre/dftables: Added support for specifying the preprocessor command |
| to use via --preprocessor, similar to |
| WebCore/bindings/scripts/generate-bindings.pl. |
| * pcre/pcre.pri: Pass --preprocessor='cl /e' to dftables, or more |
| generally speaking QMAKE_CC /E for the win32-msvc buildspecs. |
| |
| 2008-06-24 Simon Hausmann <hausmann@webkit.org> |
| |
| Fix the Qt build, added missing include. |
| |
| * kjs/PropertySlot.cpp: |
| |
| 2008-06-24 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Cameron Zwarich. |
| |
| Make ParserRefCountedCounter actually perform a leak check. |
| |
| * kjs/nodes.cpp: |
| (KJS::ParserRefCountedCounter::~ParserRefCountedCounter): Check for leaks in destructor, |
| not in constructor. |
| (KJS::ParserRefCountedCounter::increment): |
| (KJS::ParserRefCountedCounter::decrement): |
| (KJS::ParserRefCounted::ParserRefCounted): |
| (KJS::ParserRefCounted::~ParserRefCounted): |
| While at it, also made counting thread-safe. |
| |
| 2008-06-24 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Bug 19730: REGRESSION (r34497): Text in alerts in "Leisure suit Larry" is not wrapped |
| <https://bugs.webkit.org/show_bug.cgi?id=19730> |
| |
| Do not convert the pair (less, jtrue) to jless when jtrue is a jump |
| target. An example of this is when the condition of a while loop is a |
| LogicalOrNode. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitLabel): |
| |
| 2008-06-20 Ariya Hidayat <ariya.hidayat@trolltech.com> |
| |
| Reviewed by Adam Roben. |
| |
| Fix compile with MinGW. |
| |
| * kjs/Shell.cpp: |
| * wtf/Threading.h: |
| (WTF::atomicIncrement): |
| (WTF::atomicDecrement): |
| |
| 2008-06-23 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Prepration for returning memory to the OS on Windows. Track whether a portion of a span of memory was returned to the OS. |
| If it was, ask that it be recommitted before returning it to the application as an allocated region. |
| |
| * wtf/FastMalloc.cpp: |
| (WTF::TCMalloc_PageHeap::New): If the span was decommitted, ask that it be recommitted before returning it. |
| (WTF::TCMalloc_PageHeap::AllocLarge): Ditto. |
| (WTF::TCMalloc_PageHeap::Carve): When splitting a span, ensure that the decommitted state propogates to the two new spans. |
| (WTF::TCMalloc_PageHeap::Delete): When merging a span, ensure that the resulting span is marked as decommitted if any of the |
| spans being merged were marked as decommitted. |
| (WTF::TCMalloc_PageHeap::IncrementalScavenge): Mark as decommitted after releasing the span. |
| (WTF::TCMalloc_Central_FreeList::FetchFromSpans): Add an assertion to catch a decommitted span being returned to the application |
| without first being recommitted. |
| (WTF::TCMalloc_Central_FreeList::Populate): Ditto. |
| * wtf/TCSystemAlloc.cpp: Stub out TCMalloc_SystemCommit. |
| * wtf/TCSystemAlloc.h: |
| |
| 2008-06-23 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Remove the sample member of Span when NO_TCMALLOC_SAMPLES is defined. |
| |
| * wtf/FastMalloc.cpp: |
| (WTF::TCMalloc_PageHeap::Delete): Only update Span::sample if NO_TCMALLOC_SAMPLES is not defined. |
| (WTF::TCMallocStats::do_free): Ditto. |
| |
| 2008-06-23 Darin Adler <darin@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - work toward https://bugs.webkit.org/show_bug.cgi?id=19721 |
| |
| More preparation toward making functions work on primitive types without |
| creating wrapper objects. No speedup this time, but prepares for a future |
| speedup without slowing things down. |
| |
| SunSpider reports no change. |
| |
| - Eliminated the implementsCall, callAsFunction and construct virtual |
| functions from JSObject. Instead, the CallData and ConstructData for |
| a native function includes a function pointer that the caller can use |
| directly. Changed all call sites to use CallData and ConstructData. |
| |
| - Changed the "this" argument to native functions to be a JSValue rather |
| than a JSObject. This prepares us for passing primitives into these |
| functions. The conversion to an object now must be done inside the |
| function. Critically, if it's a function that can be called on a DOM |
| window object, then we have to be sure to call toThisObject on the |
| argument before we use it for anything even if it's already an object. |
| |
| - Eliminated the practice of using constructor objects in the global |
| object to make objects of the various basic types. Since these |
| constructors can't be replaced by script, there's no reason to involve |
| a constructor object at all. Added functions to do the construction |
| directly. |
| |
| - Made some more class members private and protected, including virtual |
| function overrides. This can catch code using unnecessarily slow virtual |
| function code paths when the type of an object is known statically. If we |
| later find a new reason use the members outside the class it's easy to |
| make them public again. |
| |
| - Moved the declarations of the native implementations for functions out |
| of header files. These can have internal linkage and be declared inside |
| the source file. |
| |
| - Changed PrototypeFunction to take function pointers with the right |
| arguments to be put directly into CallData. This eliminates the |
| need to have a separate PrototypeReflexiveFunction, and reveals that the |
| real purpose of that class included something else specific to eval -- |
| storage of a cached global object. So renamed PrototypeReflexiveFunction |
| to GlobalEvalFunction. |
| |
| * API/JSCallbackConstructor.cpp: |
| (KJS::constructJSCallback): |
| (KJS::JSCallbackConstructor::getConstructData): |
| * API/JSCallbackConstructor.h: |
| * API/JSCallbackFunction.cpp: |
| (KJS::JSCallbackFunction::implementsHasInstance): |
| (KJS::JSCallbackFunction::call): |
| (KJS::JSCallbackFunction::getCallData): |
| * API/JSCallbackFunction.h: |
| (KJS::JSCallbackFunction::classInfo): |
| * API/JSCallbackObject.h: |
| (KJS::JSCallbackObject::classRef): |
| (KJS::JSCallbackObject::classInfo): |
| * API/JSCallbackObjectFunctions.h: |
| (KJS::::getConstructData): |
| (KJS::::construct): |
| (KJS::::getCallData): |
| (KJS::::call): |
| * API/JSObjectRef.cpp: |
| (JSObjectMakeFunction): |
| (JSObjectIsFunction): |
| (JSObjectCallAsFunction): |
| (JSObjectCallAsConstructor): |
| * JavaScriptCore.exp: |
| * VM/Machine.cpp: |
| (KJS::jsTypeStringForValue): |
| (KJS::Machine::privateExecute): |
| * kjs/ArrayPrototype.cpp: |
| (KJS::arrayProtoFuncToString): |
| (KJS::arrayProtoFuncToLocaleString): |
| (KJS::arrayProtoFuncJoin): |
| (KJS::arrayProtoFuncConcat): |
| (KJS::arrayProtoFuncPop): |
| (KJS::arrayProtoFuncPush): |
| (KJS::arrayProtoFuncReverse): |
| (KJS::arrayProtoFuncShift): |
| (KJS::arrayProtoFuncSlice): |
| (KJS::arrayProtoFuncSort): |
| (KJS::arrayProtoFuncSplice): |
| (KJS::arrayProtoFuncUnShift): |
| (KJS::arrayProtoFuncFilter): |
| (KJS::arrayProtoFuncMap): |
| (KJS::arrayProtoFuncEvery): |
| (KJS::arrayProtoFuncForEach): |
| (KJS::arrayProtoFuncSome): |
| (KJS::arrayProtoFuncIndexOf): |
| (KJS::arrayProtoFuncLastIndexOf): |
| (KJS::ArrayConstructor::ArrayConstructor): |
| (KJS::constructArrayWithSizeQuirk): |
| (KJS::constructWithArrayConstructor): |
| (KJS::ArrayConstructor::getConstructData): |
| (KJS::callArrayConstructor): |
| (KJS::ArrayConstructor::getCallData): |
| * kjs/ArrayPrototype.h: |
| * kjs/BooleanObject.cpp: |
| (KJS::booleanProtoFuncToString): |
| (KJS::booleanProtoFuncValueOf): |
| (KJS::constructBoolean): |
| (KJS::constructWithBooleanConstructor): |
| (KJS::BooleanConstructor::getConstructData): |
| (KJS::callBooleanConstructor): |
| (KJS::BooleanConstructor::getCallData): |
| (KJS::constructBooleanFromImmediateBoolean): |
| * kjs/BooleanObject.h: |
| * kjs/CallData.h: |
| (KJS::): |
| * kjs/ConstructData.h: |
| (KJS::): |
| * kjs/FunctionPrototype.cpp: |
| (KJS::callFunctionPrototype): |
| (KJS::FunctionPrototype::getCallData): |
| (KJS::functionProtoFuncToString): |
| (KJS::functionProtoFuncApply): |
| (KJS::functionProtoFuncCall): |
| (KJS::constructWithFunctionConstructor): |
| (KJS::FunctionConstructor::getConstructData): |
| (KJS::callFunctionConstructor): |
| (KJS::FunctionConstructor::getCallData): |
| (KJS::constructFunction): |
| * kjs/FunctionPrototype.h: |
| * kjs/JSArray.cpp: |
| (KJS::AVLTreeAbstractorForArrayCompare::compare_key_key): |
| (KJS::JSArray::sort): |
| (KJS::constructEmptyArray): |
| (KJS::constructArray): |
| * kjs/JSArray.h: |
| (KJS::JSArray::classInfo): |
| * kjs/JSFunction.cpp: |
| (KJS::JSFunction::call): |
| (KJS::globalFuncEval): |
| (KJS::globalFuncParseInt): |
| (KJS::globalFuncParseFloat): |
| (KJS::globalFuncIsNaN): |
| (KJS::globalFuncIsFinite): |
| (KJS::globalFuncDecodeURI): |
| (KJS::globalFuncDecodeURIComponent): |
| (KJS::globalFuncEncodeURI): |
| (KJS::globalFuncEncodeURIComponent): |
| (KJS::globalFuncEscape): |
| (KJS::globalFuncUnescape): |
| (KJS::globalFuncKJSPrint): |
| (KJS::PrototypeFunction::PrototypeFunction): |
| (KJS::PrototypeFunction::getCallData): |
| (KJS::GlobalEvalFunction::GlobalEvalFunction): |
| (KJS::GlobalEvalFunction::mark): |
| * kjs/JSFunction.h: |
| (KJS::InternalFunction::classInfo): |
| (KJS::InternalFunction::functionName): |
| (KJS::JSFunction::classInfo): |
| (KJS::GlobalEvalFunction::cachedGlobalObject): |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::reset): |
| (KJS::JSGlobalObject::mark): |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::JSGlobalObject): |
| (KJS::JSGlobalObject::evalFunction): |
| * kjs/JSImmediate.cpp: |
| (KJS::JSImmediate::toObject): |
| * kjs/JSNotAnObject.cpp: |
| * kjs/JSNotAnObject.h: |
| * kjs/JSObject.cpp: |
| (KJS::JSObject::put): |
| (KJS::callDefaultValueFunction): |
| (KJS::JSObject::defaultValue): |
| (KJS::JSObject::lookupGetter): |
| (KJS::JSObject::lookupSetter): |
| (KJS::JSObject::hasInstance): |
| (KJS::JSObject::fillGetterPropertySlot): |
| (KJS::Error::create): |
| (KJS::constructEmptyObject): |
| * kjs/JSObject.h: |
| (KJS::GetterSetter::GetterSetter): |
| (KJS::GetterSetter::getter): |
| (KJS::GetterSetter::setGetter): |
| (KJS::GetterSetter::setter): |
| (KJS::GetterSetter::setSetter): |
| * kjs/JSValue.cpp: |
| (KJS::JSCell::deleteProperty): |
| (KJS::call): |
| (KJS::construct): |
| * kjs/JSValue.h: |
| * kjs/MathObject.cpp: |
| (KJS::mathProtoFuncAbs): |
| (KJS::mathProtoFuncACos): |
| (KJS::mathProtoFuncASin): |
| (KJS::mathProtoFuncATan): |
| (KJS::mathProtoFuncATan2): |
| (KJS::mathProtoFuncCeil): |
| (KJS::mathProtoFuncCos): |
| (KJS::mathProtoFuncExp): |
| (KJS::mathProtoFuncFloor): |
| (KJS::mathProtoFuncLog): |
| (KJS::mathProtoFuncMax): |
| (KJS::mathProtoFuncMin): |
| (KJS::mathProtoFuncPow): |
| (KJS::mathProtoFuncRandom): |
| (KJS::mathProtoFuncRound): |
| (KJS::mathProtoFuncSin): |
| (KJS::mathProtoFuncSqrt): |
| (KJS::mathProtoFuncTan): |
| * kjs/MathObject.h: |
| * kjs/NumberObject.cpp: |
| (KJS::numberProtoFuncToString): |
| (KJS::numberProtoFuncToLocaleString): |
| (KJS::numberProtoFuncValueOf): |
| (KJS::numberProtoFuncToFixed): |
| (KJS::numberProtoFuncToExponential): |
| (KJS::numberProtoFuncToPrecision): |
| (KJS::NumberConstructor::NumberConstructor): |
| (KJS::constructWithNumberConstructor): |
| (KJS::NumberConstructor::getConstructData): |
| (KJS::callNumberConstructor): |
| (KJS::NumberConstructor::getCallData): |
| (KJS::constructNumber): |
| (KJS::constructNumberFromImmediateNumber): |
| * kjs/NumberObject.h: |
| (KJS::NumberObject::classInfo): |
| (KJS::NumberConstructor::classInfo): |
| * kjs/PropertySlot.cpp: |
| (KJS::PropertySlot::functionGetter): |
| * kjs/RegExpObject.cpp: |
| (KJS::regExpProtoFuncTest): |
| (KJS::regExpProtoFuncExec): |
| (KJS::regExpProtoFuncCompile): |
| (KJS::regExpProtoFuncToString): |
| (KJS::callRegExpObject): |
| (KJS::RegExpObject::getCallData): |
| (KJS::constructRegExp): |
| (KJS::constructWithRegExpConstructor): |
| (KJS::RegExpConstructor::getConstructData): |
| (KJS::callRegExpConstructor): |
| (KJS::RegExpConstructor::getCallData): |
| * kjs/RegExpObject.h: |
| (KJS::RegExpConstructor::classInfo): |
| * kjs/Shell.cpp: |
| (GlobalObject::GlobalObject): |
| (functionPrint): |
| (functionDebug): |
| (functionGC): |
| (functionVersion): |
| (functionRun): |
| (functionLoad): |
| (functionReadline): |
| (functionQuit): |
| * kjs/date_object.cpp: |
| (KJS::gmtoffset): |
| (KJS::formatLocaleDate): |
| (KJS::fillStructuresUsingDateArgs): |
| (KJS::DateInstance::getTime): |
| (KJS::DateInstance::getUTCTime): |
| (KJS::DateConstructor::DateConstructor): |
| (KJS::constructDate): |
| (KJS::DateConstructor::getConstructData): |
| (KJS::callDate): |
| (KJS::DateConstructor::getCallData): |
| (KJS::dateParse): |
| (KJS::dateNow): |
| (KJS::dateUTC): |
| (KJS::dateProtoFuncToString): |
| (KJS::dateProtoFuncToUTCString): |
| (KJS::dateProtoFuncToDateString): |
| (KJS::dateProtoFuncToTimeString): |
| (KJS::dateProtoFuncToLocaleString): |
| (KJS::dateProtoFuncToLocaleDateString): |
| (KJS::dateProtoFuncToLocaleTimeString): |
| (KJS::dateProtoFuncValueOf): |
| (KJS::dateProtoFuncGetTime): |
| (KJS::dateProtoFuncGetFullYear): |
| (KJS::dateProtoFuncGetUTCFullYear): |
| (KJS::dateProtoFuncToGMTString): |
| (KJS::dateProtoFuncGetMonth): |
| (KJS::dateProtoFuncGetUTCMonth): |
| (KJS::dateProtoFuncGetDate): |
| (KJS::dateProtoFuncGetUTCDate): |
| (KJS::dateProtoFuncGetDay): |
| (KJS::dateProtoFuncGetUTCDay): |
| (KJS::dateProtoFuncGetHours): |
| (KJS::dateProtoFuncGetUTCHours): |
| (KJS::dateProtoFuncGetMinutes): |
| (KJS::dateProtoFuncGetUTCMinutes): |
| (KJS::dateProtoFuncGetSeconds): |
| (KJS::dateProtoFuncGetUTCSeconds): |
| (KJS::dateProtoFuncGetMilliSeconds): |
| (KJS::dateProtoFuncGetUTCMilliseconds): |
| (KJS::dateProtoFuncGetTimezoneOffset): |
| (KJS::dateProtoFuncSetTime): |
| (KJS::setNewValueFromTimeArgs): |
| (KJS::setNewValueFromDateArgs): |
| (KJS::dateProtoFuncSetMilliSeconds): |
| (KJS::dateProtoFuncSetUTCMilliseconds): |
| (KJS::dateProtoFuncSetSeconds): |
| (KJS::dateProtoFuncSetUTCSeconds): |
| (KJS::dateProtoFuncSetMinutes): |
| (KJS::dateProtoFuncSetUTCMinutes): |
| (KJS::dateProtoFuncSetHours): |
| (KJS::dateProtoFuncSetUTCHours): |
| (KJS::dateProtoFuncSetDate): |
| (KJS::dateProtoFuncSetUTCDate): |
| (KJS::dateProtoFuncSetMonth): |
| (KJS::dateProtoFuncSetUTCMonth): |
| (KJS::dateProtoFuncSetFullYear): |
| (KJS::dateProtoFuncSetUTCFullYear): |
| (KJS::dateProtoFuncSetYear): |
| (KJS::dateProtoFuncGetYear): |
| * kjs/date_object.h: |
| (KJS::DateInstance::internalNumber): |
| (KJS::DateInstance::classInfo): |
| * kjs/error_object.cpp: |
| (KJS::errorProtoFuncToString): |
| (KJS::constructError): |
| (KJS::constructWithErrorConstructor): |
| (KJS::ErrorConstructor::getConstructData): |
| (KJS::callErrorConstructor): |
| (KJS::ErrorConstructor::getCallData): |
| (KJS::NativeErrorConstructor::construct): |
| (KJS::constructWithNativeErrorConstructor): |
| (KJS::NativeErrorConstructor::getConstructData): |
| (KJS::callNativeErrorConstructor): |
| (KJS::NativeErrorConstructor::getCallData): |
| * kjs/error_object.h: |
| (KJS::NativeErrorConstructor::classInfo): |
| * kjs/internal.cpp: |
| (KJS::JSNumberCell::toObject): |
| (KJS::JSNumberCell::toThisObject): |
| (KJS::GetterSetter::mark): |
| (KJS::GetterSetter::toPrimitive): |
| (KJS::GetterSetter::toBoolean): |
| (KJS::GetterSetter::toNumber): |
| (KJS::GetterSetter::toString): |
| (KJS::GetterSetter::toObject): |
| (KJS::InternalFunction::InternalFunction): |
| (KJS::InternalFunction::implementsHasInstance): |
| * kjs/lookup.h: |
| (KJS::HashEntry::): |
| * kjs/nodes.cpp: |
| (KJS::FuncDeclNode::makeFunction): |
| (KJS::FuncExprNode::makeFunction): |
| * kjs/object_object.cpp: |
| (KJS::objectProtoFuncValueOf): |
| (KJS::objectProtoFuncHasOwnProperty): |
| (KJS::objectProtoFuncIsPrototypeOf): |
| (KJS::objectProtoFuncDefineGetter): |
| (KJS::objectProtoFuncDefineSetter): |
| (KJS::objectProtoFuncLookupGetter): |
| (KJS::objectProtoFuncLookupSetter): |
| (KJS::objectProtoFuncPropertyIsEnumerable): |
| (KJS::objectProtoFuncToLocaleString): |
| (KJS::objectProtoFuncToString): |
| (KJS::ObjectConstructor::ObjectConstructor): |
| (KJS::constructObject): |
| (KJS::constructWithObjectConstructor): |
| (KJS::ObjectConstructor::getConstructData): |
| (KJS::callObjectConstructor): |
| (KJS::ObjectConstructor::getCallData): |
| * kjs/object_object.h: |
| * kjs/string_object.cpp: |
| (KJS::replace): |
| (KJS::stringProtoFuncToString): |
| (KJS::stringProtoFuncValueOf): |
| (KJS::stringProtoFuncCharAt): |
| (KJS::stringProtoFuncCharCodeAt): |
| (KJS::stringProtoFuncConcat): |
| (KJS::stringProtoFuncIndexOf): |
| (KJS::stringProtoFuncLastIndexOf): |
| (KJS::stringProtoFuncMatch): |
| (KJS::stringProtoFuncSearch): |
| (KJS::stringProtoFuncReplace): |
| (KJS::stringProtoFuncSlice): |
| (KJS::stringProtoFuncSplit): |
| (KJS::stringProtoFuncSubstr): |
| (KJS::stringProtoFuncSubstring): |
| (KJS::stringProtoFuncToLowerCase): |
| (KJS::stringProtoFuncToUpperCase): |
| (KJS::stringProtoFuncToLocaleLowerCase): |
| (KJS::stringProtoFuncToLocaleUpperCase): |
| (KJS::stringProtoFuncLocaleCompare): |
| (KJS::stringProtoFuncBig): |
| (KJS::stringProtoFuncSmall): |
| (KJS::stringProtoFuncBlink): |
| (KJS::stringProtoFuncBold): |
| (KJS::stringProtoFuncFixed): |
| (KJS::stringProtoFuncItalics): |
| (KJS::stringProtoFuncStrike): |
| (KJS::stringProtoFuncSub): |
| (KJS::stringProtoFuncSup): |
| (KJS::stringProtoFuncFontcolor): |
| (KJS::stringProtoFuncFontsize): |
| (KJS::stringProtoFuncAnchor): |
| (KJS::stringProtoFuncLink): |
| (KJS::stringFromCharCode): |
| (KJS::StringConstructor::StringConstructor): |
| (KJS::constructWithStringConstructor): |
| (KJS::StringConstructor::getConstructData): |
| (KJS::callStringConstructor): |
| (KJS::StringConstructor::getCallData): |
| * kjs/string_object.h: |
| |
| 2008-06-23 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Bug 19716: REGRESSION (SquirrelFish): Reproducible crash after entering a username at mint.com |
| <https://bugs.webkit.org/show_bug.cgi?id=19716> |
| |
| When unwinding callframes for exceptions, check whether the callframe |
| was created by a reentrant native call to JavaScript after tearing off |
| the local variables instead of before. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::unwindCallFrame): |
| |
| 2008-06-23 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Get testapi passing again in a debug build. |
| |
| * API/testapi.c: |
| (main): Update the expected output of calling JSValueMakeString on a function object. |
| |
| 2008-06-21 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Print a blank line when exiting the jsc interactive mode to ensure that the shell |
| prompt will start on a new line. |
| |
| * kjs/Shell.cpp: |
| (runInteractive): |
| |
| 2008-06-21 Mark Rowe <mrowe@apple.com> |
| |
| Rubber-stamped by Sam Weinig. |
| |
| Tweak the paths of the items in the "tests" group to clean things up a little. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2008-06-21 Mark Rowe <mrowe@apple.com> |
| |
| Rubber-stamped by Sam Weinig. |
| |
| Fix jsc to link against libedit.dylib rather than libedit.2.dylib. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2008-06-21 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Copy the JavaScriptCore shell (jsc) into JavaScriptCore.framework so that it will |
| be included in nightly builds. |
| https://bugs.webkit.org/show_bug.cgi?id=19691 |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2008-06-21 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Mark Rowe. |
| |
| Fix the build for non-Mac Darwin platforms by disabling their support |
| for readline in the JavaScript shell. |
| |
| * kjs/config.h: |
| |
| 2008-06-20 Timothy Hatcher <timothy@apple.com> |
| |
| Use member function pointers for the Profile::forEach function. |
| Eliminating a few static functions and simplified things a little. |
| |
| Reviewed by Alexey Proskuryakov. |
| |
| * JavaScriptCore.exp: Change the symbol for forEach. |
| * profiler/Profile.cpp: |
| (KJS::Profile::forEach): Use a member function pointer. |
| * profiler/Profile.h: |
| (KJS::Profile::sortTotalTimeDescending): Pass a function pointer. |
| (KJS::Profile::sortTotalTimeAscending): Ditto. |
| (KJS::Profile::sortSelfTimeDescending): Ditto. |
| (KJS::Profile::sortSelfTimeAscending): Ditto. |
| (KJS::Profile::sortCallsDescending): Ditto. |
| * profiler/ProfileNode.h: |
| (KJS::ProfileNode::sortTotalTimeDescending): No longer static. |
| (KJS::ProfileNode::sortTotalTimeAscending): Ditto. |
| (KJS::ProfileNode::sortSelfTimeDescending): Ditto. |
| (KJS::ProfileNode::sortSelfTimeAscending): Ditto. |
| (KJS::ProfileNode::sortCallsDescending): Ditto. |
| |
| 2008-06-20 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Remove unused destructors. |
| |
| * kjs/nodes.cpp: |
| * kjs/nodes.h: |
| |
| 2008-06-20 Timothy Hatcher <timothy@apple.com> |
| |
| Fixed an ASSERT(m_actualSelfTime <= m_actualTotalTime) when starting |
| and stopping a profile from the Develop menu. Also prevents |
| inserting an incorrect parent node as the new head after profiling |
| is stopped from the Develop menu. |
| |
| Reviewed by Dan Bernstein. |
| |
| * profiler/Profile.cpp: |
| (KJS::Profile::stopProfiling): If the current node is already the head |
| then there is no more need to record future nodes in didExecute. |
| (KJS::Profile::didExecute): Move the code of setupCurrentNodeAsStopped |
| into here since this was the only caller. When setting the total time |
| keep any current total time while adding the self time of the head. |
| (KJS::Profile::setupCurrentNodeAsStopped): Removed. |
| * profiler/Profile.h: Removed setupCurrentNodeAsStopped. |
| |
| 2008-06-20 Kevin Ollivier <kevino@theolliviers.com> |
| |
| !USE(MULTIPLE_THREADS) on Darwin build fix |
| |
| * kjs/InitializeThreading.cpp: |
| (KJS::initializeThreading): |
| * kjs/collector.h: |
| |
| 2008-06-20 Kevin McCullough <kmccullough@apple.com> |
| |
| -Leopard Build Fix. |
| |
| * profiler/Profile.cpp: |
| (KJS::Profile::removeProfileStart): |
| (KJS::Profile::removeProfileEnd): |
| |
| 2008-06-20 Kevin McCullough <kmccullough@apple.com> |
| |
| Just giving credit. |
| |
| * ChangeLog: |
| |
| 2008-06-20 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Tim and Dan. |
| |
| <rdar://problem/6024846> JSProfiler: ASSERT hit in Profiler. |
| - Because InspectorController can call startProfiling() and |
| stopProfiling() we cannot assert that console.profile() and |
| console.profileEnd() will be in the profile tree. |
| |
| * profiler/Profile.cpp: |
| (KJS::Profile::removeProfileStart): |
| (KJS::Profile::removeProfileEnd): |
| |
| 2008-06-20 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Tim. |
| |
| <rdar://problem/5958770> JSProfiler: Time incorrectly given to (idle) |
| if profiling is started and finished within the same function. (19230) |
| - Now we profile one more stack frame up from the last frame to allocate |
| the time spent in it, if it exists. |
| |
| * JavaScriptCore.exp: |
| * VM/Machine.cpp: We need to let the profiler know when the JS program |
| has finished since that is what will actually stop the profiler instead |
| of just calling stopProfiling(). |
| (KJS::Machine::execute): |
| * profiler/Profile.cpp: |
| (KJS::Profile::create): Moved from Profile.h since it was getting pretty |
| long. |
| (KJS::Profile::Profile): We now have a client, which is a listener who |
| we will return this profile to, once it has actually finished. |
| (KJS::Profile::stopProfiling): Instead of fully stopping the profiler |
| here, we set the flag and keep it profiling in the background. |
| (KJS::Profile::didFinishAllExecution): This is where the profiler |
| actually finishes and creates the (idle) node if one should be made. |
| (KJS::Profile::removeProfileStart): Don't use m_currentNode since it is |
| needed by the profiler as it runs silently in the background. |
| (KJS::Profile::removeProfileEnd): Ditto. |
| (KJS::Profile::willExecute): Don't profile new functions if we have |
| stopped profiling. |
| (KJS::Profile::didExecute): Only record one more return as all the |
| remaining time will be attributed to that function. |
| (KJS::Profile::setupCurrentNodeAsStopped): Sets the current node's time. |
| * profiler/Profile.h: Added functions and variables for the above |
| changes. |
| (KJS::Profile::client): |
| * profiler/ProfileNode.h: |
| (KJS::CallIdentifier::toString): Debug method. |
| * profiler/Profiler.cpp: Added support for the ProfilerClient. |
| (KJS::Profiler::startProfiling): |
| (KJS::Profiler::stopProfiling): No longer return sthe profile. |
| (KJS::Profiler::didFinishAllExecution): Now returns the profile to the |
| client instead of stopProfiling. |
| * profiler/Profiler.h: |
| (KJS::ProfilerClient::~ProfilerClient): Clients will implement this |
| interface. |
| |
| 2008-06-19 Ariya Hidayat <ariya.hidayat@trolltech.com> |
| |
| Reviewed by Simon. |
| |
| Surpress compiler warning (int vs unsigned comparison). |
| |
| * wtf/unicode/qt4/UnicodeQt4.h: |
| (WTF::Unicode::toLower): |
| |
| 2008-06-19 Ariya Hidayat <ariya.hidayat@trolltech.com> |
| |
| Reviewed by Timothy Hatcher. |
| |
| Introduce compiler define for MinGW, to have COMPILER(MINGW). |
| |
| * wtf/Platform.h: |
| |
| 2008-06-19 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Geoff. |
| |
| Make Machine per-JSGlobalData. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitOpcode): |
| * VM/Machine.cpp: |
| (KJS::callEval): |
| (KJS::Machine::unwindCallFrame): |
| (KJS::Machine::throwException): |
| (KJS::Machine::execute): |
| (KJS::Machine::debug): |
| * VM/Machine.h: |
| * kjs/DebuggerCallFrame.cpp: |
| (KJS::DebuggerCallFrame::evaluate): |
| * kjs/DebuggerCallFrame.h: |
| (KJS::DebuggerCallFrame::DebuggerCallFrame): |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::ExecState): |
| * kjs/ExecState.h: |
| (KJS::ExecState::machine): |
| * kjs/JSFunction.cpp: |
| (KJS::JSFunction::callAsFunction): |
| (KJS::JSFunction::argumentsGetter): |
| (KJS::JSFunction::callerGetter): |
| (KJS::JSFunction::construct): |
| (KJS::globalFuncEval): |
| * kjs/JSGlobalData.cpp: |
| (KJS::JSGlobalData::JSGlobalData): |
| * kjs/JSGlobalData.h: |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::evaluate): |
| |
| 2008-06-19 Alp Toker <alp@nuanti.com> |
| |
| GTK+/autotools build fix. JSGlobalObject.cpp in now in |
| AllInOneFile.cpp and shouldn't be built separately. |
| |
| * GNUmakefile.am: |
| |
| 2008-06-19 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Get rid of some threadInstance calls. |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::init): |
| * kjs/Parser.cpp: |
| (KJS::Parser::parse): |
| * kjs/Shell.cpp: |
| (jscmain): |
| |
| 2008-06-19 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Fix an assertion failure at startup. |
| |
| * kjs/JSObject.h: (KJS::JSObject::JSObject): Allow jsNull prototype in an assertion (I had |
| it fixed in a wrong copy of the file, so I wasn't getting the failure). |
| |
| 2008-06-19 Alexey Proskuryakov <ap@webkit.org> |
| |
| Build fix. |
| |
| * kjs/collector.cpp: |
| (KJS::Heap::Heap): |
| (KJS::allocateBlock): |
| * kjs/collector.h: |
| No, #if PLATFORM(UNIX) was not right. I've just moved the unsafe initialization back for now, |
| as the platforms that use that code path do not use multiple threads yet. |
| |
| 2008-06-19 Alexey Proskuryakov <ap@webkit.org> |
| |
| Windows and Qt build fixes. |
| |
| * kjs/collector.h: |
| * kjs/collector.cpp: |
| (KJS::Heap::Heap): |
| Wrapped m_pagesize in #if PLATFORM(UNIX), which should better match the sequence of #elifs |
| in allocateBlock(). Changed MIN_ARRAY_SIZE to be explicitly size_t, as this type is different |
| on different platforms. |
| |
| 2008-06-17 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Prepare JavaScript heap for being per-thread. |
| |
| * kjs/ExecState.h: Shuffle includes, making it possible to include ExecState.h in JSValue.h. |
| (KJS::ExecState::heap): Added an accessor. |
| |
| * API/JSBase.cpp: (JSGarbageCollect): Collect both shared and per-thread heaps. |
| |
| * API/JSContextRef.cpp: (JSGlobalContextCreate): When allocating JSGlobalObject, indicate |
| that it belongs to a shared heap. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/AllInOneFile.cpp: |
| Moved JSGlobalObject.cpp to AllInOneFile, as a build fix for inlineAllocate magic. |
| |
| * VM/CodeGenerator.h: (KJS::CodeGenerator::globalExec): Added an accessor (working via |
| m_scopeChain). |
| |
| * VM/RegisterFile.h: |
| (KJS::RegisterFile::mark): |
| * VM/RegisterFileStack.h: |
| (KJS::RegisterFileStack::mark): |
| Made these pseudo-mark functions take Heap*. |
| |
| * kjs/InitializeThreading.cpp: |
| (KJS::initializeThreading): Initialize heap introspector. |
| |
| * kjs/JSGlobalData.h: Added Heap to the structure. |
| |
| * kjs/JSGlobalData.cpp: |
| (KJS::JSGlobalData::JSGlobalData): Initialize Heap. |
| (KJS::JSGlobalData::sharedInstance): Added a method to access shared global data instance |
| for legacy clients. |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::~JSGlobalObject): Changed to work with per-thread head; fixed list |
| maintenance logic. |
| (KJS::JSGlobalObject::init): Changed to work with per-thread head. |
| (KJS::JSGlobalObject::put): Assert that a cross-heap operation is not being attempted. |
| (KJS::JSGlobalObject::reset): Pass ExecState* where now required. |
| (KJS::JSGlobalObject::mark): Pass the current heap to RegisterFileStack::mark. |
| (KJS::JSGlobalObject::operator new): Overload operator new to use per-thread or shared heap. |
| * kjs/JSGlobalObject.h: Removed static s_head member. |
| |
| * kjs/PropertyMap.h: (KJS::PropertyMap::PropertyMap): Removed unused SavedProperty. |
| |
| * kjs/collector.h: Turned Collector into an actual object with its own data, renamed to Heap. |
| (KJS::Heap::initializeHeapIntrospector): Added. |
| (KJS::Heap::heap): Added a method to determine which heap a JSValue is in, if any. |
| (KJS::Heap::allocate): Made non-static. |
| (KJS::Heap::inlineAllocateNumber): Ditto. |
| (KJS::Heap::markListSet): Ditto. |
| (KJS::Heap::cellBlock): Ditto. |
| (KJS::Heap::cellOffset): Ditto. |
| (KJS::Heap::isCellMarked): Ditto. |
| (KJS::Heap::markCell): Ditto. |
| (KJS::Heap::reportExtraMemoryCost): Ditto. |
| (KJS::CollectorBlock): Added a back-reference to Heap for Heap::heap() method. |
| (KJS::SmallCellCollectorBlock): Ditto. |
| |
| * kjs/collector.cpp: Changed MIN_ARRAY_SIZE to a #define to avoid a PIC branch. Removed |
| main thread related machinery. |
| (KJS::Heap::Heap): Initialize the newly added data members. |
| (KJS::allocateBlock): Marked NEVER_INLINE, as this is a rare case that uses a PIC branch. |
| Moved static pagesize to the class to make it safely initialized. |
| (KJS::Heap::heapAllocate): Initialize heap back reference after a new block is allocated. |
| (KJS::Heap::registerThread): Removed introspector initialization, as it is now performed |
| in InitializeThreading.cpp. |
| (KJS::Heap::markOtherThreadConservatively): Assert that the "other thread" case only occurs |
| for legacy clients using a shared heap. |
| (KJS::Heap::markStackObjectsConservatively): Moved fastMallocForbid/Allow down here, since |
| it doesn't need to be forbidden during other GC phases. |
| |
| * kjs/JSImmediate.h: |
| (KJS::jsUndefined): |
| (KJS::jsNull): |
| (KJS::jsBoolean): |
| Moved from JSvalue.h, to make these usable in files that cannot include JSValue.h (such |
| as list.h). |
| |
| * API/JSCallbackObjectFunctions.h: |
| (KJS::::staticFunctionGetter): |
| * API/JSClassRef.cpp: |
| (OpaqueJSClass::prototype): |
| * API/JSObjectRef.cpp: |
| (JSObjectMake): |
| (JSObjectMakeFunctionWithCallback): |
| (JSObjectMakeConstructor): |
| (JSObjectMakeFunction): |
| * API/JSValueRef.cpp: |
| (JSValueMakeNumber): |
| (JSValueMakeString): |
| * JavaScriptCore.exp: |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitLoad): |
| * VM/JSPropertyNameIterator.cpp: |
| (KJS::JSPropertyNameIterator::create): |
| (KJS::JSPropertyNameIterator::next): |
| * VM/Machine.cpp: |
| (KJS::jsAddSlowCase): |
| (KJS::jsAdd): |
| (KJS::jsTypeStringForValue): |
| (KJS::scopeChainForCall): |
| (KJS::Machine::throwException): |
| (KJS::Machine::execute): |
| (KJS::Machine::privateExecute): |
| (KJS::Machine::retrieveArguments): |
| * kjs/ArrayPrototype.cpp: |
| (KJS::arrayProtoFuncToString): |
| (KJS::arrayProtoFuncToLocaleString): |
| (KJS::arrayProtoFuncJoin): |
| (KJS::arrayProtoFuncConcat): |
| (KJS::arrayProtoFuncPop): |
| (KJS::arrayProtoFuncPush): |
| (KJS::arrayProtoFuncShift): |
| (KJS::arrayProtoFuncSlice): |
| (KJS::arrayProtoFuncSplice): |
| (KJS::arrayProtoFuncUnShift): |
| (KJS::arrayProtoFuncFilter): |
| (KJS::arrayProtoFuncMap): |
| (KJS::arrayProtoFuncEvery): |
| (KJS::arrayProtoFuncForEach): |
| (KJS::arrayProtoFuncSome): |
| (KJS::arrayProtoFuncIndexOf): |
| (KJS::arrayProtoFuncLastIndexOf): |
| (KJS::ArrayConstructor::ArrayConstructor): |
| (KJS::ArrayConstructor::construct): |
| (KJS::ArrayConstructor::callAsFunction): |
| * kjs/BooleanObject.cpp: |
| (KJS::BooleanPrototype::BooleanPrototype): |
| (KJS::booleanProtoFuncToString): |
| (KJS::BooleanConstructor::BooleanConstructor): |
| (KJS::BooleanConstructor::construct): |
| * kjs/FunctionPrototype.cpp: |
| (KJS::FunctionPrototype::FunctionPrototype): |
| (KJS::functionProtoFuncToString): |
| (KJS::FunctionConstructor::FunctionConstructor): |
| (KJS::FunctionConstructor::construct): |
| * kjs/JSActivation.cpp: |
| (KJS::JSActivation::createArgumentsObject): |
| * kjs/JSArray.cpp: |
| (KJS::JSArray::JSArray): |
| (KJS::JSArray::lengthGetter): |
| * kjs/JSFunction.cpp: |
| (KJS::JSFunction::lengthGetter): |
| (KJS::JSFunction::construct): |
| (KJS::Arguments::Arguments): |
| (KJS::encode): |
| (KJS::decode): |
| (KJS::globalFuncParseInt): |
| (KJS::globalFuncParseFloat): |
| (KJS::globalFuncEscape): |
| (KJS::globalFuncUnescape): |
| (KJS::PrototypeFunction::PrototypeFunction): |
| (KJS::PrototypeReflexiveFunction::PrototypeReflexiveFunction): |
| * kjs/JSImmediate.cpp: |
| (KJS::JSImmediate::toObject): |
| * kjs/JSLock.cpp: |
| (KJS::JSLock::registerThread): |
| * kjs/JSObject.cpp: |
| (KJS::JSObject::put): |
| (KJS::JSObject::defineGetter): |
| (KJS::JSObject::defineSetter): |
| (KJS::Error::create): |
| * kjs/JSObject.h: |
| (KJS::JSObject::putDirect): |
| * kjs/JSString.h: |
| (KJS::JSString::JSString): |
| * kjs/JSValue.cpp: |
| (KJS::JSCell::operator new): |
| (KJS::jsString): |
| (KJS::jsOwnedString): |
| * kjs/JSValue.h: |
| (KJS::JSNumberCell::operator new): |
| (KJS::jsNumberCell): |
| (KJS::jsNaN): |
| (KJS::jsNumber): |
| (KJS::JSCell::marked): |
| (KJS::JSCell::mark): |
| (KJS::JSValue::toJSNumber): |
| * kjs/MathObject.cpp: |
| (KJS::MathObject::getValueProperty): |
| (KJS::mathProtoFuncAbs): |
| (KJS::mathProtoFuncACos): |
| (KJS::mathProtoFuncASin): |
| (KJS::mathProtoFuncATan): |
| (KJS::mathProtoFuncATan2): |
| (KJS::mathProtoFuncCeil): |
| (KJS::mathProtoFuncCos): |
| (KJS::mathProtoFuncExp): |
| (KJS::mathProtoFuncFloor): |
| (KJS::mathProtoFuncLog): |
| (KJS::mathProtoFuncMax): |
| (KJS::mathProtoFuncMin): |
| (KJS::mathProtoFuncPow): |
| (KJS::mathProtoFuncRandom): |
| (KJS::mathProtoFuncRound): |
| (KJS::mathProtoFuncSin): |
| (KJS::mathProtoFuncSqrt): |
| (KJS::mathProtoFuncTan): |
| * kjs/NumberObject.cpp: |
| (KJS::NumberPrototype::NumberPrototype): |
| (KJS::numberProtoFuncToString): |
| (KJS::numberProtoFuncToLocaleString): |
| (KJS::numberProtoFuncToFixed): |
| (KJS::numberProtoFuncToExponential): |
| (KJS::numberProtoFuncToPrecision): |
| (KJS::NumberConstructor::NumberConstructor): |
| (KJS::NumberConstructor::getValueProperty): |
| (KJS::NumberConstructor::construct): |
| (KJS::NumberConstructor::callAsFunction): |
| * kjs/RegExpObject.cpp: |
| (KJS::RegExpPrototype::RegExpPrototype): |
| (KJS::regExpProtoFuncToString): |
| (KJS::RegExpObject::getValueProperty): |
| (KJS::RegExpConstructor::RegExpConstructor): |
| (KJS::RegExpMatchesArray::fillArrayInstance): |
| (KJS::RegExpConstructor::arrayOfMatches): |
| (KJS::RegExpConstructor::getBackref): |
| (KJS::RegExpConstructor::getLastParen): |
| (KJS::RegExpConstructor::getLeftContext): |
| (KJS::RegExpConstructor::getRightContext): |
| (KJS::RegExpConstructor::getValueProperty): |
| (KJS::RegExpConstructor::construct): |
| * kjs/RegExpObject.h: |
| * kjs/Shell.cpp: |
| (GlobalObject::GlobalObject): |
| (functionGC): |
| (functionRun): |
| (functionReadline): |
| (jscmain): |
| * kjs/date_object.cpp: |
| (KJS::formatLocaleDate): |
| (KJS::DatePrototype::DatePrototype): |
| (KJS::DateConstructor::DateConstructor): |
| (KJS::DateConstructor::construct): |
| (KJS::DateConstructor::callAsFunction): |
| (KJS::DateFunction::DateFunction): |
| (KJS::DateFunction::callAsFunction): |
| (KJS::dateProtoFuncToString): |
| (KJS::dateProtoFuncToUTCString): |
| (KJS::dateProtoFuncToDateString): |
| (KJS::dateProtoFuncToTimeString): |
| (KJS::dateProtoFuncToLocaleString): |
| (KJS::dateProtoFuncToLocaleDateString): |
| (KJS::dateProtoFuncToLocaleTimeString): |
| (KJS::dateProtoFuncValueOf): |
| (KJS::dateProtoFuncGetTime): |
| (KJS::dateProtoFuncGetFullYear): |
| (KJS::dateProtoFuncGetUTCFullYear): |
| (KJS::dateProtoFuncToGMTString): |
| (KJS::dateProtoFuncGetMonth): |
| (KJS::dateProtoFuncGetUTCMonth): |
| (KJS::dateProtoFuncGetDate): |
| (KJS::dateProtoFuncGetUTCDate): |
| (KJS::dateProtoFuncGetDay): |
| (KJS::dateProtoFuncGetUTCDay): |
| (KJS::dateProtoFuncGetHours): |
| (KJS::dateProtoFuncGetUTCHours): |
| (KJS::dateProtoFuncGetMinutes): |
| (KJS::dateProtoFuncGetUTCMinutes): |
| (KJS::dateProtoFuncGetSeconds): |
| (KJS::dateProtoFuncGetUTCSeconds): |
| (KJS::dateProtoFuncGetMilliSeconds): |
| (KJS::dateProtoFuncGetUTCMilliseconds): |
| (KJS::dateProtoFuncGetTimezoneOffset): |
| (KJS::dateProtoFuncSetTime): |
| (KJS::setNewValueFromTimeArgs): |
| (KJS::setNewValueFromDateArgs): |
| (KJS::dateProtoFuncSetYear): |
| (KJS::dateProtoFuncGetYear): |
| * kjs/error_object.cpp: |
| (KJS::ErrorPrototype::ErrorPrototype): |
| (KJS::errorProtoFuncToString): |
| (KJS::ErrorConstructor::ErrorConstructor): |
| (KJS::ErrorConstructor::construct): |
| (KJS::NativeErrorPrototype::NativeErrorPrototype): |
| (KJS::NativeErrorConstructor::NativeErrorConstructor): |
| (KJS::NativeErrorConstructor::construct): |
| * kjs/identifier.h: |
| * kjs/internal.cpp: |
| (KJS::StringObject::create): |
| (KJS::JSString::lengthGetter): |
| (KJS::JSString::indexGetter): |
| (KJS::JSString::indexNumericPropertyGetter): |
| * kjs/interpreter.cpp: |
| * kjs/list.cpp: |
| (KJS::ArgList::slowAppend): |
| * kjs/list.h: |
| * kjs/lookup.h: |
| (KJS::staticFunctionGetter): |
| (KJS::cacheGlobalObject): |
| * kjs/nodes.cpp: |
| (KJS::Node::emitThrowError): |
| (KJS::StringNode::emitCode): |
| (KJS::ArrayNode::emitCode): |
| (KJS::FuncDeclNode::makeFunction): |
| (KJS::FuncExprNode::makeFunction): |
| * kjs/nodes.h: |
| * kjs/object_object.cpp: |
| (KJS::ObjectPrototype::ObjectPrototype): |
| (KJS::objectProtoFuncToLocaleString): |
| (KJS::objectProtoFuncToString): |
| (KJS::ObjectConstructor::ObjectConstructor): |
| (KJS::ObjectConstructor::construct): |
| * kjs/protect.h: |
| (KJS::gcProtect): |
| (KJS::gcUnprotect): |
| * kjs/string_object.cpp: |
| (KJS::StringObject::StringObject): |
| (KJS::StringPrototype::StringPrototype): |
| (KJS::replace): |
| (KJS::stringProtoFuncCharAt): |
| (KJS::stringProtoFuncCharCodeAt): |
| (KJS::stringProtoFuncConcat): |
| (KJS::stringProtoFuncIndexOf): |
| (KJS::stringProtoFuncLastIndexOf): |
| (KJS::stringProtoFuncMatch): |
| (KJS::stringProtoFuncSearch): |
| (KJS::stringProtoFuncReplace): |
| (KJS::stringProtoFuncSlice): |
| (KJS::stringProtoFuncSplit): |
| (KJS::stringProtoFuncSubstr): |
| (KJS::stringProtoFuncSubstring): |
| (KJS::stringProtoFuncToLowerCase): |
| (KJS::stringProtoFuncToUpperCase): |
| (KJS::stringProtoFuncToLocaleLowerCase): |
| (KJS::stringProtoFuncToLocaleUpperCase): |
| (KJS::stringProtoFuncLocaleCompare): |
| (KJS::stringProtoFuncBig): |
| (KJS::stringProtoFuncSmall): |
| (KJS::stringProtoFuncBlink): |
| (KJS::stringProtoFuncBold): |
| (KJS::stringProtoFuncFixed): |
| (KJS::stringProtoFuncItalics): |
| (KJS::stringProtoFuncStrike): |
| (KJS::stringProtoFuncSub): |
| (KJS::stringProtoFuncSup): |
| (KJS::stringProtoFuncFontcolor): |
| (KJS::stringProtoFuncFontsize): |
| (KJS::stringProtoFuncAnchor): |
| (KJS::stringProtoFuncLink): |
| (KJS::StringConstructor::StringConstructor): |
| (KJS::StringConstructor::construct): |
| (KJS::StringConstructor::callAsFunction): |
| (KJS::StringConstructorFunction::StringConstructorFunction): |
| (KJS::StringConstructorFunction::callAsFunction): |
| * kjs/string_object.h: |
| (KJS::StringObjectThatMasqueradesAsUndefined::StringObjectThatMasqueradesAsUndefined): |
| * kjs/ustring.h: |
| Updated for the above changes. |
| |
| 2008-06-17 Timothy Hatcher <timothy@apple.com> |
| |
| Added a type to DebuggerCallFrame so the under interface can |
| distinguish anonymous functions and program call frames. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=19585 |
| |
| Reviewed by Geoff Garen. |
| |
| * JavaScriptCore.exp: Export the DebuggerCallFrame::type symbol. |
| * kjs/DebuggerCallFrame.cpp: |
| (KJS::DebuggerCallFrame::type): Added. |
| * kjs/DebuggerCallFrame.h: |
| |
| 2008-06-17 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Tim H. |
| |
| Remove bogus ASSERT which tripped every time for those who use PAC files. |
| |
| * kjs/Parser.cpp: |
| (KJS::Parser::parse): |
| |
| 2008-06-17 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Geoff. |
| |
| <rdar://problem/5951534> JSProfiler: Don't profile console.profile() |
| or console.profileEnd() |
| |
| * profiler/Profile.cpp: |
| (KJS::Profile::stopProfiling): Moved the creation of the (idle) node to |
| the Profile (not ProfileNode). This makes sense since the Profile |
| should be the one to modify the profile tree. Also each stopProfiling() |
| does not need to check if it's the head node anymore. Also fixed an |
| oddity where I was using willExecute to create the node. |
| (KJS::Profile::removeProfileStart): Removes the call to console.profile |
| that started this profile. |
| (KJS::Profile::removeProfileEnd): Removes the call to console.profileEnd |
| that ended this profile. |
| * profiler/Profile.h: |
| * profiler/ProfileNode.cpp: Moved the creation of the (idle) node to |
| the Profile object. |
| (KJS::ProfileNode::stopProfiling): |
| * profiler/ProfileNode.h: Added some helper functions and whitespace to |
| facilitate readability and the removal of profile() and profileEnd() |
| from the Profile tree. |
| (KJS::CallIdentifier::operator const char* ): |
| (KJS::ProfileNode::firstChild): |
| (KJS::ProfileNode::lastChild): |
| (KJS::ProfileNode::removeChild): |
| (KJS::ProfileNode::toString): |
| |
| 2008-06-17 Ariya Hidayat <ariya.hidayat@trolltech.com> |
| |
| Rubber stamped by Adam Roben. |
| |
| Include JSGlobalObject.h to fix the build. |
| |
| * kjs/ScopeChain.cpp: |
| |
| 2008-06-17 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Reduce code duplication in emitReadModifyAssignment(). |
| |
| * kjs/nodes.cpp: |
| (KJS::emitReadModifyAssignment): |
| |
| 2008-06-17 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Sort includes alphabetically. |
| |
| * kjs/nodes.cpp: |
| |
| 2008-06-16 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Bug 19596: LEAK: Gmail leaks SegmentedVector<RegisterID> |
| <https://bugs.webkit.org/show_bug.cgi?id=19596> |
| |
| When growing SegmentedVector, we start adding segments at the position |
| of the last segment, overwriting it. The destructor frees allocated |
| segments starting at the segment of index 1, because the segment of |
| index 0 is assumed to be the initial inline segment. This causes a leak |
| of the segment that is referenced by index 0. Modifying grow() so that |
| it starts adding segments at the position after the last segment fixes |
| the leak. |
| |
| Since the initial segment is a special case in the lookup code, this |
| bug never manifested itself via incorrect results. |
| |
| * VM/SegmentedVector.h: |
| (KJS::SegmentedVector::grow): |
| |
| 2008-06-16 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Alexey. |
| |
| - removed nearly unused types.h and LocalStorageEntry.h headers |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/ExecState.h: |
| * kjs/LocalStorageEntry.h: Removed. |
| * kjs/RegExpObject.cpp: |
| * kjs/error_object.cpp: |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| * kjs/types.h: Removed. |
| |
| 2008-06-16 Alp Toker <alp@nuanti.com> |
| |
| Rubber-stamped by Geoff. |
| |
| Change c++ to c in minidom and testapi emacs mode line comments. |
| |
| * API/Node.h: |
| * API/NodeList.c: |
| * API/NodeList.h: |
| * API/testapi.c: |
| |
| 2008-06-16 Alexey Proskuryakov <ap@webkit.org> |
| |
| Trying to fix Windows build. |
| |
| * kjs/PropertyNameArray.h: |
| * kjs/identifier.cpp: |
| Include ExecState.h |
| |
| 2008-06-16 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Slight cleanup to the SymbolTableEntry class. |
| |
| Renamed isEmpty to isNull, since we usually use "empty" to mean "holds |
| the valid, empty value", and "null" to mean "holds no value". |
| |
| Changed an "== 0" to a "!", to match our style guidelines. |
| |
| Added some ASSERTs to verify the (possibly questionable) assumption that |
| all register indexes will have their high two bits set. Also clarified a |
| comment to make that assumption clear. |
| |
| 2008-06-16 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Initialize functionQueueMutex in a safe manner. |
| |
| * wtf/MainThread.cpp: |
| (WTF::functionQueueMutex): Made it an AtomicallyInitializedStatic. |
| |
| (WTF::dispatchFunctionsFromMainThread): |
| (WTF::setMainThreadCallbacksPaused): |
| Assert that the current thread is main, meaning that the callbacksPaused static can be |
| accessed. |
| |
| 2008-06-16 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Geoff Garen. |
| |
| Make Identifier construction use an explicitly passed IdentifierTable. |
| |
| No change on SunSpider total. |
| |
| * API/JSCallbackObjectFunctions.h: |
| (KJS::::getOwnPropertySlot): |
| (KJS::::put): |
| (KJS::::deleteProperty): |
| (KJS::::getPropertyNames): |
| * API/JSObjectRef.cpp: |
| (JSObjectMakeFunctionWithCallback): |
| (JSObjectMakeFunction): |
| (JSObjectHasProperty): |
| (JSObjectGetProperty): |
| (JSObjectSetProperty): |
| (JSObjectDeleteProperty): |
| (OpaqueJSPropertyNameArray::OpaqueJSPropertyNameArray): |
| (JSObjectCopyPropertyNames): |
| * JavaScriptCore.exp: |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::CodeGenerator): |
| (KJS::CodeGenerator::registerForLocal): |
| (KJS::CodeGenerator::isLocal): |
| (KJS::CodeGenerator::addConstant): |
| (KJS::CodeGenerator::findScopedProperty): |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::globalData): |
| (KJS::CodeGenerator::propertyNames): |
| * VM/JSPropertyNameIterator.cpp: |
| (KJS::JSPropertyNameIterator::create): |
| * VM/Machine.cpp: |
| (KJS::Machine::throwException): |
| (KJS::Machine::privateExecute): |
| * kjs/ArrayPrototype.cpp: |
| (KJS::ArrayConstructor::ArrayConstructor): |
| * kjs/BooleanObject.cpp: |
| (KJS::BooleanConstructor::BooleanConstructor): |
| * kjs/FunctionPrototype.cpp: |
| (KJS::FunctionConstructor::FunctionConstructor): |
| (KJS::FunctionConstructor::construct): |
| * kjs/JSArray.cpp: |
| (KJS::JSArray::inlineGetOwnPropertySlot): |
| (KJS::JSArray::put): |
| (KJS::JSArray::deleteProperty): |
| (KJS::JSArray::getPropertyNames): |
| * kjs/JSFunction.cpp: |
| (KJS::Arguments::Arguments): |
| * kjs/JSGlobalData.cpp: |
| (KJS::JSGlobalData::JSGlobalData): |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::reset): |
| * kjs/JSObject.cpp: |
| (KJS::JSObject::getOwnPropertySlot): |
| (KJS::JSObject::put): |
| (KJS::JSObject::putWithAttributes): |
| (KJS::JSObject::deleteProperty): |
| (KJS::JSObject::findPropertyHashEntry): |
| (KJS::JSObject::getPropertyNames): |
| (KJS::Error::create): |
| * kjs/JSVariableObject.cpp: |
| (KJS::JSVariableObject::getPropertyNames): |
| * kjs/NumberObject.cpp: |
| (KJS::NumberConstructor::NumberConstructor): |
| * kjs/PropertyNameArray.cpp: |
| (KJS::PropertyNameArray::add): |
| * kjs/PropertyNameArray.h: |
| (KJS::PropertyNameArray::PropertyNameArray): |
| (KJS::PropertyNameArray::addKnownUnique): |
| * kjs/PropertySlot.h: |
| (KJS::PropertySlot::getValue): |
| * kjs/RegExpObject.cpp: |
| (KJS::RegExpConstructor::RegExpConstructor): |
| * kjs/ScopeChain.cpp: |
| (KJS::ScopeChainNode::print): |
| * kjs/Shell.cpp: |
| (GlobalObject::GlobalObject): |
| * kjs/date_object.cpp: |
| (KJS::DateConstructor::DateConstructor): |
| * kjs/error_object.cpp: |
| (KJS::ErrorConstructor::ErrorConstructor): |
| (KJS::NativeErrorConstructor::NativeErrorConstructor): |
| * kjs/grammar.y: |
| * kjs/identifier.cpp: |
| (KJS::Identifier::add): |
| (KJS::Identifier::addSlowCase): |
| * kjs/identifier.h: |
| (KJS::Identifier::Identifier): |
| (KJS::Identifier::from): |
| (KJS::Identifier::equal): |
| (KJS::Identifier::add): |
| (KJS::operator==): |
| (KJS::operator!=): |
| * kjs/internal.cpp: |
| (KJS::JSString::getOwnPropertySlot): |
| * kjs/lexer.cpp: |
| (KJS::Lexer::Lexer): |
| (KJS::Lexer::lex): |
| (KJS::Lexer::makeIdentifier): |
| * kjs/lexer.h: |
| * kjs/lookup.cpp: |
| (KJS::HashTable::createTable): |
| * kjs/lookup.h: |
| (KJS::HashTable::initializeIfNeeded): |
| (KJS::HashTable::entry): |
| (KJS::getStaticPropertySlot): |
| (KJS::getStaticFunctionSlot): |
| (KJS::getStaticValueSlot): |
| (KJS::lookupPut): |
| * kjs/object_object.cpp: |
| (KJS::objectProtoFuncHasOwnProperty): |
| (KJS::objectProtoFuncDefineGetter): |
| (KJS::objectProtoFuncDefineSetter): |
| (KJS::objectProtoFuncLookupGetter): |
| (KJS::objectProtoFuncLookupSetter): |
| (KJS::objectProtoFuncPropertyIsEnumerable): |
| (KJS::ObjectConstructor::ObjectConstructor): |
| * kjs/string_object.cpp: |
| (KJS::StringObject::getOwnPropertySlot): |
| (KJS::StringObject::getPropertyNames): |
| (KJS::StringConstructor::StringConstructor): |
| Just pass ExecState or JSGlobalData everywhere. Identifier construction is now always |
| explicit. |
| |
| * kjs/nodes.cpp: (KJS::RegExpNode::emitCode): Here, Identifier was created from a non-literal |
| char*, which was incorrect, as that uses the pointer value as a key. |
| |
| 2008-06-16 Thiago Macieira <tjmaciei@trolltech.com> |
| |
| Reviewed by Darin. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=19577 |
| |
| Fix compilation in C++ environments where C99 headers are not present |
| |
| The stdbool.h header is a C99 feature, defining the "_Bool" type as well as the |
| "true" and "false" constants. But it's completely unnecessary in C++ as the |
| language already defines the "bool" type and its two values. |
| |
| * API/JSBase.h: |
| * API/JSContextRef.h: |
| * API/JSObjectRef.h: |
| * API/JSStringRef.h: |
| * API/JSValueRef.h: |
| |
| 2008-06-16 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by John. |
| |
| <rdar://problem/6012509> JSProfiler: %s are incorrect if you exclude a |
| top level node like (idle) |
| |
| * profiler/Profile.cpp: |
| (KJS::Profile::focus): |
| (KJS::Profile::exclude): Subtract the selfTime from the totalTime of the |
| head since its self time will only be non-zero when one of its children |
| were excluded. Since the head's totalTime is used to calculate %s when |
| its totalTime is the same as the sum of all its visible childrens' times |
| their %s will sum to 100%. |
| |
| 2008-06-16 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| <rdar://problem/5969992> JSProfiler: Remove the recursion limit in the profiler. |
| |
| * profiler/Profile.cpp: |
| (KJS::Profile::willExecute): |
| |
| 2008-06-16 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Sam. |
| |
| <rdar://problem/5969992> JSProfiler: Remove the recursion limit in the |
| profiler. |
| - Remove the last of the uses of recursion in the profiler. |
| |
| * JavaScriptCore.exp: Export the new function's signature. |
| * profiler/Profile.cpp: |
| (KJS::calculateVisibleTotalTime): Added a new static method for |
| recalculating the visibleTotalTime of methods after focus has changed |
| which are visible. |
| (KJS::stopProfiling): |
| (KJS::Profile::focus): Implemented focus without recursion. |
| * profiler/Profile.h: Moved implementation into the definition file. |
| * profiler/ProfileNode.cpp: |
| (KJS::ProfileNode::traverseNextNodePreOrder): Added an argument for |
| whether or not to process the children nodes, this allows focus to skip |
| sub trees which have been set as not visible. |
| (KJS::ProfileNode::calculateVisibleTotalTime): This function set's a |
| node's total visible time to the sum of its self time and its children's |
| total times. |
| (KJS::ProfileNode::focus): Implemented focus without recursion. |
| * profiler/ProfileNode.h: |
| (KJS::CallIdentifier::operator!= ): |
| (KJS::ProfileNode::setActualTotalTime): Expanded setting the total time |
| so that focus could modify only the visible total time. |
| (KJS::ProfileNode::setVisibleTotalTime): |
| |
| 2008-06-16 Christian Dywan <christian@twotoasts.de> |
| |
| Reviewed by Sam. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=19552 |
| JavaScriptCore headers use C++ style comments |
| |
| Replace all C++ style comments with C style multiline |
| comments and remove all "mode" lines. |
| |
| * API/JSBase.h: |
| * API/JSClassRef.h: |
| * API/JSContextRef.h: |
| * API/JSObjectRef.h: |
| * API/JSStringRef.h: |
| * API/JSStringRefBSTR.h: |
| * API/JSStringRefCF.h: |
| * API/JSValueRef.h: |
| * API/JavaScript.h: |
| * API/JavaScriptCore.h: |
| |
| 2008-06-16 Christian Dywan <christian@twotoasts.de> |
| |
| Reviewed by Sam. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=19557 |
| (JavaScriptCore) minidom uses C++ style comments |
| |
| Use only C style comments in minidom sources |
| |
| * API/JSNode.c: |
| (JSNode_appendChild): |
| (JSNode_removeChild): |
| * API/JSNode.h: |
| * API/JSNodeList.c: |
| (JSNodeList_getProperty): |
| * API/JSNodeList.h: |
| * API/Node.c: |
| * API/Node.h: |
| * API/NodeList.c: |
| (NodeList_new): |
| (NodeList_item): |
| * API/NodeList.h: |
| * API/minidom.c: |
| (createStringWithContentsOfFile): |
| * wtf/Assertions.h: |
| * wtf/UnusedParam.h: |
| |
| 2008-06-16 Adriaan de Groot <groot@kde.org> |
| |
| Reviewed by Simon. |
| |
| Fix compilation on Solaris |
| |
| On some systems, munmap takes a char* instead of a void* (contrary to POSIX and |
| Single Unix Specification). Since you can always convert from char* to void* |
| but not vice-versa, do the casting to char*. |
| |
| * kjs/collector.cpp: |
| (KJS::allocateBlock): |
| (KJS::freeBlock): |
| |
| 2008-06-16 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Make a UnaryOpNode class to reduce boilerplate code for UnaryPlusNode, |
| NegateNode, BitwiseNotNode, and LogicalNotNode. |
| |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::emitToJSNumber): |
| * kjs/nodes.cpp: |
| (KJS::UnaryOpNode::emitCode): |
| * kjs/nodes.h: |
| (KJS::UnaryOpNode::UnaryOpNode): |
| (KJS::UnaryPlusNode::): |
| (KJS::NegateNode::): |
| (KJS::NegateNode::precedence): |
| (KJS::BitwiseNotNode::): |
| (KJS::BitwiseNotNode::precedence): |
| (KJS::LogicalNotNode::): |
| (KJS::LogicalNotNode::precedence): |
| |
| 2008-06-16 Jan Michael Alonzo <jmalonzo@webkit.org> |
| |
| Gtk build fix |
| |
| * GNUmakefile.am: |
| |
| 2008-06-15 Darin Adler <darin@apple.com> |
| |
| - rename KJS::List to KJS::ArgList |
| |
| * API/JSCallbackConstructor.cpp: |
| (KJS::JSCallbackConstructor::construct): |
| * API/JSCallbackConstructor.h: |
| * API/JSCallbackFunction.cpp: |
| (KJS::JSCallbackFunction::callAsFunction): |
| * API/JSCallbackFunction.h: |
| * API/JSCallbackObject.h: |
| * API/JSCallbackObjectFunctions.h: |
| (KJS::::construct): |
| (KJS::::callAsFunction): |
| * API/JSObjectRef.cpp: |
| (JSObjectMakeFunction): |
| (JSObjectCallAsFunction): |
| (JSObjectCallAsConstructor): |
| * JavaScriptCore.exp: |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): |
| (KJS::Machine::privateExecute): |
| * VM/Machine.h: |
| * kjs/ArrayPrototype.cpp: |
| (KJS::arrayProtoFuncToString): |
| (KJS::arrayProtoFuncToLocaleString): |
| (KJS::arrayProtoFuncJoin): |
| (KJS::arrayProtoFuncConcat): |
| (KJS::arrayProtoFuncPop): |
| (KJS::arrayProtoFuncPush): |
| (KJS::arrayProtoFuncReverse): |
| (KJS::arrayProtoFuncShift): |
| (KJS::arrayProtoFuncSlice): |
| (KJS::arrayProtoFuncSort): |
| (KJS::arrayProtoFuncSplice): |
| (KJS::arrayProtoFuncUnShift): |
| (KJS::arrayProtoFuncFilter): |
| (KJS::arrayProtoFuncMap): |
| (KJS::arrayProtoFuncEvery): |
| (KJS::arrayProtoFuncForEach): |
| (KJS::arrayProtoFuncSome): |
| (KJS::arrayProtoFuncIndexOf): |
| (KJS::arrayProtoFuncLastIndexOf): |
| (KJS::ArrayConstructor::construct): |
| (KJS::ArrayConstructor::callAsFunction): |
| * kjs/ArrayPrototype.h: |
| * kjs/BooleanObject.cpp: |
| (KJS::booleanProtoFuncToString): |
| (KJS::booleanProtoFuncValueOf): |
| (KJS::BooleanConstructor::construct): |
| (KJS::BooleanConstructor::callAsFunction): |
| * kjs/BooleanObject.h: |
| * kjs/CommonIdentifiers.h: |
| * kjs/ExecState.h: |
| (KJS::ExecState::emptyList): |
| * kjs/FunctionPrototype.cpp: |
| (KJS::FunctionPrototype::callAsFunction): |
| (KJS::functionProtoFuncToString): |
| (KJS::functionProtoFuncApply): |
| (KJS::functionProtoFuncCall): |
| (KJS::FunctionConstructor::construct): |
| (KJS::FunctionConstructor::callAsFunction): |
| * kjs/FunctionPrototype.h: |
| * kjs/JSActivation.cpp: |
| (KJS::JSActivation::createArgumentsObject): |
| * kjs/JSArray.cpp: |
| (KJS::JSArray::JSArray): |
| (KJS::AVLTreeAbstractorForArrayCompare::compare_key_key): |
| * kjs/JSArray.h: |
| * kjs/JSFunction.cpp: |
| (KJS::JSFunction::callAsFunction): |
| (KJS::JSFunction::construct): |
| (KJS::IndexToNameMap::IndexToNameMap): |
| (KJS::Arguments::Arguments): |
| (KJS::encode): |
| (KJS::decode): |
| (KJS::globalFuncEval): |
| (KJS::globalFuncParseInt): |
| (KJS::globalFuncParseFloat): |
| (KJS::globalFuncIsNaN): |
| (KJS::globalFuncIsFinite): |
| (KJS::globalFuncDecodeURI): |
| (KJS::globalFuncDecodeURIComponent): |
| (KJS::globalFuncEncodeURI): |
| (KJS::globalFuncEncodeURIComponent): |
| (KJS::globalFuncEscape): |
| (KJS::globalFuncUnescape): |
| (KJS::globalFuncKJSPrint): |
| (KJS::PrototypeFunction::callAsFunction): |
| (KJS::PrototypeReflexiveFunction::callAsFunction): |
| * kjs/JSFunction.h: |
| * kjs/JSGlobalData.h: |
| * kjs/JSImmediate.cpp: |
| (KJS::JSImmediate::toObject): |
| * kjs/JSNotAnObject.cpp: |
| (KJS::JSNotAnObject::construct): |
| (KJS::JSNotAnObject::callAsFunction): |
| * kjs/JSNotAnObject.h: |
| * kjs/JSObject.cpp: |
| (KJS::JSObject::put): |
| (KJS::JSObject::construct): |
| (KJS::JSObject::callAsFunction): |
| (KJS::Error::create): |
| * kjs/JSObject.h: |
| * kjs/MathObject.cpp: |
| (KJS::mathProtoFuncAbs): |
| (KJS::mathProtoFuncACos): |
| (KJS::mathProtoFuncASin): |
| (KJS::mathProtoFuncATan): |
| (KJS::mathProtoFuncATan2): |
| (KJS::mathProtoFuncCeil): |
| (KJS::mathProtoFuncCos): |
| (KJS::mathProtoFuncExp): |
| (KJS::mathProtoFuncFloor): |
| (KJS::mathProtoFuncLog): |
| (KJS::mathProtoFuncMax): |
| (KJS::mathProtoFuncMin): |
| (KJS::mathProtoFuncPow): |
| (KJS::mathProtoFuncRandom): |
| (KJS::mathProtoFuncRound): |
| (KJS::mathProtoFuncSin): |
| (KJS::mathProtoFuncSqrt): |
| (KJS::mathProtoFuncTan): |
| * kjs/MathObject.h: |
| * kjs/NumberObject.cpp: |
| (KJS::numberProtoFuncToString): |
| (KJS::numberProtoFuncToLocaleString): |
| (KJS::numberProtoFuncValueOf): |
| (KJS::numberProtoFuncToFixed): |
| (KJS::numberProtoFuncToExponential): |
| (KJS::numberProtoFuncToPrecision): |
| (KJS::NumberConstructor::construct): |
| (KJS::NumberConstructor::callAsFunction): |
| * kjs/NumberObject.h: |
| * kjs/RegExpObject.cpp: |
| (KJS::regExpProtoFuncTest): |
| (KJS::regExpProtoFuncExec): |
| (KJS::regExpProtoFuncCompile): |
| (KJS::regExpProtoFuncToString): |
| (KJS::RegExpObject::match): |
| (KJS::RegExpObject::test): |
| (KJS::RegExpObject::exec): |
| (KJS::RegExpObject::callAsFunction): |
| (KJS::RegExpConstructor::construct): |
| (KJS::RegExpConstructor::callAsFunction): |
| * kjs/RegExpObject.h: |
| * kjs/Shell.cpp: |
| (functionPrint): |
| (functionDebug): |
| (functionGC): |
| (functionVersion): |
| (functionRun): |
| (functionLoad): |
| (functionReadline): |
| (functionQuit): |
| * kjs/collector.cpp: |
| (KJS::Collector::collect): |
| * kjs/collector.h: |
| (KJS::Collector::markListSet): |
| * kjs/date_object.cpp: |
| (KJS::formatLocaleDate): |
| (KJS::fillStructuresUsingTimeArgs): |
| (KJS::fillStructuresUsingDateArgs): |
| (KJS::DateConstructor::construct): |
| (KJS::DateConstructor::callAsFunction): |
| (KJS::DateFunction::callAsFunction): |
| (KJS::dateProtoFuncToString): |
| (KJS::dateProtoFuncToUTCString): |
| (KJS::dateProtoFuncToDateString): |
| (KJS::dateProtoFuncToTimeString): |
| (KJS::dateProtoFuncToLocaleString): |
| (KJS::dateProtoFuncToLocaleDateString): |
| (KJS::dateProtoFuncToLocaleTimeString): |
| (KJS::dateProtoFuncValueOf): |
| (KJS::dateProtoFuncGetTime): |
| (KJS::dateProtoFuncGetFullYear): |
| (KJS::dateProtoFuncGetUTCFullYear): |
| (KJS::dateProtoFuncToGMTString): |
| (KJS::dateProtoFuncGetMonth): |
| (KJS::dateProtoFuncGetUTCMonth): |
| (KJS::dateProtoFuncGetDate): |
| (KJS::dateProtoFuncGetUTCDate): |
| (KJS::dateProtoFuncGetDay): |
| (KJS::dateProtoFuncGetUTCDay): |
| (KJS::dateProtoFuncGetHours): |
| (KJS::dateProtoFuncGetUTCHours): |
| (KJS::dateProtoFuncGetMinutes): |
| (KJS::dateProtoFuncGetUTCMinutes): |
| (KJS::dateProtoFuncGetSeconds): |
| (KJS::dateProtoFuncGetUTCSeconds): |
| (KJS::dateProtoFuncGetMilliSeconds): |
| (KJS::dateProtoFuncGetUTCMilliseconds): |
| (KJS::dateProtoFuncGetTimezoneOffset): |
| (KJS::dateProtoFuncSetTime): |
| (KJS::setNewValueFromTimeArgs): |
| (KJS::setNewValueFromDateArgs): |
| (KJS::dateProtoFuncSetMilliSeconds): |
| (KJS::dateProtoFuncSetUTCMilliseconds): |
| (KJS::dateProtoFuncSetSeconds): |
| (KJS::dateProtoFuncSetUTCSeconds): |
| (KJS::dateProtoFuncSetMinutes): |
| (KJS::dateProtoFuncSetUTCMinutes): |
| (KJS::dateProtoFuncSetHours): |
| (KJS::dateProtoFuncSetUTCHours): |
| (KJS::dateProtoFuncSetDate): |
| (KJS::dateProtoFuncSetUTCDate): |
| (KJS::dateProtoFuncSetMonth): |
| (KJS::dateProtoFuncSetUTCMonth): |
| (KJS::dateProtoFuncSetFullYear): |
| (KJS::dateProtoFuncSetUTCFullYear): |
| (KJS::dateProtoFuncSetYear): |
| (KJS::dateProtoFuncGetYear): |
| * kjs/date_object.h: |
| * kjs/debugger.h: |
| * kjs/error_object.cpp: |
| (KJS::errorProtoFuncToString): |
| (KJS::ErrorConstructor::construct): |
| (KJS::ErrorConstructor::callAsFunction): |
| (KJS::NativeErrorConstructor::construct): |
| (KJS::NativeErrorConstructor::callAsFunction): |
| * kjs/error_object.h: |
| * kjs/internal.cpp: |
| (KJS::JSNumberCell::toObject): |
| (KJS::JSNumberCell::toThisObject): |
| * kjs/list.cpp: |
| (KJS::ArgList::getSlice): |
| (KJS::ArgList::markLists): |
| (KJS::ArgList::slowAppend): |
| * kjs/list.h: |
| (KJS::ArgList::ArgList): |
| (KJS::ArgList::~ArgList): |
| * kjs/object_object.cpp: |
| (KJS::objectProtoFuncValueOf): |
| (KJS::objectProtoFuncHasOwnProperty): |
| (KJS::objectProtoFuncIsPrototypeOf): |
| (KJS::objectProtoFuncDefineGetter): |
| (KJS::objectProtoFuncDefineSetter): |
| (KJS::objectProtoFuncLookupGetter): |
| (KJS::objectProtoFuncLookupSetter): |
| (KJS::objectProtoFuncPropertyIsEnumerable): |
| (KJS::objectProtoFuncToLocaleString): |
| (KJS::objectProtoFuncToString): |
| (KJS::ObjectConstructor::construct): |
| (KJS::ObjectConstructor::callAsFunction): |
| * kjs/object_object.h: |
| * kjs/string_object.cpp: |
| (KJS::replace): |
| (KJS::stringProtoFuncToString): |
| (KJS::stringProtoFuncValueOf): |
| (KJS::stringProtoFuncCharAt): |
| (KJS::stringProtoFuncCharCodeAt): |
| (KJS::stringProtoFuncConcat): |
| (KJS::stringProtoFuncIndexOf): |
| (KJS::stringProtoFuncLastIndexOf): |
| (KJS::stringProtoFuncMatch): |
| (KJS::stringProtoFuncSearch): |
| (KJS::stringProtoFuncReplace): |
| (KJS::stringProtoFuncSlice): |
| (KJS::stringProtoFuncSplit): |
| (KJS::stringProtoFuncSubstr): |
| (KJS::stringProtoFuncSubstring): |
| (KJS::stringProtoFuncToLowerCase): |
| (KJS::stringProtoFuncToUpperCase): |
| (KJS::stringProtoFuncToLocaleLowerCase): |
| (KJS::stringProtoFuncToLocaleUpperCase): |
| (KJS::stringProtoFuncLocaleCompare): |
| (KJS::stringProtoFuncBig): |
| (KJS::stringProtoFuncSmall): |
| (KJS::stringProtoFuncBlink): |
| (KJS::stringProtoFuncBold): |
| (KJS::stringProtoFuncFixed): |
| (KJS::stringProtoFuncItalics): |
| (KJS::stringProtoFuncStrike): |
| (KJS::stringProtoFuncSub): |
| (KJS::stringProtoFuncSup): |
| (KJS::stringProtoFuncFontcolor): |
| (KJS::stringProtoFuncFontsize): |
| (KJS::stringProtoFuncAnchor): |
| (KJS::stringProtoFuncLink): |
| (KJS::StringConstructor::construct): |
| (KJS::StringConstructor::callAsFunction): |
| (KJS::StringConstructorFunction::callAsFunction): |
| * kjs/string_object.h: |
| |
| 2008-06-15 Darin Adler <darin@apple.com> |
| |
| - new names for more JavaScriptCore files |
| |
| * API/JSCallbackFunction.cpp: |
| * API/JSObjectRef.cpp: |
| * DerivedSources.make: |
| * GNUmakefile.am: |
| * JavaScriptCore.exp: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * VM/Machine.cpp: |
| * kjs/AllInOneFile.cpp: |
| * kjs/ArrayPrototype.cpp: Copied from JavaScriptCore/kjs/array_object.cpp. |
| * kjs/ArrayPrototype.h: Copied from JavaScriptCore/kjs/array_object.h. |
| * kjs/BooleanObject.cpp: Copied from JavaScriptCore/kjs/bool_object.cpp. |
| * kjs/BooleanObject.h: Copied from JavaScriptCore/kjs/bool_object.h. |
| * kjs/ExecState.cpp: |
| * kjs/ExecState.h: |
| * kjs/FunctionPrototype.cpp: Copied from JavaScriptCore/kjs/function_object.cpp. |
| * kjs/FunctionPrototype.h: Copied from JavaScriptCore/kjs/function_object.h. |
| * kjs/JSArray.cpp: Copied from JavaScriptCore/kjs/array_instance.cpp. |
| * kjs/JSArray.h: Copied from JavaScriptCore/kjs/array_instance.h. |
| * kjs/JSFunction.cpp: |
| * kjs/JSFunction.h: |
| * kjs/JSGlobalObject.cpp: |
| * kjs/JSImmediate.cpp: |
| * kjs/JSObject.h: |
| * kjs/JSString.h: |
| * kjs/JSValue.h: |
| * kjs/JSVariableObject.cpp: |
| * kjs/MathObject.cpp: Copied from JavaScriptCore/kjs/math_object.cpp. |
| * kjs/MathObject.h: Copied from JavaScriptCore/kjs/math_object.h. |
| * kjs/NumberObject.cpp: Copied from JavaScriptCore/kjs/number_object.cpp. |
| * kjs/NumberObject.h: Copied from JavaScriptCore/kjs/number_object.h. |
| * kjs/PropertyMap.cpp: Copied from JavaScriptCore/kjs/property_map.cpp. |
| * kjs/PropertyMap.h: Copied from JavaScriptCore/kjs/property_map.h. |
| * kjs/PropertySlot.cpp: Copied from JavaScriptCore/kjs/property_slot.cpp. |
| * kjs/PropertySlot.h: Copied from JavaScriptCore/kjs/property_slot.h. |
| * kjs/RegExpObject.cpp: Copied from JavaScriptCore/kjs/regexp_object.cpp. |
| * kjs/RegExpObject.h: Copied from JavaScriptCore/kjs/regexp_object.h. |
| * kjs/ScopeChain.cpp: Copied from JavaScriptCore/kjs/scope_chain.cpp. |
| * kjs/ScopeChain.h: Copied from JavaScriptCore/kjs/scope_chain.h. |
| * kjs/ScopeChainMark.h: Copied from JavaScriptCore/kjs/scope_chain_mark.h. |
| * kjs/Shell.cpp: |
| * kjs/array_instance.cpp: Removed. |
| * kjs/array_instance.h: Removed. |
| * kjs/array_object.cpp: Removed. |
| * kjs/array_object.h: Removed. |
| * kjs/bool_object.cpp: Removed. |
| * kjs/bool_object.h: Removed. |
| * kjs/error_object.h: |
| * kjs/function_object.cpp: Removed. |
| * kjs/function_object.h: Removed. |
| * kjs/internal.cpp: |
| * kjs/math_object.cpp: Removed. |
| * kjs/math_object.h: Removed. |
| * kjs/nodes.cpp: |
| * kjs/number_object.cpp: Removed. |
| * kjs/number_object.h: Removed. |
| * kjs/object_object.cpp: |
| * kjs/property_map.cpp: Removed. |
| * kjs/property_map.h: Removed. |
| * kjs/property_slot.cpp: Removed. |
| * kjs/property_slot.h: Removed. |
| * kjs/regexp_object.cpp: Removed. |
| * kjs/regexp_object.h: Removed. |
| * kjs/scope_chain.cpp: Removed. |
| * kjs/scope_chain.h: Removed. |
| * kjs/scope_chain_mark.h: Removed. |
| * kjs/string_object.cpp: |
| * kjs/string_object.h: |
| |
| 2008-06-15 Darin Adler <darin@apple.com> |
| |
| - new names for a few key JavaScriptCore files |
| |
| * API/JSBase.cpp: |
| * API/JSCallbackConstructor.h: |
| * API/JSCallbackFunction.cpp: |
| * API/JSCallbackFunction.h: |
| * API/JSCallbackObject.h: |
| * API/JSCallbackObjectFunctions.h: |
| * API/JSClassRef.h: |
| * API/JSContextRef.cpp: |
| * API/JSObjectRef.cpp: |
| * API/JSStringRef.cpp: |
| * API/JSStringRefCF.cpp: |
| * API/JSValueRef.cpp: |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * VM/CodeBlock.cpp: |
| * VM/CodeGenerator.cpp: |
| * VM/ExceptionHelpers.cpp: |
| * VM/ExceptionHelpers.h: |
| * VM/JSPropertyNameIterator.cpp: |
| * VM/JSPropertyNameIterator.h: |
| * VM/Machine.cpp: |
| * kjs/AllInOneFile.cpp: |
| * kjs/DateMath.cpp: |
| * kjs/DebuggerCallFrame.cpp: |
| * kjs/ExecState.cpp: |
| * kjs/JSActivation.cpp: |
| * kjs/JSFunction.cpp: Copied from JavaScriptCore/kjs/function.cpp. |
| * kjs/JSFunction.h: Copied from JavaScriptCore/kjs/function.h. |
| * kjs/JSImmediate.cpp: |
| * kjs/JSNotAnObject.h: |
| * kjs/JSObject.cpp: Copied from JavaScriptCore/kjs/object.cpp. |
| * kjs/JSObject.h: Copied from JavaScriptCore/kjs/object.h. |
| * kjs/JSString.h: Copied from JavaScriptCore/kjs/internal.h. |
| * kjs/JSValue.cpp: Copied from JavaScriptCore/kjs/value.cpp. |
| * kjs/JSValue.h: Copied from JavaScriptCore/kjs/value.h. |
| * kjs/JSVariableObject.h: |
| * kjs/JSWrapperObject.h: |
| * kjs/Shell.cpp: |
| * kjs/SymbolTable.h: |
| * kjs/array_instance.h: |
| * kjs/collector.cpp: |
| * kjs/date_object.cpp: |
| * kjs/date_object.h: |
| * kjs/error_object.cpp: |
| * kjs/function.cpp: Removed. |
| * kjs/function.h: Removed. |
| * kjs/function_object.cpp: |
| * kjs/function_object.h: |
| * kjs/grammar.y: |
| * kjs/internal.cpp: |
| * kjs/internal.h: Removed. |
| * kjs/lexer.cpp: |
| * kjs/list.h: |
| * kjs/lookup.h: |
| * kjs/nodes.h: |
| * kjs/object.cpp: Removed. |
| * kjs/object.h: Removed. |
| * kjs/object_object.h: |
| * kjs/operations.cpp: |
| * kjs/property_map.cpp: |
| * kjs/property_slot.cpp: |
| * kjs/property_slot.h: |
| * kjs/protect.h: |
| * kjs/regexp_object.cpp: |
| * kjs/scope_chain.cpp: |
| * kjs/string_object.h: |
| * kjs/ustring.cpp: |
| * kjs/value.cpp: Removed. |
| * kjs/value.h: Removed. |
| * profiler/Profile.cpp: |
| * profiler/Profiler.cpp: |
| |
| 2008-06-15 Darin Adler <darin@apple.com> |
| |
| Rubber stamped by Sam. |
| |
| - cut down on confusing uses of "Object" and "Imp" in |
| JavaScriptCore class names |
| |
| * API/JSCallbackFunction.cpp: |
| (KJS::JSCallbackFunction::JSCallbackFunction): |
| * API/JSCallbackFunction.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * kjs/ExecState.h: |
| (KJS::ExecState::regExpTable): |
| (KJS::ExecState::regExpConstructorTable): |
| * kjs/JSGlobalData.cpp: |
| (KJS::JSGlobalData::JSGlobalData): |
| (KJS::JSGlobalData::~JSGlobalData): |
| * kjs/JSGlobalData.h: |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::reset): |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::objectConstructor): |
| (KJS::JSGlobalObject::functionConstructor): |
| (KJS::JSGlobalObject::arrayConstructor): |
| (KJS::JSGlobalObject::booleanConstructor): |
| (KJS::JSGlobalObject::stringConstructor): |
| (KJS::JSGlobalObject::numberConstructor): |
| (KJS::JSGlobalObject::dateConstructor): |
| (KJS::JSGlobalObject::regExpConstructor): |
| (KJS::JSGlobalObject::errorConstructor): |
| (KJS::JSGlobalObject::evalErrorConstructor): |
| (KJS::JSGlobalObject::rangeErrorConstructor): |
| (KJS::JSGlobalObject::referenceErrorConstructor): |
| (KJS::JSGlobalObject::syntaxErrorConstructor): |
| (KJS::JSGlobalObject::typeErrorConstructor): |
| (KJS::JSGlobalObject::URIErrorConstructor): |
| * kjs/array_object.cpp: |
| (KJS::ArrayConstructor::ArrayConstructor): |
| (KJS::ArrayConstructor::getConstructData): |
| (KJS::ArrayConstructor::construct): |
| (KJS::ArrayConstructor::callAsFunction): |
| * kjs/array_object.h: |
| * kjs/bool_object.cpp: |
| (KJS::BooleanObject::BooleanObject): |
| (KJS::BooleanPrototype::BooleanPrototype): |
| (KJS::booleanProtoFuncToString): |
| (KJS::booleanProtoFuncValueOf): |
| (KJS::BooleanConstructor::BooleanConstructor): |
| (KJS::BooleanConstructor::getConstructData): |
| (KJS::BooleanConstructor::construct): |
| (KJS::BooleanConstructor::callAsFunction): |
| * kjs/bool_object.h: |
| * kjs/date_object.cpp: |
| (KJS::DatePrototype::DatePrototype): |
| (KJS::DateConstructor::DateConstructor): |
| (KJS::DateConstructor::getConstructData): |
| (KJS::DateConstructor::construct): |
| (KJS::DateConstructor::callAsFunction): |
| (KJS::DateFunction::DateFunction): |
| (KJS::DateFunction::callAsFunction): |
| * kjs/date_object.h: |
| * kjs/error_object.cpp: |
| (KJS::ErrorPrototype::ErrorPrototype): |
| (KJS::ErrorConstructor::ErrorConstructor): |
| (KJS::ErrorConstructor::getConstructData): |
| (KJS::ErrorConstructor::construct): |
| (KJS::ErrorConstructor::callAsFunction): |
| (KJS::NativeErrorConstructor::NativeErrorConstructor): |
| (KJS::NativeErrorConstructor::getConstructData): |
| (KJS::NativeErrorConstructor::construct): |
| (KJS::NativeErrorConstructor::callAsFunction): |
| (KJS::NativeErrorConstructor::mark): |
| * kjs/error_object.h: |
| * kjs/function.cpp: |
| (KJS::JSFunction::JSFunction): |
| (KJS::JSFunction::mark): |
| (KJS::JSFunction::getOwnPropertySlot): |
| (KJS::JSFunction::put): |
| (KJS::JSFunction::deleteProperty): |
| (KJS::PrototypeFunction::PrototypeFunction): |
| (KJS::PrototypeReflexiveFunction::PrototypeReflexiveFunction): |
| (KJS::PrototypeReflexiveFunction::mark): |
| * kjs/function.h: |
| * kjs/function_object.cpp: |
| (KJS::functionProtoFuncToString): |
| (KJS::FunctionConstructor::FunctionConstructor): |
| (KJS::FunctionConstructor::getConstructData): |
| (KJS::FunctionConstructor::construct): |
| (KJS::FunctionConstructor::callAsFunction): |
| * kjs/function_object.h: |
| * kjs/internal.cpp: |
| (KJS::StringObject::create): |
| (KJS::JSString::toObject): |
| (KJS::JSString::toThisObject): |
| (KJS::JSString::getOwnPropertySlot): |
| (KJS::InternalFunction::InternalFunction): |
| (KJS::InternalFunction::getCallData): |
| (KJS::InternalFunction::implementsHasInstance): |
| * kjs/math_object.cpp: |
| (KJS::MathObject::MathObject): |
| (KJS::MathObject::getOwnPropertySlot): |
| (KJS::MathObject::getValueProperty): |
| * kjs/math_object.h: |
| * kjs/number_object.cpp: |
| (KJS::NumberObject::NumberObject): |
| (KJS::NumberPrototype::NumberPrototype): |
| (KJS::numberProtoFuncToString): |
| (KJS::numberProtoFuncToLocaleString): |
| (KJS::numberProtoFuncValueOf): |
| (KJS::numberProtoFuncToFixed): |
| (KJS::numberProtoFuncToExponential): |
| (KJS::numberProtoFuncToPrecision): |
| (KJS::NumberConstructor::NumberConstructor): |
| (KJS::NumberConstructor::getOwnPropertySlot): |
| (KJS::NumberConstructor::getValueProperty): |
| (KJS::NumberConstructor::getConstructData): |
| (KJS::NumberConstructor::construct): |
| (KJS::NumberConstructor::callAsFunction): |
| * kjs/number_object.h: |
| * kjs/object.cpp: |
| (KJS::JSObject::putDirectFunction): |
| * kjs/object.h: |
| * kjs/object_object.cpp: |
| (KJS::ObjectConstructor::ObjectConstructor): |
| (KJS::ObjectConstructor::getConstructData): |
| (KJS::ObjectConstructor::construct): |
| (KJS::ObjectConstructor::callAsFunction): |
| * kjs/object_object.h: |
| * kjs/regexp.cpp: |
| (KJS::RegExp::RegExp): |
| * kjs/regexp_object.cpp: |
| (KJS::regExpProtoFuncTest): |
| (KJS::regExpProtoFuncExec): |
| (KJS::regExpProtoFuncCompile): |
| (KJS::regExpProtoFuncToString): |
| (KJS::RegExpObject::RegExpObject): |
| (KJS::RegExpObject::~RegExpObject): |
| (KJS::RegExpObject::getOwnPropertySlot): |
| (KJS::RegExpObject::getValueProperty): |
| (KJS::RegExpObject::put): |
| (KJS::RegExpObject::putValueProperty): |
| (KJS::RegExpObject::match): |
| (KJS::RegExpObject::test): |
| (KJS::RegExpObject::exec): |
| (KJS::RegExpObject::getCallData): |
| (KJS::RegExpObject::callAsFunction): |
| (KJS::RegExpConstructorPrivate::RegExpConstructorPrivate): |
| (KJS::RegExpConstructor::RegExpConstructor): |
| (KJS::RegExpConstructor::performMatch): |
| (KJS::RegExpMatchesArray::RegExpMatchesArray): |
| (KJS::RegExpMatchesArray::~RegExpMatchesArray): |
| (KJS::RegExpMatchesArray::fillArrayInstance): |
| (KJS::RegExpConstructor::arrayOfMatches): |
| (KJS::RegExpConstructor::getBackref): |
| (KJS::RegExpConstructor::getLastParen): |
| (KJS::RegExpConstructor::getLeftContext): |
| (KJS::RegExpConstructor::getRightContext): |
| (KJS::RegExpConstructor::getOwnPropertySlot): |
| (KJS::RegExpConstructor::getValueProperty): |
| (KJS::RegExpConstructor::put): |
| (KJS::RegExpConstructor::putValueProperty): |
| (KJS::RegExpConstructor::getConstructData): |
| (KJS::RegExpConstructor::construct): |
| (KJS::RegExpConstructor::callAsFunction): |
| (KJS::RegExpConstructor::input): |
| * kjs/regexp_object.h: |
| * kjs/string_object.cpp: |
| (KJS::StringObject::StringObject): |
| (KJS::StringObject::getOwnPropertySlot): |
| (KJS::StringObject::put): |
| (KJS::StringObject::deleteProperty): |
| (KJS::StringObject::getPropertyNames): |
| (KJS::StringPrototype::StringPrototype): |
| (KJS::StringPrototype::getOwnPropertySlot): |
| (KJS::replace): |
| (KJS::stringProtoFuncToString): |
| (KJS::stringProtoFuncValueOf): |
| (KJS::stringProtoFuncCharAt): |
| (KJS::stringProtoFuncCharCodeAt): |
| (KJS::stringProtoFuncConcat): |
| (KJS::stringProtoFuncIndexOf): |
| (KJS::stringProtoFuncLastIndexOf): |
| (KJS::stringProtoFuncMatch): |
| (KJS::stringProtoFuncSearch): |
| (KJS::stringProtoFuncReplace): |
| (KJS::stringProtoFuncSlice): |
| (KJS::stringProtoFuncSplit): |
| (KJS::stringProtoFuncSubstr): |
| (KJS::stringProtoFuncSubstring): |
| (KJS::stringProtoFuncToLowerCase): |
| (KJS::stringProtoFuncToUpperCase): |
| (KJS::stringProtoFuncToLocaleLowerCase): |
| (KJS::stringProtoFuncToLocaleUpperCase): |
| (KJS::stringProtoFuncLocaleCompare): |
| (KJS::stringProtoFuncBig): |
| (KJS::stringProtoFuncSmall): |
| (KJS::stringProtoFuncBlink): |
| (KJS::stringProtoFuncBold): |
| (KJS::stringProtoFuncFixed): |
| (KJS::stringProtoFuncItalics): |
| (KJS::stringProtoFuncStrike): |
| (KJS::stringProtoFuncSub): |
| (KJS::stringProtoFuncSup): |
| (KJS::stringProtoFuncFontcolor): |
| (KJS::stringProtoFuncFontsize): |
| (KJS::stringProtoFuncAnchor): |
| (KJS::stringProtoFuncLink): |
| (KJS::StringConstructor::StringConstructor): |
| (KJS::StringConstructor::getConstructData): |
| (KJS::StringConstructor::construct): |
| (KJS::StringConstructor::callAsFunction): |
| (KJS::StringConstructorFunction::StringConstructorFunction): |
| (KJS::StringConstructorFunction::callAsFunction): |
| * kjs/string_object.h: |
| (KJS::StringObjectThatMasqueradesAsUndefined::StringObjectThatMasqueradesAsUndefined): |
| * profiler/Profiler.cpp: |
| (KJS::createCallIdentifier): |
| |
| 2008-06-15 Darin Adler <darin@apple.com> |
| |
| Rubber stamped by Sam. |
| |
| - use JS prefix and simpler names for basic JavaScriptCore types, |
| to complement JSValue and JSObject |
| |
| * JavaScriptCore.exp: |
| * VM/Machine.cpp: |
| (KJS::jsLess): |
| (KJS::jsLessEq): |
| (KJS::jsAdd): |
| (KJS::callEval): |
| (KJS::Machine::execute): |
| (KJS::Machine::retrieveArguments): |
| (KJS::Machine::retrieveCaller): |
| (KJS::Machine::getCallFrame): |
| (KJS::Machine::getFunctionAndArguments): |
| * VM/Machine.h: |
| * VM/Register.h: |
| * kjs/DebuggerCallFrame.cpp: |
| (KJS::DebuggerCallFrame::functionName): |
| * kjs/ExecState.h: |
| * kjs/JSActivation.cpp: |
| (KJS::JSActivation::createArgumentsObject): |
| * kjs/array_instance.cpp: |
| (KJS::JSArray::checkConsistency): |
| (KJS::JSArray::JSArray): |
| (KJS::JSArray::~JSArray): |
| (KJS::JSArray::getItem): |
| (KJS::JSArray::lengthGetter): |
| (KJS::JSArray::inlineGetOwnPropertySlot): |
| (KJS::JSArray::getOwnPropertySlot): |
| (KJS::JSArray::put): |
| (KJS::JSArray::deleteProperty): |
| (KJS::JSArray::getPropertyNames): |
| (KJS::JSArray::increaseVectorLength): |
| (KJS::JSArray::setLength): |
| (KJS::JSArray::mark): |
| (KJS::JSArray::sort): |
| (KJS::JSArray::compactForSorting): |
| (KJS::JSArray::lazyCreationData): |
| (KJS::JSArray::setLazyCreationData): |
| * kjs/array_instance.h: |
| * kjs/array_object.cpp: |
| (KJS::ArrayPrototype::ArrayPrototype): |
| (KJS::ArrayPrototype::getOwnPropertySlot): |
| (KJS::arrayProtoFuncToString): |
| (KJS::arrayProtoFuncToLocaleString): |
| (KJS::arrayProtoFuncConcat): |
| (KJS::arrayProtoFuncSort): |
| (KJS::ArrayObjectImp::construct): |
| * kjs/array_object.h: |
| * kjs/completion.h: |
| * kjs/function.cpp: |
| (KJS::JSFunction::JSFunction): |
| (KJS::JSFunction::mark): |
| (KJS::JSFunction::getCallData): |
| (KJS::JSFunction::callAsFunction): |
| (KJS::JSFunction::argumentsGetter): |
| (KJS::JSFunction::callerGetter): |
| (KJS::JSFunction::lengthGetter): |
| (KJS::JSFunction::getOwnPropertySlot): |
| (KJS::JSFunction::put): |
| (KJS::JSFunction::deleteProperty): |
| (KJS::JSFunction::getParameterName): |
| (KJS::JSFunction::getConstructData): |
| (KJS::JSFunction::construct): |
| (KJS::IndexToNameMap::IndexToNameMap): |
| (KJS::Arguments::Arguments): |
| * kjs/function.h: |
| * kjs/function_object.cpp: |
| (KJS::functionProtoFuncToString): |
| (KJS::functionProtoFuncApply): |
| (KJS::FunctionObjectImp::construct): |
| * kjs/internal.cpp: |
| (KJS::JSString::toPrimitive): |
| (KJS::JSString::getPrimitiveNumber): |
| (KJS::JSString::toBoolean): |
| (KJS::JSString::toNumber): |
| (KJS::JSString::toString): |
| (KJS::StringInstance::create): |
| (KJS::JSString::toObject): |
| (KJS::JSString::toThisObject): |
| (KJS::JSString::lengthGetter): |
| (KJS::JSString::indexGetter): |
| (KJS::JSString::indexNumericPropertyGetter): |
| (KJS::JSString::getOwnPropertySlot): |
| (KJS::JSNumberCell::type): |
| (KJS::JSNumberCell::toPrimitive): |
| (KJS::JSNumberCell::getPrimitiveNumber): |
| (KJS::JSNumberCell::toBoolean): |
| (KJS::JSNumberCell::toNumber): |
| (KJS::JSNumberCell::toString): |
| (KJS::JSNumberCell::toObject): |
| (KJS::JSNumberCell::toThisObject): |
| (KJS::JSNumberCell::getUInt32): |
| (KJS::JSNumberCell::getTruncatedInt32): |
| (KJS::JSNumberCell::getTruncatedUInt32): |
| (KJS::GetterSetter::mark): |
| (KJS::GetterSetter::toPrimitive): |
| (KJS::GetterSetter::getPrimitiveNumber): |
| (KJS::GetterSetter::toBoolean): |
| (KJS::GetterSetter::toNumber): |
| (KJS::GetterSetter::toString): |
| (KJS::GetterSetter::toObject): |
| (KJS::GetterSetter::getOwnPropertySlot): |
| (KJS::GetterSetter::put): |
| (KJS::GetterSetter::toThisObject): |
| * kjs/internal.h: |
| (KJS::JSString::JSString): |
| (KJS::JSString::getStringPropertySlot): |
| * kjs/nodes.cpp: |
| (KJS::FuncDeclNode::makeFunction): |
| (KJS::FuncExprNode::makeFunction): |
| * kjs/nodes.h: |
| * kjs/object.cpp: |
| (KJS::JSObject::put): |
| (KJS::JSObject::deleteProperty): |
| (KJS::JSObject::defineGetter): |
| (KJS::JSObject::defineSetter): |
| (KJS::JSObject::lookupGetter): |
| (KJS::JSObject::lookupSetter): |
| (KJS::JSObject::fillGetterPropertySlot): |
| * kjs/object.h: |
| (KJS::GetterSetter::GetterSetter): |
| * kjs/operations.cpp: |
| (KJS::equal): |
| (KJS::strictEqual): |
| * kjs/property_map.cpp: |
| (KJS::PropertyMap::containsGettersOrSetters): |
| * kjs/regexp_object.cpp: |
| (KJS::RegExpMatchesArray::getOwnPropertySlot): |
| (KJS::RegExpMatchesArray::put): |
| (KJS::RegExpMatchesArray::deleteProperty): |
| (KJS::RegExpMatchesArray::getPropertyNames): |
| (KJS::RegExpMatchesArray::RegExpMatchesArray): |
| (KJS::RegExpMatchesArray::fillArrayInstance): |
| * kjs/string_object.cpp: |
| (KJS::StringInstance::StringInstance): |
| (KJS::replace): |
| (KJS::stringProtoFuncReplace): |
| (KJS::stringProtoFuncToLowerCase): |
| (KJS::stringProtoFuncToUpperCase): |
| (KJS::stringProtoFuncToLocaleLowerCase): |
| (KJS::stringProtoFuncToLocaleUpperCase): |
| * kjs/string_object.h: |
| (KJS::StringInstance::internalValue): |
| * kjs/value.cpp: |
| (KJS::JSCell::getNumber): |
| (KJS::JSCell::getString): |
| (KJS::JSCell::getObject): |
| (KJS::jsString): |
| (KJS::jsOwnedString): |
| * kjs/value.h: |
| (KJS::JSNumberCell::JSNumberCell): |
| (KJS::jsNumberCell): |
| (KJS::JSValue::uncheckedGetNumber): |
| * profiler/Profiler.cpp: |
| (KJS::createCallIdentifier): |
| (KJS::createCallIdentifierFromFunctionImp): |
| |
| 2008-06-15 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Alexey. |
| |
| - add emitUnaryOp, emitNullaryOp and emitUnaryOpNoDst; use them |
| |
| This removes some boilerplate code and also reduces the number of |
| places that will need to be changed to do on-demand emit of |
| loads (and thus support k operands). |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitUnaryOp): |
| (KJS::CodeGenerator::emitNullaryOp): |
| (KJS::CodeGenerator::emitUnaryOpNoDst): |
| (KJS::CodeGenerator::emitPushScope): |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::emitNewObject): |
| (KJS::CodeGenerator::emitNewArray): |
| (KJS::CodeGenerator::emitNot): |
| (KJS::CodeGenerator::emitBitNot): |
| (KJS::CodeGenerator::emitToJSNumber): |
| (KJS::CodeGenerator::emitNegate): |
| (KJS::CodeGenerator::emitInstanceOf): |
| (KJS::CodeGenerator::emitTypeOf): |
| (KJS::CodeGenerator::emitIn): |
| (KJS::CodeGenerator::emitReturn): |
| (KJS::CodeGenerator::emitEnd): |
| (KJS::CodeGenerator::emitGetPropertyNames): |
| |
| 2008-06-15 Alp Toker <alp@nuanti.com> |
| |
| Rubber-stamped by Maciej. |
| |
| Install 'jsc' application by default. |
| |
| * GNUmakefile.am: |
| |
| 2008-06-15 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - rename testkjs to jsc |
| |
| * GNUmakefile.am: |
| * JavaScriptCore.vcproj/JavaScriptCore.sln: |
| * JavaScriptCore.vcproj/jsc: Added. |
| * JavaScriptCore.vcproj/jsc/jsc.vcproj: Copied from JavaScriptCore.vcproj/testkjs/testkjs.vcproj. |
| * JavaScriptCore.vcproj/testkjs: Removed. |
| * JavaScriptCore.vcproj/testkjs/testkjs.vcproj: Removed. |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * jscore.bkl: |
| * kjs/Shell.cpp: Copied from kjs/testkjs.cpp. |
| (main): |
| (printUsageStatement): |
| (jscmain): |
| * kjs/jsc.pro: Copied from kjs/testkjs.pro. |
| * kjs/testkjs.cpp: Removed. |
| * kjs/testkjs.pro: Removed. |
| * tests/mozilla/expected.html: |
| * tests/mozilla/js1_2/Array/tostring_1.js: |
| * tests/mozilla/js1_2/Array/tostring_2.js: |
| * tests/mozilla/jsDriver.pl: |
| |
| 2008-06-15 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Mac build fix. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/nodes.h: |
| |
| 2008-06-15 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Change the spelling of PrecMultiplicitave to PrecMultiplicative. |
| |
| * kjs/nodes.h: |
| (KJS::MultNode::precedence): |
| (KJS::DivNode::precedence): |
| (KJS::ModNode::precedence): |
| |
| 2008-06-15 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Remove unused preprocessor macros related to exceptions in the old |
| interpreter. |
| |
| * kjs/nodes.cpp: |
| |
| 2008-06-15 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Bug 19484: More instructions needs to use temporary registers |
| <https://bugs.webkit.org/show_bug.cgi?id=19484> |
| |
| Fix codegen for all binary operations so that temporaries are used if |
| necessary. This was done by making BinaryOpNode and ReverseBinaryOpNode |
| subclasses of ExpressionNode, and eliminating the custom emitCode() |
| methods for the individual node classes. |
| |
| This only adds 3 new instructions to SunSpider code, and there is no |
| difference in SunSpider execution time. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitBitNot): |
| (KJS::CodeGenerator::emitBinaryOp): |
| * VM/CodeGenerator.h: |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::PreIncResolveNode::emitCode): |
| (KJS::PreDecResolveNode::emitCode): |
| (KJS::BinaryOpNode::emitCode): |
| (KJS::ReverseBinaryOpNode::emitCode): |
| (KJS::emitReadModifyAssignment): |
| (KJS::CaseBlockNode::emitCodeForBlock): |
| * kjs/nodes.h: |
| (KJS::BinaryOpNode::BinaryOpNode): |
| (KJS::ReverseBinaryOpNode::ReverseBinaryOpNode): |
| (KJS::MultNode::): |
| (KJS::DivNode::): |
| (KJS::DivNode::precedence): |
| (KJS::ModNode::): |
| (KJS::ModNode::precedence): |
| (KJS::AddNode::): |
| (KJS::AddNode::precedence): |
| (KJS::SubNode::): |
| (KJS::SubNode::precedence): |
| (KJS::LeftShiftNode::): |
| (KJS::LeftShiftNode::precedence): |
| (KJS::RightShiftNode::): |
| (KJS::RightShiftNode::precedence): |
| (KJS::UnsignedRightShiftNode::): |
| (KJS::UnsignedRightShiftNode::precedence): |
| (KJS::LessNode::): |
| (KJS::LessNode::precedence): |
| (KJS::GreaterNode::): |
| (KJS::GreaterNode::precedence): |
| (KJS::LessEqNode::): |
| (KJS::LessEqNode::precedence): |
| (KJS::GreaterEqNode::): |
| (KJS::GreaterEqNode::precedence): |
| (KJS::InstanceOfNode::): |
| (KJS::InstanceOfNode::precedence): |
| (KJS::InNode::): |
| (KJS::InNode::precedence): |
| (KJS::EqualNode::): |
| (KJS::EqualNode::precedence): |
| (KJS::NotEqualNode::): |
| (KJS::NotEqualNode::precedence): |
| (KJS::StrictEqualNode::): |
| (KJS::StrictEqualNode::precedence): |
| (KJS::NotStrictEqualNode::): |
| (KJS::NotStrictEqualNode::precedence): |
| (KJS::BitAndNode::): |
| (KJS::BitAndNode::precedence): |
| (KJS::BitOrNode::): |
| (KJS::BitOrNode::precedence): |
| (KJS::BitXOrNode::): |
| (KJS::BitXOrNode::precedence): |
| * kjs/nodes2string.cpp: |
| (KJS::LessNode::streamTo): |
| (KJS::GreaterNode::streamTo): |
| (KJS::LessEqNode::streamTo): |
| (KJS::GreaterEqNode::streamTo): |
| (KJS::InstanceOfNode::streamTo): |
| (KJS::InNode::streamTo): |
| (KJS::EqualNode::streamTo): |
| (KJS::NotEqualNode::streamTo): |
| (KJS::StrictEqualNode::streamTo): |
| (KJS::NotStrictEqualNode::streamTo): |
| (KJS::BitAndNode::streamTo): |
| (KJS::BitXOrNode::streamTo): |
| (KJS::BitOrNode::streamTo): |
| |
| 2008-06-14 Darin Adler <darin@apple.com> |
| |
| Rubber stamped by Sam. |
| |
| - rename a bunch of local symbols within the regular expression code to |
| follow our usual coding style, and do a few other name tweaks |
| |
| * pcre/pcre_compile.cpp: |
| (CompileData::CompileData): |
| (checkEscape): |
| (readRepeatCounts): |
| (compileBranch): |
| (compileBracket): |
| (calculateCompiledPatternLength): |
| (returnError): |
| (jsRegExpCompile): |
| * pcre/pcre_exec.cpp: |
| (MatchStack::MatchStack): |
| (MatchStack::canUseStackBufferForNextFrame): |
| (MatchStack::popCurrentFrame): |
| (match): |
| (tryFirstByteOptimization): |
| (tryRequiredByteOptimization): |
| (jsRegExpExecute): |
| * pcre/pcre_internal.h: |
| |
| 2008-06-14 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Darin. |
| |
| Remove redundant uses of get(). |
| |
| * kjs/nodes.cpp: |
| (KJS::BracketAccessorNode::emitCode): |
| (KJS::AddNode::emitCode): |
| (KJS::SubNode::emitCode): |
| (KJS::ReadModifyResolveNode::emitCode): |
| (KJS::AssignDotNode::emitCode): |
| (KJS::ReadModifyDotNode::emitCode): |
| (KJS::AssignBracketNode::emitCode): |
| (KJS::ReadModifyBracketNode::emitCode): |
| |
| 2008-06-14 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Make code generation not use a temporary for the left-hand side of an |
| expression if the right-hand side is a local variable. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::isLocal): |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::leftHandSideNeedsCopy): |
| (KJS::CodeGenerator::emitNodeForLeftHandSide): |
| * kjs/nodes.cpp: |
| (KJS::ResolveNode::isPure): |
| (KJS::BracketAccessorNode::emitCode): |
| (KJS::AddNode::emitCode): |
| (KJS::SubNode::emitCode): |
| (KJS::ReadModifyResolveNode::emitCode): |
| (KJS::AssignDotNode::emitCode): |
| (KJS::ReadModifyDotNode::emitCode): |
| (KJS::AssignBracketNode::emitCode): |
| (KJS::ReadModifyBracketNode::emitCode): |
| * kjs/nodes.h: |
| (KJS::ExpressionNode::): |
| (KJS::BooleanNode::): |
| (KJS::NumberNode::): |
| (KJS::StringNode::): |
| |
| 2008-06-14 Darin Adler <darin@apple.com> |
| |
| Reviewed by Sam. |
| |
| - more of https://bugs.webkit.org/show_bug.cgi?id=17257 |
| start ref counts at 1 instead of 0 for speed |
| |
| * kjs/nodes.cpp: |
| (KJS::ParserRefCounted::hasOneRef): Added. Replaces refcount. |
| * kjs/nodes.h: Replaced refcount with hasOneRef. |
| |
| * wtf/ListRefPtr.h: |
| (WTF::ListRefPtr::~ListRefPtr): Changed to use hasOneRef instead of |
| refcount, so this class can be used with the RefCounted template. |
| |
| * wtf/RefCounted.h: |
| (WTF::RefCounted::hasOneRef): Made const, since there's no reason for |
| it to be non-const. |
| |
| 2008-06-14 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - initialize local vars as side effect of call instead of in bytecode |
| 1.004x speedup on SunSpider. |
| |
| This removes just the dispatch overhead for these loads - in the |
| future, dead store elimination might be able to eliminate them |
| entirely. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::CodeGenerator): For function blocks, don't |
| emit loads of undefined for var initialization. |
| * VM/Machine.cpp: |
| (KJS::slideRegisterWindowForCall): Instead, initialize locals |
| as part of the call. |
| |
| 2008-06-14 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Remove helper functions in the parser that are no longer needed. |
| |
| * kjs/grammar.y: |
| |
| 2008-06-14 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Bug 19484: More instructions needs to use temporary registers |
| <https://bugs.webkit.org/show_bug.cgi?id=19484> |
| |
| Make code generation for AddNode and SubNode use temporaries when |
| necessary. |
| |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::AddNode::emitCode): |
| (KJS::SubNode::emitCode): |
| * kjs/nodes.h: |
| (KJS::AddNode::): |
| (KJS::SubNode::): |
| |
| 2008-06-13 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Combine TrueNode and FalseNode to make BooleanNode, and remove the |
| unused class PlaceholderTrueNode. |
| |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::BooleanNode::emitCode): |
| * kjs/nodes.h: |
| (KJS::BooleanNode::): |
| (KJS::BooleanNode::precedence): |
| * kjs/nodes2string.cpp: |
| (KJS::BooleanNode::streamTo): |
| |
| 2008-06-13 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Eliminate the use of temporaries to store the left hand side of an |
| expression when the right hand side is a constant. This slightly |
| improves the generated bytecode for a few SunSpider tests, but it is |
| mostly in preparation for fixing |
| |
| Bug 19484: More instructions needs to use temporary registers |
| <https://bugs.webkit.org/show_bug.cgi?id=19484> |
| |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::leftHandSideNeedsCopy): |
| (KJS::CodeGenerator::emitNodeForLeftHandSide): |
| * kjs/nodes.cpp: |
| (KJS::BracketAccessorNode::emitCode): |
| (KJS::ReadModifyResolveNode::emitCode): |
| (KJS::AssignDotNode::emitCode): |
| (KJS::ReadModifyDotNode::emitCode): |
| (KJS::AssignBracketNode::emitCode): |
| (KJS::ReadModifyBracketNode::emitCode): |
| * kjs/nodes.h: |
| (KJS::ExpressionNode::): |
| (KJS::FalseNode::): |
| (KJS::TrueNode::): |
| (KJS::NumberNode::): |
| (KJS::StringNode::): |
| |
| 2008-06-13 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - prettify opcode stats output |
| |
| I changed things to be a bit more aligned, also there is a new |
| section listing most common opcodes and most common sequences that |
| include them. |
| |
| * VM/Opcode.cpp: |
| (KJS::OpcodeStats::~OpcodeStats): |
| * VM/Opcode.h: |
| |
| 2008-06-13 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Geoff. |
| |
| <rdar://problem/5969992> JSProfiler: Remove the recursion limit in the |
| profiler. |
| - Remove recursion from exclude(). This leaves only focus() to fix. |
| |
| * JavaScriptCore.exp: Change the signatures of the exported functions. |
| * profiler/Profile.cpp: |
| (KJS::Profile::forEach): I added a traverseNextNodePreOrder() function |
| and so needed to distinguish the other function by labeling it |
| traverseNextNodePostOrder(). |
| (KJS::Profile::exclude): All new exclude that iteratively walks the tree |
| * profiler/Profile.h: |
| (KJS::Profile::focus): Add a null check for m_head. |
| * profiler/ProfileNode.cpp: |
| (KJS::ProfileNode::traverseNextNodePostOrder): Renamed |
| (KJS::ProfileNode::traverseNextNodePreOrder): Walks the tree in pre- |
| order, where the parent is processed before the children. |
| (KJS::ProfileNode::setTreeVisible): Iterate over the sub-tree and set |
| all of the nodes visible value. This changes another function that used |
| recursion. |
| (KJS::ProfileNode::exclude): Remove recursion from this function. |
| Because we now check for m_visible and we are walking the tree in pre- |
| order we do not need to check if an excluded node is in an excluded |
| sub-tree. |
| * profiler/ProfileNode.h: Added specific selfTime functions to |
| facilitate exclude(). |
| (KJS::ProfileNode::setSelfTime): |
| (KJS::ProfileNode::setActualSelfTime): |
| (KJS::ProfileNode::setVisibleSelfTime): |
| |
| 2008-06-12 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - https://bugs.webkit.org/show_bug.cgi?id=19434 |
| speed up SunSpider by avoiding some string boxing |
| |
| Speeds up SunSpider by 1.1%. |
| |
| Optimized code path for getting built-in properties from strings -- avoid |
| boxing with a string object in that case. We can make further changes to avoid |
| even more boxing, but this change alone is a win. |
| |
| * API/JSCallbackObjectFunctions.h: |
| (KJS::JSCallbackObject::staticValueGetter): Use isObject instead of inherits |
| in asssert, since the type of slotBase() is now JSValue, not JSObject. |
| (KJS::JSCallbackObject::staticFunctionGetter): Ditto. |
| (KJS::JSCallbackObject::callbackGetter): Ditto. |
| |
| * kjs/internal.cpp: |
| (KJS::StringImp::getPrimitiveNumber): Updated for change of data member name. |
| (KJS::StringImp::toBoolean): Ditto. |
| (KJS::StringImp::toNumber): Ditto. |
| (KJS::StringImp::toString): Ditto. |
| (KJS::StringInstance::create): Added; avoids a bit of cut and paste code. |
| (KJS::StringImp::toObject): Use StringInstance::create. |
| (KJS::StringImp::toThisObject): Ditto. |
| (KJS::StringImp::lengthGetter): Added. Replaces the getter that used to live in |
| the StringInstance class. |
| (KJS::StringImp::indexGetter): Ditto. |
| (KJS::StringImp::indexNumericPropertyGetter): Ditto. |
| (KJS::StringImp::getOwnPropertySlot): Added. Deals with built in properties of |
| the string class without creating a StringInstance. |
| |
| * kjs/internal.h: |
| (KJS::StringImp::getStringPropertySlot): Added. To be used by both the string |
| and string object getOwnPropertySlot function. |
| |
| * kjs/lookup.h: |
| (KJS::staticFunctionGetter): Updated since slotBase() is now a JSValue rather |
| than a JSObject. |
| |
| * kjs/object.h: Removed PropertySlot::slotBase() function, which can now move |
| back into property_slot.h where it belongs since it doesn't have to cast to |
| JSObject*. |
| |
| * kjs/property_slot.cpp: |
| (KJS::PropertySlot::functionGetter): Updated since slot.slotBase() is now a JSValue* |
| instead of JSObject*. setGetterSlot still guarantees the base is a JSObject*. |
| * kjs/property_slot.h: |
| (KJS::PropertySlot::PropertySlot): Changed base to JSValue* intead of JSCell*. |
| (KJS::PropertySlot::setStaticEntry): Ditto. |
| (KJS::PropertySlot::setCustom): Ditto. |
| (KJS::PropertySlot::setCustomIndex): Ditto. |
| (KJS::PropertySlot::setCustomNumeric): Ditto. |
| (KJS::PropertySlot::slotBase): Moved inline here since it no longer involves a |
| downcast to JSObject*. |
| (KJS::PropertySlot::setBase): Changed to JSValue*. |
| |
| * kjs/string_object.cpp: |
| (KJS::StringInstance::getOwnPropertySlot): Changed to use getStringPropertySlot |
| instead of coding the properties here. This allows sharing the code with StringImp. |
| |
| * kjs/string_object.h: Removed inlineGetOwnPropertySlot, lengthGetter, and indexGetter. |
| Made one of the constructors protected. |
| |
| * kjs/value.h: Made getOwnPropertySlot private in the JSCell class -- this is better |
| since it's not the real JSObject getOwnPropertySlot semantic and most callers shouldn't |
| use it. |
| |
| 2008-06-12 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Preparation to making JavaScript heap per-thread. |
| |
| * kjs/collector.cpp: |
| (KJS::Collector::collect): |
| * kjs/collector.h: |
| (KJS::Collector::markListSet): |
| The collector now holds the list of protected lists itself, to be made per-instance. |
| |
| * kjs/list.h: Changed to hold a pointer to a mark set this list is in, if any. |
| (KJS::List::List): Explicitly initialize m_size with zero, as m_vector.size() is |
| guaranteed to be such anyway. |
| (KJS::List::append): Changed the fast case to only be executed as long as inline buffer |
| is used, because otherwise, we now do more expensive checks. |
| |
| * kjs/list.cpp: |
| (KJS::List::markLists): Renamed from markProtectedListsSlowCase, made it take the list set |
| as a parameter. |
| (KJS::List::slowAppend): If a non-immediate value is appended, the list needs to be added |
| to an appropriate Heap's protected list. For now, a static Collector::markListSet() is |
| used, but the code is layed out in preparation to making the switch to multiple heaps. |
| |
| * JavaScriptCore.exp: Updated export list. |
| |
| 2008-06-12 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Bug 19510: CodeBlock::needsFullScopeChain not always set for global code |
| <https://bugs.webkit.org/show_bug.cgi?id=19510> |
| |
| This fixes the symptoms by using CodeGenerator::m_codeType to determine |
| when to use temporaries instead of CodeBlock::needsFullScopeChain, but |
| it does not fix the problem itself. |
| |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::leftHandSideNeedsCopy): |
| |
| 2008-06-11 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Bug 19498: REGRESSION (r34497): crash while loading GMail |
| <https://bugs.webkit.org/show_bug.cgi?id=19498> |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitJumpIfTrueMayCombine): |
| (KJS::CodeGenerator::emitJumpIfTrue): |
| * VM/CodeGenerator.h: |
| * kjs/nodes.cpp: |
| (KJS::DoWhileNode::emitCode): |
| (KJS::WhileNode::emitCode): |
| (KJS::ForNode::emitCode): |
| (KJS::CaseBlockNode::emitCodeForBlock): |
| |
| 2008-06-11 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - a little bit of cleanup and prep for some upcoming optimizations |
| |
| * JavaScriptCore.exp: Re-sorted this file (with sort command line tool). |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): Fixed printf to avoid warnings -- to use %lu we |
| need to make sure the type is unsigned long. |
| * kjs/object.cpp: |
| (KJS::Error::create): Eliminated unused error names array, and also put |
| the strings into the code since there was already a switch statment. |
| This also avoids having to contemplate a hypothetical access past the |
| end of the array. |
| * kjs/object.h: Got rid of errorNames. |
| * kjs/property_slot.cpp: Deleted unused ungettableGetter. |
| * kjs/property_slot.h: Ditto. |
| * wtf/AlwaysInline.h: Added LIKELY alongside UNLIKELY. |
| |
| 2008-06-11 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Darin. |
| |
| Bug 19457: Create fused opcodes for tests and conditional jumps |
| <https://bugs.webkit.org/show_bug.cgi?id=19457> |
| |
| Add a new jless instruction, and modify the code generator to emit it |
| instead of the pair (less, jtrue). |
| |
| Gives a 3.6% improvement on SunSpider. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::CodeGenerator): |
| (KJS::CodeGenerator::emitOpcode): |
| (KJS::CodeGenerator::retrieveLastBinaryOp): |
| (KJS::CodeGenerator::rewindBinaryOp): |
| (KJS::CodeGenerator::emitJump): |
| (KJS::CodeGenerator::emitJumpIfTrue): |
| (KJS::CodeGenerator::emitJumpIfFalse): |
| (KJS::CodeGenerator::emitMove): |
| (KJS::CodeGenerator::emitNot): |
| (KJS::CodeGenerator::emitEqual): |
| (KJS::CodeGenerator::emitNotEqual): |
| (KJS::CodeGenerator::emitStrictEqual): |
| (KJS::CodeGenerator::emitNotStrictEqual): |
| (KJS::CodeGenerator::emitLess): |
| (KJS::CodeGenerator::emitLessEq): |
| (KJS::CodeGenerator::emitPreInc): |
| (KJS::CodeGenerator::emitPreDec): |
| (KJS::CodeGenerator::emitPostInc): |
| (KJS::CodeGenerator::emitPostDec): |
| (KJS::CodeGenerator::emitToJSNumber): |
| (KJS::CodeGenerator::emitNegate): |
| (KJS::CodeGenerator::emitAdd): |
| (KJS::CodeGenerator::emitMul): |
| (KJS::CodeGenerator::emitDiv): |
| (KJS::CodeGenerator::emitMod): |
| (KJS::CodeGenerator::emitSub): |
| (KJS::CodeGenerator::emitLeftShift): |
| (KJS::CodeGenerator::emitRightShift): |
| (KJS::CodeGenerator::emitUnsignedRightShift): |
| (KJS::CodeGenerator::emitBitAnd): |
| (KJS::CodeGenerator::emitBitXOr): |
| (KJS::CodeGenerator::emitBitOr): |
| (KJS::CodeGenerator::emitBitNot): |
| (KJS::CodeGenerator::emitInstanceOf): |
| (KJS::CodeGenerator::emitTypeOf): |
| (KJS::CodeGenerator::emitIn): |
| (KJS::CodeGenerator::emitLoad): |
| (KJS::CodeGenerator::emitNewObject): |
| (KJS::CodeGenerator::emitNewArray): |
| (KJS::CodeGenerator::emitResolve): |
| (KJS::CodeGenerator::emitGetScopedVar): |
| (KJS::CodeGenerator::emitPutScopedVar): |
| (KJS::CodeGenerator::emitResolveBase): |
| (KJS::CodeGenerator::emitResolveWithBase): |
| (KJS::CodeGenerator::emitResolveFunction): |
| (KJS::CodeGenerator::emitGetById): |
| (KJS::CodeGenerator::emitPutById): |
| (KJS::CodeGenerator::emitPutGetter): |
| (KJS::CodeGenerator::emitPutSetter): |
| (KJS::CodeGenerator::emitDeleteById): |
| (KJS::CodeGenerator::emitGetByVal): |
| (KJS::CodeGenerator::emitPutByVal): |
| (KJS::CodeGenerator::emitDeleteByVal): |
| (KJS::CodeGenerator::emitPutByIndex): |
| (KJS::CodeGenerator::emitNewFunction): |
| (KJS::CodeGenerator::emitNewRegExp): |
| (KJS::CodeGenerator::emitNewFunctionExpression): |
| (KJS::CodeGenerator::emitCall): |
| (KJS::CodeGenerator::emitReturn): |
| (KJS::CodeGenerator::emitEnd): |
| (KJS::CodeGenerator::emitConstruct): |
| (KJS::CodeGenerator::emitPushScope): |
| (KJS::CodeGenerator::emitPopScope): |
| (KJS::CodeGenerator::emitDebugHook): |
| (KJS::CodeGenerator::emitComplexJumpScopes): |
| (KJS::CodeGenerator::emitJumpScopes): |
| (KJS::CodeGenerator::emitNextPropertyName): |
| (KJS::CodeGenerator::emitGetPropertyNames): |
| (KJS::CodeGenerator::emitCatch): |
| (KJS::CodeGenerator::emitThrow): |
| (KJS::CodeGenerator::emitNewError): |
| (KJS::CodeGenerator::emitJumpSubroutine): |
| (KJS::CodeGenerator::emitSubroutineReturn): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.cpp: |
| * VM/Opcode.h: |
| |
| 2008-06-11 Darin Adler <darin@apple.com> |
| |
| Reviewed by Alexey. |
| |
| - fix https://bugs.webkit.org/show_bug.cgi?id=19442 |
| JavaScript array implementation doesn't maintain m_numValuesInVector when sorting |
| |
| * kjs/array_instance.cpp: |
| (KJS::ArrayInstance::checkConsistency): Added. Empty inline version for when |
| consistency checks are turned off. |
| (KJS::ArrayInstance::ArrayInstance): Check consistency after construction. |
| (KJS::ArrayInstance::~ArrayInstance): Check consistency before destruction. |
| (KJS::ArrayInstance::put): Check consistency before and after. |
| (KJS::ArrayInstance::deleteProperty): Ditto. |
| (KJS::ArrayInstance::setLength): Ditto. |
| (KJS::compareByStringPairForQSort): Use typedef for clarity. |
| (KJS::ArrayInstance::sort): Check consistency before and after. Also broke the loop |
| to set up sorting into two separate passes. Added FIXMEs about various exception |
| safety issues. Added code to set m_numValuesInVector after sorting. |
| (KJS::ArrayInstance::compactForSorting): Ditto. |
| |
| * kjs/array_instance.h: Added a definition of an enum for the types of consistency |
| check and a declaration of the consistency checking function. |
| |
| 2008-06-10 Kevin Ollivier <kevino@theolliviers.com> |
| |
| wx build fix. Link against libedit on Mac since HAVE(READLINE) is defined there. |
| |
| * jscore.bkl: |
| |
| 2008-06-10 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=16503 |
| match limit takes at least 13% of the time on the SunSpider regexp-dna test |
| |
| Make the limit test slightly more efficient. It is not clear how much of a win it is, |
| as the improvement on regexp-dna varies from 2.3% to 0.6% depending on what revision I |
| apply the patch to. Today, the win on regexp-dna was minimal, but the total win was whopping |
| 0.5%, due to random code generation changes. |
| |
| * pcre/pcre_exec.cpp: (match): Avoid loading a constant on each iteration. |
| |
| 2008-06-09 Alp Toker <alp@nuanti.com> |
| |
| gcc3/autotools build fix. Add explicit -O2 -fno-strict-aliasing to |
| each of the tools since these are no longer set globally. |
| |
| * GNUmakefile.am: |
| |
| 2008-06-09 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Sam. |
| |
| Add an include for readline/history.h to fix the build for Darwin users |
| with the GNU readline library installed. Also, clean up the style of |
| the HAVE(READLINE) check. |
| |
| * kjs/testkjs.cpp: |
| (runInteractive): |
| |
| 2008-06-09 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Darin. |
| |
| Bug 17531: Add interactive mode to testkjs |
| <https://bugs.webkit.org/show_bug.cgi?id=17531> |
| |
| This is a cleaned up version of Sam's earlier patch to add an |
| interactive mode to testkjs. |
| |
| Readline support is only enabled on Darwin platforms for now, but |
| other ports can enable it by defining HAVE_READLINE in kjs/config.h. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/config.h: |
| * kjs/testkjs.cpp: |
| (Options::Options): |
| (runWithScripts): |
| (runInteractive): |
| (printUsageStatement): |
| (parseArguments): |
| (kjsmain): |
| |
| 2008-06-08 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Darin. |
| |
| Bug 19346: REGRESSION: Mootools 1.2 Class inheritance broken in post-SquirrelFish merge |
| <https://bugs.webkit.org/show_bug.cgi?id=19346> |
| |
| A check for whether a function's caller is eval code accidentally included |
| the case where the caller's caller is native code. Add a CodeType field to |
| CodeBlock and use this for the eval caller test instead. |
| |
| * VM/CodeBlock.h: |
| (KJS::CodeBlock::CodeBlock): |
| (KJS::ProgramCodeBlock::ProgramCodeBlock): |
| (KJS::EvalCodeBlock::EvalCodeBlock): |
| * VM/Machine.cpp: |
| (KJS::getCallerFunctionOffset): |
| * kjs/nodes.cpp: |
| (KJS::FunctionBodyNode::generateCode): |
| (KJS::ProgramNode::generateCode): |
| |
| 2008-06-07 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Dan Bernstein. |
| |
| Bug 17928: testkjs shouldn't require "-f" |
| <https://bugs.webkit.org/show_bug.cgi?id=17928> |
| |
| * kjs/testkjs.cpp: |
| (printUsageStatement): |
| (parseArguments): |
| |
| 2008-06-07 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Eric. |
| |
| Bug 17548: JavaScriptCore print(a, b) differs from Spidermonkey Behavior |
| <https://bugs.webkit.org/show_bug.cgi?id=17548> |
| |
| * kjs/testkjs.cpp: |
| (functionPrint): |
| |
| 2008-06-07 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Sam. |
| |
| Bug 17547: JavaScriptCore print() differs from Spidermonkey Behavior |
| <https://bugs.webkit.org/show_bug.cgi?id=17547> |
| |
| * kjs/testkjs.cpp: |
| (functionPrint): |
| |
| 2008-06-07 Alexey Proskuryakov <ap@webkit.org> |
| |
| More build fixes. |
| |
| * kjs/JSGlobalData.cpp: Fixed an included file name for case-sensitive file systems, fixed |
| JSGlobalData::threadInstance() for non-multithreaded builds. |
| |
| 2008-06-07 Alexey Proskuryakov <ap@webkit.org> |
| |
| Build fix - actually adding JSGlobalData.cpp to non-Mac builds! |
| |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCoreSources.bkl: |
| |
| 2008-06-07 Alexey Proskuryakov <ap@webkit.org> |
| |
| Try to fix Gtk/gcc 4.3 build. |
| |
| * kjs/JSGlobalData.h: Include ustring.h instead of forward-declaring UString::Rep. |
| |
| 2008-06-06 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Combine per-thread objects into one, to make it easier to support legacy clients (for |
| which they shouldn't be really per-thread). |
| |
| No change on SunSpider total. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: Added JSGlobalData.{h,cpp} |
| |
| * kjs/JSGlobalData.cpp: Added. |
| (KJS::JSGlobalData::JSGlobalData): |
| (KJS::JSGlobalData::~JSGlobalData): |
| (KJS::JSGlobalData::threadInstance): |
| * kjs/JSGlobalData.h: Added. |
| This class encapsulates all data that should be per-thread (or shared between legacy clients). |
| It will also keep a Heap pointer, but right now, Heap (Collector) methods are all static. |
| |
| * kjs/identifier.h: |
| (KJS::Identifier::Identifier): |
| Added a constructor explicitly taking JSGlobalData to access IdentifierTable. Actually, |
| all of them should, but this will be a separate patch. |
| |
| * kjs/identifier.cpp: |
| (KJS::IdentifierTable::literalTable): |
| (KJS::createIdentifierTable): |
| (KJS::deleteIdentifierTable): |
| (KJS::Identifier::add): |
| (KJS::Identifier::addSlowCase): |
| Combined IdentifierTable and LiteralIdentifierTable into a single class for simplicity. |
| |
| * kjs/grammar.y: kjsyyparse now takes JSGlobalData, not just a Lexer. |
| |
| * kjs/nodes.cpp: |
| (KJS::Node::Node): |
| (KJS::EvalFunctionCallNode::emitCode): |
| (KJS::ScopeNode::ScopeNode): |
| Changed to access Lexer and Parser via JSGlobalData::threadInstance(). This is also a |
| temporary measure, they will need to use JSGlobalData explicitly. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::CodeGenerator): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::callEval): |
| * kjs/CommonIdentifiers.cpp: |
| (KJS::CommonIdentifiers::CommonIdentifiers): |
| * kjs/CommonIdentifiers.h: |
| * kjs/DebuggerCallFrame.cpp: |
| (KJS::DebuggerCallFrame::evaluate): |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::ExecState): |
| * kjs/ExecState.h: |
| (KJS::ExecState::globalData): |
| (KJS::ExecState::identifierTable): |
| (KJS::ExecState::propertyNames): |
| (KJS::ExecState::emptyList): |
| (KJS::ExecState::lexer): |
| (KJS::ExecState::parser): |
| (KJS::ExecState::arrayTable): |
| (KJS::ExecState::dateTable): |
| (KJS::ExecState::mathTable): |
| (KJS::ExecState::numberTable): |
| (KJS::ExecState::RegExpImpTable): |
| (KJS::ExecState::RegExpObjectImpTable): |
| (KJS::ExecState::stringTable): |
| * kjs/InitializeThreading.cpp: |
| (KJS::initializeThreadingOnce): |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::init): |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::JSGlobalObjectData::JSGlobalObjectData): |
| (KJS::JSGlobalObject::head): |
| (KJS::JSGlobalObject::globalData): |
| * kjs/Parser.cpp: |
| (KJS::Parser::parse): |
| * kjs/Parser.h: |
| * kjs/function.cpp: |
| (KJS::FunctionImp::getParameterName): |
| (KJS::IndexToNameMap::unMap): |
| (KJS::globalFuncEval): |
| * kjs/function_object.cpp: |
| (KJS::FunctionObjectImp::construct): |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::checkSyntax): |
| (KJS::Interpreter::evaluate): |
| * kjs/lexer.cpp: |
| (kjsyylex): |
| * kjs/lexer.h: |
| * kjs/testkjs.cpp: |
| (prettyPrintScript): |
| Updated for the above changes. Most of threadInstance uses here will need to be replaced with |
| explicitly passed pointers to support legacy JSC clients. |
| |
| * JavaScriptCore.exp: Removed KJS::parser(). |
| |
| 2008-06-06 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Bug 19424: Add support for logging opcode pair counts |
| <https://bugs.webkit.org/show_bug.cgi?id=19424> |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.cpp: |
| (KJS::OpcodeStats::OpcodeStats): |
| (KJS::compareOpcodeIndices): |
| (KJS::compareOpcodePairIndices): |
| (KJS::OpcodeStats::~OpcodeStats): |
| (KJS::OpcodeStats::recordInstruction): |
| (KJS::OpcodeStats::resetLastInstruction): |
| * VM/Opcode.h: |
| |
| 2008-06-06 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Adam. |
| |
| <rdar://problem/5969992> JSProfiler: Remove the recursion limit in the |
| profiler. |
| - Change the remaining functions that do not take arguments, from using |
| recursion to using iteration. |
| |
| * JavaScriptCore.exp: |
| * profiler/Profile.cpp: |
| (KJS::stopProfiling): |
| (KJS::restoreAll): |
| (KJS::Profile::stopProfiling): Use foreach instead of recursion. |
| (KJS::Profile::restoreAll): Ditto. |
| * profiler/Profile.h: |
| * profiler/ProfileNode.cpp: Remove recursion. |
| (KJS::ProfileNode::stopProfiling): |
| (KJS::ProfileNode::restore): |
| * profiler/ProfileNode.h: |
| |
| 2008-06-05 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Alexey. |
| |
| Fix Greater and GreaterEq nodes to emit code for the left |
| and right sub-expressions in the correct order. |
| |
| * kjs/nodes.cpp: |
| (KJS::GreaterNode::emitCode): |
| (KJS::GreaterEqNode::emitCode): |
| |
| 2008-06-05 Antti Koivisto <antti@apple.com> |
| |
| Reviewed by Alp Toker. |
| |
| Fix whitespaces. |
| |
| * kjs/collector.cpp: |
| (KJS::getPlatformThreadRegisters): |
| |
| 2008-06-05 Antti Koivisto <antti@apple.com> |
| |
| Reviewed by Darin. |
| |
| Support compiling JavaScriptCore for ARM. |
| |
| * kjs/collector.cpp: |
| (KJS::getPlatformThreadRegisters): |
| (KJS::otherThreadStackPointer): |
| |
| 2008-06-05 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Jon. |
| |
| - Name changes. |
| |
| * JavaScriptCore.exp: |
| * profiler/Profile.cpp: |
| (KJS::Profile::Profile): |
| (KJS::Profile::stopProfiling): |
| (KJS::Profile::didExecute): |
| (KJS::Profile::forEach): |
| (KJS::Profile::debugPrintData): |
| (KJS::Profile::debugPrintDataSampleStyle): |
| * profiler/Profile.h: |
| (KJS::Profile::callTree): |
| (KJS::Profile::totalTime): |
| (KJS::Profile::sortTotalTimeDescending): |
| (KJS::Profile::sortTotalTimeAscending): |
| (KJS::Profile::sortSelfTimeDescending): |
| (KJS::Profile::sortSelfTimeAscending): |
| (KJS::Profile::sortCallsDescending): |
| (KJS::Profile::sortCallsAscending): |
| (KJS::Profile::sortFunctionNameDescending): |
| (KJS::Profile::sortFunctionNameAscending): |
| (KJS::Profile::focus): |
| (KJS::Profile::exclude): |
| (KJS::Profile::restoreAll): |
| |
| 2008-06-05 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Stephanie Lewis. |
| |
| Added the -fno-move-loop-invariants flag to the pcre_exec.cpp build, to |
| tell GCC not to perform loop invariant motion, since GCC's loop |
| invariant motion doesn't do very well with computed goto code. |
| |
| SunSpider reports no change. |
| |
| 2008-06-05 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Stephanie Lewis. |
| |
| Added the -fno-tree-pre flag to the Machine.cpp build, to tell GCC not |
| to perform Partial Redundancy Elimination (PRE) on trees in Machine.cpp, |
| since GCC's PRE doesn't do very well with computed goto code. |
| |
| SunSpider reports a .7% speedup. |
| |
| 2008-06-05 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Stephanie Lewis (or maybe the other way around). |
| |
| Minor change to PCRE to help out certain compilers. |
| |
| SunSpider reports no change, maybe a small speedup. |
| |
| * pcre/pcre_exec.cpp: |
| (match): Use instructionPtr++ a little less, to avoid confusing the |
| optimizer. |
| |
| 2008-06-05 Alexey Proskuryakov <ap@webkit.org> |
| |
| Re-landing an independent part of a previously rolled out threading patch. |
| |
| * wtf/ThreadSpecific.h: Make sure to initialize POD thread-specific varaibles, too |
| (replaced "new T" with "new T()"). |
| |
| 2008-06-05 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Hyatt. |
| |
| - force inlining of a template function that only has one call site per specialization |
| 1.3% speedup on SunSpider |
| |
| * kjs/collector.cpp: |
| (KJS::Collector::heapAllocate): This template function is only |
| called from allocate() and allocateNumber() (once per |
| specialization) and the extra call overhead for GC allocation |
| shows up, so force inlining. |
| |
| 2008-06-05 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Alexey and Oliver. |
| |
| - remove profiler fetch hack |
| I measure an 0.5% progression from this, others show a wash. It seems not needed any more. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-06-05 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Bug 19400: subscript operator does not protect base when necessary |
| <https://bugs.webkit.org/show_bug.cgi?id=19400> |
| |
| Use a temporary for the base in BracketAccessorNode if the subscript |
| might possibly modify it. |
| |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::BracketAccessorNode::emitCode): |
| * kjs/nodes.h: |
| (KJS::BracketAccessorNode::): |
| |
| 2008-06-04 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Big cleanup of formatting and whitespace. |
| |
| 2008-06-04 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Add an option to dump statistics on executed instructions. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.cpp: |
| (KJS::OpcodeStats::~OpcodeStats): |
| (KJS::OpcodeStats::recordInstruction): |
| * VM/Opcode.h: |
| |
| 2008-06-04 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Geoff. |
| |
| <rdar://problem/5969992> JSProfiler: Remove the recursion limit in the |
| profiler. |
| - This patch removes the use of recursion for the sort functions. |
| |
| * JavaScriptCore.exp: Change the signatures of the functions being |
| exported. |
| * profiler/Profile.cpp: |
| (KJS::Profile::sort): This generic function will accept any of the |
| static sort functions and apply them to the whole tree. |
| * profiler/Profile.h: All of the sorting functions now call the new |
| sort() function. |
| (KJS::Profile::sortTotalTimeDescending): |
| (KJS::Profile::sortTotalTimeAscending): |
| (KJS::Profile::sortSelfTimeDescending): |
| (KJS::Profile::sortSelfTimeAscending): |
| (KJS::Profile::sortCallsDescending): |
| (KJS::Profile::sortCallsAscending): |
| (KJS::Profile::sortFunctionNameDescending): |
| (KJS::Profile::sortFunctionNameAscending): |
| * profiler/ProfileNode.cpp: |
| (KJS::ProfileNode::ProfileNode): m_head used to point to the head node |
| if this was the head node. It now points to null to make iteration easy |
| (KJS::ProfileNode::willExecute): Now must check if m_head is null, this |
| check used to happend in the constructor. |
| (KJS::ProfileNode::stopProfiling): Again the check is slightly different |
| to determine if this is the head. |
| (KJS::ProfileNode::traverseNextNode): This function returns the next |
| node in post order. |
| (KJS::ProfileNode::sort): This generic function will sort according to |
| the comparator passed in, then reset the children pointers to macth the |
| new order. |
| * profiler/ProfileNode.h: The sorting function were removed from the |
| definition file and instead use the new generic sort() function |
| (KJS::ProfileNode::totalPercent): because the head can now be empty we |
| need to check here too for the head node. |
| (KJS::ProfileNode::selfPercent): Ditto |
| (KJS::ProfileNode::firstChild): This function is necessary for the |
| iterative algorithm in Profile.cpp. |
| (KJS::ProfileNode::sortTotalTimeDescending): |
| (KJS::ProfileNode::sortTotalTimeAscending): |
| (KJS::ProfileNode::sortSelfTimeDescending): |
| (KJS::ProfileNode::sortSelfTimeAscending): |
| (KJS::ProfileNode::sortCallsDescending): |
| (KJS::ProfileNode::sortCallsAscending): |
| (KJS::ProfileNode::sortFunctionNameDescending): |
| (KJS::ProfileNode::sortFunctionNameAscending): |
| (KJS::ProfileNode::childrenBegin): |
| (KJS::ProfileNode::childrenEnd): |
| (KJS::ProfileNode::totalTimeDescendingComparator): |
| (KJS::ProfileNode::totalTimeAscendingComparator): |
| (KJS::ProfileNode::selfTimeDescendingComparator): |
| (KJS::ProfileNode::selfTimeAscendingComparator): |
| (KJS::ProfileNode::callsDescendingComparator): |
| (KJS::ProfileNode::callsAscendingComparator): |
| (KJS::ProfileNode::functionNameDescendingComparator): |
| (KJS::ProfileNode::functionNameAscendingComparator): |
| |
| 2008-06-04 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Fix JSClassCreate to work with old JSCore API threading model. |
| |
| No change on SunSpider. |
| |
| * API/JSClassRef.cpp: (OpaqueJSClass::OpaqueJSClass): Since JSClass is constructed without |
| a context, there is no way for it to create Identifiers. |
| Also, added initializeThreading(), just for good measure. |
| |
| * API/JSCallbackObjectFunctions.h: (KJS::::getPropertyNames): Make an Identifier out of the |
| string here, because propertyNames.add() needs that. |
| |
| * kjs/identifier.cpp: |
| * kjs/identifier.h: |
| (KJS::Identifier::equal): |
| * kjs/ustring.cpp: |
| (KJS::equal): |
| Moved equal() from identifier.h to ustring.h, because it's not really about Identifiers, |
| and to make it possible to use it from StrHash. |
| Include StrHash.h from ustring.h to avoid having the behavior depend on headers that happen |
| to be included. |
| |
| * wtf/StrHash.h: Removed. |
| * kjs/ustring.h: Made RefPtr<UString::Rep> use the same default hash as UString::Rep* (it |
| used to default to pointer equality). Moved the whole StrHash header into ustring.h. |
| |
| * JavaScriptCore.exp: Export equal() for WebCore use (this StrHash is used in c_class.cpp, |
| jni_class.cpp, and npruntime.cpp). |
| |
| 2008-06-04 Alexey Proskuryakov <ap@webkit.org> |
| |
| Rubber-stamped by Darin. |
| |
| Fix spacing in collector.{h,cpp}. |
| |
| * kjs/collector.cpp: |
| * kjs/collector.h: |
| |
| 2008-06-03 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Build fix. The cleanup in r34355 missed a method. |
| |
| * kjs/nodes.cpp: |
| * kjs/nodes.h: |
| |
| 2008-06-03 Darin Adler <darin@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - https://bugs.webkit.org/show_bug.cgi?id=19269 |
| speed up SunSpider by eliminating the toObject call for most get/put/delete |
| |
| Makes standalone SunSpider 1.025x as fast as before. |
| |
| The getOwnPropertySlot virtual function now takes care of the toObject call |
| for get. Similarly, the put function (and later deleteProperty) does the |
| same for those operations. To do this, the virtual functions were moved from |
| the JSObject class to the JSCell class. Also, since the caller no longer knows |
| the identity of the "original object", which is used by JavaScript-function |
| based getters, changed the PropertySlot class so the original object is |
| already stored in the slot when getOwnPropertySlot is called, if the caller |
| intends to call getValue. |
| |
| This affected the old interpreter code enough that the easiest thing for me |
| was to just delete it. While I am not certain the mysterious slowdown is not |
| still occurring, the net change is definitely a significant speedup. |
| |
| * JavaScriptCore.exp: Updated. |
| |
| * VM/Machine.cpp: Moved the UNLIKELY macro into AlwaysInline.h. |
| (KJS::resolve): Set up the originalObject in the PropertySlot before |
| calling getPropertySlot. Also removed the originalObject argument from |
| getValue. |
| (KJS::resolve_skip): Ditto. |
| (KJS::resolveBaseAndProperty): Ditto. |
| (KJS::resolveBaseAndFunc): Ditto. |
| (KJS::Machine::privateExecute): Removed the toObject calls from the get and |
| put functions where possible, instead calling directly with JSValue and letting |
| the JSValue and JSCell calls handle toObject. Same for toThisObject. |
| |
| * kjs/ExecState.h: Removed OldInterpreterExecState. |
| |
| * API/JSBase.cpp: Updated includes. |
| |
| * kjs/LocalStorageEntry.h: Removed contents. Later we can remove the file too. |
| |
| * kjs/array_instance.cpp: |
| (KJS::ArrayInstance::lengthGetter): Removed originalObject argumet. |
| (KJS::ArrayInstance::inlineGetOwnPropertySlot): Don't pass a base value to |
| setValueSlot. Also use UNLIKELY around the "getting elements past the end of |
| the array" code path; less common than successfully getting an element. |
| |
| * kjs/array_object.cpp: |
| (KJS::getProperty): Initialize the PropertySlot with the original object. |
| Don't pass the original object to the get function. |
| (KJS::arrayProtoFuncFilter): Ditto. |
| (KJS::arrayProtoFuncMap): Ditto. |
| (KJS::arrayProtoFuncEvery): Ditto. |
| (KJS::arrayProtoFuncForEach): Ditto. |
| (KJS::arrayProtoFuncSome): Ditto. |
| |
| * kjs/function_object.cpp: |
| (KJS::FunctionObjectImp::construct): Removed an obsolete comment. |
| |
| * kjs/grammar.y: Eliminated support for some of the node types that were |
| used to optimize executing from the syntax tree. |
| |
| * kjs/internal.cpp: |
| (KJS::StringImp::toThisObject): Added. Same as toObject. |
| (KJS::NumberImp::toThisObject): Ditto. |
| (KJS::GetterSetterImp::getOwnPropertySlot): Added. Not reached. |
| (KJS::GetterSetterImp::put): Ditto. |
| (KJS::GetterSetterImp::toThisObject): Ditto. |
| |
| * kjs/internal.h: Added toThisObject to NumberImp for speed. |
| |
| * kjs/lexer.cpp: |
| (KJS::Lexer::shift): Changed shift to just do a single character, to unroll |
| the loop and especially to make the one character case faster. |
| (KJS::Lexer::setCode): Call shift multiple times instead of passing a number. |
| (KJS::Lexer::lex): Ditto. |
| (KJS::Lexer::matchPunctuator): Ditto. Also removed unneeded elses after returns. |
| (KJS::Lexer::scanRegExp): Ditto. |
| * kjs/lexer.h: Removed the count argument from shift. |
| |
| * kjs/math_object.cpp: |
| (KJS::mathProtoFuncPow): Call jsNaN instead of jsNumber(NaN). |
| |
| * kjs/nodes.cpp: Removed some of the things needed only for the pre-SquirrelFish |
| execution model. |
| (KJS::ForNode::emitCode): Handle cases where some expressions are missing by |
| not emitting any code at all. The old way was to emit code for "true", but |
| this is an unnecessary remnant of the old way of doing things. |
| |
| * kjs/nodes.h: Removed some of the things needed only for the pre-SquirrelFish |
| execution model. |
| |
| * kjs/object.cpp: |
| (KJS::JSObject::fillGetterPropertySlot): Changed to only pass in the getter |
| function. The old code passed in a base, but it was never used when |
| actually getting the property; the toThisObject call was pointless. Also |
| changed to not pass a base for setUndefined. |
| |
| * kjs/object.h: Added the new JSCell operations to GetterSetterImp. |
| Never called. |
| (KJS::JSObject::get): Initialize the object in the PropertySlot and don't |
| pass it in getValue. |
| (KJS::JSObject::getOwnPropertySlotForWrite): Removed the base argument |
| in calls to setValueSlot. |
| (KJS::JSObject::getOwnPropertySlot): Ditto. |
| (KJS::JSValue::get): Added. Here because it calls through to JSObject. |
| A version of JSObject::get that also handles the other types of JSValue |
| by creating the appropriate wrapper. Saves the virtual call to toObject. |
| (KJS::JSValue::put): Ditto. |
| (KJS::JSValue::deleteProperty): Ditto. |
| |
| * kjs/property_slot.cpp: |
| (KJS::PropertySlot::undefinedGetter): Removed the originalObject argument. |
| (KJS::PropertySlot::ungettableGetter): Ditto. |
| (KJS::PropertySlot::functionGetter): Ditto. Use the value in the base |
| as the "this" object, which will be set to the original object by the new |
| PropertySlot initialization code. Also call toThisObject. The old code did |
| not do this, but needed to so we can properly handle the activation object |
| like the other similar code paths. |
| |
| * kjs/property_slot.h: |
| (KJS::PropertySlot::PropertySlot): Added a constructor that takes a base |
| object. In debug builds, set the base to 0 if you don't pass one. |
| (KJS::PropertySlot::getValue): Don't take or pass the originalObject. |
| (KJS::PropertySlot::setValueSlot): Don't take a base object, and clear the |
| base object in debug builds. |
| (KJS::PropertySlot::setGetterSlot): Ditto. |
| (KJS::PropertySlot::setUndefined): Ditto. |
| (KJS::PropertySlot::setUngettable): Ditto. |
| (KJS::PropertySlot::slotBase): Assert that a base object is present. |
| This will fire if someone actually calls the get function without having |
| passed in a base object and the getter needs it. |
| (KJS::PropertySlot::setBase): Added. Used by the code that implements |
| toObject so it can supply the original object after the fact. |
| (KJS::PropertySlot::clearBase): Added. Clears the base, but is debug-only |
| code because it's an error to fetch the base if you don't have a guarantee |
| it was set. |
| |
| * API/JSCallbackObject.h: |
| * API/JSCallbackObjectFunctions.h: |
| (KJS::JSCallbackObject::cachedValueGetter): |
| (KJS::JSCallbackObject::staticValueGetter): |
| (KJS::JSCallbackObject::staticFunctionGetter): |
| (KJS::JSCallbackObject::callbackGetter): |
| * kjs/JSActivation.cpp: |
| (KJS::JSActivation::getOwnPropertySlot): |
| (KJS::JSActivation::argumentsGetter): |
| * kjs/JSActivation.h: |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::symbolTableGet): |
| * kjs/array_instance.h: |
| * kjs/function.cpp: |
| (KJS::FunctionImp::argumentsGetter): |
| (KJS::FunctionImp::callerGetter): |
| (KJS::FunctionImp::lengthGetter): |
| (KJS::Arguments::mappedIndexGetter): |
| * kjs/function.h: |
| * kjs/lookup.h: |
| (KJS::staticFunctionGetter): |
| (KJS::staticValueGetter): |
| * kjs/string_object.cpp: |
| (KJS::StringInstance::lengthGetter): |
| (KJS::StringInstance::indexGetter): |
| (KJS::stringInstanceNumericPropertyGetter): |
| * kjs/string_object.h: |
| Removed originalObject arguments from getters. Don't pass base values to |
| the various PropertySlot functions that no longer take them. |
| |
| * kjs/value.cpp: |
| (KJS::JSCell::getOwnPropertySlot): Added. Calls toObject and then sets the slot. |
| This function has to always return true, because the caller can't walk the prototype |
| chain. Because of that, we do a getPropertySlot, not getOwnPropertySlot, which works |
| for the caller. This is private, only called by getOwnPropertySlotInternal. |
| (KJS::JSCell::put): Added. Calls toObject and then put. |
| (KJS::JSCell::toThisObject): Added. Calls toObject. |
| |
| * kjs/value.h: Added get, put, and toThisObject to both JSValue |
| and JSCell. These take care of the toObject operation without an additional virtual |
| function call, and so make the common "already an object" case faster. |
| |
| * wtf/AlwaysInline.h: Moved the UNLIKELY macro here for now. Maybe we can find a |
| better place later, or rename this header. |
| |
| 2008-06-03 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Tim. |
| |
| Bug 12983: Web Inspector break on the debugger keyword |
| <https://bugs.webkit.org/show_bug.cgi?id=12983> |
| |
| Added a DebuggerStatementNode to handle codegen, and added a new |
| DidReachBreakPoint debug event (which will hopefully be useful |
| if we ever move breakpoint management into JSC proper). Also |
| added didReachBreakpoint to Debugger to allow us to actually respond |
| to this event. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::debugHookName): |
| * VM/Machine.cpp: |
| (KJS::Machine::debug): |
| * VM/Machine.h: |
| * kjs/debugger.h: |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::DebuggerStatementNode::emitCode): |
| (KJS::DebuggerStatementNode::execute): |
| * kjs/nodes.h: |
| (KJS::DebuggerStatementNode::): |
| * kjs/nodes2string.cpp: |
| (KJS::DebuggerStatementNode::streamTo): |
| |
| 2008-06-03 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - document remaining opcodes. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): Document call, call_eval, |
| construct, ret and end opcodes. |
| |
| 2008-06-03 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): Document throw and catch opcodes. |
| |
| 2008-06-02 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Alexey Proskuryakov. |
| |
| Removed JSObject::call, since it just called JSObject::callAsFunction. |
| |
| SunSpider reports no change. |
| |
| 2008-06-02 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| A little cleanup in the CodeGenerator. |
| |
| * VM/CodeGenerator.cpp: A few changes here. |
| |
| (1) Removed remaining cases of the old hack of putting "this" into the |
| symbol table; replaced with explicit tracking of m_thisRegister. |
| |
| (2) Made m_thisRegister behave the same for function, eval, and program |
| code, removing the static programCodeThis() function. |
| |
| (3) Added a feature to nix a ScopeNode's declaration stacks when done |
| compiling, to save memory. |
| |
| (4) Removed code that copied eval declarations into special vectors: we |
| just use the originals in the ScopeNode now. |
| |
| * VM/CodeGenerator.h: Removed unneded parameters from the CodeGenerator |
| constructor: we just use get that data from the ScopeNode now. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): When executing an eval node, don't iterate a |
| special copy of its declarations; iterate the originals, instead. |
| |
| * kjs/nodes.cpp: Moved responsibility for knowing what AST data to throw |
| away into the CodeGenerator. Nodes no longer call shrinkCapacity on |
| their data directly. |
| |
| * kjs/nodes.h: Changed FunctionStack to ref its contents, so declaration |
| data stays around even after we've thrown away the AST, unless we explicitly |
| throw away the declaration data, too. This is useful for eval code, which |
| needs to reference its declaration data at execution time. (Soon, it will |
| be useful for program code, too, since program code should do the same.) |
| |
| 2008-06-02 Adam Roben <aroben@apple.com> |
| |
| Build fix for non-AllInOne builds |
| |
| * kjs/array_object.cpp: Added a missing #include. |
| |
| 2008-06-02 Kevin McCullough <kmccullough@apple.com> |
| |
| Took out accidental confilct lines I checked in. |
| |
| * ChangeLog: |
| |
| 2008-06-02 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Darin. |
| |
| <rdar://problem/5969992> JSProfiler: Remove the recursion limit in the |
| profiler |
| Implement Next Sibling pointers as groundwork for removing the recursion |
| limit in the profiler. |
| |
| * profiler/ProfileNode.cpp: Also I renamed parentNode and headNode since |
| 'node' is redundant. |
| (KJS::ProfileNode::ProfileNode): Initialize the nextSibling. |
| (KJS::ProfileNode::willExecute): If there are already children then the |
| new child needs to be the nextSibling of the last child. |
| (KJS::ProfileNode::didExecute): |
| (KJS::ProfileNode::addChild): Ditto. |
| (KJS::ProfileNode::stopProfiling): |
| (KJS::ProfileNode::sortTotalTimeDescending): For all of the sorting |
| algorithms once the children are sorted their nextSibling pointers need |
| to be reset to reflect the new order. |
| (KJS::ProfileNode::sortTotalTimeAscending): |
| (KJS::ProfileNode::sortSelfTimeDescending): |
| (KJS::ProfileNode::sortSelfTimeAscending): |
| (KJS::ProfileNode::sortCallsDescending): |
| (KJS::ProfileNode::sortCallsAscending): |
| (KJS::ProfileNode::sortFunctionNameDescending): |
| (KJS::ProfileNode::sortFunctionNameAscending): |
| (KJS::ProfileNode::resetChildrensSiblings): This new function simply |
| loops over all of the children and sets their nextSibling pointers to |
| the next child in the Vector |
| (KJS::ProfileNode::debugPrintData): |
| * profiler/ProfileNode.h: |
| (KJS::ProfileNode::parent): |
| (KJS::ProfileNode::setParent): |
| (KJS::ProfileNode::nextSibling): |
| (KJS::ProfileNode::setNextSibling): |
| (KJS::ProfileNode::totalPercent): |
| (KJS::ProfileNode::selfPercent): |
| |
| 2008-06-02 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Removed the recursion limit from JSObject::call, since the VM does |
| recursion checking now. |
| |
| This should allow us to remove JSObject::call entirely, netting a small |
| speedup. |
| |
| * kjs/object.cpp: |
| (KJS::JSObject::call): |
| |
| 2008-06-02 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Adele Peterson. |
| |
| Added a specific affordance for avoiding stack overflow when converting |
| recursive arrays to string, in preparation for removing generic stack |
| overflow checking from JSObject::call. |
| |
| Tested by fast/js/toString-stack-overflow.html. |
| |
| 2008-06-02 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Alice Liu. |
| |
| Refactored some hand-rolled code to call ScopeChain::globalObject instead. |
| |
| 2008-06-02 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Fixed ASSERT due to execution continuing after an exception is thrown |
| during array sort. |
| |
| * kjs/array_instance.cpp: |
| (KJS::AVLTreeAbstractorForArrayCompare::compare_key_key): Don't call the |
| custom comparator function if an exception has been thrown. Just return |
| 1 for everything, so the sort completes quickly. (The result will be |
| thrown away.) |
| |
| 2008-05-30 Timothy Hatcher <timothy@apple.com> |
| |
| Made the starting line number of scripts be 1-based throughout the engine. |
| This cleans up script line numbers so they are all consistent now and fixes |
| some cases where script execution was shown as off by one line in the debugger. |
| |
| No change in SunSpider. |
| |
| Reviewed by Oliver Hunt. |
| |
| * API/minidom.c: |
| (main): Pass a line number of 1 instead of 0 to parser().parse(). |
| * API/testapi.c: |
| (main): Ditto. And removes a FIXME and changed an assertEqualsAsNumber |
| to use 1 instead of 2 for the line number. |
| * VM/Machine.cpp: |
| (KJS::callEval): Pass a line number of 1 instead of 0. |
| (KJS::Machine::debug): Use firstLine for WillExecuteProgram instead of |
| lastLine. Use lastLine for DidExecuteProgram instead of firstLine. |
| * kjs/DebuggerCallFrame.cpp: |
| (KJS::DebuggerCallFrame::evaluate): Pass a line number of 1 instead of |
| 0 to parser().parse(). |
| * kjs/Parser.cpp: |
| (KJS::Parser::parse): ASSERT startingLineNumber is greatter than 0. Change |
| the startingLineNumber to be 1 if it was less than or equal to 0. This is needed |
| for release builds to maintain compatibility with the JavaScriptCore API. |
| * kjs/function.cpp: |
| (KJS::globalFuncEval): Pass a line number of 1 instead of 0 to parser().parse(). |
| * kjs/function_object.cpp: |
| (FunctionObjectImp::construct): Pass a line number of 1 instead of 0 to construct(). |
| * kjs/lexer.cpp: |
| (Lexer::setCode): Made yylineno = startingLineNumber instead of adding 1. |
| * kjs/testkjs.cpp: |
| (functionRun): Pass a line number of 1 instead of 0 to Interpreter::evaluate(). |
| (functionLoad): Ditto. |
| (prettyPrintScript): Ditto. |
| (runWithScripts): Ditto. |
| * profiler/Profiler.cpp: |
| (WebCore::createCallIdentifier): Removed a plus 1 of startingLineNumber. |
| |
| 2008-05-30 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=19180 |
| speed up SunSpider by optimizing immediate number cases |
| |
| Also fixed a JavaScriptCore regression seen on PowerPC - we didn't clip left shift |
| parameter to 0...31. |
| |
| 0.5% improvement on SunSpider overall, although a 8.5 regression on bitops-3bit-bits-in-byte. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| * kjs/JSImmediate.h: |
| (KJS::JSImmediate::toTruncatedUInt32): Added. Same as getTruncatedInt32, but casts the result |
| to unsigned. |
| |
| 2008-05-30 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Oliver Hunt. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=19180 |
| speed up SunSpider by optimizing immediate number cases |
| |
| Also fixed two JavaScriptCore regressions seen on PowerPC - we didn't clip right shift |
| parameter to 0...31. |
| |
| 1.6% improvement on SunSpider, without significant regressions on any tests. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| Added fast paths for >>, ==, ===, !=, !==. Changed order of memory accesses in many |
| cases, making them less dependent on gcc's ability to properly assign registers. With this, |
| I could move exception checks back into slow code paths, and saw less randomness in general. |
| |
| * kjs/JSImmediate.h: |
| (KJS::JSImmediate::rightShiftImmediateNumbers): |
| Added. |
| |
| 2008-05-29 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fixed <rdar://problem/5972943> REGRESSION(r33979): Flash clips do not play on cnn.com |
| |
| Finally blocks could clobber registers that had to remain live |
| until they returned. This patch takes a conservative approach and |
| makes sure that finally blocks do not reuse any registers that |
| were previously allocated for the function. In the future this |
| could probably be tightened up to be less profligate with the |
| register allocation. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::highestUsedRegister): |
| * VM/CodeGenerator.h: |
| * kjs/nodes.cpp: |
| (KJS::TryNode::emitCode): |
| |
| 2008-05-29 Steve Falkenburg <sfalken@apple.com> |
| |
| Build fix. |
| |
| * kjs/array_instance.cpp: |
| |
| 2008-05-29 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=19294 |
| <rdar://problem/5969062> A crash when iterating over a sparse array backwards. |
| |
| * kjs/array_instance.cpp: Turned sparseArrayCutoff into a macro, so that using max() on it |
| doesn't cause a PIC branch. |
| (KJS::ArrayInstance::increaseVectorLength): Added a comment about this function not |
| preserving class invariants. |
| (KJS::ArrayInstance::put): Update m_storage after reallocation. Move values that fit to |
| the vector from the map in all code paths. |
| |
| 2008-05-29 Thiago Macieira <tjmaciei@trolltech.com> |
| |
| Reviewed by Simon. |
| |
| Fix compilation in Solaris with Sun CC |
| |
| Lots of WebKit code uses C99 functions that, strict as it |
| is, the Solaris system doesn't provide in C++. So we must define them |
| for both GCC and the Sun CC. |
| |
| * wtf/MathExtras.h: |
| |
| 2008-05-28 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Anders. |
| |
| Fix codegen for assignment being used as a function. |
| |
| FunctionCallValueNode::emitCode failed to account for the |
| potential of the function expression to allocate arbitrary |
| registers. |
| |
| * kjs/nodes.cpp: |
| (KJS::FunctionCallValueNode::emitCode): |
| |
| 2008-05-27 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Tim Hatcher. |
| |
| Fixed https://bugs.webkit.org/show_bug.cgi?id=19183 |
| REGRESSION (r33979): Crash in DebuggerCallFrame::functionName when |
| clicking button in returnEvent-crash.html |
| |
| Added two new debugger hooks, willExecuteProgram and didExecuteProgram, |
| along with code to generate them, code to invoke them when unwinding |
| due to an exception, and code to dump them. |
| |
| SunSpider reports no change. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::debugHookName): I had to mark this function NEVER_INLINE to avoid |
| a .4% performance regression. The mind boggles. |
| |
| 2008-05-28 Adam Roben <aroben@apple.com> |
| |
| Fix JavaScriptCore tests on OS X |
| |
| We were quoting the path to testkjs too late, after it had already |
| been combined with spaces and other options. |
| |
| * tests/mozilla/jsDriver.pl: |
| (top level): Move path quoting from here... |
| (sub get_kjs_engine_command): ...to here. |
| |
| 2008-05-28 Anders Carlsson <andersca@apple.com> |
| |
| Reviewed by Oliver. |
| |
| <rdar://problem/5968071> "const f" crashes in JavaScriptCore |
| |
| Make sure to null check the initializer. |
| |
| * kjs/nodes.cpp: |
| (KJS::ConstDeclNode::emitCodeSingle): |
| |
| 2008-05-28 Adam Roben <aroben@apple.com> |
| |
| Make run-javascriptcore-tests work with a space in the path to testkjs |
| |
| Reviewed by Alexey Proskuryakov. |
| |
| * tests/mozilla/jsDriver.pl: Quote the path to the engine so that |
| spaces will be interpreted correctly. |
| |
| 2008-05-28 Alexey Proskuryakov <ap@webkit.org> |
| |
| Fixed a misguiding comment - my measurement for negative numbers only included cases |
| where both operands were negative, which is not very interesting. |
| |
| * VM/Machine.cpp: |
| |
| 2008-05-28 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Based on a patch by Oliver Hunt. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=19180 |
| speed up SunSpider by optimizing immediate number cases |
| |
| 1.4% speedup on SunSpider. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * kjs/JSImmediate.h: |
| (KJS::JSImmediate::incImmediateNumber): |
| (KJS::JSImmediate::decImmediateNumber): |
| Added fast paths for ++ and --. |
| |
| (KJS::JSImmediate::canDoFastAdditiveOperations): Corrected a comment. |
| |
| 2008-05-28 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=19180 |
| speed up SunSpider by optimizing immediate number cases |
| |
| 2% speedup overall, maximum 10% on controlflow-recursive and bitops-3bit-bits-in-byte, |
| but a 4% regression on bitops-bits-in-byte and bitops-bitwise-and. |
| |
| * kjs/JSImmediate.h: |
| (KJS::JSImmediate::canDoFastAdditiveOperations): |
| (KJS::JSImmediate::addImmediateNumbers): |
| (KJS::JSImmediate::subImmediateNumbers): |
| Added fast cases that work with positive values less than 2^30. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): Use the above operations. Also updated SunSpider frequencies |
| with my results (looks like tag values have changed, not sure what caused the minor variation |
| in actual frequencies). |
| |
| 2008-05-27 Adam Roben <aroben@apple.com> |
| |
| Windows build fix |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCoreGenerated.make: |
| Remove code that appended Cygwin's /bin directory to PATH. |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCoreGenerated.vcproj: |
| Prepend Cygwin's /bin directory to PATH. We prepend instead of append |
| so that Cygwin's utilities will win out over Win32 versions of the |
| same utilities (particularly perl). We do the prepend here instead of |
| in the Makefile because nmake doesn't seem to like prepending to PATH |
| inside the Makefile. This also matches the way WebCoreGenerated works. |
| |
| 2008-05-27 Adam Roben <aroben@apple.com> |
| |
| Roll out r34163 |
| |
| A better fix is on the way. |
| |
| * DerivedSources.make: |
| * JavaScriptCore.vcproj/JavaScriptCore/build-generated-files.sh: |
| |
| 2008-05-27 Adam Roben <aroben@apple.com> |
| |
| Windows build fix |
| |
| * DerivedSources.make: Don't generate the bytecode docs if |
| OMIT_BYTECODE_DOCS is set to 1. |
| * JavaScriptCore.vcproj/JavaScriptCore/build-generated-files.sh: Set |
| OMIT_BYTECODE_DOCS for production builds. |
| |
| 2008-05-27 Anders Carlsson <andersca@apple.com> |
| |
| Reviewed by Geoff and Maciej. |
| |
| <rdar://problem/5806428> |
| https://bugs.webkit.org/show_bug.cgi?id=17925 |
| Crash in KJS::JSObject::put after setting this.__proto__ |
| |
| Set slotIsWriteable to false for __proto__, we want setting __proto__ to go through JSObject::put instead. |
| |
| * kjs/object.h: |
| (KJS::JSObject::getOwnPropertySlotForWrite): |
| |
| 2008-05-27 Kevin Ollivier <kevino@theolliviers.com> |
| |
| wx build fixes to catch up with SquirrelFish, etc. |
| |
| * JavaScriptCoreSources.bkl: |
| * jscore.bkl: |
| * wtf/Platform.h: |
| |
| 2008-05-27 Darin Adler <darin@apple.com> |
| |
| Reviewed by Tim Hatcher. |
| |
| - https://bugs.webkit.org/show_bug.cgi?id=19180 |
| speed up SunSpider by optimizing immediate number cases |
| |
| Add immediate number cases for the &, |, and ^ operators. |
| Makes standalone SunSpider 1.010x faster. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): Add areBothImmediateNumbers special cases |
| for the &, |, and ^ operators. |
| |
| * kjs/JSImmediate.h: |
| (KJS::JSImmediate::xorImmediateNumbers): Added. |
| (KJS::JSImmediate::orImmediateNumbers): Added. |
| |
| 2008-05-26 Stephanie Lewis <slewis@apple.com> |
| |
| Windows build fix. |
| |
| * kjs/testkjs.cpp: |
| |
| 2008-05-26 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Anders. |
| |
| - make addStaticGlobals protected instead of private so subclasses can use it |
| |
| * JavaScriptCore.exp: |
| * kjs/JSGlobalObject.h: |
| |
| 2008-05-26 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Fixed <rdar://problem/5960859> After an eval of a non-string or a syntax |
| error, all profile stack frames are incorrect |
| |
| SunSpider reports a .3% speedup, possibly because eval of a string is a |
| little more efficient now. |
| |
| * VM/Machine.cpp: |
| (KJS::callEval): Make sure to call didExecute when returning early. I |
| simplified this function to remove one early return, making the job |
| of adding special code to early returns easier. |
| |
| (KJS::Machine::execute): Use the new function ExecState when notifying |
| the profiler. (This doesn't change behavior now, but it might prevent |
| subtle errors in the future.) |
| |
| 2008-05-23 Tor Arne Vestbø <tavestbo@trolltech.com> |
| |
| Reviewed by Simon. |
| |
| Fixed toLower and toUpper implementations to allow being called |
| with a null result pointer and resultLength, to determine the |
| number of characters needed for the case conversion. |
| |
| * wtf/unicode/qt4/UnicodeQt4.h: |
| (WTF::Unicode::toLower): |
| (WTF::Unicode::toUpper): |
| |
| 2008-05-25 Alexey Proskuryakov <ap@webkit.org> |
| |
| Fixing a typo in the previous commit made as a last minute change. |
| |
| * kjs/regexp_object.cpp: |
| |
| 2008-05-24 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Changed regular expression matching result array to be lazily filled, because many callers |
| only care about it being non-null. |
| |
| 2% improvement on Acid3 test 26. |
| |
| * kjs/array_instance.cpp: Added a void* member to ArrayStorage for ArrayInstance subclasses |
| to use. |
| * kjs/array_instance.h: |
| (KJS::ArrayInstance::lazyCreationData): |
| (KJS::ArrayInstance::setLazyCreationData): |
| Added methods to access it from subclasses. |
| |
| * kjs/regexp_object.cpp: |
| (KJS::RegExpMatchesArray::RegExpMatchesArray): |
| (KJS::RegExpMatchesArray::getOwnPropertySlot): |
| (KJS::RegExpMatchesArray::put): |
| (KJS::RegExpMatchesArray::deleteProperty): |
| (KJS::RegExpMatchesArray::getPropertyNames): |
| (KJS::RegExpMatchesArray::fillArrayInstanceIfNeeded): |
| (KJS::RegExpMatchesArray::~RegExpMatchesArray): |
| (KJS::RegExpObjectImp::arrayOfMatches): |
| RegExpMatchesArray is a subclass of ArrayInstance that isn't filled until |
| accessed for the first time. |
| |
| 2008-05-24 Alp Toker <alp@nuanti.com> |
| |
| Win32/gcc build fix. Remove MSVC assumption. |
| |
| * wtf/TCSpinLock.h: |
| (TCMalloc_SlowLock): |
| |
| 2008-05-24 Oleg Finkelshteyn <olegfink@gmail.com> |
| |
| Rubber-stamped, tweaked and landed by Alexey. |
| |
| Build fix for gcc 4.3. |
| |
| * JavaScriptCore/kjs/testkjs.cpp: |
| * JavaScriptCore/VM/CodeBlock.cpp: |
| Add missing standard includes. |
| |
| 2008-05-23 Anders Carlsson <andersca@apple.com> |
| |
| Reviewed by Geoff. |
| |
| <rdar://problem/5959886> REGRESSION: Assertion failure in JSImmediate::toString when loading GMail (19217) |
| |
| Change List to store a JSValue*** pointer + an offset instead of a JSValue** pointer to protect against the case where |
| a register file changes while a list object points to its buffer. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * kjs/JSActivation.cpp: |
| (KJS::JSActivation::createArgumentsObject): |
| * kjs/list.cpp: |
| (KJS::List::getSlice): |
| * kjs/list.h: |
| (KJS::List::List): |
| (KJS::List::at): |
| (KJS::List::append): |
| (KJS::List::begin): |
| (KJS::List::end): |
| (KJS::List::buffer): |
| |
| 2008-05-23 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Sam. |
| |
| <rdar://problem/5960012> JSProfiler: Stack overflow if recursion is |
| too deep. |
| -Use a simple depth limit to restrict too deep of recursion. |
| |
| * profiler/Profile.cpp: |
| (KJS::Profile::willExecute): |
| (KJS::Profile::didExecute): |
| * profiler/Profile.h: |
| |
| 2008-05-23 Geoffrey Garen <ggaren@apple.com> |
| |
| Rolling back in r34085, with performance resolved. |
| |
| Apparently, passing the eval function to callEval gave GCC a hernia. |
| |
| Reviewed by Darin Adler, Kevin McCullough, and Oliver Hunt. |
| |
| Fixed <rdar://problem/5959447> Crashes and incorrect reporting in the |
| JavaScript profiler |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::unwindCallFrame): Fixed incorrect reporting / a crash |
| when unwinding from inside eval and/or program code: detect the |
| difference, and do the right thing. Also, be sure to notify the profiler |
| *before* deref'ing the scope chain, since the profiler uses the scope chain. |
| |
| (KJS::Machine::execute): Fixed incorrect reporting / crash when calling |
| a JS function re-entrently: Machine::execute(FunctionBodyNode*...) |
| should not invoke the didExecute hook, because op_ret already does that. |
| Also, use the new function's ExecState when calling out to the profiler. |
| (Not important now, but could have become a subtle bug later.) |
| |
| (KJS::Machine::privateExecute): Fixed a hard to reproduce crash when |
| profiling JS functions: notify the profiler *before* deref'ing the scope |
| chain, since the profiler uses the scope chain. |
| |
| * kjs/object.cpp: |
| (KJS::JSObject::call): Removed these hooks, because they are now unnecessary. |
| |
| * profiler/Profile.cpp: Added a comment to explain a subtlety that only |
| Kevin and I understood previously. (Now, the whole world can understand!) |
| |
| * profiler/Profiler.cpp: |
| (KJS::shouldExcludeFunction): Don't exclude .call and .apply. That was |
| a hack to fix bugs that no longer exist. |
| |
| Finally, sped things up a little bit by changing the "Is the profiler |
| running?" check into an ASSERT, since we only call into the profiler |
| when it's running: |
| |
| (KJS::Profiler::willExecute): |
| (KJS::Profiler::didExecute): |
| |
| 2008-05-23 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| - fixed <rdar://problem/5957662> REGRESSION(r33943-r33980): Can't send email , attach file or save as draft from hotmail.com |
| |
| SunSpider reports no change. |
| |
| This is a reworking of r34073, which I rolled out because it caused |
| lots of crashes. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::CodeGenerator): Use removeDirect to nix old |
| properties whose names collide with new functions. (Don't use putWithAttributes |
| because that tries to write to the register file, which hasn't grown to |
| fit this program yet.) |
| |
| 2008-05-23 Darin Adler <darin@apple.com> |
| |
| Reviewed by Mark Rowe. |
| |
| As allocateNumber is used via jsNumberCell outside of JavaScriptCore, |
| we need to provide a non-inlined version of it to avoid creating a |
| weak external symbol. |
| |
| * JavaScriptCore.exp: |
| * kjs/AllInOneFile.cpp: |
| * kjs/collector.cpp: |
| (KJS::Collector::allocate): |
| (KJS::Collector::allocateNumber): |
| * kjs/collector.h: |
| (KJS::Collector::allocate): |
| (KJS::Collector::inlineAllocateNumber): |
| * kjs/value.h: |
| (KJS::NumberImp::operator new): |
| |
| 2008-05-23 Geoffrey Garen <ggaren@apple.com> |
| |
| Rolled out r34073 because it caused lots of layout test crashes. |
| |
| 2008-05-23 Geoffrey Garen <ggaren@apple.com> |
| |
| Rolled out r34085 because it measured as a 7.6% performance regression. |
| |
| 2008-05-23 Adam Roben <aroben@apple.com> |
| |
| Windows build fix |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Add the |
| profiler directory to the include path. |
| |
| 2008-05-23 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Anders. |
| |
| SQUIRRELFISH: JavaScript error messages are missing informative text |
| |
| Partial fix. |
| Tidy up error messages, makes a couple of them provide slightly more info. |
| Inexplicably leads to a 1% SunSpider Progression. |
| |
| * VM/ExceptionHelpers.cpp: |
| (KJS::createError): |
| (KJS::createInvalidParamError): |
| (KJS::createNotAConstructorError): |
| (KJS::createNotAFunctionError): |
| * VM/ExceptionHelpers.h: |
| * VM/Machine.cpp: |
| (KJS::isNotObject): |
| |
| 2008-05-23 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Tim H. |
| |
| Fix call stack reported by profiler when entering event handlers. |
| |
| JSObject::call was arbitrarily notifying the profiler when it was |
| called, even if it was JS code, which notifies the profile on entry |
| in any case. |
| |
| * kjs/object.cpp: |
| (KJS::JSObject::call): |
| |
| 2008-05-16 Alp Toker <alp@nuanti.com> |
| |
| Build fix for gcc 3. Default constructor required in ExecState, |
| used by OldInterpreterExecState. |
| |
| * kjs/ExecState.h: |
| (KJS::ExecState::ExecState): |
| |
| 2008-05-23 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fix <rdar://problem/5954997> global-recursion-on-full-stack.html crashes under guardmalloc. |
| |
| Growing the register file with uncheckedGrow from within Machine::execute is not safe as the |
| register file may be too close to its maximum size to grow successfully. By using grow, |
| checking the result and throwing a stack overflow error we can avoid crashing. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): |
| * VM/RegisterFile.h: Remove the now-unused uncheckedGrow. |
| |
| 2008-05-23 Oliver Hunt <oliver@apple.com> |
| |
| RS=Kevin McCullough |
| |
| Remove JAVASCRIPT_PROFILER define |
| |
| * VM/Machine.cpp: |
| (KJS::callEval): |
| (KJS::Machine::unwindCallFrame): |
| (KJS::Machine::execute): |
| (KJS::Machine::privateExecute): |
| * kjs/config.h: |
| * kjs/object.cpp: |
| (KJS::JSObject::call): |
| |
| 2008-05-23 Oliver Hunt <oliver@apple.com> |
| |
| <rdar://problem/5951561> Turn on JavaScript Profiler |
| |
| Reviewed by Kevin McCullough. |
| |
| Flipped the switch on the profiler, rearranged how we |
| signal the the profiler is active so that calls aren't |
| needed in the general case. |
| |
| Also fixed the entry point for Machine::execute(FunctionBodyNode..) |
| to correctly indicate function exit. |
| |
| Results in a 0.7-1.0% regression in SunSpider :-( |
| |
| * VM/Machine.cpp: |
| (KJS::callEval): |
| (KJS::Machine::unwindCallFrame): |
| (KJS::Machine::execute): |
| (KJS::Machine::privateExecute): |
| * kjs/config.h: |
| * profiler/Profiler.cpp: |
| (KJS::Profiler::profiler): |
| (KJS::Profiler::startProfiling): |
| (KJS::Profiler::stopProfiling): |
| * profiler/Profiler.h: |
| (KJS::Profiler::enabledProfilerReference): |
| |
| 2008-05-23 Simon Hausmann <hausmann@webkit.org> |
| |
| Fix the Qt build by adding profiler/ to the include search path. |
| |
| * JavaScriptCore.pri: |
| |
| 2008-05-22 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Adam. |
| |
| Fix a bug in the profiler where time in the current function is given to |
| (idle). |
| |
| * profiler/Profile.cpp: |
| (KJS::Profile::didExecute): Set the start time and then call didExecute |
| to calculate the time spent in this function. |
| * profiler/ProfileNode.cpp: Remove confusing calculations that are no |
| longer necessary. |
| (KJS::ProfileNode::insertNode): |
| * profiler/ProfileNode.h: Expose access to the start time to allow the |
| simpler time calculations above. |
| (KJS::ProfileNode::startTime): |
| (KJS::ProfileNode::setStartTime): |
| |
| 2008-05-22 Adam Roben <aroben@apple.com> |
| |
| Show "(Function object)" instead of "(JSInpectorCallbackWrapper |
| object)" in profiles |
| |
| Reviewed by Kevin McCullough. |
| |
| * profiler/Profiler.cpp: |
| (KJS::createCallIdentifier): Use JSObject::className instead of |
| getting the class name from the ClassInfo directly. JSObject |
| subclasses can override className to provide a custom class name, and |
| it seems like we should honor that. |
| |
| 2008-05-22 Timothy Hatcher <timothy@apple.com> |
| |
| Added Profile::restoreAll and added ProfileNode::restoreAll |
| to the export file. |
| |
| Reviewed by Adam Roben. |
| |
| * JavaScriptCore.exp: |
| * profiler/Profile.h: |
| |
| 2008-05-22 Alp Toker <alp@nuanti.com> |
| |
| GTK+ build fix. Add JavaScriptCore/profiler to include path. |
| |
| * GNUmakefile.am: |
| |
| 2008-05-22 Adam Roben <aroben@apple.com> |
| |
| Implement sub-millisecond profiling on Windows |
| |
| Reviewed by Kevin McCullough. |
| |
| * profiler/ProfileNode.cpp: |
| (KJS::getCount): Added. On Windows, we use QueryPerformanceCounter. On |
| other platforms, we use getCurrentUTCTimeWithMicroseconds. |
| (KJS::ProfileNode::endAndRecordCall): Use getCount instead of |
| getCurrentUTCTimeWithMicroseconds. |
| (KJS::ProfileNode::startTimer): Ditto. |
| |
| 2008-05-22 Adam Roben <aroben@apple.com> |
| |
| Fix a profiler assertion when calling a NodeList as a function |
| |
| Reviewed by Kevin McCullough. |
| |
| * profiler/Profiler.cpp: |
| (KJS::createCallIdentifier): Don't assert when a non-function object |
| is called as a function. Instead, build up a CallIdentifier using the |
| object's class name. |
| |
| 2008-05-22 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Darin. |
| |
| <rdar://problem/5951529> JSProfiler: Allow the profiler to "Exclude" a |
| profile node. |
| -Implement 'exclude'; where the excluded node attributes its time to its |
| parent's self time. |
| |
| * JavaScriptCore.exp: Export the exclude function. |
| * profiler/Profile.h: |
| (KJS::Profile::exclude): |
| * profiler/ProfileNode.cpp: |
| (KJS::ProfileNode::setTreeVisible): New function that allows a change in |
| visiblitiy to be propogated to all the children of a node. |
| (KJS::ProfileNode::exclude): If the node matches the callIdentifier then |
| set the visiblity of this node and all of its children to false and |
| attribute it's total time to it's caller's self time. |
| * profiler/ProfileNode.h: |
| |
| 2008-05-22 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fix access to static global variables in Windows release builds. |
| |
| * kjs/JSGlobalObject.h: Don't store a reference to an Identifier |
| in GlobalPropertyInfo as the Identifier is likely to be a temporary |
| and therefore may be destroyed before the GlobalPropertyInfo. |
| |
| 2008-05-22 Kevin McCullough <kmccullough@apple.com> |
| |
| Build fix. |
| |
| * VM/Machine.cpp: |
| (KJS::callEval): |
| |
| 2008-05-22 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Sam. |
| |
| <rdar://problem/5951561> Turn on JavaScript Profiler |
| Get basic JS profiling working. |
| Even with this patch the profiler will not be compiled in because we do |
| not know the extend, if any, of the performance regression it would cause |
| when it is not in use. However with these changes, if the profiler were |
| on, it would not crash and show good profiling data. |
| |
| * VM/Machine.cpp: Instrument the calls sites that are needed for profiling. |
| (KJS::callEval): |
| (KJS::Machine::unwindCallFrame): |
| (KJS::Machine::execute): |
| (KJS::Machine::privateExecute): |
| * kjs/function.cpp: Ditto. |
| (KJS::globalFuncEval): |
| * kjs/interpreter.cpp: Ditto. |
| (KJS::Interpreter::evaluate): |
| * profiler/Profile.cpp: |
| (KJS::Profile::willExecute): |
| (KJS::Profile::didExecute): Because we do not get a good context when |
| startProfiling is called it is possible that m_currentNode will be at the |
| top of the known stack when a didExecute() is called. What we then do is |
| create a new node that represents the function being exited and insert |
| it between the head and the currently known children, since they should |
| be children of this new node. |
| * profiler/ProfileNode.cpp: |
| (KJS::ProfileNode::ProfileNode): |
| (KJS::ProfileNode::willExecute): Rename the add function for consistency. |
| (KJS::ProfileNode::addChild): Appends the child to this node but also |
| sets the parent pointer of the children to this node. |
| (KJS::ProfileNode::insertNode): Insert a node between this node and its |
| children. Also set the time for the new node since it is now exiting |
| and we don't really know when it started. |
| (KJS::ProfileNode::stopProfiling): |
| (KJS::ProfileNode::startTimer): |
| * profiler/ProfileNode.h: |
| (KJS::CallIdentifier::toString): Added for debugging. |
| (KJS::ProfileNode::setParent): |
| (KJS::ProfileNode::setSelfTime): Fixed an old bug where we set the |
| visibleTotalTime not the visibleSelfTime. |
| (KJS::ProfileNode::children): |
| (KJS::ProfileNode::toString): Added for debugging. |
| * profiler/Profiler.cpp: remove unecessary calls. |
| (KJS::Profiler::startProfiling): |
| |
| 2008-05-22 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Oliver Hunt. |
| |
| Rename register arguments for op_call, op_call_eval, op_end, and op_construct |
| to document what they are for. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitCall): |
| (KJS::CodeGenerator::emitCallEval): |
| (KJS::CodeGenerator::emitEnd): |
| (KJS::CodeGenerator::emitConstruct): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-05-22 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Darin. |
| |
| Bug 19116: SquirrelFish shouldn't regress on variable lookups |
| <https://bugs.webkit.org/show_bug.cgi?id=19116> |
| |
| Last of the multiscope look up optimisations. This is a wash overall on SunSpider |
| but is a factor of 5-10 improvement in multiscope read/write/modify (eg. ++, --, +=, |
| ... applied to any non-local var). |
| |
| * kjs/nodes.cpp: |
| (KJS::PostIncResolveNode::emitCode): |
| (KJS::PostDecResolveNode::emitCode): |
| (KJS::PreIncResolveNode::emitCode): |
| (KJS::PreDecResolveNode::emitCode): |
| (KJS::ReadModifyResolveNode::emitCode): |
| |
| 2008-05-22 David Kilzer <ddkilzer@apple.com> |
| |
| <rdar://problem/5954233> Add method to release free memory from FastMalloc |
| |
| Patch suggested by Mark Rowe. Rubber-stamped by Maciej. |
| |
| * JavaScriptCore.exp: Export _releaseFastMallocFreeMemory. |
| * wtf/FastMalloc.cpp: |
| (WTF::TCMallocStats::): Added releaseFastMallocFreeMemory() for both |
| system malloc and FastMalloc code paths. |
| * wtf/FastMalloc.h: Define releaseFastMallocFreeMemory(). |
| |
| 2008-05-22 Oliver Hunt <oliver@apple.com> |
| |
| RS=Maciej. |
| |
| Roll out r34020 as it causes recursion tests to fail. |
| |
| * kjs/object.cpp: |
| (KJS::JSObject::call): |
| |
| 2008-05-22 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Mark. |
| |
| Don't leak the SymbolTable when compiling eval code. |
| |
| * kjs/nodes.cpp: |
| (KJS::EvalNode::generateCode): |
| |
| 2008-05-22 Simon Hausmann <hausmann@webkit.org> |
| |
| Reviewed by Oliver. |
| |
| Qt build fix. |
| |
| * JavaScriptCore.pri: Added DebuggerCallFrame to the build. |
| * VM/LabelID.h: Include limits.h for UINT_MAX. |
| * wtf/VectorTraits.h: Include memory for std::auto_ptr. |
| |
| 2008-05-22 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Adam Roben. |
| |
| Removed the old recursion guard mechanism, since squirrelfish has its |
| own mechanism. Also removed some old JS call tracing code, since we |
| have other ways to do that, too. |
| |
| SunSpider reports no change. |
| |
| * kjs/object.cpp: |
| (KJS::JSObject::call): |
| |
| 2008-05-22 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fixed <rdar://problem/5954979> crash on celtic kane JS benchmark |
| |
| * kjs/nodes.cpp: |
| (KJS::WithNode::emitCode): |
| (KJS::TryNode::emitCode): |
| |
| 2008-05-21 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Maciej and Geoff. |
| |
| <rdar://problem/5951561> Turn on JavaScript Profiler |
| -As part of the effort to turn on the profiler it would be helpful if it |
| did not need ExecStates to represent the stack location of the currently |
| executing statement. |
| -We now create each node as necessary with a reference to the current |
| node and each node knows its parent so that the tree can be made without |
| the entire stack. |
| |
| * profiler/Profile.cpp: |
| (KJS::Profile::Profile): The current node starts at the head. |
| (KJS::Profile::stopProfiling): The current node is cleared when profiling |
| stops. |
| (KJS::Profile::willExecute): The current node either adds a new child or |
| starts and returns a reference to an already existing child if the call |
| ID that is requested already exists. |
| (KJS::Profile::didExecute): The current node finishes and returns its |
| parent. |
| * profiler/Profile.h: Use a single callIdentifier instead of a vector |
| since we no longer use the whole stack. |
| * profiler/ProfileNode.cpp: Now profile nodes keep a reference to their |
| parent. |
| (KJS::ProfileNode::ProfileNode): Initialize the parent. |
| (KJS::ProfileNode::didExecute): Record the time and return the parent. |
| (KJS::ProfileNode::addOrStartChild): If the given callIdentifier is |
| already a child, start it and return it, otherwise create a new one and |
| return that. |
| (KJS::ProfileNode::stopProfiling): Same logic, just use the new function. |
| * profiler/ProfileNode.h: Utilize the parent. |
| (KJS::ProfileNode::create): |
| (KJS::ProfileNode::parent): |
| * profiler/Profiler.cpp: |
| (KJS::Profiler::startProfiling): Here is the only place where the |
| ExecState is used to figure out where in the stack the profiler is |
| currently profiling. |
| (KJS::dispatchFunctionToProfiles): Only send one CallIdentifier instead |
| of a vector of them. |
| (KJS::Profiler::willExecute): Ditto. |
| (KJS::Profiler::didExecute): Ditto. |
| (KJS::createCallIdentifier): Create only one CallIdentifier. |
| (KJS::createCallIdentifierFromFunctionImp): Ditto. |
| * profiler/Profiler.h: |
| |
| 2008-05-21 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - https://bugs.webkit.org/show_bug.cgi?id=19180 |
| speed up the < operator for the case when both values are integers |
| |
| Makes standalone SunSpider 1.022x faster. |
| |
| * VM/Machine.cpp: |
| (KJS::jsLess): Add a special case for when both are numbers that fit in a JSImmediate. |
| |
| 2008-05-21 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver and Sam. |
| |
| - fixed <rdar://problem/5815631> REGRESSION (r31239): Multiscope optimisation of function calls results in incorrect this value (breaks tvtv.de) |
| |
| Track global this value in the scope chain so we can retrieve it |
| efficiently but it follows lexical scope properly. |
| |
| * kjs/ExecState.h: |
| (KJS::ExecState::globalThisValue): |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::JSGlobalObjectData::JSGlobalObjectData): |
| * kjs/function_object.cpp: |
| (KJS::FunctionObjectImp::construct): |
| * kjs/scope_chain.h: |
| (KJS::ScopeChainNode::ScopeChainNode): |
| (KJS::ScopeChainNode::globalThisObject): |
| (KJS::ScopeChainNode::push): |
| (KJS::ScopeChain::ScopeChain): |
| |
| 2008-05-21 Kevin McCullough <kmccullough@apple.com> |
| |
| Sadness :( |
| |
| * kjs/config.h: |
| |
| 2008-05-21 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Maciej. |
| |
| <rdar://problem/5950867> JSProfiler: Allow the profiler to "Focus" a |
| profile node. |
| - This patch updatest the times of the visible nodes correctly, but to do |
| so, some of the design of the ProfileNode changed. |
| |
| * JavaScriptCore.exp: export focus' symbol. |
| * profiler/Profile.cpp: ProfileNodes now take a reference to the head of |
| the profile tree to get up-to-date accurate total profile time. |
| (KJS::Profile::Profile): Pass 0 for the head node. |
| (KJS::Profile::stopProfiling): stopProfiling no longer needs the time |
| passed into it, since it can get it from the head and it does not need to |
| be told it is the head because it can figure it out on it's own. |
| (KJS::Profile::willExecute): Set the head node for each created node. |
| * profiler/Profile.h: |
| (KJS::Profile::focus): Instead of taking a CallIdentifier that the caller |
| would have to create, now focus() takes a ProfileNode that they should |
| already have a reference to and focus() can extract the CallIdentifier |
| from it. |
| * profiler/ProfileNode.cpp: Create actual and visible versions fo the |
| total and self times for focus and exclude. Also add a head node |
| reference so that nodes can get information from their head. |
| (KJS::ProfileNode::ProfileNode): |
| (KJS::ProfileNode::stopProfiling): Rename the total and self time |
| variables and set the visual ones to the actual ones, so that without any |
| changes to the visual versions of these variables, their times will match |
| the actual times. |
| (KJS::ProfileNode::focus): Now focus() has a bool to force it's children |
| to be visible if this node is visible. If this node does not match the |
| CallIdentifier being focused then the visibleTotalTime is only updated if |
| one or more of it's children is the CallIdentifier being focused. |
| (KJS::ProfileNode::restoreAll): Restores all variables with respect to |
| the visible data in the ProfileNode. |
| (KJS::ProfileNode::endAndRecordCall): Name change. |
| (KJS::ProfileNode::debugPrintData): Dump the new variables. |
| (KJS::ProfileNode::debugPrintDataSampleStyle): Name change. |
| * profiler/ProfileNode.h: Use the new variables and reference to the head |
| node. |
| (KJS::ProfileNode::create): |
| (KJS::ProfileNode::totalTime): |
| (KJS::ProfileNode::setTotalTime): |
| (KJS::ProfileNode::selfTime): |
| (KJS::ProfileNode::setSelfTime): |
| (KJS::ProfileNode::totalPercent): |
| (KJS::ProfileNode::selfPercent): |
| (KJS::ProfileNode::setVisible): |
| |
| 2008-05-21 Alp Toker <alp@nuanti.com> |
| |
| GTK+/UNIX testkjs build fix. Include signal.h. |
| |
| * kjs/testkjs.cpp: |
| |
| 2008-05-21 Oliver Hunt <oliver@apple.com> |
| |
| Yet more windows build fixes |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| |
| 2008-05-21 Oliver Hunt <oliver@apple.com> |
| |
| Yet more windows build fixes |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| |
| 2008-05-21 Alp Toker <alp@nuanti.com> |
| |
| GTK+ build fix. Add DebuggerCallFrame.cpp and take AllInOneFile.cpp |
| changes into account. |
| |
| * GNUmakefile.am: |
| |
| 2008-05-21 Oliver Hunt <oliver@apple.com> |
| |
| Add DebuggerCallFrame.{h,cpp} to the project file |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| |
| 2008-05-21 Alp Toker <alp@nuanti.com> |
| |
| GTK+ port build fixes following squirrelfish merge r33979. |
| |
| * GNUmakefile.am: |
| |
| 2008-05-21 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Darin. |
| |
| - save a hash lookup wne writing to global properties |
| 0.3% speedup on SunSpider, 7% on bitops-bitwise-and |
| |
| * VM/Machine.cpp: |
| (KJS::resolveBase): Check for being a the end of the scope chain |
| before hash lookup. |
| |
| 2008-05-21 Alp Toker <alp@nuanti.com> |
| |
| Rubber-stamped by Maciej. |
| |
| Replace non-standard #pragma marks with comments to avoid compiler |
| warnings. |
| |
| * profiler/ProfileNode.cpp: |
| |
| 2008-05-21 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Mark Rowe. |
| |
| Fix layout test failure in fast/dom/getter-on-window-object2 introduced in r33961. |
| |
| * JavaScriptCore.exp: |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::defineGetter): |
| (KJS::JSGlobalObject::defineSetter): |
| * kjs/JSGlobalObject.h: |
| |
| === End merge of squirrelfish === |
| |
| 2008-05-21 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Tim Hatcher. |
| |
| Merged with trunk WebCore's new debugger. |
| |
| * kjs/DebuggerCallFrame.cpp: |
| (KJS::DebuggerCallFrame::evaluate): Changed this function to separate |
| the exception value from the return value. The WebKit debugger treats |
| them as one, but the WebCore debugger doesn't. |
| |
| * kjs/DebuggerCallFrame.h: |
| (KJS::DebuggerCallFrame::dynamicGlobalObject): Added a new accessor for |
| the dynamic global object, since the debugger doesn't want the lexical |
| global object. |
| |
| 2008-05-21 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bug 19116: SquirrelFish shouldn't regress on variable lookups |
| <https://bugs.webkit.org/show_bug.cgi?id=19116> |
| |
| Optimise cross scope assignment, 0.4% progression in sunspider. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitPutScopedVar): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::AssignResolveNode::emitCode): |
| |
| 2008-05-21 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - check property map before symbol table in JSGlobalObject::getOwnPropertySlot |
| 0.5% speedup on SunSpider |
| |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::getOwnPropertySlot): Check property map before symbol table |
| because symbol table access is likely to have been optimized. |
| |
| 2008-05-21 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bug 19116: SquirrelFish shouldn't regress on variable lookups |
| <https://bugs.webkit.org/show_bug.cgi?id=19116> |
| |
| Optimise multiscope lookup of statically resolvable function calls. |
| SunSpider reports a 1.5% improvement, including 37% on |
| controlflow-recursive for some reason :D |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitResolve): |
| * VM/CodeGenerator.h: |
| * kjs/nodes.cpp: |
| (KJS::FunctionCallResolveNode::emitCode): |
| |
| 2008-05-21 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - give JSGlobalObject a special version of getOwnPropertySlot that tells you if the slot is directly writable |
| (WebCore change using this is a 2.6% speedup on in-browser SunSpider). |
| |
| * JavaScriptCore.exp: |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::getOwnPropertySlot): |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::symbolTableGet): |
| * kjs/object.h: |
| (KJS::JSObject::getDirectLocation): |
| (KJS::JSObject::getOwnPropertySlotForWrite): |
| * kjs/property_map.cpp: |
| (KJS::PropertyMap::getLocation): |
| * kjs/property_map.h: |
| * kjs/property_slot.h: |
| (KJS::PropertySlot::putValue): |
| |
| 2008-05-20 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bug 19116: SquirrelFish shouldn't regress on variable lookups |
| <https://bugs.webkit.org/show_bug.cgi?id=19116> |
| |
| This restores multiscope optimisation to simple resolve, producing |
| a 2.6% progression in SunSpider. Have verified that none of the |
| sites broken by the multiscope optimisation in trunk were effected |
| by this change. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeBlock.h: |
| (KJS::CodeBlock::CodeBlock): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::findScopedProperty): |
| (KJS::CodeGenerator::emitResolve): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::resolve_n): |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/JSVariableObject.h: |
| |
| 2008-05-20 Oliver Hunt <oliver@apple.com> |
| |
| Fixerate the windows build. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * VM/CodeGenerator.cpp: |
| * VM/RegisterFile.h: |
| * kjs/JSGlobalObject.h: |
| * kjs/Parser.cpp: |
| * kjs/interpreter.h: |
| |
| 2008-05-20 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Bug 19110: SquirrelFish: Google Maps - no maps |
| <https://bugs.webkit.org/show_bug.cgi?id=19110> |
| |
| Correct a comedy of errors present in my original patch to "fix" |
| exceptions occurring midway through pre and post increment. This |
| solution is cleaner than the original, doesn't need the additional |
| opcodes, and as an added benefit does not break Google Maps. |
| |
| Sunspider reports a 0.4% progression. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::PreIncResolveNode::emitCode): |
| (KJS::PreDecResolveNode::emitCode): |
| (KJS::PreIncBracketNode::emitCode): |
| (KJS::PreDecBracketNode::emitCode): |
| (KJS::PreIncDotNode::emitCode): |
| (KJS::PreDecDotNode::emitCode): |
| |
| 2008-05-20 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - inline JSGlobalObject::getOwnPropertySlot |
| 1% improvement on in-browser SunSpider (a wash command-line) |
| |
| * kjs/JSGlobalObject.cpp: |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::getOwnPropertySlot): |
| |
| 2008-05-18 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bug 18752: SQUIRRELFISH: exceptions are not always handled by the vm |
| <https://bugs.webkit.org/show_bug.cgi?id=18752> |
| |
| Handle exceptions thrown by toString conversion in subscript operators, |
| this should basically complete exception handling in SquirrelFish. |
| |
| Sunspider reports no regression. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-05-17 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| [Reapplying patch with previously missing files from r33553 -- Oliver] |
| |
| Behold: debugging. |
| |
| SunSpider reports no change. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: Added DebuggerCallFrame.h/.cpp, |
| and created a debugger folder. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::generate): If the debugger is attached, always |
| generate full scope chains for its sake. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::unwindCallFrame): Notify the debugger when unwinding |
| due to an exception, so it doesn't keep stale call frames around. |
| |
| (KJS::Machine::execute): Set Callee to 0 in eval frames, so the |
| debugger can distinguish them from function call frames. |
| |
| (KJS::Machine::debug): Simplified this function, since the debugger |
| doesn't actually need all the information we used to provide. |
| |
| (KJS::Machine::privateExecute): Treat debugging hooks like other function |
| calls, so the code we hook into (the debugger UI) can be optimized. |
| |
| * kjs/debugger.cpp: Nixed these default callback implementations and |
| made the callbacks pure virtual instead, so the compiler could tell me |
| if I made a mistake in one of the subclasses. |
| |
| * kjs/debugger.h: Removed a bunch of irrelevent data from the debugger |
| callbacks. Changed from passing an ExecState* to passing a |
| DebuggerCallFrame*, since an ExecState* doesn't contain sufficient |
| information anymore. |
| |
| * kjs/function.cpp: |
| (KJS::globalFuncEval): Easiest bug fix evar! |
| |
| [Previously missing files from r33553] |
| * kjs/DebuggerCallFrame.cpp: Copied from JavaScriptCore/profiler/FunctionCallProfile.h. |
| (KJS::DebuggerCallFrame::functionName): |
| (KJS::DebuggerCallFrame::thisObject): |
| (KJS::DebuggerCallFrame::evaluateScript): |
| * kjs/DebuggerCallFrame.h: Copied from JavaScriptCore/VM/Register.h. |
| (KJS::DebuggerCallFrame::DebuggerCallFrame): |
| (KJS::DebuggerCallFrame::scopeChain): |
| (KJS::DebuggerCallFrame::exception): |
| |
| 2008-05-17 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Bug 18991: SquirrelFish: Major codegen issue in a.b=expr, a[b]=expr |
| <https://bugs.webkit.org/show_bug.cgi?id=18991> |
| |
| Fix the last remaining blocking cases of this bug. |
| |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::ReadModifyResolveNode::emitCode): |
| |
| 2008-05-17 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Partial fix for: |
| |
| Bug 18991: SquirrelFish: Major codegen issue in a.b=expr, a[b]=expr |
| <https://bugs.webkit.org/show_bug.cgi?id=18991> |
| |
| Ensure that the code generated for assignments uses temporaries whenever |
| necessary. This patch covers the vast majority of situations, but there |
| are still a few left. |
| |
| This patch also adds some missing cases to CodeBlock::dump(). |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::destinationForAssignResult): |
| (KJS::CodeGenerator::leftHandSideNeedsCopy): |
| (KJS::CodeGenerator::emitNodeForLeftHandSide): |
| * kjs/NodeInfo.h: |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::AssignDotNode::emitCode): |
| (KJS::ReadModifyDotNode::emitCode): |
| (KJS::AssignBracketNode::emitCode): |
| (KJS::ReadModifyBracketNode::emitCode): |
| (KJS::ForInNode::ForInNode): |
| * kjs/nodes.h: |
| (KJS::ReadModifyResolveNode::): |
| (KJS::AssignResolveNode::): |
| (KJS::ReadModifyBracketNode::): |
| (KJS::AssignBracketNode::): |
| (KJS::AssignDotNode::): |
| (KJS::ReadModifyDotNode::): |
| |
| 2008-05-17 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bug 19106: SquirrelFish: Activation is not marked correctly |
| <https://bugs.webkit.org/show_bug.cgi?id=19106> |
| |
| We can't rely on the symbol table for a count of the number of globals |
| we need to mark as that misses duplicate parameters and 'this'. Now we |
| use the actual local register count from the codeBlock. |
| |
| * kjs/JSActivation.cpp: |
| (KJS::JSActivation::mark): |
| |
| 2008-05-16 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Bug 19076: SquirrelFish: RegisterFile can be corrupted if implictly reenter global scope with no declared vars |
| <https://bugs.webkit.org/show_bug.cgi?id=19076> |
| |
| Don't delay allocation of initial global RegisterFile, as we can't guarantee we will be able |
| to allocate the global 'this' register safely at any point after initialisation of the Global |
| Object. |
| |
| Unfortunately this initial allocation caused a regression of 0.2-0.3%, however this patch adds |
| support for the static slot optimisation for the global Math object which brings it to a 0.3% |
| progression. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::programCodeThis): |
| (KJS::CodeGenerator::CodeGenerator): |
| (KJS::CodeGenerator::addParameter): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): |
| * kjs/ExecState.h: |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::reset): |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::GlobalPropertyInfo::GlobalPropertyInfo): |
| (KJS::JSGlobalObject::addStaticGlobals): |
| * kjs/nodes.cpp: |
| |
| 2008-05-16 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver Hunt. |
| |
| Bug 19098: SquirrelFish: Ref'd temporaries can be clobbered |
| <https://bugs.webkit.org/show_bug.cgi?id=19098> |
| |
| When doing code generation for a statement list, increase the reference |
| count on a register that might eventually be returned, so that it doesn't |
| get clobbered by a request for a new temporary. |
| |
| * kjs/nodes.cpp: |
| (KJS::statementListEmitCode): |
| |
| 2008-05-16 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fixed Bug 19044: SquirrelFish: Bogus values enter evaluation when closing over scope with parameter and var with same name |
| https://bugs.webkit.org/show_bug.cgi?id=19044 |
| |
| * kjs/JSActivation.cpp: |
| (KJS::JSActivation::copyRegisters): Use numLocals from the code |
| block rather than the size of the symbol table for the number of |
| registers to copy, to account for duplicate parameters and vars |
| with the same name as parameters (we still have potentially |
| suboptimal codegen in that we allocate a local register for the |
| var in the latter case but it is never used). |
| |
| 2008-05-15 Geoffrey Garen <ggaren@apple.com> |
| |
| Not reviewed. |
| |
| We regret to inform you that your program is crashing because you were |
| stupid. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): Math is hard. |
| |
| 2008-05-14 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| A little more debugger action: filled in op_debug. All debugger control |
| flow works now, but variable inspection and backtraces still don't. |
| |
| SunSpider reports no change. |
| |
| * VM/CodeGenerator.cpp: Changed op_debug to accept line number parameters. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::getFunctionAndArguments): Moved op_debug into a |
| NEVER_INLINE function to avoid a stunning 10% performance regression. |
| Also factored out a common function for retrieving the function and |
| arguments from a call frame. |
| |
| * kjs/JSActivation.cpp: |
| (KJS::JSActivation::createArgumentsObject): Use the new factored out |
| function mentioned above. |
| |
| * kjs/Parser.cpp: |
| (KJS::Parser::parse): Increment m_sourceId before assigning it, so the |
| sourceId we send to the debugger matches the sourceId recorded in the |
| node. |
| |
| * kjs/nodes.cpp: Emit debugging hooks. |
| |
| 2008-05-14 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bug 19024: SQUIRRELFISH: ASSERTION FAILED: activation->isActivationObject() in Machine::unwindCallFrame |
| <https://bugs.webkit.org/show_bug.cgi?id=19024> |
| |
| This fixes a number of issues. The most important is that we now check every register |
| file for tainting rather than just looking for function register files as that was |
| insufficient. Additionally guarded against implicit re-entry into Eval code. |
| |
| Also added a few additional assertions to reduce the amout of time between something |
| going wrong and us seeing the error. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): |
| (KJS::Machine::privateExecute): |
| * VM/RegisterFile.cpp: |
| (KJS::RegisterFile::growBuffer): |
| (KJS::RegisterFile::addGlobalSlots): |
| * VM/RegisterFileStack.cpp: |
| (KJS::RegisterFileStack::pushGlobalRegisterFile): |
| (KJS::RegisterFileStack::pushFunctionRegisterFile): |
| * VM/RegisterFileStack.h: |
| (KJS::RegisterFileStack::inImplicitCall): |
| |
| 2008-05-14 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| A little more debugger action: emit opcodes for debugger hooks. Right |
| now, the opcode implementation is just a stub. |
| |
| SunSpider reports no change. |
| |
| Some example codegen for "function f() { 1; }": |
| |
| [ 0] dbg DidEnterCallFrame |
| [ 2] dbg WillExecuteStatement |
| [ 4] load tr0, 1(@k0) |
| [ 7] load tr0, undefined(@k1) |
| [ 10] dbg WillLeaveCallFrame |
| [ 12] ret tr0 |
| |
| 2008-05-14 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Bug 19025: SQUIRRELFISH: malformed syntax in onload handler causes crash |
| <https://bugs.webkit.org/show_bug.cgi?id=19025> |
| |
| Simple fix -- move the use of functionBodyNode to after the null check. |
| |
| * kjs/function_object.cpp: |
| (KJS::FunctionObjectImp::construct): |
| |
| 2008-05-13 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fixed a codegen crash with run-time parse errors. |
| |
| SunSpider reports no change. |
| |
| emitThrowError needs to return the temporary holding the error, not dst, |
| since dst may be NULL. In fact, emitThrowError shouldn't take a dst |
| parameter at all, since exceptions should not modify the destination |
| register. |
| |
| 2008-05-13 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Bug 19027: SquirrelFish: Incorrect codegen for pre-increment |
| <https://bugs.webkit.org/show_bug.cgi?id=19027> |
| |
| This fixes the codegen issues for the pre-inc/decrement operators |
| to prevent incorrectly clobbering the destination in the event of |
| an exception. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitPreInc): |
| (KJS::CodeGenerator::emitPreDec): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::PreIncResolveNode::emitCode): |
| (KJS::PreDecResolveNode::emitCode): |
| (KJS::PreIncBracketNode::emitCode): |
| (KJS::PreDecBracketNode::emitCode): |
| (KJS::PreIncDotNode::emitCode): |
| (KJS::PreDecDotNode::emitCode): |
| |
| 2008-05-13 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| A little more debugger action: supply a real line number, sourceId, |
| and sourceURL in op_new_error. |
| |
| SunSpider reports a .2% speedup. Not sure what that's about. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): Use the new good stuff in op_new_error. |
| |
| * kjs/nodes.cpp: |
| (KJS::RegExpNode::emitCode): Use the shared emitThrowError instead of |
| rolling our own. |
| |
| 2008-05-13 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| A little more debugger action: implemented the exception callback. |
| |
| SunSpider reports a .2% speedup. Not sure what that's about. |
| |
| * VM/CodeBlock.h: A little refactoring here. Store a pointer to our |
| owner ScopeNode so we can retrieve data from it. This allows us to |
| stop storing copies of the data ourselves. Also, store a "this" register |
| instead of a code type, since we were only using the code type to |
| calculate the "this" register. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::generate): Calculate the "this" register mentioned |
| above. Also, take care of removing "this" from the symbol table after |
| codegen is done, since relying on the timing of a destructor for correct |
| behavior is not so good. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::throwException): Invoke the debugger's exception callback. |
| (KJS::Machine::privateExecute): Use the "this" register mentioned above. |
| |
| 2008-05-13 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Removed some unused exception machinery. |
| |
| SunSpider reports a .3% speedup. |
| |
| * API/JSCallbackObject.h: |
| * API/JSCallbackObjectFunctions.h: |
| * JavaScriptCore.exp: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * kjs/internal.cpp: |
| * kjs/object.cpp: |
| * kjs/object.h: |
| * kjs/value.h: |
| |
| 2008-05-13 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| A little more debugger action. |
| |
| * kjs/debugger.cpp: |
| * kjs/debugger.h: Removed debuggersPresent because it was unused. |
| Replaced AttachedGlobalObject linked list with a HashSet because HashSet |
| is faster and simpler. Changed all functions to return void instead of |
| bool, because no clients ever return false, and we don't want to support |
| it. |
| |
| * kjs/nodes.cpp: Did some up-keep to avoid build bustage. |
| (KJS::Node::handleException): |
| (KJS::BreakpointCheckStatement::execute): |
| (KJS::FunctionBodyNodeWithDebuggerHooks::execute): |
| |
| 2008-05-13 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Darin. |
| |
| Bug 18752: SQUIRRELFISH: exceptions are not always handled by the vm |
| <https://bugs.webkit.org/show_bug.cgi?id=18752> |
| |
| Replace old attempt at "branchless" exceptions as the extra information |
| being passed made gcc an unhappy compiler, replacing these custom toNumber |
| calls with ordinary toNumber logic (by relying on toNumber now preventing |
| side effects after an exception has been thrown) provided sufficient leeway |
| to add the additional checks for the remaining unchecked cases. |
| |
| This leaves only toString conversions in certain contexts as possibly |
| misbehaving. |
| |
| * VM/Machine.cpp: |
| (KJS::jsAdd): |
| (KJS::resolve): |
| (KJS::resolveBaseAndProperty): |
| (KJS::resolveBaseAndFunc): |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/value.h: |
| (KJS::JSValue::safeGetNumber): |
| |
| 2008-05-13 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| First steps toward supporting the debugger API: support the sourceParsed |
| callback; plus some minor fixups. |
| |
| SunSpider reports no regression. |
| |
| * VM/CodeGenerator.h: Removed a misleading comment. |
| |
| * kjs/Parser.h: Changed the parser to take an ExecState*, so it can |
| implement the sourceParsed callback -- that way, we only have to |
| implement the callback in one place. |
| |
| * kjs/debugger.cpp: Nixed DebuggerImp, because its sole purpose in life |
| was to demonstrate the misapplication of design patterns. |
| |
| * kjs/debugger.h: Changed sourceParsed to take a SourceProvider, to |
| reduce copying, and not to return a value, because pausing execution |
| after parsing is complicated, and no clients needed that ability, anyway. |
| |
| * kjs/grammar.y: Make sure never to pass a NULL SourceElements* to |
| didFinishParsing -- that simplifies some code down the road. |
| |
| * kjs/nodes.cpp: Don't generate special AST nodes just because the |
| debugger is attached -- that's a relic of the old AST execution model, |
| and those nodes haven't been maintained. |
| |
| 2008-05-13 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Bug 18752: SQUIRRELFISH: exceptions are not always handled by the vm |
| <https://bugs.webkit.org/show_bug.cgi?id=18752> |
| |
| First step: prevent incorrect evaluation of valueOf/toString conversion |
| in right hand side of expression after earlier conversion throws. |
| |
| * API/JSCallbackObjectFunctions.h: |
| (KJS::::toNumber): |
| * kjs/object.cpp: |
| (KJS::JSObject::defaultValue): |
| |
| 2008-05-12 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Bug 18934: SQUIRRELFISH: ASSERT @ nytimes.com due to RegisterFile being clobbered |
| <https://bugs.webkit.org/show_bug.cgi?id=18934> |
| |
| Unfortunately we cannot create new statically optimised globals if there are any |
| tainted RegisterFiles on the RegisterFileStack. To handle this we re-introduce |
| (in a slightly cleaner form) the inImplicitCall concept to the RegisterFileStack. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): |
| * VM/RegisterFileStack.cpp: |
| (KJS::RegisterFileStack::pushFunctionRegisterFile): |
| * VM/RegisterFileStack.h: |
| |
| 2008-05-12 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Introduced support for function.caller. |
| |
| Improved support for walking interesting scopes for function introspection. |
| |
| This fixes all remaining layout tests not blocked by rebasing to trunk. |
| |
| SunSpider reports no change. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::dumpRegisters): Fixed a spacing issue. |
| |
| 2008-05-11 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Bug 18961: SQUIRRELFISH: Gmail doesn't load |
| <https://bugs.webkit.org/show_bug.cgi?id=18961> |
| |
| Fix codegen for logical nodes so that they don't use their destination |
| as a temporary. |
| |
| * kjs/nodes.cpp: |
| (KJS::LogicalAndNode::emitCode): |
| (KJS::LogicalOrNode::emitCode): |
| |
| 2008-05-10 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - JavaScriptCore part of fix for: "SQUIRRELFISH: function toString broken after calling" |
| https://bugs.webkit.org/show_bug.cgi?id=18869 |
| |
| Three layout tests are fixed: |
| fast/js/toString-elision-trailing-comma.html |
| fast/js/toString-prefix-postfix-preserve-parens.html |
| fast/js/kde/lval-exceptions.html |
| |
| Functions now save a shared subrange of the original source used |
| to make them (so in the common case this adds no storage above the |
| memory cache). |
| |
| * kjs/SourceProvider.h: Added. |
| (KJS::SourceProvider): New abstract base class for classes that provide on-demand access |
| to the source for a JavaScript program. This allows function objects to have access to their |
| original source without copying. |
| (KJS::UStringSourceProvider): SourceProvider subclass backed by a KJS::UString. |
| (KJS::UStringSourceProvider::create): |
| (KJS::UStringSourceProvider::getRange): |
| (KJS::UStringSourceProvider::data): |
| (KJS::UStringSourceProvider::length): |
| (KJS::UStringSourceProvider::UStringSourceProvider): |
| * kjs/SourceRange.h: Added. |
| (KJS::SourceRange::SourceRange): Class that holds a SourceProvider and a character range into |
| the source, to encapsulate on-demand access to the source of a function. |
| (KJS::SourceRange::toString): |
| * VM/Machine.cpp: |
| (KJS::eval): Pass a UStringSourceProvider to the parser. |
| * kjs/Parser.cpp: |
| (KJS::Parser::parse): Take a SourceProvider and pass it on to the lexer. |
| * kjs/Parser.h: |
| (KJS::Parser::parse): Take a SourceProvider. |
| * kjs/lexer.cpp: |
| (KJS::Lexer::setCode): Take a SourceProvider; keep it around, and |
| use it to get the raw buffer and length. |
| * kjs/lexer.h: |
| (KJS::Lexer::sourceRange): Convenience function to get a source |
| range based on the lexer's source provieder, and char offsets |
| right before and after the desired range. |
| * kjs/function.cpp: |
| (KJS::globalFuncEval): Pass a UStringSourceProvider to the parser. |
| * kjs/function_object.cpp: |
| (KJS::functionProtoFuncToString): Use toSourceString to get the source. |
| (KJS::FunctionObjectImp::construct): Give the parser a UStringSourceProvider. |
| * kjs/grammar.y: When parsing a function declaration, function |
| expression, or getter or setter, tell the function body about its |
| SourceRange. |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::checkSyntax): Pass a SourceProvider to the parser. |
| (KJS::Interpreter::evaluate): Pass a SourceProvider to the parser. |
| * kjs/interpreter.h: |
| * kjs/nodes.h: |
| (KJS::FunctionBodyNode::setSource): Establish a SourceRange for this function. |
| (KJS::FunctionBodyNode::toSourceString): Get the source string out |
| of the SourceRange. |
| (KJS::FuncExprNode::): Take a SourceRange and set it on the body. |
| (KJS::FuncDeclNode::): ditto |
| * kjs/testkjs.cpp: |
| (prettyPrintScript): Use a SourceProvider appropriately. |
| * JavaScriptCore.exp: Export new symbols. |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Add new files. |
| * JavaScriptCore.xcodeproj/project.pbxproj: Add new files. |
| |
| 2008-05-09 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bring back RegisterFile tainting in order to correctly handle |
| natively implemented getters and setters that re-enter JavaScript |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/RegisterFile.h: |
| * kjs/function.cpp: |
| (KJS::FunctionImp::callAsFunction): |
| * kjs/object.cpp: |
| (KJS::JSObject::put): |
| (KJS::tryGetAndCallProperty): |
| * kjs/property_slot.cpp: |
| (KJS::PropertySlot::functionGetter): |
| |
| 2008-05-09 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - track character offsets of open and close braces, in preparation for saving function source |
| |
| I verified that there is no performance regression from this change. |
| |
| * kjs/grammar.y: |
| * kjs/lexer.cpp: |
| (KJS::Lexer::lex): |
| (KJS::Lexer::matchPunctuator): |
| * kjs/lexer.h: |
| |
| 2008-05-09 Oliver Hunt <oliver@apple.com> |
| |
| Debug build fix |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::restoreLocalStorage): |
| |
| 2008-05-09 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Build fixes for SquirrelFish on windows. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.vcproj/testkjs/testkjs.vcproj: |
| * VM/Register.h: |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::restoreLocalStorage): |
| * kjs/collector.cpp: |
| (KJS::Collector::allocate): |
| (KJS::Collector::allocateNumber): |
| * kjs/collector.h: |
| (KJS::Collector::allocate): |
| (KJS::Collector::allocateNumber): |
| * kjs/property_slot.cpp: |
| |
| 2008-05-08 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - fix activation tearoff in the case where functions are called with too many arguments |
| |
| Fixes: |
| fast/canvas/patternfill-repeat.html |
| fast/dom/SelectorAPI/bug-17313.html |
| |
| * VM/Machine.cpp: |
| (KJS::slideRegisterWindowForCall): |
| (KJS::scopeChainForCall): |
| (KJS::Machine::execute): |
| (KJS::Machine::privateExecute): |
| |
| 2008-05-08 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fixed failure in fast/canvas/canvas-pattern-behaviour.html. |
| |
| SunSpider reports a small speedup. Not sure what that's about. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): Fixed op_call_eval to dump as "op_call_eval". |
| This helped me while debugging. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::unwindCallFrame): When looking for an activation to tear |
| off, don't use the scope chain. Inside eval, the scope chain doesn't |
| belong to us; it belongs to our calling function. |
| |
| Also, don't use the needsFullScopeChain flag to decide whether to tear |
| off the activation. "function.arguments" can create an activation |
| for a function whose needsFullScopeChain flag is set to false. |
| |
| 2008-05-08 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fix function.call for calls of more than 8 arguments |
| |
| Fixes svg/carto.net/button.svg |
| |
| * kjs/list.cpp: |
| (KJS::List::getSlice): properly set up the m_buffer of the target list. |
| |
| 2008-05-08 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - don't return a null RegisterID from RegExpNode in the exception case, since the caller may need a real register |
| |
| Fixes: |
| - fast/regex/early-acid3-86.html |
| - http/tests/misc/acid3.html |
| |
| * kjs/nodes.cpp: |
| (KJS::RegExpNode::emitCode): |
| |
| 2008-05-07 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Fix a performance regression caused by the introduction of property |
| attributes to SymbolTable in r32859 by encoding the attributes and the |
| register index into a single field of SymbolTableEntry. |
| |
| This leaves Node::optimizeVariableAccess() definitely broken, although |
| it was probably not entirely correct in SquirrelFish before this change. |
| |
| * VM/CodeBlock.h: |
| (KJS::missingThisObjectMarker): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::addVar): |
| (KJS::CodeGenerator::CodeGenerator): |
| (KJS::CodeGenerator::registerForLocal): |
| (KJS::CodeGenerator::registerForLocalConstInit): |
| (KJS::CodeGenerator::isLocalConstant): |
| (KJS::CodeGenerator::addConstant): |
| (KJS::CodeGenerator::emitCall): |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::IdentifierMapIndexHashTraits::emptyValue): |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::saveLocalStorage): |
| * kjs/JSVariableObject.cpp: |
| (KJS::JSVariableObject::getPropertyNames): |
| (KJS::JSVariableObject::getPropertyAttributes): |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::symbolTableGet): |
| (KJS::JSVariableObject::symbolTablePut): |
| (KJS::JSVariableObject::symbolTablePutWithAttributes): |
| * kjs/SymbolTable.h: |
| (KJS::SymbolTableEntry::SymbolTableEntry): |
| (KJS::SymbolTableEntry::isEmpty): |
| (KJS::SymbolTableEntry::getIndex): |
| (KJS::SymbolTableEntry::getAttributes): |
| (KJS::SymbolTableEntry::setAttributes): |
| (KJS::SymbolTableEntry::isReadOnly): |
| * kjs/nodes.cpp: |
| (KJS::getSymbolTableEntry): |
| (KJS::PostIncResolveNode::optimizeVariableAccess): |
| (KJS::PostDecResolveNode::optimizeVariableAccess): |
| (KJS::DeleteResolveNode::optimizeVariableAccess): |
| (KJS::TypeOfResolveNode::optimizeVariableAccess): |
| (KJS::PreIncResolveNode::optimizeVariableAccess): |
| (KJS::PreDecResolveNode::optimizeVariableAccess): |
| (KJS::ReadModifyResolveNode::optimizeVariableAccess): |
| (KJS::AssignResolveNode::optimizeVariableAccess): |
| (KJS::ProgramNode::initializeSymbolTable): |
| |
| 2008-05-06 Maciej Stachowiak <mjs@apple.com> |
| |
| Rubber stamped by Oliver. |
| |
| - add missing ! in an assert that I failed to reverse |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::CodeGenerator): |
| |
| 2008-05-06 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fixed "SQUIRRELFISH: window.this shows up as a property, but it shouldn't" |
| https://bugs.webkit.org/show_bug.cgi?id=18868 |
| |
| The basic approach is to have "this" only be present in the symbol |
| table at compile time, not runtime. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::~CodeGenerator): Remove "this" from symbol table. |
| (KJS::CodeGenerator::CodeGenerator): Add "this" back when re-using |
| a symbol table. |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): Don't assert that "this" is in the symbol table. |
| |
| 2008-05-06 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Trivial support for function.arguments: Currently, we only support |
| function.arguments from within the scope of function. |
| |
| This fixes the remaining Mozilla JS test failures. |
| |
| SunSpider reports no change. |
| |
| * JavaScriptCore.exp: |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): Separated scope chain deref from |
| activation register copying: since it is now possible for client code |
| to create an activation on behalf of a function that otherwise wouldn't |
| need one, having an activation no longer necessarily means that you need |
| to deref the scope chain. |
| |
| (KJS::Machine::getCallFrame): For now, this function only examines the |
| current scope. Walking parent scopes requires some refactoring in the |
| way we track execution stacks. |
| |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::ExecState): We use a negative call frame offset to |
| indicate that a given scope is not a function call scope. |
| |
| 2008-05-05 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Fix call frame set up for native -> JS function calls. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): |
| |
| 2008-05-05 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Fixed ecma_3/Object/8.6.2.6-001.js, and similar bugs. |
| |
| SunSpider reports a .4% speedup. Not sure what that's about. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): Check for exception return from equal, |
| since toPrimitive can throw. |
| |
| * kjs/operations.cpp: |
| (KJS::strictEqual): In response to an error I made in an earlier version |
| of this patch, I changed strictEqual to make clear the fact that it |
| performs no conversions and can't throw, making it slightly more efficient |
| in the process. |
| |
| 2008-05-05 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fix some dumb mistakes in my last patch |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitPushScope): |
| (KJS::CodeGenerator::emitGetPropertyNames): |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-05-05 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - document opcodes relating to jumps, scopes, and property name iteration |
| |
| Documented jmp, jtrue, false, push_scope, pop_scope, get_pnames, |
| next_pname and jmp_scopes. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitJump): |
| (KJS::CodeGenerator::emitJumpIfTrue): |
| (KJS::CodeGenerator::emitJumpIfFalse): |
| (KJS::CodeGenerator::emitPushScope): |
| (KJS::CodeGenerator::emitNextPropertyName): |
| (KJS::CodeGenerator::emitGetPropertyNames): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * kjs/nodes.cpp: |
| (KJS::LogicalAndNode::emitCode): |
| (KJS::LogicalOrNode::emitCode): |
| (KJS::ConditionalNode::emitCode): |
| (KJS::IfNode::emitCode): |
| (KJS::IfElseNode::emitCode): |
| (KJS::DoWhileNode::emitCode): |
| (KJS::WhileNode::emitCode): |
| (KJS::ForNode::emitCode): |
| (KJS::ForInNode::emitCode): |
| (KJS::WithNode::emitCode): |
| |
| 2008-05-05 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Bug 18749: SQUIRRELFISH: const support is broken |
| <https://bugs.webkit.org/show_bug.cgi?id=18749> |
| |
| Adds support for const during code generation. |
| |
| Fixes 2 layout tests. |
| |
| * ChangeLog: |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::addVar): |
| (KJS::CodeGenerator::CodeGenerator): |
| (KJS::CodeGenerator::isLocalConstant): |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::addVar): |
| * kjs/nodes.cpp: |
| (KJS::PostIncResolveNode::emitCode): |
| (KJS::PostDecResolveNode::emitCode): |
| (KJS::PreIncResolveNode::emitCode): |
| (KJS::PreDecResolveNode::emitCode): |
| (KJS::ReadModifyResolveNode::emitCode): |
| (KJS::AssignResolveNode::emitCode): |
| |
| 2008-05-04 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - document some more opcodes (and fix argument names) |
| |
| Added docs for eq, neq, stricteq, nstriceq, less and lesseq. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitEqual): |
| (KJS::CodeGenerator::emitNotEqual): |
| (KJS::CodeGenerator::emitStrictEqual): |
| (KJS::CodeGenerator::emitNotStrictEqual): |
| (KJS::CodeGenerator::emitLess): |
| (KJS::CodeGenerator::emitLessEq): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * kjs/nodes.cpp: |
| (KJS::LessNode::emitCode): |
| (KJS::GreaterNode::emitCode): |
| (KJS::LessEqNode::emitCode): |
| (KJS::GreaterEqNode::emitCode): |
| (KJS::EqualNode::emitCode): |
| (KJS::NotEqualNode::emitCode): |
| (KJS::StrictEqualNode::emitCode): |
| (KJS::NotStrictEqualNode::emitCode): |
| (KJS::CaseBlockNode::emitCodeForBlock): |
| |
| 2008-05-04 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| More scaffolding for f.arguments. |
| |
| Track the offset of the last call frame in the ExecState, so we can |
| produce a backtrace at any time. |
| |
| Also, record numLocals, the sum of numVars + numParameters, in each code |
| block, to make updates to the ExecState a little cheaper than they |
| would be otherwise. |
| |
| We now use numLocals in a bunch of places where we used to calculate |
| numVars + numParameters or -numVars - numParameters. |
| |
| Reports are mixed, but all in all, this seems to be a wash on SunSpider. |
| |
| 2008-05-04 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Whoops, correctly handle properties that don't exist in the |
| symbol table. |
| |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::symbolTablePutWithAttributes): |
| |
| 2008-05-04 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Add attribute information to SymbolTable as ground work for |
| various DontEnum and ReadOnly issues. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::addVar): |
| (KJS::CodeGenerator::CodeGenerator): |
| (KJS::CodeGenerator::registerForLocal): |
| (KJS::CodeGenerator::registerForLocalConstInit): |
| (KJS::CodeGenerator::addConstant): |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::saveLocalStorage): |
| * kjs/JSVariableObject.cpp: |
| (KJS::JSVariableObject::getPropertyNames): |
| (KJS::JSVariableObject::getPropertyAttributes): |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::symbolTablePut): |
| (KJS::JSVariableObject::symbolTablePutWithAttributes): |
| * kjs/SymbolTable.h: |
| (KJS::SymbolTableEntry::SymbolTableEntry): |
| (KJS::SymbolTableIndexHashTraits::emptyValue): |
| * kjs/nodes.cpp: |
| (KJS::getSymbolTableEntry): |
| (KJS::ReadModifyResolveNode::optimizeVariableAccess): |
| (KJS::AssignResolveNode::optimizeVariableAccess): |
| (KJS::ProgramNode::initializeSymbolTable): |
| |
| 2008-05-04 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| More scaffolding for f.arguments. |
| |
| Store the register file associated with an ExecState in the ExecState. |
| |
| SunSpider reports no change. |
| |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::JSGlobalObjectData::JSGlobalObjectData): Moved |
| registerFileStack above globalExec, so it gets initialized first. |
| Removed remnants of old activation scheme. |
| |
| 2008-05-04 Maciej Stachowiak <mjs@apple.com> |
| |
| Rubber stamped by Oliver. |
| |
| - renamed a few opcodes and fixed assembly formatting to accomodate the longest opcode |
| |
| equal --> eq |
| nequal --> neq |
| resolve_base_and_property --> resolve_with_base |
| resolve_base_and_func --> resolve_func |
| get_prop_id --> get_by_id |
| put_prop_id --> put_by_id |
| delete_prop_id --> del_by_id |
| get_prop_val --> get_by_val |
| put_prop_val --> put_by_val |
| delete_prop_val --> del_by_val |
| put_prop_index --> put_by_index |
| |
| * VM/CodeBlock.cpp: |
| (KJS::printUnaryOp): |
| (KJS::printBinaryOp): |
| (KJS::printConditionalJump): |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitEqual): |
| (KJS::CodeGenerator::emitNotEqual): |
| (KJS::CodeGenerator::emitResolveWithBase): |
| (KJS::CodeGenerator::emitResolveFunction): |
| (KJS::CodeGenerator::emitGetById): |
| (KJS::CodeGenerator::emitPutById): |
| (KJS::CodeGenerator::emitDeleteById): |
| (KJS::CodeGenerator::emitGetByVal): |
| (KJS::CodeGenerator::emitPutByVal): |
| (KJS::CodeGenerator::emitDeleteByVal): |
| (KJS::CodeGenerator::emitPutByIndex): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::ArrayNode::emitCode): |
| (KJS::PropertyListNode::emitCode): |
| (KJS::BracketAccessorNode::emitCode): |
| (KJS::DotAccessorNode::emitCode): |
| (KJS::EvalFunctionCallNode::emitCode): |
| (KJS::FunctionCallResolveNode::emitCode): |
| (KJS::FunctionCallBracketNode::emitCode): |
| (KJS::FunctionCallDotNode::emitCode): |
| (KJS::PostIncResolveNode::emitCode): |
| (KJS::PostDecResolveNode::emitCode): |
| (KJS::PostIncBracketNode::emitCode): |
| (KJS::PostDecBracketNode::emitCode): |
| (KJS::PostIncDotNode::emitCode): |
| (KJS::PostDecDotNode::emitCode): |
| (KJS::DeleteResolveNode::emitCode): |
| (KJS::DeleteBracketNode::emitCode): |
| (KJS::DeleteDotNode::emitCode): |
| (KJS::TypeOfResolveNode::emitCode): |
| (KJS::PreIncResolveNode::emitCode): |
| (KJS::PreDecResolveNode::emitCode): |
| (KJS::PreIncBracketNode::emitCode): |
| (KJS::PreDecBracketNode::emitCode): |
| (KJS::PreIncDotNode::emitCode): |
| (KJS::PreDecDotNode::emitCode): |
| (KJS::ReadModifyResolveNode::emitCode): |
| (KJS::AssignResolveNode::emitCode): |
| (KJS::AssignDotNode::emitCode): |
| (KJS::ReadModifyDotNode::emitCode): |
| (KJS::AssignBracketNode::emitCode): |
| (KJS::ReadModifyBracketNode::emitCode): |
| (KJS::ConstDeclNode::emitCodeSingle): |
| (KJS::ForInNode::emitCode): |
| (KJS::TryNode::emitCode): |
| |
| 2008-05-04 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Fix assertion when accessing arguments object with too many arguments provided |
| |
| The arguments constructor was assuming that the register offset given for argv |
| was an absolute offset into the registerfile, rather than the offset from the |
| frame. This patches corrects that issue. |
| |
| * kjs/JSActivation.cpp: |
| (KJS::JSActivation::createArgumentsObject): |
| |
| 2008-05-04 Geoffrey Garen <ggaren@apple.com> |
| |
| Rubber stamped by Sam Weinig. |
| |
| Cleaned up Machine.cpp according to our style guidelines: moved static |
| data to the top of the file; moved stand-alone functions below that; |
| moved the Machine constructor above other Machine member functions. |
| |
| 2008-05-03 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Sam. |
| |
| - fix accidental breakage from last patch |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-05-03 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - a bunch more opcode documentation and corresponding parameter name fixes |
| |
| I renamed a few opcodes: |
| |
| type_of --> typeof (that's what the JS operator is named) |
| instance_of --> instanceof (ditto) |
| create_error --> new_error (for consistency with other new_* opcodes) |
| |
| I documented the following opcodes: |
| |
| - load |
| - new_object |
| - new_array |
| - new_regexp |
| - mov |
| - pre_inc |
| - pre_dec |
| - post_inc |
| - post_dec |
| - to_jsnumber |
| - negate |
| - bitnot |
| - not |
| - instanceof |
| - typeof |
| - in |
| - new_func |
| - new_funcexp |
| - new_error |
| |
| I also fixed formatting on some existing opcode docs. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitMove): |
| (KJS::CodeGenerator::emitNot): |
| (KJS::CodeGenerator::emitPreInc): |
| (KJS::CodeGenerator::emitPreDec): |
| (KJS::CodeGenerator::emitPostInc): |
| (KJS::CodeGenerator::emitPostDec): |
| (KJS::CodeGenerator::emitToJSNumber): |
| (KJS::CodeGenerator::emitNegate): |
| (KJS::CodeGenerator::emitBitNot): |
| (KJS::CodeGenerator::emitInstanceOf): |
| (KJS::CodeGenerator::emitTypeOf): |
| (KJS::CodeGenerator::emitIn): |
| (KJS::CodeGenerator::emitLoad): |
| (KJS::CodeGenerator::emitNewObject): |
| (KJS::CodeGenerator::emitNewArray): |
| (KJS::CodeGenerator::emitNewRegExp): |
| (KJS::CodeGenerator::emitNewError): |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::scopeDepth): |
| (KJS::CodeGenerator::addVar): |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::Node::emitThrowError): |
| (KJS::RegExpNode::emitCode): |
| (KJS::TypeOfValueNode::emitCode): |
| (KJS::UnaryPlusNode::emitCode): |
| (KJS::NegateNode::emitCode): |
| (KJS::BitwiseNotNode::emitCode): |
| (KJS::LogicalNotNode::emitCode): |
| (KJS::InstanceOfNode::emitCode): |
| (KJS::InNode::emitCode): |
| |
| 2008-05-03 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Geoff and Sam. |
| |
| - generate HTML bytecode docs at build time |
| |
| * DerivedSources.make: |
| * docs: Added. |
| * docs/make-bytecode-docs.pl: Added. |
| |
| 2008-05-03 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Update ExecState::m_scopeChain when switching scope chains inside the |
| machine. |
| |
| This fixes uses of lexicalGlobalObject, such as, in a subframe |
| |
| alert(top.makeArray() instanceof Array ? "FAIL" : "PASS"); |
| |
| and a bunch of the security failures listed in |
| https://bugs.webkit.org/show_bug.cgi?id=18870. (Those tests still fail, |
| seemingly because of regressions in exception messages). |
| |
| SunSpider reports no change. |
| |
| * VM/Machine.cpp: Factored out scope chain updating into a common |
| function that takes care to update ExecState::m_scopeChain, too. |
| |
| * kjs/ExecState.h: I made Machine a friend of ExecState so that Machine |
| could update ExecState::m_scopeChain, even though that value is |
| read-only for everyone else. |
| |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::JSGlobalObjectData::JSGlobalObjectData): Changed |
| this client to be a little friendlier to ExecState's internal |
| storage type for scope chain data. |
| |
| 2008-05-03 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Fixed https://bugs.webkit.org/show_bug.cgi?id=18876 |
| Squirrelfish: ScopeChainNode leak in op_jmp_scopes. |
| |
| SunSpider reports no change. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): Don't construct a ScopeChain object, |
| since the direct threaded interpreter will goto across its destructor. |
| |
| 2008-05-03 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| A bit more efficient fix than r32832: Don't copy globals into function |
| register files; instead, have the RegisterFileStack track only the base |
| of the last *global* register file, so the global object's register |
| references stay good. |
| |
| SunSpider reports a .3% speedup. Not sure what that's about. |
| |
| 2008-05-03 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bug 18864: SquirrelFish: Support getter and setter definition in object literals |
| <https://bugs.webkit.org/show_bug.cgi?id=18864> |
| |
| Add new opcodes to allow us to add getters and setters to an object. These are |
| only used by the codegen for object literals. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitPutGetter): |
| (KJS::CodeGenerator::emitPutSetter): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::PropertyListNode::emitCode): |
| |
| 2008-05-02 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - properly copy globals into and out of implicit call register |
| files, otherwise they will fail at global lookup |
| |
| Fixes fast/js/array-tostring-and-join.html layout test. |
| |
| * VM/RegisterFileStack.cpp: |
| (KJS::RegisterFileStack::pushGlobalRegisterFile): |
| (KJS::RegisterFileStack::popGlobalRegisterFile): |
| (KJS::RegisterFileStack::pushFunctionRegisterFile): |
| (KJS::RegisterFileStack::popFunctionRegisterFile): |
| |
| 2008-05-02 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fixed https://bugs.webkit.org/show_bug.cgi?id=18822 |
| SQUIRRELFISH: incorrect eval used in some cases |
| |
| Changed all code inside the machine to fetch the lexical global object |
| directly from the scope chain, instead of from the ExecState. |
| |
| Clients who fetch the lexical global object through the ExecState |
| still don't work. |
| |
| SunSpider reports no change. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): Fetch the lexical global object from |
| the scope chain. |
| |
| * kjs/ExecState.h: |
| (KJS::ExecState::ExecState::lexicalGlobalObject): Moved the logic for |
| this function into ScopeChainNode, but kept this function around to |
| support existing clients. |
| |
| 2008-05-02 Geoffrey Garen <ggaren@apple.com> |
| |
| Rubber stamped by Oliver Hunt. |
| |
| Removed ExecState.cpp from AllInOneFile.cpp, for a .2% speedup. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/AllInOneFile.cpp: |
| |
| 2008-05-01 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff and Maciej. |
| |
| Bug 18827: SquirrelFish: Prevent getters and setters from destroying the current RegisterFile |
| <https://bugs.webkit.org/show_bug.cgi?id=18827> |
| |
| Remove safe/unsafe RegisterFile concept, and instead just add additional |
| logic to ensure we always push/pop RegisterFiles when executing getters |
| and setters, similar to the logic for valueOf and toString. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/RegisterFile.h: |
| * kjs/function.cpp: |
| (KJS::FunctionImp::callAsFunction): |
| * kjs/object.cpp: |
| (KJS::JSObject::put): |
| * kjs/property_slot.cpp: |
| (KJS::PropertySlot::functionGetter): |
| |
| 2008-05-01 Oliver Hunt <oliver@apple.com> |
| |
| RS=Geoff |
| |
| Rename unsafeForReentry to safeForReentry to avoid double negatives. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/RegisterFile.h: |
| * kjs/function.cpp: |
| (KJS::FunctionImp::callAsFunction): |
| |
| 2008-05-01 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bug 18827: SquirrelFish: Prevent getters and setters from destroying the current RegisterFile |
| <https://bugs.webkit.org/show_bug.cgi?id=18827> |
| |
| This patch makes getters and setters work. It does this by |
| tracking whether the RegisterFile is "safe", that is whether |
| the interpreter is in a state that in which it can handle |
| the RegisterFile being reallocated. |
| |
| * VM/Machine.cpp: |
| (KJS::resolve): |
| (KJS::Machine::privateExecute): |
| * VM/RegisterFile.h: |
| * kjs/function.cpp: |
| (KJS::FunctionImp::callAsFunction): |
| |
| 2008-04-30 Geoffrey Garen <ggaren@apple.com> |
| |
| Release build fix: Always compile in "isGlobalObject", since it's |
| listed in our .exp file. |
| |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::isGlobalObject): |
| * kjs/ExecState.h: |
| |
| 2008-04-30 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Minor code restructuring to prepare for getters and setters, |
| also helps exception semantics a bit. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-04-30 Geoffrey Garen <ggaren@apple.com> |
| |
| Fixed tyop. |
| |
| * kjs/ExecState.h: |
| |
| 2008-04-30 Geoffrey Garen <ggaren@apple.com> |
| |
| Debug build fix: export a missing symbol. |
| |
| * JavaScriptCore.exp: |
| |
| 2008-04-30 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| A little more ExecState refactoring: Now, only the global object creates |
| an ExecState. |
| |
| Also inlined ExecState::lexicalGlobalObject(). |
| |
| SunSpider reports no change. |
| |
| 2008-04-30 Geoffrey Garen <ggaren@apple.com> |
| |
| WebCore build fix: forward-declare ScopeChain. |
| |
| * kjs/interpreter.h: |
| |
| 2008-04-30 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix for JavaScriptGlue: export a missing symbol. |
| |
| * JavaScriptCore.exp: |
| |
| 2008-04-30 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Removed a lot of unused bits from ExecState, moving them into |
| OldInterpreterExecState, the fake scaffolding class. |
| |
| The clutter was making it hard to see the forest from the trees. |
| |
| .4% SunSpider speedup, probably because ExecState::lexicalGlobalObject() |
| is faster now. |
| |
| 2008-04-29 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bug 18643: SQUIRRELFISH: need to support implicit function calls (valueOf, toString, getters/setters) |
| <https://bugs.webkit.org/show_bug.cgi?id=18643> |
| |
| Prevent static slot optimisation for new variables and functions in |
| globally re-entrant code called from an an implicit function call. |
| |
| This is necessary to prevent us from needing to resize the global |
| slot portion of the root RegisterFile during an implicit (and hence |
| unguarded) function call. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::CodeGenerator): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): |
| * VM/RegisterFile.h: |
| * VM/RegisterFileStack.cpp: |
| (KJS::RegisterFileStack::pushGlobalRegisterFile): |
| (KJS::RegisterFileStack::popGlobalRegisterFile): |
| (KJS::RegisterFileStack::pushFunctionRegisterFile): |
| (KJS::RegisterFileStack::popFunctionRegisterFile): |
| * VM/RegisterFileStack.h: |
| (KJS::RegisterFileStack::inImplicitFunctionCall): |
| (KJS::RegisterFileStack::lastGlobal): |
| * kjs/nodes.cpp: |
| (KJS::ProgramNode::generateCode): |
| * kjs/nodes.h: |
| (KJS::ProgramNode::): |
| |
| 2008-04-29 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| In nested program code, don't propogate "this" back to the parent |
| register file. ("this" should remain constant in the parent register |
| file, regardless of the scripts it invokes.) |
| |
| * VM/RegisterFile.cpp: |
| (KJS::RegisterFile::copyGlobals): |
| |
| 2008-04-28 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Restore base pointer when popping a global RegisterFile |
| |
| * VM/RegisterFileStack.cpp: |
| (KJS::RegisterFileStack::popGlobalRegisterFile): |
| |
| 2008-04-28 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Bug 18643: SQUIRRELFISH: need to support implicit function calls (valueOf, toString, getters/setters) |
| <https://bugs.webkit.org/show_bug.cgi?id=18643> |
| |
| Partial fix. This results in all implicit calls to toString or valueOf |
| executing in a separate RegisterFile, so ensuring that the the pointers |
| in the triggering interpreter don't get trashed. This still leaves the |
| task of preventing new global re-entry from toString and valueOf from |
| clobbering the RegisterFile. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): |
| * VM/RegisterFileStack.cpp: |
| (KJS::RegisterFileStack::pushFunctionRegisterFile): |
| (KJS::RegisterFileStack::popFunctionRegisterFile): |
| * VM/RegisterFileStack.h: |
| * kjs/object.cpp: |
| (KJS::tryGetAndCallProperty): |
| |
| 2008-04-28 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Simplified activation object a bit: No need to store the callee |
| in the activation object -- we can pull it out of the call frame |
| when needed, instead. |
| |
| SunSpider reports no change. |
| |
| 2008-04-28 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| RS by Oliver Hunt on moving JSArguments.cpp out of AllInOneFile.cpp. |
| |
| Substantially more handling of "arguments": "arguments" works fully |
| now, but "f.arguments" still doesn't work. |
| |
| Fixes 10 regression tests. |
| |
| SunSpider reports no regression. |
| |
| * kjs/JSActivation.cpp: |
| (KJS::JSActivation::createArgumentsObject): Reconstruct an arguments |
| List to pass to the arguments object constructor. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/AllInOneFile.cpp: Removed JSActivation.cpp from AllInOneFile.cpp |
| because that seems to make GCC happy. (Previously, I had added |
| JSActivation.cpp to AllInOneFile.cpp because *that* seemed to make GCC |
| happy. So it goes.) |
| |
| 2008-04-28 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Groundwork for more handling of "arguments". I'm not checking in the |
| actual handling of "arguments" yet, because it still needs a little |
| fiddling to avoid a performance regression. |
| |
| SunSpider reports no change. |
| |
| * VM/Machine.cpp: |
| (KJS::initializeCallFrame): Put argc in the register file, so the |
| arguments object can find it later, to determine arguments.length. |
| |
| * kjs/nodes.h: |
| (KJS::FunctionBodyNode::): Added a special code accessor for when you |
| know the code has already been generated, and you don't have a scopeChain |
| to supply for potential code generation. (This is the case when the |
| activation object creates the arguments object.) |
| |
| 2008-04-28 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Replace unsafe use of auto_ptr in Vector with manual memory |
| management. |
| |
| * VM/RegisterFileStack.cpp: |
| (KJS::RegisterFileStack::~RegisterFileStack): |
| (KJS::RegisterFileStack::popRegisterFile): |
| * VM/RegisterFileStack.h: |
| |
| 2008-04-27 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Bug 18746: SQUIRRELFISH: indirect eval used when direct eval should be used |
| <https://bugs.webkit.org/show_bug.cgi?id=18746> |
| |
| Change the base to the correct value of the 'this' object after the direct |
| eval test instead of before. |
| |
| Fixes 5 layout tests. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * kjs/nodes.cpp: |
| (KJS::EvalFunctionCallNode::emitCode): |
| |
| 2008-04-26 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - document all property getting, setting and deleting opcodes |
| |
| (And fix function parameter names to match corresponding opcode parameter names.) |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitResolve): |
| (KJS::CodeGenerator::emitResolveBase): |
| (KJS::CodeGenerator::emitResolveBaseAndProperty): |
| (KJS::CodeGenerator::emitResolveBaseAndFunc): |
| (KJS::CodeGenerator::emitGetPropId): |
| (KJS::CodeGenerator::emitPutPropId): |
| (KJS::CodeGenerator::emitDeletePropId): |
| (KJS::CodeGenerator::emitPutPropVal): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::resolve): |
| (KJS::resolveBase): |
| (KJS::resolveBaseAndProperty): |
| (KJS::resolveBaseAndFunc): |
| (KJS::Machine::privateExecute): |
| * kjs/nodes.cpp: |
| (KJS::ResolveNode::emitCode): |
| (KJS::ArrayNode::emitCode): |
| (KJS::PropertyListNode::emitCode): |
| (KJS::BracketAccessorNode::emitCode): |
| (KJS::EvalFunctionCallNode::emitCode): |
| (KJS::FunctionCallResolveNode::emitCode): |
| (KJS::FunctionCallBracketNode::emitCode): |
| (KJS::PostIncResolveNode::emitCode): |
| (KJS::PostDecResolveNode::emitCode): |
| (KJS::PostIncBracketNode::emitCode): |
| (KJS::PostDecBracketNode::emitCode): |
| (KJS::PostIncDotNode::emitCode): |
| (KJS::PostDecDotNode::emitCode): |
| (KJS::DeleteResolveNode::emitCode): |
| (KJS::TypeOfResolveNode::emitCode): |
| (KJS::PreIncResolveNode::emitCode): |
| (KJS::PreDecResolveNode::emitCode): |
| (KJS::PreIncBracketNode::emitCode): |
| (KJS::PreDecBracketNode::emitCode): |
| (KJS::AssignResolveNode::emitCode): |
| (KJS::AssignDotNode::emitCode): |
| (KJS::ReadModifyDotNode::emitCode): |
| (KJS::AssignBracketNode::emitCode): |
| (KJS::ReadModifyBracketNode::emitCode): |
| (KJS::ConstDeclNode::emitCodeSingle): |
| |
| 2008-04-26 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bug 18628: SQUIRRELFISH: need to support recursion limit |
| <https://bugs.webkit.org/show_bug.cgi?id=18628> |
| |
| Basically completes recursion limiting. There is still some |
| tuning we may want to do to make things better in the face of |
| very bad code, but certainly nothing worse than anything already |
| possible in trunk. |
| |
| Also fixes a WebKit test by fixing the exception text :D |
| |
| * JavaScriptCore.exp: |
| * VM/ExceptionHelpers.cpp: |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): |
| * VM/RegisterFile.cpp: |
| (KJS::RegisterFile::growBuffer): |
| (KJS::RegisterFile::addGlobalSlots): |
| * VM/RegisterFile.h: |
| (KJS::RegisterFile::grow): |
| (KJS::RegisterFile::uncheckedGrow): |
| * VM/RegisterFileStack.cpp: |
| (KJS::RegisterFileStack::pushRegisterFile): |
| * VM/RegisterFileStack.h: |
| |
| 2008-04-25 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Bug 18628: SQUIRRELFISH: need to support recursion limit |
| <https://bugs.webkit.org/show_bug.cgi?id=18628> |
| |
| Put a limit on the level of reentry recursion. 128 levels of re-entrant recursion |
| seems reasonable as it is greater than the old eval limit, and a long way short of |
| the reentry depth needed to overflow the stack. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): |
| * VM/Machine.h: |
| |
| 2008-04-25 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| A tiny bit of cleanup to the regexp code. |
| |
| Removed some static_cast. |
| |
| Removed createRegExpImp because it's no longer used. |
| |
| 2008-04-25 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bug 18736: SQUIRRELFISH: switch statements with no default have incorrect codegen |
| <https://bugs.webkit.org/show_bug.cgi?id=18736> |
| |
| Ensure the "default" target is correct in the absence of an explicit default handler. |
| |
| * kjs/nodes.cpp: |
| (KJS::CaseBlockNode::emitCodeForBlock): |
| |
| 2008-04-25 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bug 18628: SQUIRRELFISH: need to support recursion limit |
| <https://bugs.webkit.org/show_bug.cgi?id=18628> |
| |
| More bounds checking. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): |
| * VM/RegisterFile.cpp: |
| (KJS::RegisterFile::growBuffer): |
| * VM/RegisterFile.h: |
| |
| 2008-04-25 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fix signal catching magic |
| |
| The signal handlers are restored to _exit but are only set when |
| running under run-javascriptcore-tests. fprintf from a signal |
| handler is not safe. |
| |
| * kjs/testkjs.cpp: |
| (main): |
| (parseArguments): |
| * tests/mozilla/jsDriver.pl: |
| |
| 2008-04-25 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Bug 18732: SQUIRRELFISH: exceptions thrown by native constructors are ignored |
| <https://bugs.webkit.org/show_bug.cgi?id=18732> |
| |
| Fixes another regression test. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-04-25 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Bug 18728: SQUIRRELFISH: invalid regular expression constants should throw exceptions |
| <https://bugs.webkit.org/show_bug.cgi?id=18728> |
| |
| Fixes another regression test. |
| |
| * kjs/nodes.cpp: |
| (KJS::RegExpNode::emitCode): |
| |
| 2008-04-24 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Geoffrey Garen. |
| |
| Bug 18735: SQUIRRELFISH: closures are sometimes given an incorrect 'this' value when called |
| <https://bugs.webkit.org/show_bug.cgi?id=18735> |
| |
| The overloaded toThisObject method was not copied over to JSActivation. |
| |
| Fixes two regression tests. |
| |
| * kjs/JSActivation.cpp: |
| (KJS::JSActivation::toThisObject): |
| * kjs/JSActivation.h: |
| |
| 2008-04-24 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Added support for arguments.callee. |
| |
| 2008-04-24 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bug 18628: SQUIRRELFISH: need to support recursion limit |
| <https://bugs.webkit.org/show_bug.cgi?id=18628> |
| |
| Partial fix -- this gets us some of the required bounds checking, but not |
| complete coverage. But it does manage to do them without regressing :D |
| |
| * VM/ExceptionHelpers.cpp: |
| (KJS::createError): |
| (KJS::createStackOverflowError): |
| * VM/ExceptionHelpers.h: |
| * VM/Machine.cpp: |
| (KJS::slideRegisterWindowForCall): |
| (KJS::Machine::execute): |
| (KJS::Machine::privateExecute): |
| * VM/RegisterFile.cpp: |
| * VM/RegisterFile.h: |
| (KJS::RegisterFile::): |
| (KJS::RegisterFile::RegisterFile): |
| (KJS::RegisterFile::grow): |
| |
| 2008-04-24 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| A tiny bit more handling of "arguments": create a real, but mostly |
| hollow, arguments object. |
| |
| Fixes 2 regression tests. |
| |
| 2008-04-24 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Bug 18717: SQUIRRELFISH: eval returns the wrong value for a variable declaration statement |
| <https://bugs.webkit.org/show_bug.cgi?id=18717> |
| |
| Fixes a regression test, but exposes the failure of another due to the |
| lack of getters and setters. |
| |
| * kjs/nodes.cpp: |
| (KJS::ConstDeclNode::emitCodeSingle): |
| (KJS::ConstDeclNode::emitCode): |
| (KJS::ConstStatementNode::emitCode): |
| (KJS::VarStatementNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-04-24 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Print a CRASH statement when crashing, so test failures are not a |
| mystery. |
| |
| * kjs/testkjs.cpp: |
| (handleCrash): |
| (main): |
| |
| 2008-04-24 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Geoffrey Garen. |
| |
| Bug 18716: SQUIRRELFISH: typeof should return undefined for an undefined variable reference |
| <https://bugs.webkit.org/show_bug.cgi?id=18716> |
| |
| This fixes 2 more regression tests. |
| |
| * kjs/nodes.cpp: |
| (KJS::TypeOfResolveNode::emitCode): |
| |
| 2008-04-24 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Put the callee in the call frame. |
| |
| Necessary in order to support "arguments" and "arguments.callee". |
| |
| Also fixes a latent GC bug, where an executing function could be |
| subject to GC if the register holding it were overwritten. Here's |
| an example that would have caused problems: |
| |
| function f() |
| { |
| // Flood the machine stack to eliminate any old pointers to f. |
| g.call({}); |
| |
| // Overwrite f in the register file. |
| f = 1; |
| |
| // Force a GC. |
| for (var i = 0; i < 5000; ++i) { |
| ({}); |
| } |
| |
| // Welcome to crash-ville. |
| } |
| |
| function g() |
| { |
| } |
| |
| f(); |
| |
| * VM/Machine.h: Changed the order of arguments to |
| execute(FunctionBodyNode*...) to match the other execute functions. |
| * kjs/function.cpp: Updated to match new argument requirements from |
| execute(FunctionBodyNode*...). Renamed newObj to thisObj to match the |
| rest of JavaScriptCore. |
| |
| SunSpider reports no change. |
| |
| 2008-04-23 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Bug 18707: SQUIRRELFISH: eval always performs toString() on its argument |
| <https://bugs.webkit.org/show_bug.cgi?id=18707> |
| |
| This fixes 4 more regression tests. |
| |
| * VM/Machine.cpp: |
| (KJS::eval): |
| |
| 2008-04-23 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fix logic bug in SegmentedVector::grow which would sometimes fail to resize a segment when needed |
| |
| Fixes 3 JSC tests. |
| |
| * VM/SegmentedVector.h: |
| (KJS::SegmentedVector::grow): |
| |
| 2008-04-23 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Degenerate handling of "arguments" as a property of the activation |
| object. Currently, we just return a vanilla object. |
| |
| SunSpider reports no change. |
| |
| Fixes: |
| |
| ecma_3/Function/regress-94506.js. |
| |
| Reveals to have been secretly broken: |
| |
| ecma_3/Function/15.3.4.3-1.js |
| ecma_3/Function/15.3.4.4-1.js |
| |
| These tests were passing incorrectly. testkjs creates a global array |
| named "arguments" to hold command-line arguments. That array was |
| tricking these tests into thinking that an arguments object with length |
| 0 had been created. Since our new vanilla object shadows the global |
| property named arguments, that object no longer fools these tests into |
| passing. |
| |
| Net change: +1 failing test. |
| |
| * kjs/AllInOneFile.cpp: Had to put JSActivation.cpp into AllInOneFile.cpp |
| to solve a surprising 8.6% regression in bitops-3bit-bits-in-byte. |
| |
| 2008-04-23 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - save and restore callFrame |
| |
| * VM/Machine.cpp: |
| (KJS::slideRegisterWindowForCall): |
| (KJS::Machine::execute): |
| (KJS::Machine::privateExecute): |
| * kjs/testkjs.cpp: |
| (main): |
| |
| 2008-04-23 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Fixed scopes for named function expressions. |
| |
| Fixes one regression test. |
| |
| Two changes here: |
| |
| (1) The function's name is supposed to have attributes DontDelete, |
| ReadOnly, regardless of the type of code executing. |
| |
| (2) Push the name object on the function's scope chain, rather than |
| the ExecState's scope chain because, well, that's where it belongs. |
| |
| 2008-04-23 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Inlined JSObject::putDirect, for a .4% SunSpider speedup. |
| |
| I did this as a first step toward removing nodes.cpp from |
| AllInOneFile.cpp, but I'm putting that larger project aside for now. |
| |
| 2008-04-23 Maciej Stachowiak <mjs@apple.com> |
| |
| Rubber stamped by Geoff. |
| |
| - add OldInterpreterExecState class and use it in dead code |
| |
| This will allow removing things from the real ExecState class |
| without having to figure out how to remove all this code without |
| getting a perf regression. |
| |
| * kjs/nodes.cpp: |
| (KJS::ExpressionNode::evaluateToNumber): |
| (KJS::ExpressionNode::evaluateToBoolean): |
| (KJS::ExpressionNode::evaluateToInt32): |
| (KJS::ExpressionNode::evaluateToUInt32): |
| (KJS::Node::setErrorCompletion): |
| (KJS::Node::throwError): |
| (KJS::Node::throwUndefinedVariableError): |
| (KJS::Node::handleException): |
| (KJS::Node::rethrowException): |
| (KJS::BreakpointCheckStatement::execute): |
| (KJS::BreakpointCheckStatement::optimizeVariableAccess): |
| (KJS::NullNode::evaluate): |
| (KJS::FalseNode::evaluate): |
| (KJS::TrueNode::evaluate): |
| (KJS::NumberNode::evaluate): |
| (KJS::NumberNode::evaluateToNumber): |
| (KJS::NumberNode::evaluateToBoolean): |
| (KJS::NumberNode::evaluateToInt32): |
| (KJS::NumberNode::evaluateToUInt32): |
| (KJS::ImmediateNumberNode::evaluate): |
| (KJS::ImmediateNumberNode::evaluateToInt32): |
| (KJS::ImmediateNumberNode::evaluateToUInt32): |
| (KJS::StringNode::evaluate): |
| (KJS::StringNode::evaluateToNumber): |
| (KJS::StringNode::evaluateToBoolean): |
| (KJS::RegExpNode::evaluate): |
| (KJS::ThisNode::evaluate): |
| (KJS::ResolveNode::inlineEvaluate): |
| (KJS::ResolveNode::evaluate): |
| (KJS::ResolveNode::evaluateToNumber): |
| (KJS::ResolveNode::evaluateToBoolean): |
| (KJS::ResolveNode::evaluateToInt32): |
| (KJS::ResolveNode::evaluateToUInt32): |
| (KJS::getSymbolTableEntry): |
| (KJS::ResolveNode::optimizeVariableAccess): |
| (KJS::LocalVarAccessNode::inlineEvaluate): |
| (KJS::LocalVarAccessNode::evaluate): |
| (KJS::LocalVarAccessNode::evaluateToNumber): |
| (KJS::LocalVarAccessNode::evaluateToBoolean): |
| (KJS::LocalVarAccessNode::evaluateToInt32): |
| (KJS::LocalVarAccessNode::evaluateToUInt32): |
| (KJS::getNonLocalSymbol): |
| (KJS::ScopedVarAccessNode::inlineEvaluate): |
| (KJS::ScopedVarAccessNode::evaluate): |
| (KJS::ScopedVarAccessNode::evaluateToNumber): |
| (KJS::ScopedVarAccessNode::evaluateToBoolean): |
| (KJS::ScopedVarAccessNode::evaluateToInt32): |
| (KJS::ScopedVarAccessNode::evaluateToUInt32): |
| (KJS::NonLocalVarAccessNode::inlineEvaluate): |
| (KJS::NonLocalVarAccessNode::evaluate): |
| (KJS::NonLocalVarAccessNode::evaluateToNumber): |
| (KJS::NonLocalVarAccessNode::evaluateToBoolean): |
| (KJS::NonLocalVarAccessNode::evaluateToInt32): |
| (KJS::NonLocalVarAccessNode::evaluateToUInt32): |
| (KJS::ElementNode::optimizeVariableAccess): |
| (KJS::ElementNode::evaluate): |
| (KJS::ArrayNode::optimizeVariableAccess): |
| (KJS::ArrayNode::evaluate): |
| (KJS::ObjectLiteralNode::optimizeVariableAccess): |
| (KJS::ObjectLiteralNode::evaluate): |
| (KJS::PropertyListNode::optimizeVariableAccess): |
| (KJS::PropertyListNode::evaluate): |
| (KJS::PropertyNode::optimizeVariableAccess): |
| (KJS::PropertyNode::evaluate): |
| (KJS::BracketAccessorNode::optimizeVariableAccess): |
| (KJS::BracketAccessorNode::inlineEvaluate): |
| (KJS::BracketAccessorNode::evaluate): |
| (KJS::BracketAccessorNode::evaluateToNumber): |
| (KJS::BracketAccessorNode::evaluateToBoolean): |
| (KJS::BracketAccessorNode::evaluateToInt32): |
| (KJS::BracketAccessorNode::evaluateToUInt32): |
| (KJS::DotAccessorNode::optimizeVariableAccess): |
| (KJS::DotAccessorNode::inlineEvaluate): |
| (KJS::DotAccessorNode::evaluate): |
| (KJS::DotAccessorNode::evaluateToNumber): |
| (KJS::DotAccessorNode::evaluateToBoolean): |
| (KJS::DotAccessorNode::evaluateToInt32): |
| (KJS::DotAccessorNode::evaluateToUInt32): |
| (KJS::ArgumentListNode::optimizeVariableAccess): |
| (KJS::ArgumentListNode::evaluateList): |
| (KJS::ArgumentsNode::optimizeVariableAccess): |
| (KJS::NewExprNode::optimizeVariableAccess): |
| (KJS::NewExprNode::inlineEvaluate): |
| (KJS::NewExprNode::evaluate): |
| (KJS::NewExprNode::evaluateToNumber): |
| (KJS::NewExprNode::evaluateToBoolean): |
| (KJS::NewExprNode::evaluateToInt32): |
| (KJS::NewExprNode::evaluateToUInt32): |
| (KJS::ExpressionNode::resolveAndCall): |
| (KJS::EvalFunctionCallNode::optimizeVariableAccess): |
| (KJS::EvalFunctionCallNode::evaluate): |
| (KJS::FunctionCallValueNode::optimizeVariableAccess): |
| (KJS::FunctionCallValueNode::evaluate): |
| (KJS::FunctionCallResolveNode::optimizeVariableAccess): |
| (KJS::FunctionCallResolveNode::inlineEvaluate): |
| (KJS::FunctionCallResolveNode::evaluate): |
| (KJS::FunctionCallResolveNode::evaluateToNumber): |
| (KJS::FunctionCallResolveNode::evaluateToBoolean): |
| (KJS::FunctionCallResolveNode::evaluateToInt32): |
| (KJS::FunctionCallResolveNode::evaluateToUInt32): |
| (KJS::LocalVarFunctionCallNode::inlineEvaluate): |
| (KJS::LocalVarFunctionCallNode::evaluate): |
| (KJS::LocalVarFunctionCallNode::evaluateToNumber): |
| (KJS::LocalVarFunctionCallNode::evaluateToBoolean): |
| (KJS::LocalVarFunctionCallNode::evaluateToInt32): |
| (KJS::LocalVarFunctionCallNode::evaluateToUInt32): |
| (KJS::ScopedVarFunctionCallNode::inlineEvaluate): |
| (KJS::ScopedVarFunctionCallNode::evaluate): |
| (KJS::ScopedVarFunctionCallNode::evaluateToNumber): |
| (KJS::ScopedVarFunctionCallNode::evaluateToBoolean): |
| (KJS::ScopedVarFunctionCallNode::evaluateToInt32): |
| (KJS::ScopedVarFunctionCallNode::evaluateToUInt32): |
| (KJS::NonLocalVarFunctionCallNode::inlineEvaluate): |
| (KJS::NonLocalVarFunctionCallNode::evaluate): |
| (KJS::NonLocalVarFunctionCallNode::evaluateToNumber): |
| (KJS::NonLocalVarFunctionCallNode::evaluateToBoolean): |
| (KJS::NonLocalVarFunctionCallNode::evaluateToInt32): |
| (KJS::NonLocalVarFunctionCallNode::evaluateToUInt32): |
| (KJS::FunctionCallBracketNode::optimizeVariableAccess): |
| (KJS::FunctionCallBracketNode::evaluate): |
| (KJS::FunctionCallDotNode::optimizeVariableAccess): |
| (KJS::FunctionCallDotNode::inlineEvaluate): |
| (KJS::FunctionCallDotNode::evaluate): |
| (KJS::FunctionCallDotNode::evaluateToNumber): |
| (KJS::FunctionCallDotNode::evaluateToBoolean): |
| (KJS::FunctionCallDotNode::evaluateToInt32): |
| (KJS::FunctionCallDotNode::evaluateToUInt32): |
| (KJS::PostIncResolveNode::optimizeVariableAccess): |
| (KJS::PostIncResolveNode::evaluate): |
| (KJS::PostIncLocalVarNode::evaluate): |
| (KJS::PostDecResolveNode::optimizeVariableAccess): |
| (KJS::PostDecResolveNode::evaluate): |
| (KJS::PostDecLocalVarNode::evaluate): |
| (KJS::PostDecLocalVarNode::inlineEvaluateToNumber): |
| (KJS::PostDecLocalVarNode::evaluateToNumber): |
| (KJS::PostDecLocalVarNode::evaluateToBoolean): |
| (KJS::PostDecLocalVarNode::evaluateToInt32): |
| (KJS::PostDecLocalVarNode::evaluateToUInt32): |
| (KJS::PostfixBracketNode::optimizeVariableAccess): |
| (KJS::PostIncBracketNode::evaluate): |
| (KJS::PostDecBracketNode::evaluate): |
| (KJS::PostfixDotNode::optimizeVariableAccess): |
| (KJS::PostIncDotNode::evaluate): |
| (KJS::PostDecDotNode::evaluate): |
| (KJS::PostfixErrorNode::evaluate): |
| (KJS::DeleteResolveNode::optimizeVariableAccess): |
| (KJS::DeleteResolveNode::evaluate): |
| (KJS::LocalVarDeleteNode::evaluate): |
| (KJS::DeleteBracketNode::optimizeVariableAccess): |
| (KJS::DeleteBracketNode::evaluate): |
| (KJS::DeleteDotNode::optimizeVariableAccess): |
| (KJS::DeleteDotNode::evaluate): |
| (KJS::DeleteValueNode::optimizeVariableAccess): |
| (KJS::DeleteValueNode::evaluate): |
| (KJS::VoidNode::optimizeVariableAccess): |
| (KJS::VoidNode::evaluate): |
| (KJS::TypeOfValueNode::optimizeVariableAccess): |
| (KJS::TypeOfResolveNode::optimizeVariableAccess): |
| (KJS::LocalVarTypeOfNode::evaluate): |
| (KJS::TypeOfResolveNode::evaluate): |
| (KJS::TypeOfValueNode::evaluate): |
| (KJS::PreIncResolveNode::optimizeVariableAccess): |
| (KJS::PreIncLocalVarNode::evaluate): |
| (KJS::PreIncResolveNode::evaluate): |
| (KJS::PreDecResolveNode::optimizeVariableAccess): |
| (KJS::PreDecLocalVarNode::evaluate): |
| (KJS::PreDecResolveNode::evaluate): |
| (KJS::PreIncConstNode::evaluate): |
| (KJS::PreDecConstNode::evaluate): |
| (KJS::PostIncConstNode::evaluate): |
| (KJS::PostDecConstNode::evaluate): |
| (KJS::PrefixBracketNode::optimizeVariableAccess): |
| (KJS::PreIncBracketNode::evaluate): |
| (KJS::PreDecBracketNode::evaluate): |
| (KJS::PrefixDotNode::optimizeVariableAccess): |
| (KJS::PreIncDotNode::evaluate): |
| (KJS::PreDecDotNode::evaluate): |
| (KJS::PrefixErrorNode::evaluate): |
| (KJS::UnaryPlusNode::optimizeVariableAccess): |
| (KJS::UnaryPlusNode::evaluate): |
| (KJS::UnaryPlusNode::evaluateToBoolean): |
| (KJS::UnaryPlusNode::evaluateToNumber): |
| (KJS::UnaryPlusNode::evaluateToInt32): |
| (KJS::UnaryPlusNode::evaluateToUInt32): |
| (KJS::NegateNode::optimizeVariableAccess): |
| (KJS::NegateNode::evaluate): |
| (KJS::NegateNode::evaluateToNumber): |
| (KJS::BitwiseNotNode::optimizeVariableAccess): |
| (KJS::BitwiseNotNode::inlineEvaluateToInt32): |
| (KJS::BitwiseNotNode::evaluate): |
| (KJS::BitwiseNotNode::evaluateToNumber): |
| (KJS::BitwiseNotNode::evaluateToBoolean): |
| (KJS::BitwiseNotNode::evaluateToInt32): |
| (KJS::BitwiseNotNode::evaluateToUInt32): |
| (KJS::LogicalNotNode::optimizeVariableAccess): |
| (KJS::LogicalNotNode::evaluate): |
| (KJS::LogicalNotNode::evaluateToBoolean): |
| (KJS::MultNode::optimizeVariableAccess): |
| (KJS::MultNode::inlineEvaluateToNumber): |
| (KJS::MultNode::evaluate): |
| (KJS::MultNode::evaluateToNumber): |
| (KJS::MultNode::evaluateToBoolean): |
| (KJS::MultNode::evaluateToInt32): |
| (KJS::MultNode::evaluateToUInt32): |
| (KJS::DivNode::optimizeVariableAccess): |
| (KJS::DivNode::inlineEvaluateToNumber): |
| (KJS::DivNode::evaluate): |
| (KJS::DivNode::evaluateToNumber): |
| (KJS::DivNode::evaluateToInt32): |
| (KJS::DivNode::evaluateToUInt32): |
| (KJS::ModNode::optimizeVariableAccess): |
| (KJS::ModNode::inlineEvaluateToNumber): |
| (KJS::ModNode::evaluate): |
| (KJS::ModNode::evaluateToNumber): |
| (KJS::ModNode::evaluateToBoolean): |
| (KJS::ModNode::evaluateToInt32): |
| (KJS::ModNode::evaluateToUInt32): |
| (KJS::throwOutOfMemoryErrorToNumber): |
| (KJS::addSlowCase): |
| (KJS::addSlowCaseToNumber): |
| (KJS::add): |
| (KJS::addToNumber): |
| (KJS::AddNode::optimizeVariableAccess): |
| (KJS::AddNode::evaluate): |
| (KJS::AddNode::inlineEvaluateToNumber): |
| (KJS::AddNode::evaluateToNumber): |
| (KJS::AddNode::evaluateToInt32): |
| (KJS::AddNode::evaluateToUInt32): |
| (KJS::AddNumbersNode::inlineEvaluateToNumber): |
| (KJS::AddNumbersNode::evaluate): |
| (KJS::AddNumbersNode::evaluateToNumber): |
| (KJS::AddNumbersNode::evaluateToInt32): |
| (KJS::AddNumbersNode::evaluateToUInt32): |
| (KJS::AddStringsNode::evaluate): |
| (KJS::AddStringLeftNode::evaluate): |
| (KJS::AddStringRightNode::evaluate): |
| (KJS::SubNode::optimizeVariableAccess): |
| (KJS::SubNode::inlineEvaluateToNumber): |
| (KJS::SubNode::evaluate): |
| (KJS::SubNode::evaluateToNumber): |
| (KJS::SubNode::evaluateToInt32): |
| (KJS::SubNode::evaluateToUInt32): |
| (KJS::LeftShiftNode::optimizeVariableAccess): |
| (KJS::LeftShiftNode::inlineEvaluateToInt32): |
| (KJS::LeftShiftNode::evaluate): |
| (KJS::LeftShiftNode::evaluateToNumber): |
| (KJS::LeftShiftNode::evaluateToInt32): |
| (KJS::LeftShiftNode::evaluateToUInt32): |
| (KJS::RightShiftNode::optimizeVariableAccess): |
| (KJS::RightShiftNode::inlineEvaluateToInt32): |
| (KJS::RightShiftNode::evaluate): |
| (KJS::RightShiftNode::evaluateToNumber): |
| (KJS::RightShiftNode::evaluateToInt32): |
| (KJS::RightShiftNode::evaluateToUInt32): |
| (KJS::UnsignedRightShiftNode::optimizeVariableAccess): |
| (KJS::UnsignedRightShiftNode::inlineEvaluateToUInt32): |
| (KJS::UnsignedRightShiftNode::evaluate): |
| (KJS::UnsignedRightShiftNode::evaluateToNumber): |
| (KJS::UnsignedRightShiftNode::evaluateToInt32): |
| (KJS::UnsignedRightShiftNode::evaluateToUInt32): |
| (KJS::lessThan): |
| (KJS::lessThanEq): |
| (KJS::LessNode::optimizeVariableAccess): |
| (KJS::LessNode::inlineEvaluateToBoolean): |
| (KJS::LessNode::evaluate): |
| (KJS::LessNode::evaluateToBoolean): |
| (KJS::LessNumbersNode::inlineEvaluateToBoolean): |
| (KJS::LessNumbersNode::evaluate): |
| (KJS::LessNumbersNode::evaluateToBoolean): |
| (KJS::LessStringsNode::inlineEvaluateToBoolean): |
| (KJS::LessStringsNode::evaluate): |
| (KJS::LessStringsNode::evaluateToBoolean): |
| (KJS::GreaterNode::optimizeVariableAccess): |
| (KJS::GreaterNode::inlineEvaluateToBoolean): |
| (KJS::GreaterNode::evaluate): |
| (KJS::GreaterNode::evaluateToBoolean): |
| (KJS::LessEqNode::optimizeVariableAccess): |
| (KJS::LessEqNode::inlineEvaluateToBoolean): |
| (KJS::LessEqNode::evaluate): |
| (KJS::LessEqNode::evaluateToBoolean): |
| (KJS::GreaterEqNode::optimizeVariableAccess): |
| (KJS::GreaterEqNode::inlineEvaluateToBoolean): |
| (KJS::GreaterEqNode::evaluate): |
| (KJS::GreaterEqNode::evaluateToBoolean): |
| (KJS::InstanceOfNode::optimizeVariableAccess): |
| (KJS::InstanceOfNode::evaluate): |
| (KJS::InstanceOfNode::evaluateToBoolean): |
| (KJS::InNode::optimizeVariableAccess): |
| (KJS::InNode::evaluate): |
| (KJS::InNode::evaluateToBoolean): |
| (KJS::EqualNode::optimizeVariableAccess): |
| (KJS::EqualNode::inlineEvaluateToBoolean): |
| (KJS::EqualNode::evaluate): |
| (KJS::EqualNode::evaluateToBoolean): |
| (KJS::NotEqualNode::optimizeVariableAccess): |
| (KJS::NotEqualNode::inlineEvaluateToBoolean): |
| (KJS::NotEqualNode::evaluate): |
| (KJS::NotEqualNode::evaluateToBoolean): |
| (KJS::StrictEqualNode::optimizeVariableAccess): |
| (KJS::StrictEqualNode::inlineEvaluateToBoolean): |
| (KJS::StrictEqualNode::evaluate): |
| (KJS::StrictEqualNode::evaluateToBoolean): |
| (KJS::NotStrictEqualNode::optimizeVariableAccess): |
| (KJS::NotStrictEqualNode::inlineEvaluateToBoolean): |
| (KJS::NotStrictEqualNode::evaluate): |
| (KJS::NotStrictEqualNode::evaluateToBoolean): |
| (KJS::BitAndNode::optimizeVariableAccess): |
| (KJS::BitAndNode::evaluate): |
| (KJS::BitAndNode::inlineEvaluateToInt32): |
| (KJS::BitAndNode::evaluateToNumber): |
| (KJS::BitAndNode::evaluateToBoolean): |
| (KJS::BitAndNode::evaluateToInt32): |
| (KJS::BitAndNode::evaluateToUInt32): |
| (KJS::BitXOrNode::optimizeVariableAccess): |
| (KJS::BitXOrNode::inlineEvaluateToInt32): |
| (KJS::BitXOrNode::evaluate): |
| (KJS::BitXOrNode::evaluateToNumber): |
| (KJS::BitXOrNode::evaluateToBoolean): |
| (KJS::BitXOrNode::evaluateToInt32): |
| (KJS::BitXOrNode::evaluateToUInt32): |
| (KJS::BitOrNode::optimizeVariableAccess): |
| (KJS::BitOrNode::inlineEvaluateToInt32): |
| (KJS::BitOrNode::evaluate): |
| (KJS::BitOrNode::evaluateToNumber): |
| (KJS::BitOrNode::evaluateToBoolean): |
| (KJS::BitOrNode::evaluateToInt32): |
| (KJS::BitOrNode::evaluateToUInt32): |
| (KJS::LogicalAndNode::optimizeVariableAccess): |
| (KJS::LogicalAndNode::evaluate): |
| (KJS::LogicalAndNode::evaluateToBoolean): |
| (KJS::LogicalOrNode::optimizeVariableAccess): |
| (KJS::LogicalOrNode::evaluate): |
| (KJS::LogicalOrNode::evaluateToBoolean): |
| (KJS::ConditionalNode::optimizeVariableAccess): |
| (KJS::ConditionalNode::evaluate): |
| (KJS::ConditionalNode::evaluateToBoolean): |
| (KJS::ConditionalNode::evaluateToNumber): |
| (KJS::ConditionalNode::evaluateToInt32): |
| (KJS::ConditionalNode::evaluateToUInt32): |
| (KJS::valueForReadModifyAssignment): |
| (KJS::ReadModifyResolveNode::optimizeVariableAccess): |
| (KJS::AssignResolveNode::optimizeVariableAccess): |
| (KJS::ReadModifyLocalVarNode::evaluate): |
| (KJS::AssignLocalVarNode::evaluate): |
| (KJS::ReadModifyConstNode::evaluate): |
| (KJS::AssignConstNode::evaluate): |
| (KJS::ReadModifyResolveNode::evaluate): |
| (KJS::AssignResolveNode::evaluate): |
| (KJS::AssignDotNode::optimizeVariableAccess): |
| (KJS::AssignDotNode::evaluate): |
| (KJS::ReadModifyDotNode::optimizeVariableAccess): |
| (KJS::ReadModifyDotNode::evaluate): |
| (KJS::AssignErrorNode::evaluate): |
| (KJS::AssignBracketNode::optimizeVariableAccess): |
| (KJS::AssignBracketNode::evaluate): |
| (KJS::ReadModifyBracketNode::optimizeVariableAccess): |
| (KJS::ReadModifyBracketNode::evaluate): |
| (KJS::CommaNode::optimizeVariableAccess): |
| (KJS::CommaNode::evaluate): |
| (KJS::ConstDeclNode::optimizeVariableAccess): |
| (KJS::ConstDeclNode::handleSlowCase): |
| (KJS::ConstDeclNode::evaluateSingle): |
| (KJS::ConstDeclNode::evaluate): |
| (KJS::ConstStatementNode::optimizeVariableAccess): |
| (KJS::ConstStatementNode::execute): |
| (KJS::statementListExecute): |
| (KJS::BlockNode::optimizeVariableAccess): |
| (KJS::BlockNode::execute): |
| (KJS::EmptyStatementNode::execute): |
| (KJS::ExprStatementNode::optimizeVariableAccess): |
| (KJS::ExprStatementNode::execute): |
| (KJS::VarStatementNode::optimizeVariableAccess): |
| (KJS::VarStatementNode::execute): |
| (KJS::IfNode::optimizeVariableAccess): |
| (KJS::IfNode::execute): |
| (KJS::IfElseNode::optimizeVariableAccess): |
| (KJS::IfElseNode::execute): |
| (KJS::DoWhileNode::optimizeVariableAccess): |
| (KJS::DoWhileNode::execute): |
| (KJS::WhileNode::optimizeVariableAccess): |
| (KJS::WhileNode::execute): |
| (KJS::ForNode::optimizeVariableAccess): |
| (KJS::ForNode::execute): |
| (KJS::ForInNode::optimizeVariableAccess): |
| (KJS::ForInNode::execute): |
| (KJS::ContinueNode::execute): |
| (KJS::BreakNode::execute): |
| (KJS::ReturnNode::optimizeVariableAccess): |
| (KJS::ReturnNode::execute): |
| (KJS::WithNode::optimizeVariableAccess): |
| (KJS::WithNode::execute): |
| (KJS::CaseClauseNode::optimizeVariableAccess): |
| (KJS::CaseClauseNode::evaluate): |
| (KJS::CaseClauseNode::executeStatements): |
| (KJS::ClauseListNode::optimizeVariableAccess): |
| (KJS::CaseBlockNode::optimizeVariableAccess): |
| (KJS::CaseBlockNode::executeBlock): |
| (KJS::SwitchNode::optimizeVariableAccess): |
| (KJS::SwitchNode::execute): |
| (KJS::LabelNode::optimizeVariableAccess): |
| (KJS::LabelNode::execute): |
| (KJS::ThrowNode::optimizeVariableAccess): |
| (KJS::ThrowNode::execute): |
| (KJS::TryNode::optimizeVariableAccess): |
| (KJS::TryNode::execute): |
| (KJS::ProgramNode::initializeSymbolTable): |
| (KJS::ScopeNode::optimizeVariableAccess): |
| (KJS::ProgramNode::processDeclarations): |
| (KJS::EvalNode::processDeclarations): |
| (KJS::ProgramNode::execute): |
| (KJS::EvalNode::execute): |
| (KJS::FunctionBodyNodeWithDebuggerHooks::execute): |
| (KJS::FuncDeclNode::execute): |
| (KJS::FuncExprNode::evaluate): |
| * kjs/nodes.h: |
| (KJS::Node::): |
| (KJS::FalseNode::): |
| (KJS::TrueNode::): |
| (KJS::ArgumentsNode::): |
| |
| 2008-04-23 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Bug 18672: SQUIRRELFISH: codegen fails with a large number of temporaries |
| <https://bugs.webkit.org/show_bug.cgi?id=18672> |
| |
| Add a SegmentedVector type, which provides a Vector<T> which maintains |
| existing memory locations during resize. This allows dynamically sizing |
| local, temporary and label "vectors" in CodeGenerator. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::addVar): |
| (KJS::CodeGenerator::CodeGenerator): |
| (KJS::CodeGenerator::newTemporary): |
| (KJS::CodeGenerator::newLabel): |
| * VM/CodeGenerator.h: |
| * VM/SegmentedVector.h: Added. |
| (KJS::SegmentedVector::SegmentedVector): |
| (KJS::SegmentedVector::~SegmentedVector): |
| (KJS::SegmentedVector::last): |
| (KJS::SegmentedVector::append): |
| (KJS::SegmentedVector::removeLast): |
| (KJS::SegmentedVector::size): |
| (KJS::SegmentedVector::operator[]): |
| (KJS::SegmentedVector::resize): |
| (KJS::SegmentedVector::shrink): |
| (KJS::SegmentedVector::grow): |
| |
| 2008-04-23 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| A little refactoring in preparation for supporting 'arguments'. |
| |
| Fixes 2 regression tests. |
| |
| SunSpider reports no change. |
| |
| We now check the activation register, instead of the codeBlock, to |
| determine whether we need to tear off the activation. This is to support |
| "f.arguments", which will create an activation/arguments pair for f, |
| even though the needsFullScopeChain flag is false for f's codeBlock. |
| |
| The test fixes resulted from calling initializeCallFrame for re-entrant |
| function code, instead of initializing (not enough) parts of the call |
| frame by hand. |
| |
| 2008-04-22 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Sam. |
| |
| - propagate the "this" value properly to local eval |
| |
| (fixes a measly one regression test) |
| |
| * VM/CodeBlock.h: |
| (KJS::CodeBlock::CodeBlock): |
| (KJS::ProgramCodeBlock::ProgramCodeBlock): |
| (KJS::EvalCodeBlock::EvalCodeBlock): |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-04-22 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Add support for function declarations in eval code. |
| |
| (this fixes 12 more regression tests) |
| |
| * VM/CodeBlock.h: |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::CodeGenerator): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): |
| * kjs/nodes.cpp: |
| (KJS::EvalNode::generateCode): |
| |
| 2008-04-22 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Implement LabelNode. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::pushJumpContext): |
| (KJS::CodeGenerator::jumpContextForContinue): |
| (KJS::CodeGenerator::jumpContextForBreak): |
| * VM/CodeGenerator.h: |
| * kjs/nodes.cpp: |
| (KJS::DoWhileNode::emitCode): |
| (KJS::WhileNode::emitCode): |
| (KJS::ForNode::emitCode): |
| (KJS::ForInNode::emitCode): |
| (KJS::ContinueNode::emitCode): |
| (KJS::BreakNode::emitCode): |
| (KJS::SwitchNode::emitCode): |
| (KJS::LabelNode::emitCode): |
| |
| 2008-04-22 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fixed crash when unwinding from exceptions inside eval. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::unwindCallFrame): Don't assume that the top of the |
| current call frame's scope chain is an activation: it can be the global |
| object, instead. |
| |
| 2008-04-22 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Geoff. |
| |
| * kjs/testkjs.cpp: |
| (main): Convert signals to exit codes, so that crashing tests are |
| detected as regression test failures. |
| |
| 2008-04-22 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt and Maciej Stachowiak. |
| |
| Renamed "needsActivation" to "needsFullScopeChain" because lying will |
| make hair grow on the backs of your hands. |
| |
| 2008-04-21 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Fixed ScopeChainNode lifetime problems: |
| |
| (1) In "with" and "catch" scopes, we would construct a ScopeChain |
| object and then jump across its destructor, leaking the ScopeChainNode |
| we had pushed. |
| |
| (2) In global and eval scopes, we would fail to initially ref |
| "scopeChain", causing us to overrelease it later. Now that we ref |
| "scopeChain" properly, we also need to deref it when the script |
| terminates. |
| |
| SunSpider reports a .2% regression, but an earlier round of ScopeChain |
| refactoring was a .4% speedup, so there. |
| |
| 2008-04-22 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Alexey. |
| |
| - use global object instead of null for "this" on unqualified calls |
| |
| This fixes 10 more JSC test regressions. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-04-22 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - throw proper exceptions for objects that don't implement call or construct |
| |
| This fixes 21 more JSC test regressions. It is also seemingly an |
| 0.5% progression. |
| |
| * VM/ExceptionHelpers.cpp: |
| (KJS::createNotAnObjectError): |
| (KJS::createNotAConstructorError): |
| (KJS::createNotAFunctionError): |
| * VM/ExceptionHelpers.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-04-21 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Implement emitCode for ConstDeclNode. |
| |
| This fixes the crash (assertion) in js1_5/Scope/scope-001.js |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::registerForLocalConstInit): |
| * VM/CodeGenerator.h: |
| * kjs/nodes.cpp: |
| (KJS::AssignResolveNode::emitCode): |
| (KJS::ConstDeclNode::emitCodeSingle): |
| (KJS::ConstDeclNode::emitCode): |
| (KJS::ConstStatementNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-04-21 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Sam. |
| |
| - add some support for the split window object |
| |
| This fixes many layout tests. |
| |
| * VM/Machine.cpp: |
| (KJS::resolveBaseAndFunc): Use toThisObject() to ensure we get the |
| wrapper global, if one exists, as the "this" object. |
| * kjs/function.cpp: |
| (KJS::globalFuncEval): Use toGlobalObject() to handle the wrapper |
| case properly. |
| |
| 2008-04-21 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - restore ScopeChain::operator= to avoid crash on many layout tests |
| |
| Otherwise, FunctionImp::setScope would cause a reference |
| underflow. I implemented using the copy construct and swap idiom. |
| |
| * kjs/scope_chain.h: |
| (KJS::ScopeChain::swap): |
| (KJS::ScopeChain::operator=): |
| |
| 2008-04-21 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Bug 18649: SQUIRRELFISH: correctly handle exceptions in eval code |
| <https://bugs.webkit.org/show_bug.cgi?id=18649> |
| |
| Allocate a callframe for eval() and initialise with a null codeBlock to |
| indicate native code. This prevents the unwinder from clobbering the |
| register stack. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): |
| |
| 2008-04-21 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Removed ScopeChain::push(ScopeChain&) because it was unused. Moved |
| ScopeChain::print to ScopeChainNode. |
| |
| ScopeChain is now nothing more than a resource-handling wrapper around |
| ScopeChainNode. |
| |
| 2008-04-21 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Bug 18671: SquirrelFish: continue inside switch fails |
| <https://bugs.webkit.org/show_bug.cgi?id=18671> |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::jumpContextForLabel): |
| * VM/CodeGenerator.h: |
| * kjs/nodes.cpp: |
| (KJS::ContinueNode::emitCode): |
| |
| 2008-04-21 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Moved push(JSObject*) and pop() from ScopeChain to ScopeChainNode, |
| rearranging scope_chain.h a bit. |
| |
| SunSpider reports no change. |
| |
| 2008-04-21 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Moved bottom() from ScopeChain to ScopeChainNode, simplifying it based |
| on the knowledge that the ScopeChain is never empty. |
| |
| SunSpider reports no change. |
| |
| 2008-04-21 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Moved begin() and end() from ScopeChain to ScopeChainNode. |
| |
| Also marked a few methods "const". |
| |
| SunSpider reports no change. |
| |
| 2008-04-21 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Turned ScopeChain::depth into a stand-alone function, and simplified it |
| a bit. |
| |
| I also moved ScopeChain::depth to Machine.cpp because it doesn't report |
| the true depth of the ScopeChain -- just the Machine's perspective of |
| its depth within a given call frame. |
| |
| SunSpider reports no change. |
| |
| 2008-04-21 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Removed indirection in ScopeChain::ref / ScopeChain::deref. |
| |
| SunSpider reports no change. |
| |
| * kjs/scope_chain.h: |
| (KJS::ScopeChain::ScopeChain): |
| (KJS::ScopeChain::~ScopeChain): |
| (KJS::ScopeChain::clear): |
| |
| 2008-04-21 Oliver Hunt <oliver@apple.com> |
| |
| Fix debug build |
| |
| * kjs/nodes.cpp: |
| (KJS::ConstDeclNode::evaluateSingle): |
| |
| 2008-04-21 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Bug 18664: SQUIRRELFISH: correctly throw a SyntaxError when parsing of eval code fails |
| <https://bugs.webkit.org/show_bug.cgi?id=18664> |
| |
| Correctly throw a SyntaxError when parsing of eval code fails. |
| |
| * VM/Machine.cpp: |
| (KJS::eval): |
| |
| 2008-04-21 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Partial fix for Bug 18649: SQUIRRELFISH: correctly handle exceptions in eval code |
| |
| Make sure we correct the register state before jumping to vm_throw. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-04-21 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Simplified ScopeChain ref/deref. |
| |
| SunSpider reports a .4% speedup. |
| |
| * kjs/scope_chain.h: |
| (KJS::ScopeChainNode::ref): Removed this function because it was nonsense. |
| ScopeChainNodes are initialized with a refCount of 1, so the loop was |
| guaranteed to iterate exactly once. |
| |
| 2008-04-21 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Removed support for empty ScopeChains. |
| |
| SunSpider reports no change. |
| |
| 2008-04-21 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Removed some completely unused ScopeChain member functions. |
| |
| SunSpider reports no change. |
| |
| 2008-04-21 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Avoid creating unnecessary ScopeChain objects, to reduce refcount churn. |
| |
| SunSpider reports no change. |
| |
| 2008-04-21 Maciej Stachowiak <mjs@apple.com> |
| |
| Rubber stamped by Alexey. |
| |
| Add some braces.x |
| |
| * kjs/testkjs.cpp: |
| (runWithScripts): |
| |
| 2008-04-21 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - only print "End:" output when -d flag is passed. |
| |
| This fixes half of our failing JSC regression tests. |
| |
| * kjs/testkjs.cpp: |
| (runWithScripts): |
| |
| 2008-04-21 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Add support for variable declarations in eval code. |
| |
| * VM/CodeBlock.h: |
| (KJS::EvalCodeBlock::EvalCodeBlock): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::CodeGenerator): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): |
| * VM/Machine.h: |
| * kjs/function.cpp: |
| (KJS::globalFuncEval): |
| * kjs/nodes.cpp: |
| (KJS::EvalNode::generateCode): |
| * kjs/nodes.h: |
| (KJS::EvalNode::): |
| |
| 2008-04-20 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Throw exceptions for invalid continue, break, and return statements. |
| |
| Simple refactoring and extension of Cameron's AssignErrorNode, etc patch |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::CodeGenerator): |
| (KJS::CodeGenerator::pushJumpContext): |
| (KJS::CodeGenerator::popJumpContext): |
| (KJS::CodeGenerator::jumpContextForLabel): |
| * VM/CodeGenerator.h: |
| * kjs/nodes.cpp: |
| (KJS::Node::emitThrowError): |
| (KJS::ContinueNode::emitCode): |
| (KJS::BreakNode::emitCode): |
| (KJS::ReturnNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-04-20 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Removed Machine.cpp from AllInOneFile.cpp, and manually inlined a few |
| things that used to be inlined automatically. |
| |
| 1.9% speedup on SunSpider. |
| |
| My hope is that we'll face fewer surprises in Machine.cpp codegen, now |
| that GCC is making fewer decisions. The speedup seems to confirm that. |
| |
| 2008-04-20 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bug 18642: Iterator context may get placed into the return register, leading to much badness |
| <https://bugs.webkit.org/show_bug.cgi?id=18642> |
| |
| To prevent incorrectly reusing what will become the result register for |
| eval and global code execution, we need to request and ref the destination |
| in advance of codegen. Unfortunately this may lead to unnecessary copying, |
| although in future we can probably limit this. Curiously SunSpider shows |
| a progression in a number of tests, although it comes out as a wash overall. |
| |
| * kjs/nodes.cpp: |
| (KJS::EvalNode::emitCode): |
| (KJS::ProgramNode::emitCode): |
| |
| 2008-04-20 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Add support for AssignErrorNode, PrefixErrorNode, and PostfixErrorNode. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitCreateError): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::PostfixErrorNode::emitCode): |
| (KJS::PrefixErrorNode::emitCode): |
| (KJS::AssignErrorNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-04-20 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff and Mark. |
| |
| Provide line number information in exceptions |
| |
| Simple patch, adds line number information metadata to CodeBlock |
| and a simple method to get the line number responsible for a given |
| Instruction*. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::lineNumberForVPC): |
| * VM/CodeBlock.h: |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::emitNode): |
| * VM/Machine.cpp: |
| (KJS::Machine::throwException): |
| |
| 2008-04-20 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Provide "sourceURL" in exceptions |
| |
| * VM/CodeBlock.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::throwException): |
| * kjs/nodes.cpp: |
| (KJS::EvalNode::generateCode): |
| (KJS::ProgramNode::generateCode): |
| |
| 2008-04-19 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Don't call emitCode directly on subnodes, instead use CodeGenerator::emitNode |
| |
| This patch just a preparation for tracking line numbers. |
| |
| * kjs/nodes.cpp: |
| (KJS::ObjectLiteralNode::emitCode): |
| (KJS::PropertyListNode::emitCode): |
| (KJS::ArgumentListNode::emitCode): |
| (KJS::TryNode::emitCode): |
| |
| 2008-04-19 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bug 18619: Support continue, break, and return in try .. finally blocks |
| <https://bugs.webkit.org/show_bug.cgi?id=18619> |
| |
| This patch replaces the current partial finally support (which uses code |
| duplication to achieve what it does) with a subroutine based approach. |
| This has a number of advantages over code duplication: |
| * Reduced code size |
| * Simplified exception handling as the finaliser code only exists in |
| one place, so no "magic" is needed to get the correct handler for a |
| finaliser. |
| * When we support instruction to line number mapping we won't need to |
| worry about the dramatic code movement caused by duplication |
| |
| On the downside it is necessary to add two new opcodes, op_jsr and op_sret |
| to enter and exit the finaliser subroutines, happily SunSpider reports |
| a performance progression (gcc amazes me) and ubench reports a wash. |
| |
| While jsr and sret provide a mechanism that allows us to enter and exit |
| any arbitrary finaliser we need to, it was still necessary to increase |
| the amount of information tracked when entering and exiting both finaliser |
| scopes and dynamic scopes ("with"). This means "scopeDepth" is now |
| the combination of "finaliserDepth" and "dynamicScopeDepth". We also |
| now use a scopeContextStack to ensure that we pop scopes and execute |
| finalisers in the correct order. This increases the cost of "with" nodes |
| during codegen, but it should not be significant enough to effect real |
| world performance and greatly simplifies codegen for return, break and |
| continue when interacting with finalisers. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| Pretty printing of jsr/sret opcodes |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::CodeGenerator): |
| (KJS::CodeGenerator::emitPushScope): |
| (KJS::CodeGenerator::emitPopScope): |
| Dynamic scopes need to be tracked on the scopeContextStack now |
| |
| (KJS::CodeGenerator::pushFinallyContext): |
| (KJS::CodeGenerator::popFinallyContext): |
| Handle entry and exit from code regions with finalisers. This is |
| needed solely to support return, continue and break inside finaliser |
| regions. |
| |
| (KJS::CodeGenerator::emitComplexJumpScopes): |
| Helper function for emitJumpScopes to handle the complex codegen |
| needed to handle return, continue and break inside a finaliser region |
| |
| (KJS::CodeGenerator::emitJumpScopes): |
| Updated to be aware of finalisers, if a cross-scope jump occurs inside |
| a finaliser we hand off codegen to emitComplexJumpScopes, otherwise |
| we can handle the normal (trivial) case with a single instruction. |
| |
| (KJS::CodeGenerator::emitJumpSubroutine): |
| (KJS::CodeGenerator::emitSubroutineReturn): |
| Trivial opcode emitter functions. |
| |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::scopeDepth): |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| Implement op_jsr and op_sret. |
| |
| * VM/Opcode.h: |
| Ad op_jsr and op_sret |
| |
| * kjs/nodes.cpp: |
| (KJS::TryNode::emitCode): |
| Fix codegen for new finaliser model. |
| |
| 2008-04-17 Mark Rowe <mrowe@apple.com> |
| |
| Rubber-stamped by Oliver Hunt. |
| |
| Remove unnecessary files from testkjs, testapi and minidom targets. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2008-04-17 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fixed ASSERT seen during run-sunspider of a debug build. |
| |
| * VM/CodeGenerator.h: Made the default codegen buffers bigger. SunSpider |
| runs all tests in one global environment, so you end up with more than |
| 128 locals. This is just a stop-gap until we code up a real |
| solution to arbitrary symbol and label limits. |
| |
| 2008-04-17 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fixed a bug in exception unwinding, where we wouldn't deref the scope |
| chain in global scope, so we would leak ScopeChainNodes when exceptions |
| were thrown inside "with" and "catch" scopes. |
| |
| Also did some cleanup of the unwinding code along the way. |
| |
| Scope chain reference counting is still wrong in a few ways. I thought |
| I would fix this portion of it first. |
| |
| run-sunspider shows no change. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::unwindCallFrame): |
| (KJS::Machine::throwException): |
| (KJS::Machine::privateExecute): |
| * VM/Machine.h: |
| |
| 2008-04-17 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Add more exception checking to toNumber conversions |
| |
| This corrects op_pre_dec, op_negate, op_mod and op_sub. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-04-17 Geoffrey Garen <ggaren@apple.com> and Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver Hunt. |
| |
| Behold: eval. |
| |
| Introduced a new opcode: op_call_eval. In the normal case, it performs |
| an eval. In the case where eval has been overridden in some way, it |
| performs a function call. |
| |
| * VM/CodeGenerator.h: Added a feature so the code generator knows not |
| to optimized locals in eval code. |
| |
| 2008-04-17 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Added some ASSERTs to document codegen failures in |
| run-javascriptcore-tests. |
| |
| For all tests, program-level codegen now either succeeds, or fails with |
| an ASSERT. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::addVar): |
| (KJS::CodeGenerator::CodeGenerator): |
| (KJS::CodeGenerator::newTemporary): |
| (KJS::CodeGenerator::newLabel): |
| |
| 2008-04-17 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Fixed another case of a dst register being an unreferenced temporary |
| (caused an ASSERT when running the full sunspider suite). |
| |
| * kjs/nodes.cpp: |
| (KJS::CaseBlockNode::emitCodeForBlock): |
| |
| 2008-04-16 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - add documentation (and meaningful parameter names) for arithmetic and bitwise binary ops |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitMul): |
| (KJS::CodeGenerator::emitDiv): |
| (KJS::CodeGenerator::emitMod): |
| (KJS::CodeGenerator::emitSub): |
| (KJS::CodeGenerator::emitLeftShift): |
| (KJS::CodeGenerator::emitRightShift): |
| (KJS::CodeGenerator::emitUnsignedRightShift): |
| (KJS::CodeGenerator::emitBitAnd): |
| (KJS::CodeGenerator::emitBitXOr): |
| (KJS::CodeGenerator::emitBitOr): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::MultNode::emitCode): |
| (KJS::DivNode::emitCode): |
| (KJS::ModNode::emitCode): |
| (KJS::SubNode::emitCode): |
| (KJS::LeftShiftNode::emitCode): |
| (KJS::RightShiftNode::emitCode): |
| (KJS::UnsignedRightShiftNode::emitCode): |
| (KJS::BitAndNode::emitCode): |
| (KJS::BitXOrNode::emitCode): |
| (KJS::BitOrNode::emitCode): |
| (KJS::emitReadModifyAssignment): |
| (KJS::ReadModifyResolveNode::emitCode): |
| |
| 2008-04-16 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Exception checks for toNumber in op_pre_inc |
| |
| This is somewhat more convoluted than the simple hadException checks |
| we currently use. Instead we use special toNumber conversions that |
| select between the exception and ordinary vPC. This allows us to |
| remove any branches in the common case (incrementing a number). |
| |
| * API/JSCallbackObject.h: |
| * API/JSCallbackObjectFunctions.h: |
| (KJS::::toNumber): |
| * ChangeLog: |
| * JavaScriptCore.exp: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * VM/JSPropertyNameIterator.cpp: |
| (KJS::JSPropertyNameIterator::toNumber): |
| * VM/JSPropertyNameIterator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::ExecState): |
| * kjs/ExecState.h: |
| * kjs/JSNotAnObject.cpp: |
| (KJS::JSNotAnObject::toNumber): |
| * kjs/JSNotAnObject.h: |
| * kjs/internal.cpp: |
| (KJS::StringImp::toNumber): |
| (KJS::NumberImp::toNumber): |
| (KJS::GetterSetterImp::toNumber): |
| * kjs/internal.h: |
| * kjs/object.cpp: |
| (KJS::JSObject::toNumber): |
| * kjs/object.h: |
| * kjs/value.h: |
| (KJS::JSValue::toNumber): |
| |
| 2008-04-16 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - ensure that activations are kept in a register to protect them from GC |
| |
| Also renamed OptionalCalleeScopeChain constant to OptionalCalleeActivation, since |
| that is what is now kept there, and there is no more need to keep the scope chain in |
| the register file. |
| |
| * VM/Machine.cpp: |
| (KJS::initializeCallFrame): |
| (KJS::scopeChainForCall): |
| * VM/Machine.h: |
| (KJS::Machine::): |
| |
| 2008-04-16 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Made "this" work in program code / global scope. |
| |
| The machine can initialize "this" prior to execution because it knows |
| that, for program code, "this" is always stored in lr1. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): |
| * VM/Machine.h: |
| (KJS::Machine::): |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::evaluate): |
| |
| 2008-04-16 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fixed a codegen bug when returning from inside a dynamic scope (a with |
| or catch block): we need to pop any dynamic scope(s) that have been |
| added so op_ret can find the activation object at the top of the scope |
| chain. |
| |
| * kjs/nodes.cpp: |
| (KJS::ReturnNode::emitCode): If we're returning from inside a dynamic |
| scope, emit a jmp_scopes to take care of popping any dynamic scope(s) |
| and then branching to the return instruction. |
| |
| 2008-04-16 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - document the add and get_prop_id opcodes |
| |
| In addition to adding documentation in comments, I changed |
| references to register IDs or indices relating to these opcodes to |
| have meaningful names instead of r0 r1 r2. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitAdd): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * kjs/nodes.cpp: |
| (KJS::DotAccessorNode::emitCode): |
| (KJS::FunctionCallDotNode::emitCode): |
| (KJS::PostIncDotNode::emitCode): |
| (KJS::PostDecDotNode::emitCode): |
| (KJS::PreIncDotNode::emitCode): |
| (KJS::PreDecDotNode::emitCode): |
| (KJS::AddNode::emitCode): |
| (KJS::ReadModifyDotNode::emitCode): |
| |
| 2008-04-15 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt and Maciej Stachowiak. |
| |
| Fixed a codegen bug in with and switch, and added an ASSERT to |
| make sure it doesn't happen again. |
| |
| emitCode() assumes that dst, if non-zero, is either referenced or |
| non-temporary (i.e., it assumes that newTemporary() will return a |
| register not equal to dst). Certain callers to emitCode() weren't |
| guaranteeing that to be so, so temporary register values were being |
| overwritten. |
| |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::emitNode): ASSERT that dst is referenced or non-temporary. |
| |
| * kjs/nodes.cpp: |
| (KJS::CommaNode::emitCode): Reference the dst we pass. |
| |
| (KJS::WithNode::emitCode): No need to pass an explicit dst register. |
| |
| (KJS::CaseBlockNode::emitCodeForBlock): No need to pass an explicit dst register. |
| (KJS::SwitchNode::emitCode): No need to pass an explicit dst register. |
| |
| * kjs/nodes.h: Made dst the last parameter to emitCodeForBlock, to match |
| emitCode. |
| |
| 2008-04-15 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bug 18526: Throw exceptions when resolve fails for op_resolve_base_and_func. |
| <https://bugs.webkit.org/show_bug.cgi?id=18526> |
| |
| Very simple fix, sunspider shows a 0.7% progression, ubench shows a 0.4% regression. |
| |
| * VM/Machine.cpp: |
| (KJS::resolveBaseAndFunc): |
| (KJS::Machine::privateExecute): |
| |
| 2008-04-15 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fix incorrect result on 3d-raytrace test |
| |
| Oliver found and tracked down this bug, I just typed in the fix. |
| |
| * VM/Machine.cpp: |
| (KJS::slideRegisterWindowForCall): When setting omitted parameters to undefined, |
| account for the space for local variables. |
| |
| 2008-04-15 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fix codegen handling of dst registers |
| |
| 1.006x speedup (not sure why). |
| |
| Most emitCode functions take an optional "dst" parameter that says |
| where the output of the instruction should be written. I made some |
| functions for convenient handling of the dst register: |
| |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::tempDestination): Takes the dst register. Returns it if |
| it is not null and is a temporary, otherwise allocates a new temporary. This is |
| intended for cases where an intermediate value might be written into the dst |
| |
| (KJS::CodeGenerator::finalDestination): Takes the dst register and an optional |
| register that was used as a temp destination. Picks the right thing for the final |
| output. Intended to be used as the output register for the instruction that generates |
| the final value of a particular node. |
| |
| (KJS::CodeGenerator::moveToDestinationIfNeeded): Takes dst and a |
| RegisterID; moves from the register to dst if dst is defined and |
| different from the register. This is intended for cases where the |
| result of a node is already in a specific register (likely a |
| local), and so no code needs to be generated unless a specific |
| destination has been requested, in which case a move is needed. |
| |
| I also applied these methods throughout emitCode functions. In |
| some cases this was just cleanup, in other cases I fixed actual |
| codegen bugs. Below I have given specific comments for the cases |
| where I believe I fixed a codegen bug, or improved quality of codegen. |
| |
| * kjs/nodes.cpp: |
| (KJS::NullNode::emitCode): |
| (KJS::FalseNode::emitCode): |
| (KJS::TrueNode::emitCode): |
| (KJS::NumberNode::emitCode): |
| (KJS::StringNode::emitCode): |
| (KJS::RegExpNode::emitCode): |
| (KJS::ThisNode::emitCode): Now avoids emitting a mov when dst is |
| the same as the this register (the unlikely case of "this = this"); |
| (KJS::ResolveNode::emitCode): Now avoids emitting a mov when dst |
| is the same as the local regiester, in the local var case (the |
| unlikely case of "x = x"); |
| (KJS::ArrayNode::emitCode): Fixed a codegen bug where array |
| literal element expressions may have observed an intermediate |
| value of constructing the array. |
| (KJS::ObjectLiteralNode::emitCode): |
| (KJS::PropertyListNode::emitCode): Fixed a codegen bug where object literal |
| property definition expressions may have obesrved an intermediate value of |
| constructing the object. |
| (KJS::BracketAccessorNode::emitCode): |
| (KJS::DotAccessorNode::emitCode): |
| (KJS::NewExprNode::emitCode): |
| (KJS::FunctionCallValueNode::emitCode): |
| (KJS::FunctionCallBracketNode::emitCode): |
| (KJS::FunctionCallDotNode::emitCode): |
| (KJS::PostIncResolveNode::emitCode): |
| (KJS::PostDecResolveNode::emitCode): |
| (KJS::PostIncBracketNode::emitCode): |
| (KJS::PostDecBracketNode::emitCode): |
| (KJS::PostIncDotNode::emitCode): |
| (KJS::PostDecDotNode::emitCode): |
| (KJS::DeleteResolveNode::emitCode): |
| (KJS::DeleteBracketNode::emitCode): |
| (KJS::DeleteDotNode::emitCode): |
| (KJS::DeleteValueNode::emitCode): |
| (KJS::VoidNode::emitCode): |
| (KJS::TypeOfResolveNode::emitCode): |
| (KJS::TypeOfValueNode::emitCode): |
| (KJS::PreIncResolveNode::emitCode): Fixed a codegen bug where the final |
| value would not be output to the dst register in the local var case. |
| (KJS::PreDecResolveNode::emitCode): Fixed a codegen bug where the final |
| value would not be output to the dst register in the local var case. |
| (KJS::PreIncBracketNode::emitCode): |
| (KJS::PreDecBracketNode::emitCode): |
| (KJS::PreIncDotNode::emitCode): |
| (KJS::PreDecDotNode::emitCode): |
| (KJS::UnaryPlusNode::emitCode): |
| (KJS::NegateNode::emitCode): |
| (KJS::BitwiseNotNode::emitCode): |
| (KJS::LogicalNotNode::emitCode): |
| (KJS::MultNode::emitCode): |
| (KJS::DivNode::emitCode): |
| (KJS::ModNode::emitCode): |
| (KJS::AddNode::emitCode): |
| (KJS::SubNode::emitCode): |
| (KJS::LeftShiftNode::emitCode): |
| (KJS::RightShiftNode::emitCode): |
| (KJS::UnsignedRightShiftNode::emitCode): |
| (KJS::LessNode::emitCode): |
| (KJS::GreaterNode::emitCode): |
| (KJS::LessEqNode::emitCode): |
| (KJS::GreaterEqNode::emitCode): |
| (KJS::InstanceOfNode::emitCode): |
| (KJS::InNode::emitCode): |
| (KJS::EqualNode::emitCode): |
| (KJS::NotEqualNode::emitCode): |
| (KJS::StrictEqualNode::emitCode): |
| (KJS::NotStrictEqualNode::emitCode): |
| (KJS::BitAndNode::emitCode): |
| (KJS::BitXOrNode::emitCode): |
| (KJS::BitOrNode::emitCode): |
| (KJS::LogicalAndNode::emitCode): |
| (KJS::LogicalOrNode::emitCode): |
| (KJS::ConditionalNode::emitCode): |
| (KJS::emitReadModifyAssignment): Allow an out argument separate from the operands, |
| needed for fixes below. |
| (KJS::ReadModifyResolveNode::emitCode): Fixed a codegen bug where the right side of |
| the expression may observe an intermediate value. |
| (KJS::AssignResolveNode::emitCode): Fixed a codegen bug where the right side of the |
| expression may observe an intermediate value. |
| (KJS::ReadModifyDotNode::emitCode): Fixed a codegen bug where the right side of the |
| expression may observe an intermediate value. |
| (KJS::ReadModifyBracketNode::emitCode): Fixed a codegen bug where the right side of the |
| expression may observe an intermediate value. |
| (KJS::CommaNode::emitCode): Avoid writing temporary value to dst register. |
| (KJS::ReturnNode::emitCode): Void return should return undefined, not null. |
| (KJS::FuncExprNode::emitCode): |
| |
| 2008-04-15 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - fix huge performance regression (from trunk) in string-unpack-code |
| |
| This restores string-unpack-code performance to parity with |
| trunk (2.27x speedup relative to previous SquirrelFish) |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): Shrink register file after call to avoid |
| growing repeatedly. |
| |
| 2008-04-15 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Fixed dumpCallFrame to match our new convention of passing around a |
| ScopeChainNode* instead of a ScopeChain*. |
| |
| * JavaScriptCore.exp: |
| * VM/Machine.cpp: |
| (KJS::Machine::dumpCallFrame): |
| * VM/Machine.h: |
| |
| 2008-04-15 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bug 18436: Need to throw exception on read/modify/write or similar resolve for nonexistent property |
| <https://bugs.webkit.org/show_bug.cgi?id=18436> |
| |
| Add op_resolve_base_and_property for read/modify/write operations, |
| this adds a "superinstruction" to resolve the base and value of a |
| property simultaneously. Just using resolveBase and resolve results |
| in an 5% regression in ubench, 30% in loop-empty-resolve (which is |
| expected). 1.3% progression in sunspider, 2.1% in ubench, with a |
| 21% gain in loop-empty-resolve. The only outlier is function-missing-args |
| which gets a 3% regression that I could never resolve. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitResolveBaseAndProperty): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::resolveBaseAndProperty): |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::PostIncResolveNode::emitCode): |
| (KJS::PostDecResolveNode::emitCode): |
| (KJS::PreIncResolveNode::emitCode): |
| (KJS::PreDecResolveNode::emitCode): |
| (KJS::ReadModifyResolveNode::emitCode): |
| |
| 2008-04-15 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fixed "SquirrelFish crashes due to bad scope chain on some SunSpider tests" |
| https://bugs.webkit.org/show_bug.cgi?id=18508 |
| |
| 3d-raytrace and string-unpack-code now run. |
| |
| The basic approach is to pass around ScopeChainNode* instead of |
| ScopeChain*, which in addition to not becoming suddenly an invalid |
| pointer also saves an indirection. |
| |
| This is an 0.4% speedup on SunSpider --squirrelfish (1.8% on --ubench) |
| |
| * VM/Machine.cpp: |
| (KJS::resolve): |
| (KJS::resolveBase): |
| (KJS::resolveBaseAndFunc): |
| (KJS::initializeCallFrame): |
| (KJS::scopeChainForCall): |
| (KJS::Machine::unwindCallFrame): |
| (KJS::Machine::throwException): |
| (KJS::Machine::execute): |
| (KJS::Machine::privateExecute): |
| * VM/Machine.h: |
| * VM/Register.h: |
| (KJS::Register::): |
| * kjs/nodes.cpp: |
| (KJS::EvalNode::generateCode): |
| (KJS::FunctionBodyNode::generateCode): |
| (KJS::ProgramNode::generateCode): |
| (KJS::ProgramNode::processDeclarations): |
| (KJS::EvalNode::processDeclarations): |
| (KJS::FuncDeclNode::makeFunction): |
| (KJS::FuncExprNode::makeFunction): |
| * kjs/nodes.h: |
| (KJS::ProgramNode::): |
| (KJS::EvalNode::): |
| (KJS::FunctionBodyNode::): |
| * kjs/object.h: |
| * kjs/scope_chain.h: |
| (KJS::ScopeChainNode::ScopeChainNode): |
| (KJS::ScopeChainNode::deref): |
| (KJS::ScopeChainIterator::ScopeChainIterator): |
| (KJS::ScopeChainIterator::operator*): |
| (KJS::ScopeChainIterator::operator->): |
| (KJS::ScopeChain::ScopeChain): |
| (KJS::ScopeChain::node): |
| (KJS::ScopeChain::deref): |
| (KJS::ScopeChain::ref): |
| (KJS::ScopeChainNode::ref): |
| (KJS::ScopeChainNode::release): |
| (KJS::ScopeChainNode::begin): |
| (KJS::ScopeChainNode::end): |
| |
| 2008-04-14 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fixed crash when accessing registers in a torn-off activation object. |
| |
| * kjs/JSActivation.cpp: |
| (KJS::JSActivation::copyRegisters): Update our registerOffset after |
| copying our registers, since our offset should now be relative to |
| our private register array, not the shared register file. |
| |
| 2008-04-14 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fix a codegen flaw that makes some tests run way too fast or way too slow |
| |
| The basic problem was that FunctionCallResolveNode results in |
| codegen which can incorrectly write an intermediate value into the |
| dst register even when that is a local. I added convenience |
| functions to CodeGenerator for getting this right, but for now I |
| only fixed FunctionCallResolve. |
| |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::tempDestination): |
| (KJS::CodeGenerator::): |
| * kjs/nodes.cpp: |
| (KJS::FunctionCallResolveNode::emitCode): |
| |
| 2008-04-14 Gabor Loki <loki@inf.u-szeged.hu> |
| |
| Reviewed and slightly tweaked by Geoffrey Garen. |
| |
| Bug 18489: Squirrelfish doesn't build on linux |
| <https://bugs.webkit.org/show_bug.cgi?id=18489> |
| |
| * JavaScriptCore.pri: Add VM into include path and its files into |
| source set |
| * VM/JSPropertyNameIterator.cpp: Fix include name |
| * VM/Machine.cpp: Add UNLIKELY macro for GCC |
| * VM/Machine.h: Add missing includes |
| * VM/RegisterFile.cpp: Add missing include |
| * kjs/testkjs.pro: Add VM into include path |
| |
| 2008-04-14 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Restored OwnPtr in some places where I had removed it previously. We |
| can have an OwnPtr to an undefined class in a header as long as the |
| class's destructor isn't in the header. |
| |
| 2008-04-14 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Fixed access to "this" inside dynamic scopes. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::registerForLocal): Always return a register for |
| "this", even if we're not optimizing access to other locals. Because |
| "this" is a keyword, it's always in a register and always accessible. |
| |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::shouldOptimizeLocals): Factored out a function |
| for determining whether we should optimize access to locals, since |
| eval will need to make this test a little more complicated. |
| |
| 2008-04-14 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Adam. |
| |
| - fix crash when running SunSpider full harness |
| |
| When growing the register file's buffer to make space for new globals, |
| make sure to copy accounting for the fact that the new space is logically |
| at the beginning of the buffer in this case, instead of at the end as when |
| growing for a new call frame. |
| |
| * VM/RegisterFile.cpp: |
| (KJS::RegisterFile::newBuffer): |
| (KJS::RegisterFile::growBuffer): |
| (KJS::RegisterFile::addGlobalSlots): |
| * VM/RegisterFile.h: |
| |
| 2008-04-11 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Mark constant pools for global and eval code (collectively known as |
| "program code"). (Constant pools for function code are already marked by |
| their functions.) |
| |
| The global object is responsible for marking program code constant |
| pools. Code blocks add themselves to the mark set at creation time, and |
| remove themselves from the mark set at destruction time. |
| |
| sunspider --squirrelfish reports a 1% speedup, perhaps because |
| generateCode() is now non-virtual. |
| |
| * kjs/nodes.cpp: I had to use manual init and delete in this file |
| because putting an OwnPtr into the header would have created a circular |
| header dependency. |
| |
| 2008-04-10 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Bug 18231: Improve support for function call nodes in SquirrelFish |
| <https://bugs.webkit.org/show_bug.cgi?id=18231> |
| |
| Use correct value of 'this' for function calls. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitResolveBaseAndFunc): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::resolveBaseAndFunc): |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::FunctionCallResolveNode::emitCode): |
| |
| 2008-04-10 Geoffrey Garen <ggaren@apple.com> |
| |
| This time for sure. |
| |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::evaluate): |
| |
| 2008-04-10 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Fixed Interpreter::execute to honor the new model for returning non-NULL |
| values when an exception is thrown. |
| |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::evaluate): |
| |
| 2008-04-10 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Fix SquirrelFish interpreter to pass internal exceptions back to |
| native code correctly. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-04-10 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Geoffrey Garen. |
| |
| Replace the use of getCallData in op_construct with the new |
| getConstructData function that replaces implementsConstruct. |
| |
| * API/JSCallbackConstructor.cpp: |
| (KJS::JSCallbackConstructor::getConstructData): |
| * API/JSCallbackConstructor.h: |
| * API/JSCallbackObject.h: |
| * API/JSCallbackObjectFunctions.h: |
| (KJS::::getConstructData): |
| (KJS::::construct): |
| * API/JSObjectRef.cpp: |
| (JSObjectIsConstructor): |
| * JavaScriptCore.exp: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * kjs/CallData.h: |
| * kjs/ConstructData.h: Copied from JavaScriptCore/kjs/CallData.h. |
| * kjs/array_object.cpp: |
| (KJS::ArrayObjectImp::getConstructData): |
| * kjs/array_object.h: |
| * kjs/bool_object.cpp: |
| (KJS::BooleanObjectImp::getConstructData): |
| * kjs/bool_object.h: |
| * kjs/date_object.cpp: |
| (KJS::DateObjectImp::getConstructData): |
| * kjs/date_object.h: |
| * kjs/error_object.cpp: |
| (KJS::ErrorObjectImp::getConstructData): |
| (KJS::NativeErrorImp::getConstructData): |
| * kjs/error_object.h: |
| * kjs/function.cpp: |
| (KJS::FunctionImp::getCallData): |
| (KJS::FunctionImp::getConstructData): |
| (KJS::FunctionImp::construct): |
| * kjs/function.h: |
| * kjs/function_object.cpp: |
| (KJS::FunctionObjectImp::getConstructData): |
| * kjs/function_object.h: |
| * kjs/nodes.cpp: |
| (KJS::NewExprNode::inlineEvaluate): |
| * kjs/number_object.cpp: |
| (KJS::NumberObjectImp::getConstructData): |
| * kjs/number_object.h: |
| * kjs/object.cpp: |
| * kjs/object.h: |
| * kjs/object_object.cpp: |
| (KJS::ObjectObjectImp::getConstructData): |
| * kjs/object_object.h: |
| * kjs/regexp_object.cpp: |
| (KJS::RegExpObjectImp::getConstructData): |
| * kjs/regexp_object.h: |
| * kjs/string_object.cpp: |
| (KJS::StringObjectImp::getConstructData): |
| * kjs/string_object.h: |
| * kjs/value.cpp: |
| (KJS::JSCell::getConstructData): |
| * kjs/value.h: |
| (KJS::JSValue::getConstructData): |
| |
| 2008-04-10 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Bug 18420: SquirrelFish: need to throw Reference and Type errors |
| when attempting invalid operations on JSValues |
| |
| Add validation and exception checks to SquirrelFish so that the |
| correct exceptions are thrown for undefined variables, type errors |
| and toObject failure. Also handle exceptions thrown by native |
| function calls. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * VM/ExceptionHelpers.cpp: Added. |
| (KJS::substitute): |
| (KJS::createError): |
| (KJS::createUndefinedVariableError): |
| * VM/ExceptionHelpers.h: Added. |
| Helper functions |
| * VM/Machine.cpp: |
| (KJS::resolve): |
| Modified to signal failure |
| (KJS::isNotObject): |
| Wrapper for JSValue::isObject and exception creation (these need |
| to be merged, lest GCC go off the deep end) |
| (KJS::Machine::privateExecute): |
| Adding the many exception and validity checks. |
| |
| * kjs/JSNotAnObject.cpp: Added. |
| Stub object used to reduce the need for multiple exception checks |
| when toObject fails. |
| (KJS::JSNotAnObject::toPrimitive): |
| (KJS::JSNotAnObject::getPrimitiveNumber): |
| (KJS::JSNotAnObject::toBoolean): |
| (KJS::JSNotAnObject::toNumber): |
| (KJS::JSNotAnObject::toString): |
| (KJS::JSNotAnObject::toObject): |
| (KJS::JSNotAnObject::mark): |
| (KJS::JSNotAnObject::getOwnPropertySlot): |
| (KJS::JSNotAnObject::put): |
| (KJS::JSNotAnObject::deleteProperty): |
| (KJS::JSNotAnObject::defaultValue): |
| (KJS::JSNotAnObject::construct): |
| (KJS::JSNotAnObject::callAsFunction): |
| (KJS::JSNotAnObject::getPropertyNames): |
| * kjs/JSNotAnObject.h: Added. |
| (KJS::JSNotAnObject::JSNotAnObject): |
| * kjs/JSImmediate.cpp: |
| (KJS::JSImmediate::toObject): |
| modified to create an JSNotAnObject rather than throwing an exception |
| directly. |
| |
| 2008-04-10 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Pass a function body node its function's scope chain, rather than the |
| current execution context's scope chain, when compiling it. |
| |
| This doesn't matter yet, but it will once we start using the scope |
| chain during compilation. |
| |
| sunspider --squirrelfish notes a tiny speedup. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-04-10 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fix two bugs when throwing exceptions from re-entrant JS calls: |
| |
| (1) Don't shrink the register file to 0, since our caller may still |
| be using it. |
| |
| (2) In case of exception, return jsNull() instead of 0 because, |
| surprisingly, some JavaScriptCore clients rely on a function's return |
| value being safe to operate on even if the function threw an exception. |
| |
| Also: |
| |
| - Changed FunctionImp::callAsFunction to honor the new semantics of |
| exceptions not returning 0. |
| |
| - Renamed "handlerPC" to "handlerVPC" to match other uses of "VPC". |
| |
| - Renamed "exceptionData" to "exceptionValue", because "data" seemed to |
| imply something more than just a JSValue. |
| |
| - Merged prepareException into throwException, since throwException was |
| its only caller, and it seemed weird that throwException didn't take |
| an exception as an argument. |
| |
| sunspider --squirrelfish does not seem to complain on my machine, but it |
| complains a little (.6%) on Oliver's. |
| |
| 2008-04-10 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Fixed op_construct for CallTypeNative to reacquire "r" before setting |
| its return value, since registerBase can theoretically change during the |
| execution of arbitrary code. (Not sure if any native constructors |
| actually make this possible.) |
| |
| sunspider --squirrelfish does not seem to complain. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-04-10 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt and Sam Weinig. |
| |
| Re-entrant execution of function code (global code -> built-in function |
| -> JS function): |
| |
| Miraculously, sunspider --squirrelfish does not seem to complain. |
| |
| A re-entrant function call is the same as a normal function call with |
| one exception: the re-entrant call leaves everything except for |
| CallerCodeBlock in the call frame header uninitialized, since the call |
| doesn't need to return to JS code. (It sets CallerCodeBlock to 0, to |
| indicate that the call shouldn't return to JS code.) |
| |
| Also fixed a few issues along the way: |
| |
| - Fixed two bugs in the read-write List implementation that caused |
| m_size and m_buffer to go stale. |
| |
| - Changed native call code to update "r" *before* setting the return |
| value, since the call may in turn call JS code, which changes the value |
| of "r". |
| |
| - Migrated initialization of "r" outside of Machine::privateExecute, |
| because global code and function code initialize "r" differently. |
| |
| - Migrated a codegen warning from Machine::privateExecute to the wiki. |
| |
| - Removed unnecessary "r" parameter from slideRegisterWindowForCall |
| |
| * VM/Machine.cpp: |
| (KJS::slideRegisterWindowForCall): |
| (KJS::scopeChainForCall): |
| (KJS::Machine::execute): |
| (KJS::Machine::privateExecute): |
| * VM/Machine.h: |
| * kjs/function.cpp: |
| (KJS::FunctionImp::callAsFunction): |
| * kjs/list.cpp: |
| (KJS::List::getSlice): |
| * kjs/list.h: |
| (KJS::List::clear): |
| |
| 2008-04-10 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fix problem with code generation for return with no argument |
| |
| 3d-cube now runs |
| |
| * kjs/nodes.cpp: |
| (KJS::ReturnNode::emitCode): |
| |
| 2008-04-10 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - Implement support for JS constructors |
| |
| access-binary-trees and access-nbody now run. |
| |
| Inexplicably a 1% speedup. |
| |
| * VM/Machine.cpp: |
| (KJS::initializeCallFrame): |
| (KJS::Machine::privateExecute): |
| * VM/Machine.h: |
| (KJS::Machine::): |
| |
| 2008-04-10 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - More code cleanup in preparation for JS constructors |
| |
| Factor the remaining interesting parts of JS function calls into |
| slideRegisterWindowForCall and scopeChainForCall. |
| |
| * VM/Machine.cpp: |
| (KJS::slideRegisterWindowForCall): |
| (KJS::scopeChainForCall): |
| (KJS::Machine::privateExecute): |
| |
| 2008-04-10 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - Code cleanup in preparation for JS constructors |
| |
| - Renamed returnInfo to callFrame. |
| - Made an enum which defines what goes where in the call frame. |
| - Factored out initializeCallFrame function from op_call |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitCall): |
| (KJS::CodeGenerator::emitConstruct): |
| * VM/Machine.cpp: |
| (KJS::Machine::dumpRegisters): |
| (KJS::initializeCallFrame): |
| (KJS::Machine::unwindCallFrame): |
| (KJS::Machine::execute): |
| (KJS::Machine::privateExecute): |
| * VM/Machine.h: |
| (KJS::Machine::): |
| |
| 2008-04-10 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fixed two bugs in register allocation for function calls: |
| |
| (1) op_call used to allocate codeBlock->numVars too many registers for |
| each call frame, due to duplicated math. Fixing this revealed... |
| |
| (2) By unconditionally calling resize(), op_call used to truncate the |
| register file when calling a function whose registers fit wholly within |
| the register file already allocated by its caller. |
| |
| sunspider --squirrelfish reports no regression. |
| |
| I also threw in a little extra formatting to dumpCallFrame, because it |
| helped me debug these issues. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::dumpRegisters): |
| (KJS::Machine::execute): |
| (KJS::Machine::privateExecute): |
| * VM/RegisterFile.h: |
| (KJS::RegisterFile::shrink): |
| (KJS::RegisterFile::grow): |
| * VM/RegisterFileStack.cpp: |
| (KJS::RegisterFileStack::popRegisterFile): |
| |
| 2008-04-09 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Next step toward re-entrant execution of function code (global code -> |
| built-in function -> JS function): |
| |
| Made op_ret return from Machine::privateExecute if its calling codeBlock |
| is NULL. |
| |
| I'm checking this in by itself to demonstrate that a more clever |
| mechanism is not necessary for performance. |
| |
| sunspider --squirrelfish reports no regression. |
| |
| * ChangeLog: |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): |
| (KJS::Machine::privateExecute): |
| |
| 2008-04-09 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Next step toward re-entrant execution of function code (global code -> |
| built-in function -> JS function): |
| |
| Made Machine::execute return a value. |
| |
| Sketched out some code for Machine::execute for functions -- still |
| doesn't work yet, though. |
| |
| sunspider --squirrelfish reports no regression. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::execute): |
| (KJS::Machine::privateExecute): |
| * VM/Machine.h: |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::evaluate): |
| * kjs/testkjs.cpp: |
| (runWithScripts): |
| |
| 2008-04-09 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| First step toward re-entrant execution of function code (global code -> |
| built-in function -> JS function): |
| |
| Tiny bit of refactoring in the Machine class. |
| |
| sunspider --squirrelfish reports no regression. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::dumpRegisters): |
| (KJS::Machine::unwindCallFrame): |
| (KJS::Machine::execute): |
| (KJS::Machine::privateExecute): |
| * VM/Machine.h: |
| (KJS::Machine::isGlobalCallFrame): |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::evaluate): |
| |
| 2008-04-08 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Support for re-entrant execution of global code (global code -> built-in |
| function -> global code). |
| |
| Keep a stack of register files instead of just one. Globals propogate |
| between register files as the register files enter and exit the stack. |
| |
| An activation still uses its own register file's base as its |
| registerBase, but the global object uses the register file *stack*'s |
| registerBase, which updates dynamically to match the register file at |
| the top of the stack. |
| |
| sunspider --squirrelfish reports no regression. |
| |
| 2008-04-08 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - initial preparatory work for JS constructors |
| |
| 1) Allocate registers for the returnInfo block and "this" value when generating code for |
| op_construct. These are not used yet, but the JS branch of op_construct will use them. |
| |
| 2) Adjust argc and argv appropriately for native constructor calls. |
| |
| 3) Assign return value in a more straightforward way in op_ret since this is actually |
| a bit faster (and makes up for the allocation of extra registers above). |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitConstruct): |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-04-07 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Fixed crashing SunSpider tests. |
| |
| Let's just pretend this never happened, bokay? |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::CodeGenerator): |
| * VM/CodeGenerator.h: |
| * VM/RegisterFile.cpp: |
| (KJS::RegisterFile::addGlobals): |
| |
| 2008-04-07 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Restored dumping of generated code as a command-line switch: |
| run-testkjs -d will do it. |
| |
| 2008-04-07 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Next step toward supporting re-entrant evaluation: Moved register file |
| maintenance code into a proper "RegisterFile" class. |
| |
| There's a subtle change to the register file's internal layout: for |
| global code / the global object, registerOffset is always 0 now. In |
| other words, all register counting starts at 0, not 0 + (number of |
| global variables). The helps simplify accounting when the number of |
| global variables changes. |
| |
| 2008-04-07 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Bug 18338: Support exceptions in SquirrelFish <http://bugs.webkit.org/show_bug.cgi?id=18338> |
| |
| Initial support for exceptions in SquirrelFish, only supports finalisers in the |
| simple cases (eg. exceptions and non-goto/return across finaliser boundaries). |
| This doesn't add the required exception checks to existing code, it merely adds |
| support for throw, catch, and the required stack unwinding. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| (KJS::CodeBlock::getHandlerForVPC): |
| * VM/CodeBlock.h: |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitCatch): |
| (KJS::CodeGenerator::emitThrow): |
| * VM/CodeGenerator.h: |
| * VM/JSPropertyNameIterator.cpp: |
| (KJS::JSPropertyNameIterator::create): |
| * VM/Machine.cpp: |
| (KJS::prepareException): |
| (KJS::Machine::unwindCallFrame): |
| (KJS::Machine::throwException): |
| (KJS::Machine::privateExecute): |
| * VM/Machine.h: |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::ThrowNode::emitCode): |
| (KJS::TryNode::emitCode): |
| * kjs/nodes.h: |
| * kjs/scope_chain.cpp: |
| (KJS::ScopeChain::depth): |
| * kjs/scope_chain.h: |
| |
| 2008-04-06 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| First step toward supporting re-entrant evaluation: Switch register |
| clients from using "registers", a pointer to a register vector, to |
| "registerBase", an indirect pointer to the logical first entry in the |
| register file. (The logical first entry is the first entry that is not |
| a global variable). |
| |
| With a vector, offsets into the register file remain good when the |
| underlying buffer reallocates, but they go bad when the logical |
| first entry moves. (The logical first entry moves when new global |
| variables get added to the beginning of the register file.) With an |
| indirect pointer to the logical first entry, offsets will remain good |
| regardless. |
| |
| 1.4% speedup on sunspider --squirrelfish. I suspect this is due to |
| reduced allocation when creating closures, and reduced indirection |
| through the register vector. |
| |
| * wtf/Vector.h: Added an accessor for an indirect pointer to the vector's |
| buffer, which we currently use (incorrectly) for registerBase. This is |
| temporary scaffolding to allow us to change client code without |
| changing behavior. |
| |
| 2008-04-06 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Oliver Hunt. |
| |
| Implement codegen for ReadModifyDotNode. |
| |
| * kjs/nodes.cpp: |
| (KJS::ReadModifyDotNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-04-06 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fix codegen for PostIncDotNode and implement codegen for PostIncBracketNode, |
| PostDecBracketNode and PostDecDotNode. |
| |
| * kjs/nodes.cpp: |
| (KJS::PostIncBracketNode::emitCode): |
| (KJS::PostDecBracketNode::emitCode): |
| (KJS::PostIncDotNode::emitCode): |
| (KJS::PostDecDotNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-04-06 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Geoffrey Garen. |
| |
| Implement codegen for PreDecResolveNode, PreIncBracketNode, PreDecBracketNode, |
| PreIncDotNode and PreDecDotNode. This required adding one new op code, op_pre_dec. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitPreDec): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::PreDecResolveNode::emitCode): |
| (KJS::PreIncBracketNode::emitCode): |
| (KJS::PreDecBracketNode::emitCode): |
| (KJS::PreIncDotNode::emitCode): |
| (KJS::PreDecDotNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-04-06 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Improved register dumping, plus a liberal smattering of "const". Here's |
| what the new format looks like: |
| |
| (gdb) call (void)dumpCallFrame(codeBlock, scopeChain, registers->begin(), r) |
| 4 instructions; 48 bytes at 0x509210; 3 locals (2 parameters); 1 temporaries |
| |
| [ 0] load lr1, undefined(@k0) |
| [ 3] load lr1, 2(@k1) |
| [ 6] add tr0, lr2, lr1 |
| [ 10] ret tr0 |
| |
| Constants: |
| k0 = undefined |
| k1 = 2 |
| |
| Register frame: |
| |
| ---------------------------------------- |
| use | address | value |
| ---------------------------------------- |
| [return info] | 0x80ac08 | 0x5081c0 |
| [return info] | 0x80ac0c | 0x508e90 |
| [return info] | 0x80ac10 | 0x504acc |
| [return info] | 0x80ac14 | 0x2 |
| [return info] | 0x80ac18 | 0x0 |
| [return info] | 0x80ac1c | 0x7 |
| [return info] | 0x80ac20 | 0x0 |
| ---------------------------------------- |
| [param] | 0x80ac24 | 0x1 |
| [param] | 0x80ac28 | 0x7 |
| [var] | 0x80ac2c | 0xb |
| [temp] | 0x80ac30 | 0xf |
| |
| 2008-04-06 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Support for evaluating multiple scripts in the same global environment. |
| (Still don't support re-entrant evaluation yet.) |
| |
| The main changes here are: |
| |
| (1) Obey the ECMA 10.1.3 rules regarding how to resolve collisions when |
| a given symbol is declared more than once. (This patch fixes the same |
| issue for function code, too.) |
| |
| (2) In the case of var and/or function collisions, reuse the existing |
| storage slot. For global code, this is required for previously |
| generated instructions to continue to work. For function code, it's |
| more of a "nice to have": it makes register layout in the case of |
| collisions easier to understand, and has the added benefit of saving |
| memory. |
| |
| (3) Allocate slots in the CodeGenerator's m_locals vector in parallel |
| to register indexes in the symbol table. This ensures that, given an |
| index in the symbol table, we can find the corresponding RegisterID |
| without hashing, which speeds up codegen. |
| |
| I moved responsibility for emitting var and function initialization |
| instructions into the CodeGenerator, because bookkeeping in cases where |
| var, function, and/or parameter names collide requires a lot of |
| internal knowledge about the CodeGenerator. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::addVar): Removed responsibility for checking whether |
| a var declaration overwrites "arguments", because the check is |
| inappropriate for global code, which may not have a pre-existing |
| "arguments" symbol in scope. Also changed this function to return a |
| boolean indicating whether addVar actually created a new RegisterID, |
| or just reused an old one. |
| |
| (KJS::CodeGenerator::CodeGenerator): Split out the constructors for |
| function code and global code, since they're quite different now. |
| |
| (KJS::CodeGenerator::registerForLocal): This function does its job |
| without any hashing now. |
| |
| * VM/Machine.cpp: Move old globals and update "r" before executing a |
| new script. That way, old globals stay at a constant offset from "r", |
| and previously optimized code still works. |
| |
| * VM/RegisterID.h: Added the ability to allocate a RegisterID before |
| initializing its index field. We use this for parameters now. |
| |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::symbolTableGet): Changed the ungettable getter |
| ASSERT to account for the fact that symbol indexes are all negative. |
| |
| 2008-04-05 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Geoffrey Garen. |
| |
| Implement codegen for InNode. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitIn): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::InNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-04-05 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Oliver Hunt. |
| |
| - Implement codegen for DeleteResolveNode, DeleteBracketNode, DeleteDotNode and DeleteValueNode. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitGetPropId): |
| (KJS::CodeGenerator::emitPutPropId): |
| (KJS::CodeGenerator::emitDeletePropId): |
| (KJS::CodeGenerator::emitDeletePropVal): |
| (KJS::CodeGenerator::emitPutPropIndex): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::DeleteResolveNode::emitCode): |
| (KJS::DeleteBracketNode::emitCode): |
| (KJS::DeleteDotNode::emitCode): |
| (KJS::DeleteValueNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-04-04 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Oliver Hunt. |
| |
| - Implement codegen for Switch statements. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::pushJumpContext): |
| (KJS::CodeGenerator::popJumpContext): |
| (KJS::CodeGenerator::jumpContextForLabel): |
| * VM/CodeGenerator.h: |
| Rename LoopContext to JumpContext now that it used of Switch statements in addition |
| to loops. |
| |
| * kjs/nodes.cpp: |
| (KJS::DoWhileNode::emitCode): |
| (KJS::WhileNode::emitCode): |
| (KJS::ForNode::emitCode): |
| (KJS::ForInNode::emitCode): |
| (KJS::ContinueNode::emitCode): |
| (KJS::BreakNode::emitCode): |
| (KJS::CaseBlockNode::emitCodeForBlock): |
| (KJS::SwitchNode::emitCode): |
| * kjs/nodes.h: |
| (KJS::CaseClauseNode::expr): |
| (KJS::CaseClauseNode::children): |
| (KJS::CaseBlockNode::): |
| |
| 2008-04-03 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Sam. |
| |
| - fix crash in codegen from new nodes |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitConstruct): |
| * kjs/nodes.h: |
| |
| 2008-04-03 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Geoff. |
| |
| * kjs/nodes.cpp: |
| (KJS::ReadModifyResolveNode::emitCode): |
| (KJS::ReadModifyBracketNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-04-02 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - take a shot at marking constant pools for global and eval code |
| |
| Geoff says this won't really work in all cases but is an ok stopgap. |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::mark): |
| |
| 2008-04-02 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - fix 2x perf regression in 3d-morph |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): If we subbed in null for the global object, |
| don't toObject it, since that will throw an exception (very slowly). |
| |
| 2008-04-02 Maciej Stachowiak <mjs@apple.com> |
| |
| Rubber stamped by Geoff |
| |
| - fix Release build |
| |
| * kjs/nodes.cpp: |
| (KJS::getNonLocalSymbol): |
| |
| 2008-04-02 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Removed the last vestiges of LocalStorage from JSVariableObject and |
| JSGlobalObject. |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::saveLocalStorage): Save and restore from/to |
| registers. Use stub isReadOnly and isDontEnum methods for now, until |
| we really implement attributes in the symbol table. |
| (KJS::JSGlobalObject::restoreLocalStorage): |
| (KJS::JSGlobalObject::reset): |
| |
| * kjs/JSVariableObject.cpp: |
| (KJS::JSVariableObject::getPropertyNames): Use stub isDontEnum method |
| for now, as above. |
| (KJS::JSVariableObject::getPropertyAttributes): ditto |
| |
| * kjs/JSVariableObject.h: Removed LocalStorage from JSVariableObjectData. |
| Removed mark method, because subclasses implement different strategies for |
| marking registers. |
| (KJS::JSVariableObject::isReadOnly): Stub method |
| (KJS::JSVariableObject::isDontEnum): ditto |
| |
| Changed the code below to ASSERT_NOT_REACHED() and return 0, since it |
| can no longer retrieve LocalStorage from the ExecState. (Eventually, |
| we'll just remove this code and all its friends, but that's a task for |
| later.) |
| |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::ExecState): |
| * kjs/function.cpp: |
| (KJS::ActivationImp::markChildren): |
| * kjs/function.h: |
| * kjs/nodes.cpp: |
| (KJS::getNonLocalSymbol): |
| (KJS::ScopeNode::optimizeVariableAccess): |
| (KJS::ProgramNode::processDeclarations): |
| |
| 2008-04-01 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Got globals? |
| |
| To get things working, I had to roll out |
| http://trac.webkit.org/projects/webkit/changeset/31226 for the time |
| being. |
| |
| * VM/CodeBlock.h: Removed obsolete function. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): For the sake of re-entrancy, we track |
| and restore the global object's old rOffset value. (No way to test this |
| yet, but I think it will work.) |
| |
| 2008-04-01 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - mark the constant pool (at least for function code blocks) |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::mark): |
| * VM/CodeBlock.h: |
| * kjs/function.cpp: |
| (KJS::FunctionImp::mark): |
| * kjs/nodes.cpp: |
| (KJS::ScopeNode::mark): |
| * kjs/nodes.h: |
| (KJS::FuncExprNode::body): |
| (KJS::FuncDeclNode::body): |
| |
| 2008-04-01 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Beth Dakin. |
| |
| Cleaned up a few loose ends. |
| |
| * JavaScriptCore.exp: Export dumpRegisters, so it's visible to gdb even |
| if we don't explicitly call it in the source text. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): No need to call dumpRegisters anymore, |
| since that was just a hack for gdb's sake. |
| |
| * kjs/JSActivation.h: Removed obsolete comment. |
| |
| * VM/CodeGenerator.cpp: Added ASSERTs to verify that the localCount |
| we're given matches the number of locals actually allocated. |
| |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::CodeGenerator): Changed "localCount" to include |
| the parameter count, since we're using the word "local" to mean |
| parameter, var, function, or "this". Renamed "m_nextLocal" to |
| "m_nextVar", since "m_nextLocal" doesn't contrast well with |
| "m_nextParameter". |
| |
| Also moved tracking of implicit "this" parameter from here... |
| |
| * kjs/nodes.cpp: |
| (KJS::FunctionBodyNode::generateCode): ... to here |
| (KJS::ProgramNode::generateCode): ... and here |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): Added missing "\n". |
| |
| 2008-04-01 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver. |
| |
| Bug 18274: ResolveNode::emitCode() doesn't make a new temporary when dst |
| is 0, leading to incorrect codegen |
| <http://bugs.webkit.org/show_bug.cgi?id=18274> |
| |
| * kjs/nodes.cpp: |
| (KJS::FunctionCallBracketNode::emitCode): |
| (KJS::FunctionCallDotNode::emitCode): |
| |
| 2008-04-01 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fix bug in for..in codegen (gotta use ident, not m_ident) |
| |
| * kjs/nodes.cpp: |
| (KJS::ForInNode::emitCode): |
| |
| 2008-04-01 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - Add suport for regexp literals |
| |
| * VM/CodeBlock.cpp: |
| (KJS::regexpToSourceString): |
| (KJS::regexpName): |
| (KJS::CodeBlock::dump): |
| * VM/CodeBlock.h: |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::addRegExp): |
| (KJS::CodeGenerator::emitNewRegExp): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::RegExpNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-04-01 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff |
| |
| Add support for for..in nodes |
| |
| Added two new opcodes to get_pnames and next_pname to handle iterating |
| over the set of properties on an object. This iterator is explicitly |
| invalidated and the property name array is released on standard exit |
| from the loop, otherwise we rely on GC to do the clean up for us. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitNextPropertyName): |
| (KJS::CodeGenerator::emitGetPropertyNames): |
| * VM/CodeGenerator.h: |
| * VM/JSPropertyNameIterator.cpp: Added. |
| (KJS::JSPropertyNameIterator::JSPropertyNameIterator): |
| (KJS::JSPropertyNameIterator::type): |
| (KJS::JSPropertyNameIterator::toPrimitive): |
| (KJS::JSPropertyNameIterator::getPrimitiveNumber): |
| (KJS::JSPropertyNameIterator::toBoolean): |
| (KJS::JSPropertyNameIterator::toNumber): |
| (KJS::JSPropertyNameIterator::toString): |
| (KJS::JSPropertyNameIterator::toObject): |
| (KJS::JSPropertyNameIterator::mark): |
| (KJS::JSPropertyNameIterator::next): |
| (KJS::JSPropertyNameIterator::invalidate): |
| (KJS::JSPropertyNameIterator::~JSPropertyNameIterator): |
| (KJS::JSPropertyNameIterator::create): |
| * VM/JSPropertyNameIterator.h: Added. |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * VM/Register.h: |
| (KJS::Register::): |
| * kjs/PropertyNameArray.h: |
| * kjs/nodes.cpp: |
| (KJS::ForInNode::emitCode): |
| * kjs/nodes.h: |
| * kjs/value.h: |
| |
| 2008-04-01 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Change CodeGenerator::emitCall() so it increments the reference count of |
| registers passed to it, and change its callers so they don't needlessly |
| increment the reference count of the registers they are passing. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitCall): |
| * kjs/nodes.cpp: |
| (KJS::FunctionCallResolveNode::emitCode): |
| (KJS::FunctionCallDotNode::emitCode): |
| |
| 2008-04-01 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - generate call for PostIncDotNode |
| |
| * kjs/nodes.cpp: |
| (KJS::PostIncDotNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-04-01 Maciej Stachowiak <mjs@apple.com> |
| |
| Build fix. |
| |
| - fix build (not sure how this ever worked?) |
| |
| * kjs/nodes.cpp: |
| (KJS::FunctionCallBracketNode::emitCode): |
| |
| 2008-04-01 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - generate code for FunctionCallBracketNode |
| |
| * kjs/nodes.cpp: |
| (KJS::FunctionCallBracketNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-04-01 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - Fix two crashing SunSpider tests |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): set up 'this' properly for native calls. |
| * kjs/list.h: |
| (KJS::List::List): Fix intialization of buffer and size from |
| vector, the initialization order was wrong. |
| |
| 2008-04-01 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: marked ASSERT-only variables as UNUSED_PARAMs. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::symbolTableInitializeVariable): |
| |
| 2008-04-01 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Next step toward global code: Moved get, put, and initializeVariable |
| functionality up into JSVariableObject, and changed JSActivation to |
| rely on it. |
| |
| * kjs/JSActivation.cpp: |
| (KJS::JSActivation::JSActivation): |
| (KJS::JSActivation::getOwnPropertySlot): |
| (KJS::JSActivation::put): |
| (KJS::JSActivation::initializeVariable): |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::valueAt): |
| (KJS::JSVariableObject::isReadOnly): |
| (KJS::JSVariableObject::symbolTableGet): |
| (KJS::JSVariableObject::symbolTablePut): |
| (KJS::JSVariableObject::symbolTableInitializeVariable): |
| |
| 2008-04-01 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Sam. |
| |
| - fix HashTable assertion on some SunSpider tests |
| |
| Don't use -1 as the deleted value for JSValue*-keyed hashtables, |
| since it is a valid value (it's the immediate for -1). |
| |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::JSValueHashTraits::emptyValue): |
| (KJS::CodeGenerator::JSValueHashTraits::deletedValue): |
| * kjs/JSImmediate.h: |
| (KJS::JSImmediate::impossibleValue): |
| |
| 2008-04-01 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Add support for calling Native constructors like new Array(). |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitConstruct): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::NewExprNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-04-01 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Sam. |
| |
| - add some missing toOpbject calls to avoid crashing when calling methods on primitives |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-04-01 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Changed Machine::dumpRegisters to take a pointer instead of a reference, |
| so gdb understands how to call it. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::dumpRegisters): |
| (KJS::Machine::privateExecute): |
| * VM/Machine.h: |
| |
| 2008-03-31 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Fix CodeGenerator::addConstant() so it uses the functionExpressions |
| counter for function expressions, not the functions counter. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::addConstant): |
| |
| 2008-03-31 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Geoffrey Garen. |
| |
| Add emitCode support for TypeOfResolveNode and TypeOfValueNode. |
| Added new opcode op_type_of to handle them. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitNot): |
| (KJS::CodeGenerator::emitInstanceOf): |
| (KJS::CodeGenerator::emitTypeOf): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::jsTypeStringForValue): |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::TypeOfResolveNode::emitCode): |
| (KJS::TypeOfValueNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-03-31 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fix non-computed goto version of isOpcode. op_end is a valid opcode. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::isOpcode): |
| |
| 2008-03-31 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Added op_post_dec. |
| |
| 2008-03-31 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Geoffrey Garen. |
| |
| Add support for FunctionCallDotNode. |
| |
| * kjs/nodes.cpp: |
| (KJS::FunctionCallDotNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-03-31 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Beth Dakin. |
| |
| Next step toward global code: Removed more obsolete API, moved |
| saveLocalStorage and restoreLocalStorage to JSGlobalObject subclass, |
| since it's only intended for use there. |
| |
| * ChangeLog: |
| * JavaScriptCore.exp: |
| * kjs/Activation.h: |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::saveLocalStorage): |
| (KJS::JSGlobalObject::restoreLocalStorage): |
| * kjs/JSGlobalObject.h: |
| * kjs/JSVariableObject.cpp: |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::JSVariableObjectData::JSVariableObjectData): |
| * kjs/function.cpp: |
| (KJS::ActivationImp::ActivationImp): |
| |
| 2008-03-31 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Beth Dakin. |
| |
| Next step toward global code: subclass JSActivation + JSActivationData |
| from JSVariableObject + JSVariableObjectData. |
| |
| JSActivation now relies on JSVariableObject for access to registers and |
| symbol table, and for some delete functionality, but not for anything |
| else yet. |
| |
| (KJS::JSActivation::mark): Cleaned up the style here a little bit. |
| |
| 2008-03-31 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Beth Dakin. |
| |
| Next step toward global code: store "rOffset" in JSVariableObjectData. |
| |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::JSGlobalObjectData::JSGlobalObjectData): |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::JSVariableObjectData::JSVariableObjectData): |
| |
| 2008-03-31 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Next steps toward global code: |
| |
| * Moved access to the register file into JSVariableObject. |
| |
| * Added more ASSERTs to indicate obsolete APIs there are just hanging |
| around to stave off build failures. |
| |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::JSGlobalObjectData::JSGlobalObjectData): |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::registers): |
| (KJS::JSVariableObject::JSVariableObjectData::JSVariableObjectData): |
| (KJS::JSVariableObject::JSVariableObject): |
| |
| 2008-03-31 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Oliver. Tweaked somewhat by Maciej. |
| |
| - implement codegen for ReadModifyResolveNode |
| |
| * kjs/nodes.cpp: |
| (KJS::emitReadModifyAssignment): |
| (KJS::ReadModifyResolveNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-03-31 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Geoff. |
| |
| Fix the build -- r31492 removed activation tear-off, but r31493 used it. |
| |
| * kjs/nodes.cpp: |
| (KJS::FuncExprNode::makeFunction): |
| |
| 2008-03-31 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Add support for FuncExprNode to SquirrelFish. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeBlock.h: |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::addConstant): |
| (KJS::CodeGenerator::emitNewFunctionExpression): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::FuncExprNode::emitCode): |
| (KJS::FuncExprNode::makeFunction): |
| * kjs/nodes.h: |
| |
| 2008-03-31 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| First step toward global code: removed some obsolete JSGlobalObject |
| APIs, changing clients to ASSERT_NOT_REACHED. |
| |
| Activation tear-off and scope chain pushing is obsolete because we |
| statically detect whether an activation + scope node is required. |
| |
| The variableObject() and activationObject() accessors are obsolete |
| because they haven't been maintained, and they're mostly used by |
| node evaluation code, anyway. |
| |
| The localStorage() accessor is obsolete because everything is in |
| registers now, and it's mostly used by node evaluation code, anyway. |
| |
| 2008-03-31 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Darin. |
| |
| - implement codegen for bracket accessor and bracket assign |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitGetPropVal): |
| (KJS::CodeGenerator::emitPutPropVal): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::BracketAccessorNode::emitCode): |
| (KJS::AssignBracketNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-03-31 Geoffrey Garen <ggaren@apple.com> |
| |
| Not reviewed. |
| |
| Removed FIXME that I just fixed. |
| |
| Added ASSERT to cover an error previously only covered by a FIXME. |
| |
| * kjs/JSActivation.cpp: |
| (KJS::JSActivation::getOwnPropertySlot): |
| |
| 2008-03-31 Geoffrey Garen <ggaren@apple.com> |
| |
| Not reviewed. |
| |
| Fixed indentation inside op_call. (I had left this code badly indented |
| to make the behavior-changing diff clearer.) |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-03-31 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Fixed up logging of jump instructions to follow the following style: |
| |
| jump offset(->absoluteTarget) |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| |
| 2008-03-31 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Changed the SymbolTable API to use int instead of size_t. It has been |
| using int internally for a while now (since squirrelfish symbols can |
| have negative indices). |
| |
| 2008-03-31 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Add support for FunctionCallValueNode. |
| |
| * kjs/nodes.cpp: |
| (KJS::FunctionCallValueNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-03-31 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| 1) Implemented array literals |
| |
| 2) Renamed op_object_get and op_object_put to op_get_prop_id and |
| op_put_prop_id in preparation for new variants. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitNewArray): |
| (KJS::CodeGenerator::emitGetPropId): |
| (KJS::CodeGenerator::emitPutPropId): |
| (KJS::CodeGenerator::emitPutPropIndex): |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::CodeGenerator): |
| (KJS::CodeGenerator::propertyNames): |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::ArrayNode::emitCode): |
| (KJS::PropertyListNode::emitCode): |
| (KJS::DotAccessorNode::emitCode): |
| (KJS::PostIncResolveNode::emitCode): |
| (KJS::PreIncResolveNode::emitCode): |
| (KJS::AssignResolveNode::emitCode): |
| (KJS::AssignDotNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-03-30 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Implemented native function calls. (Re-entering from native code back |
| to JS doesn't work yet, though.) |
| |
| 0.2% speedup overall, due to some inlining tweaks. 3.6% regression on |
| function-empty.js, since we're making a new virtual call and taking a |
| new branch inside every op_call. |
| |
| I adjusted the JavaScriptCore calling convention to minimize overhead, |
| like so: |
| |
| The machine calls a single virtual function, "getCallData", to get all |
| the data it needs for a function call. Native code still uses the old |
| "isObject()" check followed by an "implementsCall()" check, which |
| aliases to "getCallData". (We can optimize native code to use getCallData |
| at our leisure.) |
| |
| To supply a list of arguments, the machine calls a new List constructor |
| that just takes a pointer and a length, without copying. Native code |
| still appends to the list one argument at a time. (We can optimize |
| native code to use the new List constructor at our leisure.) |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): Changed resize() call to grow() call, |
| to encourage the compiler to inline the Vector code. |
| |
| * kjs/CallData.h: Added. |
| (KJS::): CallData is a union because eventually native calls will stuff |
| a function pointer into it, to eliminate the callAsFunction virtual call. |
| |
| * kjs/function.cpp: |
| (KJS::FunctionImp::callAsFunction): Changed this to an ASSERT since |
| it's not implemented yet. |
| |
| * kjs/list.h: Made the List class two-faced, to support the old way and |
| the new way during this transition phase: lists can be made read-only |
| with just a pointer and a legnth, or you can append to them one item |
| at a time. |
| |
| * kjs/value.h: |
| (KJS::jsUndefined): Marked this function ALWAYS_INLINE for the benefit |
| of a certain compiler that doesn't know what's best for it. |
| |
| 2008-03-30 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| Dump code that codegen can't handle yet, so it's easier to prioritize missing nodes. |
| |
| * kjs/nodes.h: |
| (KJS::Node::emitCode): |
| |
| 2008-03-30 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| Improve dumping of bytecode and fix coding style accordingly. |
| |
| Registers are printed as lr1 for locals, tr1 for temp registers. Identifiers print as |
| foobar(@id0) and constants print as "foo"(@k1) or 312.4(@k2) or the like. Constant and |
| identifier tables are dumped for reference. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::escapeQuotes): |
| (KJS::valueToSourceString): |
| (KJS::registerName): |
| (KJS::constantName): |
| (KJS::idName): |
| (KJS::printUnaryOp): |
| (KJS::printBinaryOp): |
| (KJS::CodeBlock::dump): |
| * VM/Machine.cpp: |
| (KJS::resolve): |
| (KJS::resolveBase): |
| (KJS::Machine::privateExecute): |
| |
| 2008-03-30 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| Implement StringNode and VoidNode (both pretty trivial). |
| |
| * kjs/nodes.cpp: |
| (KJS::StringNode::emitCode): |
| (KJS::VoidNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-03-30 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Sam. |
| |
| Implement CommaNode. |
| |
| * kjs/nodes.cpp: |
| (KJS::CommaNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-03-30 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Adds support for dot notation and object literals. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitNewObject): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::ObjectLiteralNode::emitCode): |
| (KJS::PropertyListNode::emitCode): |
| (KJS::DotAccessorNode::emitCode): |
| (KJS::AssignDotNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-03-29 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Mark the register file. |
| |
| It's a conservative mark for now, but once registers are typed, we can |
| do an exact mark. |
| |
| 1.4% regression regardless of whether we actually do the marking. |
| GCC is is worth every penny. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): Most of the changes here are just for |
| the fact that "registers" is a pointer now. |
| |
| * kjs/JSGlobalObject.cpp: The global object owns the register file now. |
| |
| 2008-03-28 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bug 18204: SquirrelFish: continue/break do not correctly handle scope popping |
| <http://bugs.webkit.org/show_bug.cgi?id=18204> |
| |
| We now track the scope depth as part of a loop context, and add an |
| extra instruction op_jump_scopes that is used to perform a jump across |
| dynamic scope boundaries. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitJumpScopes): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::ContinueNode::emitCode): |
| (KJS::BreakNode::emitCode): |
| |
| 2008-03-28 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Geoffrey Garen. |
| |
| Add emitCode support for ConditionalNode. |
| |
| * kjs/nodes.cpp: |
| (KJS::ConditionalNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-03-28 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Responding to feedback, added some comments, fixed up a few names, and |
| clarified that "locals" always means all local variables, functions, |
| and parameters. |
| |
| 2008-03-28 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Added support for "this". |
| |
| Supply an implicit "this" value as the first argument to every function. |
| Alias the "this" keyword to that argument. |
| |
| 1% regression overall, 2.5% regression on empty function calls. Seems |
| like a reasonable cost for now, since we're doing more work. |
| (Eventually, we might decide to create a version of op_call specialized |
| for a known null "this" value.) |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitCall): |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::CodeGenerator): |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * kjs/CommonIdentifiers.cpp: |
| (KJS::CommonIdentifiers::CommonIdentifiers): |
| * kjs/CommonIdentifiers.h: |
| * kjs/nodes.cpp: |
| (KJS::ThisNode::emitCode): |
| (KJS::FunctionCallResolveNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-03-28 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Bug 18192: Squirrelfish needs support for break and continue |
| <http://bugs.webkit.org/show_bug.cgi?id=18192> |
| |
| Added a loop context stack to the code generator to provide the |
| correct jump labels for continue and goto. Added logic to the |
| currently implemented loop constructs to manage entry and exit |
| from the loop contexts. Finally, implemented codegen for break |
| and continue (and a pass through for LabelNode) |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::pushLoopContext): |
| (KJS::CodeGenerator::popLoopContext): |
| (KJS::CodeGenerator::loopContextForIdentifier): |
| (KJS::CodeGenerator::labelForContinue): |
| (KJS::CodeGenerator::labelForBreak): |
| * VM/CodeGenerator.h: |
| * kjs/nodes.cpp: |
| (KJS::DoWhileNode::emitCode): |
| (KJS::WhileNode::emitCode): |
| (KJS::ForNode::emitCode): |
| (KJS::ContinueNode::emitCode): |
| (KJS::BreakNode::emitCode): |
| (KJS::LabelNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-03-27 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Geoffrey Garen. |
| |
| Add emitCode support for UnaryPlusNode, NegateNode, BitwiseNotNode and LogicalNotNode. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::printUnaryOp): |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitToJSNumber): |
| (KJS::CodeGenerator::emitNegate): |
| (KJS::CodeGenerator::emitBitNot): |
| (KJS::CodeGenerator::emitNot): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::UnaryPlusNode::emitCode): |
| (KJS::NegateNode::emitCode): |
| (KJS::BitwiseNotNode::emitCode): |
| (KJS::LogicalNotNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-03-27 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Add support for LogicalAndNode and LogicalOrNode. |
| |
| * kjs/nodes.cpp: |
| (KJS::LogicalAndNode::emitCode): |
| (KJS::LogicalOrNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-03-27 Sam Weinig <sam@webkit.org> |
| |
| Clean up code and debug output. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-03-27 Geoffrey Garen <ggaren@apple.com> |
| |
| Moved an ASSERT to a more logical place. |
| |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-03-27 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Oliver Hunt. |
| |
| Add emitCode support for InstanceOfNode. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitInstanceOf): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::InstanceOfNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-03-27 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Bug 18142: squirrelfish needs to support dynamic scoping/with |
| <http://bugs.webkit.org/show_bug.cgi?id=18142> |
| |
| Add support for dynamic scoping and add code to handle 'with' |
| statements. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeBlock.h: |
| (KJS::CodeBlock::CodeBlock): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::getRegister): |
| (KJS::CodeGenerator::emitPushScope): |
| (KJS::CodeGenerator::emitPopScope): |
| * VM/CodeGenerator.h: |
| (KJS::CodeGenerator::CodeGenerator): |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::WithNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-03-27 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Geoffrey Garen. |
| |
| Add emitCode support for NullNode, FalseNode, TrueNode, IfNode, IfElseNode, DoWhileNode and WhileNode |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): Dump op_jfalse opcode. |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitJumpIfFalse): Identical to emitJumpIfTrue except it emits the op_jfalse opcode. |
| (KJS::CodeGenerator::emitLoad): Add and emitLoad override for booleans. |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): Adds execution of op_jfalse. It is identical to op_jtrue, except the |
| the condition is reversed. |
| * VM/Opcode.h: Add op_jfalse. |
| * kjs/nodes.cpp: |
| (KJS::NullNode::emitCode): Added. |
| (KJS::FalseNode::emitCode): Added. |
| (KJS::TrueNode::emitCode): Added. |
| (KJS::IfNode::emitCode): Added. |
| (KJS::IfElseNode::emitCode): Added. |
| (KJS::DoWhileNode::emitCode): Added. |
| (KJS::WhileNode::emitCode): Added. |
| * kjs/nodes.h: |
| |
| 2008-03-26 Geoffrey Garen <ggaren@apple.com> |
| |
| Nixed an unused List. |
| |
| The calm before my stormy war against the List class. |
| |
| * kjs/function_object.cpp: |
| (KJS::FunctionObjectImp::construct): |
| |
| 2008-03-26 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Geoffrey Garen. |
| |
| Adds support for EqualNode, NotEqualNode, StrictEqualNode, NotStrictEqualNode, |
| LessEqNode, GreaterNode, GreaterEqNode, MultNode, DivNode, ModNode, SubNode, |
| LeftShiftNode, RightShiftNode, UnsignedRightShiftNode, BitAndNode, BitXOrNode, |
| and BitOrNode. |
| |
| * VM/CodeBlock.cpp: |
| (KJS::CodeBlock::dump): |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::emitEqual): |
| (KJS::CodeGenerator::emitNotEqual): |
| (KJS::CodeGenerator::emitStrictEqual): |
| (KJS::CodeGenerator::emitNotStrictEqual): |
| (KJS::CodeGenerator::emitLessEq): |
| (KJS::CodeGenerator::emitMult): |
| (KJS::CodeGenerator::emitDiv): |
| (KJS::CodeGenerator::emitMod): |
| (KJS::CodeGenerator::emitSub): |
| (KJS::CodeGenerator::emitLeftShift): |
| (KJS::CodeGenerator::emitRightShift): |
| (KJS::CodeGenerator::emitUnsignedRightShift): |
| (KJS::CodeGenerator::emitBitAnd): |
| (KJS::CodeGenerator::emitBitXOr): |
| (KJS::CodeGenerator::emitBitOr): |
| * VM/CodeGenerator.h: |
| * VM/Machine.cpp: |
| (KJS::jsLessEq): |
| (KJS::Machine::privateExecute): |
| * VM/Opcode.h: |
| * kjs/nodes.cpp: |
| (KJS::MultNode::emitCode): |
| (KJS::DivNode::emitCode): |
| (KJS::ModNode::emitCode): |
| (KJS::SubNode::emitCode): |
| (KJS::LeftShiftNode::emitCode): |
| (KJS::RightShiftNode::emitCode): |
| (KJS::UnsignedRightShiftNode::emitCode): |
| (KJS::GreaterNode::emitCode): |
| (KJS::LessEqNode::emitCode): |
| (KJS::GreaterEqNode::emitCode): |
| (KJS::EqualNode::emitCode): |
| (KJS::NotEqualNode::emitCode): |
| (KJS::StrictEqualNode::emitCode): |
| (KJS::NotStrictEqualNode::emitCode): |
| (KJS::BitAndNode::emitCode): |
| (KJS::BitXOrNode::emitCode): |
| (KJS::BitOrNode::emitCode): |
| * kjs/nodes.h: |
| |
| 2008-03-26 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Only print debug dumps in debug builds. |
| |
| * VM/CodeGenerator.cpp: |
| (KJS::CodeGenerator::generate): |
| * VM/Machine.cpp: |
| (KJS::Machine::privateExecute): |
| |
| 2008-03-26 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Moved a few files around in the XCode project. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2008-03-26 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Made closures work. |
| |
| An activation object aliases to the register file until its associated |
| function returns, at which point it copies the registers for locals and |
| parameters into an independent storage buffer. |
| |
| 2008-03-24 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fixed recent 25% regression on simple for loop test. GCC seems to be |
| very finicky about the code that gets inlined into |
| Machine::privateExecute. |
| |
| Everything in this patch is simply the result of experiment. |
| |
| The resolve and resolve_base opcodes do not seem to have gotten slower |
| from this change. |
| |
| * VM/Machine.cpp: |
| (KJS::resolve): |
| (KJS::resolveBase): |
| (KJS::Machine::privateExecute): |
| * kjs/nodes.h: |
| |
| 2008-03-24 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff Garen. |
| |
| Bug 18059: squirrelfish needs to compile on platforms without computed goto |
| <http://bugs.webkit.org/show_bug.cgi?id=18059> |
| |
| "Standard" macro style support for conditionalising the use of computed goto. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * VM/Machine.cpp: |
| (KJS::Machine::isOpcode): |
| (KJS::Machine::privateExecute): |
| * VM/Machine.h: |
| (KJS::Machine::getOpcode): |
| (KJS::Machine::getOpcodeID): |
| * VM/Opcode.h: |
| * wtf/Platform.h: |
| |
| 2008-03-24 Geoffrey Garen <ggaren@apple.com> |
| |
| Moved my notes from nodes.h to the wiki. |
| |
| * kjs/nodes.h: |
| |
| 2008-03-24 Geoffrey Garen <ggaren@apple.com> |
| |
| SquirrelFish lives. |
| |
| Initial check-in of the code I've been carrying around. Lots of stuff |
| doesn't work. Plus a bunch of empty files. |
| |
| === Start merge of squirrelfish === |
| |
| 2008-05-21 Darin Adler <darin@apple.com> |
| |
| - try to fix the Windows build |
| |
| * profiler/Profiler.cpp: |
| (KJS::Profiler::stopProfiling): Use ptrdiff_t instead of the less-common but incredibly |
| similar ssize_t type. |
| * wtf/AVLTree.h: |
| (KJS::AVLTree::search): Added a typename for a dependent name that's a type. |
| |
| 2008-05-21 Darin Adler <darin@apple.com> |
| |
| Reviewed by Anders. |
| |
| - fix <rdar://problem/5952721> bug in JavaScript arguments object property lookup |
| |
| Test: fast/js/arguments-bad-index.html |
| |
| * kjs/function.cpp: |
| (KJS::IndexToNameMap::IndexToNameMap): Use unsigned instead of int. |
| (KJS::IndexToNameMap::isMapped): Use unsigned instead of int, and also use the |
| strict version of the numeric conversion function, since we don't want to allow |
| trailing junk. |
| (KJS::IndexToNameMap::unMap): Ditto. |
| (KJS::IndexToNameMap::operator[]): Ditto. |
| * kjs/function.h: Changed IndexToNameMap::size type from int to unsigned. |
| |
| 2008-05-21 Timothy Hatcher <timothy@apple.com> |
| |
| Change the Profiler to allow multiple profiles to be running at |
| the same time. This can happen when you have nested console.profile() |
| calls. This required two changes. First, the Profiler needed to keep a |
| Vector of current profiles, instead of one. Second, a Profile needs |
| to keep track of the global ExecState it started in and the page group |
| identifier it is tracking. |
| |
| The stopProfiling call now takes the same arguments as startProfiling. |
| This makes sure the correct profile is stopped. Passing a null UString |
| as the title will stop the last profile for the matching ExecState. |
| |
| <rdar://problem/5951559> Multiple pages profiling can interfere with each other |
| |
| Reviewed by Kevin McCullough. |
| |
| * JavaScriptCore.exp: Added new exports. Removed old symbols. |
| * profiler/Profile.cpp: |
| (KJS::Profile::Profile): New constructor arguments for the |
| originatingGlobalExec and pageGroupIdentifier. |
| (KJS::Profile::stopProfiling): Set the m_originatingGlobalExec to null. |
| * profiler/Profile.h: |
| (KJS::Profile::create): Additional arguments. |
| (KJS::Profile::originatingGlobalExec): Return m_originatingGlobalExec. |
| (KJS::Profile::pageGroupIdentifier): Return m_pageGroupIdentifier. |
| * profiler/Profiler.cpp: |
| (KJS::Profiler::findProfile): Added. Finds a Profile that matches |
| the ExecState and title. |
| (KJS::Profiler::startProfiling): Return early if there is already |
| a Profile with the ExecState and title. If not, create a new profile |
| and append it to m_currentProfiles. |
| (KJS::Profiler::stopProfiling): Loops through m_currentProfiles |
| and find the one matching the ExecState and title. If one is found |
| call stopProfiling and return the Profile after removing it |
| from m_currentProfiles. |
| (KJS::dispatchFunctionToProfiles): Helper inline function to loop through |
| m_currentProfiles and call a Profile function. |
| (KJS::Profiler::willExecute): Call dispatchFunctionToProfiles. |
| (KJS::Profiler::didExecute): Ditto. |
| * profiler/Profiler.h: |
| |
| 2008-05-21 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| <rdar://problem/5908520> REGRESSION (3.1.1-r33033): Crash in WebKit when opening or |
| refreshing page on people.com |
| |
| The problem was that STL algorithms do not work with non-conformant comparators, and the |
| site used sort(function() { return 0.5 - Math.random(); } to randomly shuffle an array. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=18687 |
| REGRESSION(r32220): ecma/Array/15.4.4.5-3.js test now fails in GMT(BST) |
| |
| Besides relying on sort stability, this test was just broken, and kept failing with the |
| new stable sort. |
| |
| Tests: fast/js/sort-randomly.html |
| fast/js/sort-stability.html |
| fast/js/comparefn-sort-stability.html |
| |
| * kjs/avl_tree.h: Added an AVL tree implementation. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * wtf/AVLTree.h: Added. |
| Added an AVL tree implementation. |
| |
| * kjs/array_instance.cpp: |
| (KJS::ArrayInstance::increaseVectorLength): |
| (KJS::ArrayInstance::sort): |
| (KJS::AVLTreeAbstractorForArrayCompare::get_less): |
| (KJS::AVLTreeAbstractorForArrayCompare::set_less): |
| (KJS::AVLTreeAbstractorForArrayCompare::get_greater): |
| (KJS::AVLTreeAbstractorForArrayCompare::set_greater): |
| (KJS::AVLTreeAbstractorForArrayCompare::get_balance_factor): |
| (KJS::AVLTreeAbstractorForArrayCompare::set_balance_factor): |
| (KJS::AVLTreeAbstractorForArrayCompare::compare_key_key): |
| (KJS::AVLTreeAbstractorForArrayCompare::compare_key_node): |
| (KJS::AVLTreeAbstractorForArrayCompare::compare_node_node): |
| (KJS::AVLTreeAbstractorForArrayCompare::null): |
| (KJS::ArrayInstance::compactForSorting): |
| |
| * kjs/array_instance.h: increaseVectorLength() now returns a bool to indicate whether it was |
| successful. |
| |
| * wtf/Vector.h: |
| (WTF::Vector::Vector): |
| (WTF::::operator=): |
| (WTF::::fill): |
| Make these methods fail instead of crash when allocation fails, matching resize() and |
| reserveCapacity(), which already had this behavior. Callers need to check for null buffer |
| after making any Vector call that can try to allocate. |
| |
| * tests/mozilla/ecma/Array/15.4.4.5-3.js: Fixed the test to use a consistent sort function, |
| as suggested in comments to a Mozilla bug filed about it (I'll keep tracking the bug to see |
| what the final resolution is). |
| |
| 2008-05-20 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Tim. |
| |
| <rdar://problem/5950867> JSProfiler: Allow the profiler to "Focus" a |
| profile node. |
| - Implements focus by adding the idea of a profileNode being visible and |
| adding the ability to reset all of the visible flags. |
| |
| * profiler/Profile.h: |
| (KJS::Profile::focus): |
| * profiler/ProfileNode.cpp: |
| (KJS::ProfileNode::ProfileNode): Initialize the visible flag. |
| (KJS::ProfileNode::setTreeVisible): Set the visibility of this node and |
| all of its descendents. |
| (KJS::ProfileNode::focus): Determine if this node should be visible when |
| focusing, if the functionName matches this node's function name or if any |
| of this node's children are visible. |
| (KJS::ProfileNode::restoreAll): Restore all nodes' visible flag. |
| (KJS::ProfileNode::debugPrintData): |
| * profiler/ProfileNode.h: |
| (KJS::ProfileNode::visible): |
| (KJS::ProfileNode::setVisible): |
| |
| 2008-05-20 Timothy Hatcher <timothy@apple.com> |
| |
| Fixes a couple performance issues with the profiler. Also fixes |
| a regression where some nodes wouldn't be added to the tree. |
| |
| Reviewed by Kevin McCullough. |
| |
| * profiler/ProfileNode.cpp: |
| (KJS::ProfileNode::addChild): Compare callIdentifier instead |
| of functionName. |
| * profiler/ProfileNode.h: |
| (CallIdentifier.operator==): Compare the CallIdentifiers in |
| an order that fails sooner for non-matches. |
| (CallIdentifier.callIdentifier): Return the CallIdentifier by |
| reference to prevent making a new copy each time. |
| |
| 2008-05-20 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Darin. |
| |
| <rdar://problem/5950796> JSProfiler: dump functions are in the code |
| Removed dump and logging functions from the Release version of the code |
| and renamed them to be obviously for debugging only. |
| |
| * JavaScriptCore.exp: |
| * profiler/Profile.cpp: |
| (KJS::Profile::debugPrintData): |
| (KJS::Profile::debugPrintDataSampleStyle): |
| * profiler/Profile.h: |
| * profiler/ProfileNode.cpp: |
| (KJS::ProfileNode::debugPrintData): |
| (KJS::ProfileNode::debugPrintDataSampleStyle): |
| * profiler/ProfileNode.h: |
| * profiler/Profiler.cpp: |
| * profiler/Profiler.h: |
| |
| 2008-05-20 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Adam. |
| |
| <rdar://problem/5950538> JSProfiler: Keep track of non-JS execution time |
| We now have an extra node that represents the excess non-JS time. |
| - Also changed "SCRIPT" and "anonymous function" to be more consistent |
| with the debugger. |
| |
| * profiler/ProfileNode.cpp: |
| (KJS::ProfileNode::stopProfiling): If this ProfileNode is the head node |
| create a new child that has the excess execution time. |
| (KJS::ProfileNode::calculatePercentages): Moved calculation of the |
| percentages into a function since it's called from multiple places. |
| * profiler/ProfileNode.h: Add the newly needed functions used above. |
| (KJS::ProfileNode::setTotalTime): |
| (KJS::ProfileNode::setSelfTime): |
| (KJS::ProfileNode::setNumberOfCalls): |
| * profiler/Profiler.cpp: renamed "SCRIPT" and "anonymous function" to be |
| consistent with the debugger and use constants that can be localized |
| more easily. |
| (KJS::getCallIdentifiers): |
| (KJS::getCallIdentifierFromFunctionImp): |
| |
| 2008-05-20 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Tim. |
| |
| <rdar://problem/5770054> JavaScript profiler (10928) |
| Removed only profiler-internal use of currentProfile since that concept |
| is changing. |
| |
| * profiler/Profile.h: Now stopProfiling takes a time and bool as |
| arguments. The time is used to calculate %s from and the bool tells |
| if this node is the head node and should be the one calculating the time. |
| (KJS::Profile::stopProfiling): |
| * profiler/ProfileNode.cpp: Ditto. |
| (KJS::ProfileNode::stopProfiling): |
| * profiler/ProfileNode.h: Ditto. |
| |
| 2008-05-20 Kevin McCullough <kmccullough@apple.com> |
| |
| Accidentally turned on the profiler. |
| |
| * kjs/config.h: |
| |
| |
| 2008-05-20 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Tim. |
| |
| <rdar://problem/5770054> JavaScript profiler (10928) |
| Split function name into 3 parts so that the Web Inspector can link it to |
| the resource location from whence it came. |
| |
| * kjs/ustring.cpp: Implemented operator> for UStrings |
| (KJS::operator>): |
| * kjs/ustring.h: |
| * profiler/Profile.cpp: |
| (KJS::Profile::Profile): Initialize all 3 values. |
| (KJS::Profile::willExecute): Use CallIdentifier struct. |
| (KJS::Profile::didExecute): Ditto. |
| * profiler/Profile.h: Ditto and remove unused function. |
| * profiler/ProfileNode.cpp: |
| (KJS::ProfileNode::ProfileNode): Use CallIdentifier struct. |
| (KJS::ProfileNode::willExecute): Ditto and fix an issue where we |
| restarted the m_startTime even though it was already started. |
| (KJS::ProfileNode::didExecute): Ditto. |
| (KJS::ProfileNode::findChild): Ditto. |
| (KJS::functionNameDescendingComparator): Ditto and use new comparator. |
| (KJS::functionNameAscendingComparator): Ditto. |
| (KJS::ProfileNode::printDataInspectorStyle): Use CallIdentifier struct. |
| (KJS::ProfileNode::printDataSampleStyle): Ditto. |
| * profiler/ProfileNode.h: |
| (KJS::CallIdentifier::CallIdentifier): Describe the CallIdentifier struct |
| (KJS::CallIdentifier::operator== ): |
| (KJS::ProfileNode::create): Use the CallIdentifier struct. |
| (KJS::ProfileNode::callIdentifier): |
| (KJS::ProfileNode::functionName): Now only return the function name, not |
| the url and line number too. |
| (KJS::ProfileNode::url): |
| (KJS::ProfileNode::lineNumber): |
| * profiler/Profiler.cpp: Use the CallIdentifier struct. |
| (KJS::Profiler::startProfiling): |
| (KJS::Profiler::willExecute): |
| (KJS::Profiler::didExecute): |
| (KJS::getCallIdentifiers): |
| (KJS::getCallIdentifierFromFunctionImp): |
| |
| 2008-05-20 Timothy Hatcher <timothy@apple.com> |
| |
| Rename sortFileName{Ascending,Descending} to |
| sortFunctionName{Ascending,Descending}. |
| |
| Reviewed by Kevin McCullough. |
| |
| * JavaScriptCore.exp: |
| * kjs/config.h: |
| * profiler/Profile.h: |
| * profiler/ProfileNode.cpp: |
| (KJS::functionNameDescendingComparator): |
| (KJS::ProfileNode::sortFunctionNameDescending): |
| (KJS::functionNameAscendingComparator): |
| (KJS::ProfileNode::sortFunctionNameAscending): |
| * profiler/ProfileNode.h: |
| |
| 2008-05-19 Timothy Hatcher <timothy@apple.com> |
| |
| Make the profiler use higher than millisecond resolution time-stamps. |
| |
| Reviewed by Kevin McCullough. |
| |
| * kjs/DateMath.cpp: |
| (KJS::getCurrentUTCTime): Call getCurrentUTCTimeWithMicroseconds and |
| floor the result. |
| (KJS::getCurrentUTCTimeWithMicroseconds): Copied from the previous |
| implementation of getCurrentUTCTime without the floor call. |
| * kjs/DateMath.h: Addded getCurrentUTCTimeWithMicroseconds. |
| * profiler/ProfileNode.cpp: |
| (KJS::ProfileNode::ProfileNode): Use getCurrentUTCTimeWithMicroseconds. |
| |
| 2008-05-19 Timothy Hatcher <timothy@apple.com> |
| |
| Fixes a bug in the profiler where call and apply would show up |
| and double the time spent in a function. We don't want to show call |
| and apply at all in the profiles. This change excludes them. |
| |
| Reviewed by Kevin McCullough. |
| |
| * profiler/ProfileNode.cpp: |
| (KJS::ProfileNode::stopProfiling): Remove a second for loop and |
| calculate self time in the existing loop. |
| * profiler/Profiler.cpp: |
| (KJS::shouldExcludeFunction): Helper inline function that returns |
| true in the current function in an InternalFunctionImp and it is |
| has the functionName call or apply. |
| (KJS::Profiler::willExecute): Call shouldExcludeFunction and return |
| early if if returns true. |
| (KJS::Profiler::didExecute): Ditto. |
| |
| 2008-05-19 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Tim. |
| |
| <rdar://problem/5770054> JavaScript profiler (10928) |
| - Implement sorting by function name. |
| |
| * JavaScriptCore.exp: |
| * profiler/Profile.h: |
| (KJS::Profile::sortFileNameDescending): |
| (KJS::Profile::sortFileNameAscending): |
| * profiler/ProfileNode.cpp: |
| (KJS::fileNameDescendingComparator): |
| (KJS::ProfileNode::sortFileNameDescending): |
| (KJS::fileNameAscendingComparator): |
| (KJS::ProfileNode::sortFileNameAscending): |
| * profiler/ProfileNode.h: |
| |
| 2008-05-19 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Adam. |
| |
| <rdar://problem/5770054> JavaScript profiler (10928) |
| - Pass the exec state to profiler when calling startProfiling so that if |
| profiling is started within an execution context that location is |
| recorded correctly. |
| |
| * JavaScriptCore.exp: |
| * profiler/ProfileNode.cpp: |
| (KJS::ProfileNode::printDataInspectorStyle): Dump more info for debugging |
| purposes. |
| * profiler/Profiler.cpp: |
| (KJS::Profiler::startProfiling): |
| * profiler/Profiler.h: |
| |
| 2008-05-19 Kevin McCullough <kmccullough@apple.com> |
| |
| Rubberstamped by Geoff. |
| |
| Turn off the profiler because it is a performance regression. |
| |
| * kjs/config.h: |
| |
| 2008-05-19 Alp Toker <alp@nuanti.com> |
| |
| Reviewed by Anders and Beth. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=16495 |
| [GTK] Accessibility support with ATK/AT-SPI |
| |
| Initial ATK/AT-SPI accessibility support for the GTK+ port. |
| |
| * wtf/Platform.h: |
| |
| 2008-05-19 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Tim. |
| |
| <rdar://problem/5770054> JavaScript profiler (10928) |
| -In an effort to make the profiler as efficient as possible instead of |
| prepending to a vector we keep the vector in reverse order and operate |
| over it backwards. |
| |
| * profiler/Profile.cpp: |
| (KJS::Profile::willExecute): |
| (KJS::Profile::didExecute): |
| * profiler/ProfileNode.cpp: |
| (KJS::ProfileNode::didExecute): |
| (KJS::ProfileNode::endAndRecordCall): |
| * profiler/ProfileNode.h: |
| * profiler/Profiler.cpp: |
| (KJS::getStackNames): |
| |
| 2008-05-16 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Tim. |
| |
| <rdar://problem/5770054> JavaScript profiler (10928) |
| Implement sorting for the profiler. |
| I chose to sort the profileNodes in place since there is no reason they |
| need to retain their original order. |
| |
| * JavaScriptCore.exp: Export the symbols. |
| * profiler/Profile.h: Add the different ways a profile can be sorted. |
| (KJS::Profile::sortTotalTimeDescending): |
| (KJS::Profile::sortTotalTimeAscending): |
| (KJS::Profile::sortSelfTimeDescending): |
| (KJS::Profile::sortSelfTimeAscending): |
| (KJS::Profile::sortCallsDescending): |
| (KJS::Profile::sortCallsAscending): |
| * profiler/ProfileNode.cpp: Implement those ways. |
| (KJS::totalTimeDescendingComparator): |
| (KJS::ProfileNode::sortTotalTimeDescending): |
| (KJS::totalTimeAscendingComparator): |
| (KJS::ProfileNode::sortTotalTimeAscending): |
| (KJS::selfTimeDescendingComparator): |
| (KJS::ProfileNode::sortSelfTimeDescending): |
| (KJS::selfTimeAscendingComparator): |
| (KJS::ProfileNode::sortSelfTimeAscending): |
| (KJS::callsDescendingComparator): |
| (KJS::ProfileNode::sortCallsDescending): |
| (KJS::callsAscendingComparator): |
| (KJS::ProfileNode::sortCallsAscending): |
| * profiler/ProfileNode.h: No longer use a Deque since it cannot be |
| sorted by std::sort and there was no reason not to use a Vector. I |
| previously had though I would do prepending but am not. |
| (KJS::ProfileNode::selfTime): |
| (KJS::ProfileNode::totalPercent): |
| (KJS::ProfileNode::selfPercent): |
| (KJS::ProfileNode::children): |
| * profiler/Profiler.cpp: Removed these functions as they can be called |
| directoy on the Profile object after getting the Vector of them. |
| (KJS::getStackNames): |
| * profiler/Profiler.h: |
| |
| 2008-05-15 Ariya Hidayat <ariya.hidayat@trolltech.com> |
| |
| Reviewed by Simon. |
| |
| Since WebKitGtk is fully using autotools now, clean-up the .pro/.pri files |
| from gtk-port. |
| |
| * JavaScriptCore.pro: |
| * kjs/testkjs.pro: |
| |
| 2008-05-15 Kevin McCullough <kmccullough@apple.com> |
| |
| - Build fix. |
| |
| * JavaScriptCore.exp: |
| |
| 2008-05-15 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Tim. |
| |
| <rdar://problem/5770054> JavaScript profiler (10928) |
| - Cache some values to save on computing them repetitively. This will be |
| a big savings when we sort since we won't have to walk the tree for |
| every comparison! |
| - We cache these values when we end profiling because otherwise we won't |
| know which profile to get the totalTime for the whole profile from without |
| retaining a reference to the head profile or looking up the profile from |
| the list of all profiles. |
| - Also it's safe to assume we won't be asked for these values while we |
| are still profiling since the WebInspector only get's profileNodes from |
| profiles that are in the allProfiles() list and a profile is only added |
| to that list after it has finished and these values will no longer |
| change. |
| |
| * JavaScriptCore.exp: |
| * profiler/ProfileNode.cpp: |
| (KJS::ProfileNode::ProfileNode): |
| (KJS::ProfileNode::stopProfiling): |
| (KJS::ProfileNode::printDataInspectorStyle): |
| (KJS::ProfileNode::printDataSampleStyle): |
| (KJS::ProfileNode::endAndRecordCall): |
| * profiler/ProfileNode.h: |
| (KJS::ProfileNode::totalTime): |
| (KJS::ProfileNode::selfTime): |
| (KJS::ProfileNode::totalPercent): |
| (KJS::ProfileNode::selfPercent): |
| * profiler/Profiler.cpp: |
| (KJS::Profiler::stopProfiling): |
| |
| 2008-05-15 Simon Hausmann <shausman@trolltech.com> |
| |
| Reviewed by Holger. |
| |
| Fix compilation when compiling with MSVC and wchar_t support. |
| |
| * wtf/unicode/qt4/UnicodeQt4.h: |
| (WTF::Unicode::foldCase): |
| (WTF::Unicode::umemcasecmp): |
| |
| 2008-05-14 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Tim. |
| |
| <rdar://problem/5770054> JavaScript profiler (10928) |
| - Turn on the profiler. |
| |
| * kjs/config.h: |
| |
| 2008-05-14 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Tim. |
| |
| <rdar://problem/5770054> JavaScript profiler (10928) |
| - Expose the new profiler functions to the WebInspector. |
| |
| * JavaScriptCore.exp: |
| |
| 2008-05-14 Kevin McCullough <kmccullough@apple.com> |
| |
| Giving credit where credit is due. |
| |
| * ChangeLog: |
| |
| 2008-05-14 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Geoff and Sam. |
| |
| <rdar://problem/5770054> JavaScript profiler (10928) |
| Add the ability to get percentages of total and self time for displaying |
| in the WebInspector. |
| |
| * profiler/Profile.h: |
| (KJS::Profile::totalProfileTime): |
| * profiler/ProfileNode.cpp: |
| (KJS::ProfileNode::totalPercent): |
| (KJS::ProfileNode::selfPercent): |
| * profiler/ProfileNode.h: |
| * profiler/Profiler.h: |
| (KJS::Profiler::currentProfile): |
| |
| 2008-05-14 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Sam. |
| |
| <rdar://problem/5770054> JavaScript profiler (10928) |
| - Rename FunctionCallProfile to ProfileNode. |
| |
| * GNUmakefile.am: |
| * JavaScriptCore.exp: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * profiler/FunctionCallProfile.cpp: Removed. |
| * profiler/FunctionCallProfile.h: Removed. |
| * profiler/Profile.cpp: |
| (KJS::Profile::Profile): |
| (KJS::Profile::willExecute): |
| * profiler/Profile.h: |
| (KJS::Profile::callTree): |
| * profiler/ProfileNode.cpp: Copied from profiler/FunctionCallProfile.cpp. |
| (KJS::ProfileNode::ProfileNode): |
| (KJS::ProfileNode::willExecute): |
| (KJS::ProfileNode::didExecute): |
| (KJS::ProfileNode::addChild): |
| (KJS::ProfileNode::findChild): |
| (KJS::ProfileNode::stopProfiling): |
| (KJS::ProfileNode::selfTime): |
| (KJS::ProfileNode::printDataInspectorStyle): |
| (KJS::ProfileNode::printDataSampleStyle): |
| (KJS::ProfileNode::endAndRecordCall): |
| * profiler/ProfileNode.h: Copied from profiler/FunctionCallProfile.h. |
| (KJS::ProfileNode::create): |
| (KJS::ProfileNode::children): |
| * profiler/Profiler.cpp: |
| |
| 2008-05-14 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by John. |
| |
| <rdar://problem/5770054> JavaScript profiler (10928) |
| - Have each FunctionCallProfile be able to return it's total and self time. |
| |
| * JavaScriptCore.exp: |
| * profiler/FunctionCallProfile.cpp: |
| (KJS::FunctionCallProfile::selfTime): |
| * profiler/FunctionCallProfile.h: |
| (KJS::FunctionCallProfile::totalTime): |
| |
| 2008-05-14 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| <rdar://problem/5934376> REGRESSION: A script fails because of a straw BOM character in it. |
| |
| <https://bugs.webkit.org/show_bug.cgi?id=4931> |
| Unicode format characters (Cf) should be removed from JavaScript source |
| |
| Of all Cf characters, we are only removing BOM, because this is what Firefox trunk has |
| settled upon, after extensive discussion and investigation. |
| |
| Based on Darin's work on this bug. |
| |
| Test: fast/js/removing-Cf-characters.html |
| |
| * kjs/lexer.cpp: |
| (KJS::Lexer::setCode): Tweak formatting. Use a call to shift(4) to read in the |
| first characters, instead of having special case code here. |
| (KJS::Lexer::shift): Add a loop when reading a character to skip BOM characters. |
| |
| 2008-05-13 Matt Lilek <webkit@mattlilek.com> |
| |
| Not reviewed, build fix. |
| |
| * kjs/date_object.cpp: |
| (KJS::DateObjectFuncImp::callAsFunction): |
| |
| 2008-05-13 Anders Carlsson <andersca@apple.com> |
| |
| Reviewed by Sam. |
| |
| <rdar://problem/5933644> Implement Date.now |
| |
| Implement Date.now which returns the number of milliseconds since the epoch. |
| |
| * kjs/CommonIdentifiers.h: |
| * kjs/date_object.cpp: |
| (KJS::DateObjectFuncImp::): |
| (KJS::DateObjectImp::DateObjectImp): |
| (KJS::DateObjectFuncImp::callAsFunction): |
| |
| 2008-05-13 Kevin McCullough <kmccullough@apple.com> |
| |
| Giving credit where credit is due. |
| |
| * ChangeLog: |
| |
| 2008-05-13 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Adam and Geoff. |
| |
| <rdar://problem/5770054> JavaScript profiler (10928) |
| Use PassRefPtrs instead of RefPtrs when appropriate. |
| |
| * profiler/FunctionCallProfile.cpp: |
| (KJS::FunctionCallProfile::addChild): |
| * profiler/FunctionCallProfile.h: |
| * profiler/Profile.h: |
| (KJS::Profile::callTree): |
| |
| 2008-05-13 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Sam. |
| |
| <rdar://problem/5770054> JavaScript profiler (10928) |
| - Made some functions static (as per Adam) and changed from using raw |
| pointers to RefPtr for making these JavaScript Objects. |
| |
| * profiler/FunctionCallProfile.cpp: |
| (KJS::FunctionCallProfile::addChild): |
| (KJS::FunctionCallProfile::findChild): |
| * profiler/FunctionCallProfile.h: |
| (KJS::FunctionCallProfile::create): |
| * profiler/Profile.cpp: |
| (KJS::Profile::Profile): |
| (KJS::Profile::willExecute): |
| (KJS::Profile::didExecute): |
| (KJS::functionNameCountPairComparator): |
| * profiler/Profile.h: |
| (KJS::Profile::create): |
| (KJS::Profile::title): |
| (KJS::Profile::callTree): |
| * profiler/Profiler.cpp: |
| (KJS::Profiler::startProfiling): |
| * profiler/Profiler.h: |
| (KJS::Profiler::allProfiles): |
| (KJS::Profiler::clearProfiles): |
| |
| 2008-05-13 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Geoffrey Garen. |
| |
| <rdar://problem/4949018> JavaScriptCore API claims to work with UTF8 strings, but only works |
| with ASCII strings |
| |
| * kjs/ustring.h: |
| * kjs/ustring.cpp: |
| (KJS::UString::Rep::createFromUTF8): |
| Added. Implementation adapted from JSStringCreateWithUTF8CString(). |
| |
| * API/JSStringRef.cpp: |
| (JSStringCreateWithUTF8CString): |
| * API/JSClassRef.cpp: |
| (OpaqueJSClass::OpaqueJSClass): |
| Use UString::Rep::createFromUTF8(). |
| |
| 2008-05-12 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Tim Hatcher. |
| |
| <rdar://problem/4859666> WebKit needs availability macros in order to deprecate APIs |
| |
| Create WebKit availability macros that key off the Mac OS X version being targeted to |
| determine the WebKit version being targeted. Applications can define |
| WEBKIT_VERSION_MIN_REQUIRED before including WebKit headers in order to target a specific |
| version of WebKit. |
| |
| The availability header is being added to JavaScriptCore rather than WebKit as JavaScriptCore |
| is the lowest-level portion of the public WebKit API. |
| |
| * API/WebKitAvailability.h: Added. |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2008-05-12 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=18828 |
| Reproducible crash with PAC file |
| |
| Naively moving JavaScriptCore into thread-specific data was inappropriate in the face of |
| exiting JavaScriptCore API clients, which expect a different therading model. Temporarily |
| disabling ThreadSpecific implementation until this can be sorted out. |
| |
| * wtf/ThreadSpecific.h: |
| (WTF::::ThreadSpecific): |
| (WTF::::~ThreadSpecific): |
| (WTF::::get): |
| (WTF::::set): |
| |
| 2008-05-12 Alexey Proskuryakov <ap@webkit.org> |
| |
| Roll out recent threading changes (r32807, r32810, r32819, r32822) to simplify |
| SquirrelFish merging. |
| |
| * API/JSBase.cpp: |
| (JSGarbageCollect): |
| * API/JSCallbackObjectFunctions.h: |
| (KJS::::staticFunctionGetter): |
| * API/JSClassRef.cpp: |
| (OpaqueJSClass::prototype): |
| * API/JSObjectRef.cpp: |
| (JSObjectMake): |
| (JSObjectMakeFunctionWithCallback): |
| (JSObjectMakeConstructor): |
| (JSObjectMakeFunction): |
| * API/JSValueRef.cpp: |
| (JSValueMakeNumber): |
| (JSValueMakeString): |
| * JavaScriptCore.exp: |
| * kjs/ExecState.h: |
| * kjs/InitializeThreading.cpp: |
| (KJS::initializeThreadingOnce): |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::~JSGlobalObject): |
| (KJS::JSGlobalObject::init): |
| (KJS::JSGlobalObject::put): |
| (KJS::JSGlobalObject::reset): |
| (KJS::JSGlobalObject::tearOffActivation): |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::head): |
| (KJS::JSGlobalObject::perThreadData): |
| * kjs/JSLock.cpp: |
| (KJS::JSLock::registerThread): |
| * kjs/JSLock.h: |
| (KJS::JSLock::JSLock): |
| * kjs/array_instance.cpp: |
| (KJS::ArrayInstance::ArrayInstance): |
| (KJS::ArrayInstance::lengthGetter): |
| * kjs/array_object.cpp: |
| (KJS::arrayProtoFuncToString): |
| (KJS::arrayProtoFuncToLocaleString): |
| (KJS::arrayProtoFuncJoin): |
| (KJS::arrayProtoFuncConcat): |
| (KJS::arrayProtoFuncPop): |
| (KJS::arrayProtoFuncPush): |
| (KJS::arrayProtoFuncShift): |
| (KJS::arrayProtoFuncSlice): |
| (KJS::arrayProtoFuncSplice): |
| (KJS::arrayProtoFuncUnShift): |
| (KJS::arrayProtoFuncFilter): |
| (KJS::arrayProtoFuncMap): |
| (KJS::arrayProtoFuncEvery): |
| (KJS::arrayProtoFuncForEach): |
| (KJS::arrayProtoFuncSome): |
| (KJS::arrayProtoFuncIndexOf): |
| (KJS::arrayProtoFuncLastIndexOf): |
| (KJS::ArrayObjectImp::ArrayObjectImp): |
| (KJS::ArrayObjectImp::construct): |
| * kjs/bool_object.cpp: |
| (KJS::BooleanPrototype::BooleanPrototype): |
| (KJS::booleanProtoFuncToString): |
| (KJS::BooleanObjectImp::BooleanObjectImp): |
| (KJS::BooleanObjectImp::construct): |
| * kjs/collector.cpp: |
| (KJS::allocateBlock): |
| (KJS::Collector::recordExtraCost): |
| (KJS::Collector::heapAllocate): |
| (KJS::Collector::allocate): |
| (KJS::Collector::allocateNumber): |
| (KJS::Collector::registerAsMainThread): |
| (KJS::onMainThread): |
| (KJS::PlatformThread::PlatformThread): |
| (KJS::getCurrentPlatformThread): |
| (KJS::Collector::Thread::Thread): |
| (KJS::destroyRegisteredThread): |
| (KJS::initializeRegisteredThreadKey): |
| (KJS::Collector::registerThread): |
| (KJS::Collector::markStackObjectsConservatively): |
| (KJS::Collector::markCurrentThreadConservativelyInternal): |
| (KJS::Collector::markCurrentThreadConservatively): |
| (KJS::suspendThread): |
| (KJS::resumeThread): |
| (KJS::getPlatformThreadRegisters): |
| (KJS::otherThreadStackPointer): |
| (KJS::Collector::markOtherThreadConservatively): |
| (KJS::protectedValues): |
| (KJS::Collector::protect): |
| (KJS::Collector::unprotect): |
| (KJS::Collector::collectOnMainThreadOnly): |
| (KJS::Collector::markProtectedObjects): |
| (KJS::Collector::markMainThreadOnlyObjects): |
| (KJS::Collector::sweep): |
| (KJS::Collector::collect): |
| (KJS::Collector::size): |
| (KJS::Collector::globalObjectCount): |
| (KJS::Collector::protectedGlobalObjectCount): |
| (KJS::Collector::protectedObjectCount): |
| (KJS::Collector::protectedObjectTypeCounts): |
| (KJS::Collector::isBusy): |
| (KJS::Collector::reportOutOfMemoryToAllExecStates): |
| * kjs/collector.h: |
| (KJS::Collector::cellBlock): |
| (KJS::Collector::cellOffset): |
| (KJS::Collector::isCellMarked): |
| (KJS::Collector::markCell): |
| (KJS::Collector::reportExtraMemoryCost): |
| * kjs/date_object.cpp: |
| (KJS::formatLocaleDate): |
| (KJS::DatePrototype::DatePrototype): |
| (KJS::DateObjectImp::DateObjectImp): |
| (KJS::DateObjectImp::construct): |
| (KJS::DateObjectImp::callAsFunction): |
| (KJS::DateObjectFuncImp::DateObjectFuncImp): |
| (KJS::DateObjectFuncImp::callAsFunction): |
| (KJS::dateProtoFuncToString): |
| (KJS::dateProtoFuncToUTCString): |
| (KJS::dateProtoFuncToDateString): |
| (KJS::dateProtoFuncToTimeString): |
| (KJS::dateProtoFuncToLocaleString): |
| (KJS::dateProtoFuncToLocaleDateString): |
| (KJS::dateProtoFuncToLocaleTimeString): |
| (KJS::dateProtoFuncValueOf): |
| (KJS::dateProtoFuncGetTime): |
| (KJS::dateProtoFuncGetFullYear): |
| (KJS::dateProtoFuncGetUTCFullYear): |
| (KJS::dateProtoFuncToGMTString): |
| (KJS::dateProtoFuncGetMonth): |
| (KJS::dateProtoFuncGetUTCMonth): |
| (KJS::dateProtoFuncGetDate): |
| (KJS::dateProtoFuncGetUTCDate): |
| (KJS::dateProtoFuncGetDay): |
| (KJS::dateProtoFuncGetUTCDay): |
| (KJS::dateProtoFuncGetHours): |
| (KJS::dateProtoFuncGetUTCHours): |
| (KJS::dateProtoFuncGetMinutes): |
| (KJS::dateProtoFuncGetUTCMinutes): |
| (KJS::dateProtoFuncGetSeconds): |
| (KJS::dateProtoFuncGetUTCSeconds): |
| (KJS::dateProtoFuncGetMilliSeconds): |
| (KJS::dateProtoFuncGetUTCMilliseconds): |
| (KJS::dateProtoFuncGetTimezoneOffset): |
| (KJS::dateProtoFuncSetTime): |
| (KJS::setNewValueFromTimeArgs): |
| (KJS::setNewValueFromDateArgs): |
| (KJS::dateProtoFuncSetYear): |
| (KJS::dateProtoFuncGetYear): |
| * kjs/error_object.cpp: |
| (KJS::ErrorPrototype::ErrorPrototype): |
| (KJS::errorProtoFuncToString): |
| (KJS::ErrorObjectImp::ErrorObjectImp): |
| (KJS::ErrorObjectImp::construct): |
| (KJS::NativeErrorPrototype::NativeErrorPrototype): |
| (KJS::NativeErrorImp::NativeErrorImp): |
| (KJS::NativeErrorImp::construct): |
| * kjs/function.cpp: |
| (KJS::FunctionImp::lengthGetter): |
| (KJS::FunctionImp::construct): |
| (KJS::Arguments::Arguments): |
| (KJS::ActivationImp::createArgumentsObject): |
| (KJS::encode): |
| (KJS::decode): |
| (KJS::globalFuncParseInt): |
| (KJS::globalFuncParseFloat): |
| (KJS::globalFuncEscape): |
| (KJS::globalFuncUnescape): |
| (KJS::PrototypeFunction::PrototypeFunction): |
| (KJS::PrototypeReflexiveFunction::PrototypeReflexiveFunction): |
| * kjs/function_object.cpp: |
| (KJS::FunctionPrototype::FunctionPrototype): |
| (KJS::functionProtoFuncToString): |
| (KJS::FunctionObjectImp::FunctionObjectImp): |
| (KJS::FunctionObjectImp::construct): |
| * kjs/internal.cpp: |
| (KJS::StringImp::toObject): |
| * kjs/internal.h: |
| (KJS::StringImp::StringImp): |
| (KJS::NumberImp::operator new): |
| * kjs/list.cpp: |
| (KJS::List::markSet): |
| (KJS::List::markProtectedListsSlowCase): |
| (KJS::List::expandAndAppend): |
| * kjs/list.h: |
| (KJS::List::List): |
| (KJS::List::~List): |
| (KJS::List::markProtectedLists): |
| * kjs/lookup.h: |
| (KJS::staticFunctionGetter): |
| (KJS::cacheGlobalObject): |
| * kjs/math_object.cpp: |
| (KJS::MathObjectImp::getValueProperty): |
| (KJS::mathProtoFuncAbs): |
| (KJS::mathProtoFuncACos): |
| (KJS::mathProtoFuncASin): |
| (KJS::mathProtoFuncATan): |
| (KJS::mathProtoFuncATan2): |
| (KJS::mathProtoFuncCeil): |
| (KJS::mathProtoFuncCos): |
| (KJS::mathProtoFuncExp): |
| (KJS::mathProtoFuncFloor): |
| (KJS::mathProtoFuncLog): |
| (KJS::mathProtoFuncMax): |
| (KJS::mathProtoFuncMin): |
| (KJS::mathProtoFuncPow): |
| (KJS::mathProtoFuncRandom): |
| (KJS::mathProtoFuncRound): |
| (KJS::mathProtoFuncSin): |
| (KJS::mathProtoFuncSqrt): |
| (KJS::mathProtoFuncTan): |
| * kjs/nodes.cpp: |
| (KJS::ParserRefCounted::ParserRefCounted): |
| (KJS::ParserRefCounted::ref): |
| (KJS::ParserRefCounted::deref): |
| (KJS::ParserRefCounted::refcount): |
| (KJS::ParserRefCounted::deleteNewObjects): |
| (KJS::Node::handleException): |
| (KJS::NumberNode::evaluate): |
| (KJS::StringNode::evaluate): |
| (KJS::ArrayNode::evaluate): |
| (KJS::PostIncResolveNode::evaluate): |
| (KJS::PostIncLocalVarNode::evaluate): |
| (KJS::PostDecResolveNode::evaluate): |
| (KJS::PostDecLocalVarNode::evaluate): |
| (KJS::PostDecLocalVarNode::inlineEvaluateToNumber): |
| (KJS::PostIncBracketNode::evaluate): |
| (KJS::PostDecBracketNode::evaluate): |
| (KJS::PostIncDotNode::evaluate): |
| (KJS::PostDecDotNode::evaluate): |
| (KJS::typeStringForValue): |
| (KJS::LocalVarTypeOfNode::evaluate): |
| (KJS::TypeOfResolveNode::evaluate): |
| (KJS::TypeOfValueNode::evaluate): |
| (KJS::PreIncLocalVarNode::evaluate): |
| (KJS::PreIncResolveNode::evaluate): |
| (KJS::PreDecLocalVarNode::evaluate): |
| (KJS::PreDecResolveNode::evaluate): |
| (KJS::PreIncConstNode::evaluate): |
| (KJS::PreDecConstNode::evaluate): |
| (KJS::PostIncConstNode::evaluate): |
| (KJS::PostDecConstNode::evaluate): |
| (KJS::PreIncBracketNode::evaluate): |
| (KJS::PreDecBracketNode::evaluate): |
| (KJS::PreIncDotNode::evaluate): |
| (KJS::PreDecDotNode::evaluate): |
| (KJS::NegateNode::evaluate): |
| (KJS::BitwiseNotNode::evaluate): |
| (KJS::MultNode::evaluate): |
| (KJS::DivNode::evaluate): |
| (KJS::ModNode::evaluate): |
| (KJS::addSlowCase): |
| (KJS::add): |
| (KJS::AddNumbersNode::evaluate): |
| (KJS::AddStringsNode::evaluate): |
| (KJS::AddStringLeftNode::evaluate): |
| (KJS::AddStringRightNode::evaluate): |
| (KJS::SubNode::evaluate): |
| (KJS::LeftShiftNode::evaluate): |
| (KJS::RightShiftNode::evaluate): |
| (KJS::UnsignedRightShiftNode::evaluate): |
| (KJS::BitXOrNode::evaluate): |
| (KJS::BitOrNode::evaluate): |
| (KJS::valueForReadModifyAssignment): |
| (KJS::ForInNode::execute): |
| (KJS::TryNode::execute): |
| (KJS::FuncDeclNode::makeFunction): |
| (KJS::FuncExprNode::evaluate): |
| * kjs/nodes.h: |
| * kjs/number_object.cpp: |
| (KJS::NumberPrototype::NumberPrototype): |
| (KJS::numberProtoFuncToString): |
| (KJS::numberProtoFuncToLocaleString): |
| (KJS::numberProtoFuncToFixed): |
| (KJS::numberProtoFuncToExponential): |
| (KJS::numberProtoFuncToPrecision): |
| (KJS::NumberObjectImp::NumberObjectImp): |
| (KJS::NumberObjectImp::getValueProperty): |
| (KJS::NumberObjectImp::construct): |
| (KJS::NumberObjectImp::callAsFunction): |
| * kjs/object.cpp: |
| (KJS::JSObject::call): |
| (KJS::JSObject::get): |
| (KJS::JSObject::put): |
| (KJS::JSObject::defineGetter): |
| (KJS::JSObject::defineSetter): |
| (KJS::JSObject::putDirect): |
| (KJS::Error::create): |
| * kjs/object.h: |
| * kjs/object_object.cpp: |
| (KJS::ObjectPrototype::ObjectPrototype): |
| (KJS::objectProtoFuncToLocaleString): |
| (KJS::objectProtoFuncToString): |
| (KJS::ObjectObjectImp::ObjectObjectImp): |
| (KJS::ObjectObjectImp::construct): |
| * kjs/property_map.h: |
| (KJS::SavedProperty::SavedProperty): |
| (KJS::SavedProperty::init): |
| (KJS::SavedProperty::~SavedProperty): |
| (KJS::SavedProperty::name): |
| (KJS::SavedProperty::value): |
| (KJS::SavedProperty::attributes): |
| * kjs/protect.h: |
| (KJS::gcProtect): |
| (KJS::gcUnprotect): |
| * kjs/regexp_object.cpp: |
| (KJS::RegExpPrototype::RegExpPrototype): |
| (KJS::regExpProtoFuncToString): |
| (KJS::RegExpImp::getValueProperty): |
| (KJS::RegExpObjectImp::RegExpObjectImp): |
| (KJS::RegExpObjectImp::arrayOfMatches): |
| (KJS::RegExpObjectImp::getBackref): |
| (KJS::RegExpObjectImp::getLastParen): |
| (KJS::RegExpObjectImp::getLeftContext): |
| (KJS::RegExpObjectImp::getRightContext): |
| (KJS::RegExpObjectImp::getValueProperty): |
| (KJS::RegExpObjectImp::createRegExpImp): |
| * kjs/regexp_object.h: |
| * kjs/string_object.cpp: |
| (KJS::StringInstance::StringInstance): |
| (KJS::StringInstance::lengthGetter): |
| (KJS::StringInstance::indexGetter): |
| (KJS::stringInstanceNumericPropertyGetter): |
| (KJS::StringPrototype::StringPrototype): |
| (KJS::replace): |
| (KJS::stringProtoFuncCharAt): |
| (KJS::stringProtoFuncCharCodeAt): |
| (KJS::stringProtoFuncConcat): |
| (KJS::stringProtoFuncIndexOf): |
| (KJS::stringProtoFuncLastIndexOf): |
| (KJS::stringProtoFuncMatch): |
| (KJS::stringProtoFuncSearch): |
| (KJS::stringProtoFuncReplace): |
| (KJS::stringProtoFuncSlice): |
| (KJS::stringProtoFuncSplit): |
| (KJS::stringProtoFuncSubstr): |
| (KJS::stringProtoFuncSubstring): |
| (KJS::stringProtoFuncToLowerCase): |
| (KJS::stringProtoFuncToUpperCase): |
| (KJS::stringProtoFuncToLocaleLowerCase): |
| (KJS::stringProtoFuncToLocaleUpperCase): |
| (KJS::stringProtoFuncLocaleCompare): |
| (KJS::stringProtoFuncBig): |
| (KJS::stringProtoFuncSmall): |
| (KJS::stringProtoFuncBlink): |
| (KJS::stringProtoFuncBold): |
| (KJS::stringProtoFuncFixed): |
| (KJS::stringProtoFuncItalics): |
| (KJS::stringProtoFuncStrike): |
| (KJS::stringProtoFuncSub): |
| (KJS::stringProtoFuncSup): |
| (KJS::stringProtoFuncFontcolor): |
| (KJS::stringProtoFuncFontsize): |
| (KJS::stringProtoFuncAnchor): |
| (KJS::stringProtoFuncLink): |
| (KJS::StringObjectImp::StringObjectImp): |
| (KJS::StringObjectImp::construct): |
| (KJS::StringObjectImp::callAsFunction): |
| (KJS::StringObjectFuncImp::StringObjectFuncImp): |
| (KJS::StringObjectFuncImp::callAsFunction): |
| * kjs/string_object.h: |
| (KJS::StringInstanceThatMasqueradesAsUndefined::StringInstanceThatMasqueradesAsUndefined): |
| * kjs/testkjs.cpp: |
| (GlobalObject::GlobalObject): |
| (functionGC): |
| (functionRun): |
| (functionReadline): |
| (kjsmain): |
| * kjs/ustring.h: |
| * kjs/value.cpp: |
| (KJS::JSCell::operator new): |
| (KJS::jsString): |
| (KJS::jsOwnedString): |
| (KJS::jsNumberCell): |
| * kjs/value.h: |
| (KJS::jsNaN): |
| (KJS::jsNumber): |
| (KJS::jsNumberFromAnd): |
| (KJS::JSCell::marked): |
| (KJS::JSCell::mark): |
| (KJS::JSValue::toJSNumber): |
| * wtf/ThreadSpecific.h: |
| (WTF::T): |
| |
| 2008-05-10 Julien Chaffraix <jchaffraix@webkit.org> |
| |
| Qt & wx build fix. |
| |
| * JavaScriptCore.pri: Add profiler/Profile.cpp. |
| * JavaScriptCoreSources.bkl: Ditto. |
| |
| 2008-05-10 Jan Michael Alonzo <jmalonzo@unpluggable.com> |
| |
| Reviewed by Maciej. |
| |
| Gtk+ build fix |
| |
| * GNUmakefile.am: Add Profile.cpp in _sources |
| |
| 2008-05-09 Brady Eidson <beidson@apple.com> |
| |
| Build Fix. Kevin is an idiot. |
| ("My name is Kevin McCullough and I approve this message.") |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| |
| 2008-05-09 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Tim. |
| |
| -<rdar://problem/5770054> JavaScript profiler (10928) |
| -Add Profile class so that all profiles can be stored and retrieved by |
| the WebInspector when that time comes. |
| |
| * JavaScriptCore.exp: Export the new function signatures. |
| * JavaScriptCore.xcodeproj/project.pbxproj: Add the new files to the |
| project |
| * profiler/Profile.cpp: Added. This class represents a single run of the |
| profiler. |
| (KJS::Profile::Profile): |
| (KJS::Profile::willExecute): |
| (KJS::Profile::didExecute): |
| (KJS::Profile::printDataInspectorStyle): |
| (KJS::functionNameCountPairComparator): |
| (KJS::Profile::printDataSampleStyle): |
| * profiler/Profile.h: Added. Ditto |
| (KJS::Profile::stopProfiling): |
| * profiler/Profiler.cpp: Now the profiler keeps track of many profiles |
| but only runs one at a time. |
| (KJS::Profiler::startProfiling): |
| (KJS::Profiler::stopProfiling): |
| (KJS::Profiler::willExecute): |
| (KJS::Profiler::didExecute): |
| (KJS::Profiler::printDataInspectorStyle): |
| (KJS::Profiler::printDataSampleStyle): |
| * profiler/Profiler.h: Ditto. |
| (KJS::Profiler::~Profiler): |
| (KJS::Profiler::allProfiles): |
| (KJS::Profiler::clearProfiles): |
| |
| 2008-05-08 Anders Carlsson <andersca@apple.com> |
| |
| Reviewed by Mark. |
| |
| Enable NPAPI plug-ins on 64-bit. |
| |
| * wtf/Platform.h: |
| |
| 2008-05-07 Julien Chaffraix <jchaffraix@webkit.org> |
| |
| Reviewed by Adam Roben. |
| |
| wx & Gtk build fix. |
| |
| Add SIZE_MAX definition for the wx port. |
| |
| * os-win32/stdint.h: |
| |
| 2008-05-07 Ariya Hidayat <ariya.hidayat@trolltech.com> |
| |
| Reviewed by Simon. |
| |
| Support for isMainThread in the Qt port. |
| |
| * wtf/ThreadingQt.cpp: |
| (WTF::initializeThreading): Adjusted. |
| (WTF::isMainThread): Added. |
| |
| 2008-05-05 Darin Adler <darin@apple.com> |
| |
| Reviewed by John Sullivan. |
| |
| - fix debug-only leak seen on buildbot |
| |
| * wtf/HashTable.h: |
| (WTF::HashTable::checkKey): After writing an empty value in, but before constructing a |
| deleted value on top of it, call the destructor so the empty value doesn't leak. |
| |
| 2008-05-02 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Geoffrey Garen. |
| |
| Get rid of static data in nodes.cpp (well, at least of non-debug one). |
| |
| No measurable change on SunSpider. |
| |
| * kjs/InitializeThreading.cpp: |
| (KJS::initializeThreadingOnce): |
| * kjs/nodes.cpp: |
| (KJS::newTrackedObjects): |
| (KJS::trackedObjectExtraRefCounts): |
| (KJS::initializeNodesThreading): |
| (KJS::ParserRefCounted::ParserRefCounted): |
| (KJS::ParserRefCounted::ref): |
| (KJS::ParserRefCounted::deref): |
| (KJS::ParserRefCounted::refcount): |
| (KJS::ParserRefCounted::deleteNewObjects): |
| * kjs/nodes.h: |
| Made newTrackedObjects and trackedObjectExtraRefCounts per-thread. |
| |
| 2008-05-02 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Move call stack depth counter to global object. |
| |
| * kjs/ExecState.h: (KJS::ExecState::functionCallDepth): Added a recursion depth counter to |
| per-thread data. |
| * kjs/JSGlobalObject.cpp: (KJS::JSGlobalObject::init): Initialize PerThreadData.functionCallDepth. |
| * kjs/JSGlobalObject.h: (KJS::JSGlobalObject::perThreadData): Made the result non-const. |
| |
| * kjs/object.cpp: |
| (KJS::throwStackSizeExceededError): Moved throwError to a separate function, since it is now |
| the only thing in JSObject::call that needs a PIC branch. |
| (KJS::JSObject::call): Use a per-thread variable instead of local static for recursion depth |
| tracking. |
| |
| 2008-05-02 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Make JavaScriptGlue and JavaScriptCore API functions implicitly call initializeThreading |
| for the sake of non-WebKit clients. |
| |
| * API/JSBase.cpp: |
| (JSGarbageCollect): |
| * API/JSContextRef.cpp: |
| (JSGlobalContextCreate): |
| These are the JavaScriptCore API bottlenecks. There are a few other JSStringRef |
| and JSClassRef functions that can be called earlier, but they do not do anything that |
| requires initializeThreading. |
| |
| * kjs/InitializeThreading.cpp: |
| (KJS::doInitializeThreading): |
| (KJS::initializeThreading): |
| On Darwin, make the initialization happen under pthread_once, since there is no guarantee |
| that non-WebKit clients won't try to call this function re-entrantly. |
| |
| * kjs/InitializeThreading.h: |
| * wtf/Threading.h: |
| Spell out initializeThreading contract. |
| |
| * wtf/ThreadingPthreads.cpp: (WTF::isMainThread): Make sure that results are correct on |
| Darwin, even if threading was initialized from a secondary thread. |
| |
| 2008-05-02 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Geoffrey Garen. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=18826 |
| Make JavaScript heap per-thread |
| |
| * wtf/ThreadSpecific.h: Make sure to initialize POD thread-specific varaibles, too |
| (replaced "new T" with "new T()"). |
| |
| * kjs/collector.h: Renamed Collector to Heap, made the heap per-thread. Removed support for |
| multithreaded access to a heap. |
| (KJS::CollectorBlock): Removed collectOnMainThreadOnly bitmap, added a reference to owner heap. |
| (KJS::SmallCellCollectorBlock): Ditto. |
| (KJS::Heap::markListSet): Moved from a static variable in List.cpp to a per-thread one here. |
| (KJS::Heap::heap): Added a method to find which heap a JSValue is allocated in. |
| |
| * kjs/collector.cpp: Changed "const size_t" constants to #defines, to avoid a PIC branch |
| (gcc was using one to access a constant used in std::max(), because it takes a reference, |
| even though std::max() itself was inlined). |
| (KJS::Heap::threadHeap): JS heap is now per-thread. |
| (KJS::Heap::Heap): Zero-initialize the heap. |
| (KJS::allocateBlock): Added NEVER_INLINE, because this function uses a PIC branch, so |
| inlining it in Heap::heapAllocate() is bad for performance, now that the latter doesn't |
| use any global data. |
| (KJS::Heap::heapAllocate): Initialize Block::heap. |
| (KJS::Heap::markCurrentThreadConservatively): Moved into markStackObjectsConservatively(), |
| as GC only works with a current thread's heap now. |
| (KJS::Heap::sweep): Removed collectOnMainThreadOnly checks. |
| (KJS::Heap::collect): Ditto. |
| |
| * kjs/JSLock.cpp: |
| * kjs/JSLock.h: |
| (KJS::JSLock::JSLock): |
| Removed registerThread(), as the heap no longer cares. |
| |
| * kjs/InitializeThreading.cpp: (KJS::initializeThreading): Initialize new per-thread |
| variables in Heap and JSGlobalObject. |
| |
| * kjs/ExecState.h: (KJS::ExecState::heap): Added a heap pointer for faster access to |
| per-thread heap, and an accessor for it. |
| |
| * kjs/JSGlobalObject.h: Made JSGlobalObject linked list per-thread. |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::~JSGlobalObject): Fixed a bug in linked list handling. It only worked |
| right if the removed object was the head one! |
| (KJS::JSGlobalObject::head): Return a per-thread list head. |
| (KJS::JSGlobalObject::init): Store a reference to per-thread heap. |
| (KJS::JSGlobalObject::reset): Pass ExecState to functions that need it. |
| (KJS::JSGlobalObject::tearOffActivation): Ditto. |
| (KJS::JSGlobalObject::operator new): JSGlobalObject allocation cannot use an ExecState, |
| so it needs a custom operator new that directly accesses per-thread heap. |
| |
| * kjs/list.h: |
| (KJS::List::List): Replaced m_isInMarkSet boolean with an actual pointer to the set, since it |
| is no longer a single static object. |
| (KJS::List::~List): Ditto. |
| * kjs/list.cpp: |
| (KJS::List::markSet): Removed, this is now stored in Heap. |
| (KJS::List::markProtectedLists): Take a reference to the list. |
| (KJS::List::expandAndAppend): Ask the current thread heap for a mark set reference. |
| |
| * kjs/protect.h: |
| (KJS::gcProtect): |
| (KJS::gcUnprotect): |
| Use the newly added Heap::heap() method to find out which heap the value to be (un)protected |
| belongs to. |
| |
| * kjs/property_map.h: Removed unused SavedProperty class. |
| |
| * JavaScriptCore.exp: |
| * API/JSBase.cpp: |
| (JSGarbageCollect): |
| * API/JSCallbackObjectFunctions.h: |
| (KJS::::staticFunctionGetter): |
| * API/JSClassRef.cpp: |
| (OpaqueJSClass::prototype): |
| * API/JSObjectRef.cpp: |
| (JSObjectMake): |
| (JSObjectMakeFunctionWithCallback): |
| (JSObjectMakeConstructor): |
| (JSObjectMakeFunction): |
| * API/JSValueRef.cpp: |
| (JSValueMakeNumber): |
| (JSValueMakeString): |
| * kjs/array_instance.cpp: |
| (KJS::ArrayInstance::ArrayInstance): |
| (KJS::ArrayInstance::lengthGetter): |
| * kjs/array_object.cpp: |
| (KJS::arrayProtoFuncToString): |
| (KJS::arrayProtoFuncToLocaleString): |
| (KJS::arrayProtoFuncJoin): |
| (KJS::arrayProtoFuncConcat): |
| (KJS::arrayProtoFuncPop): |
| (KJS::arrayProtoFuncPush): |
| (KJS::arrayProtoFuncShift): |
| (KJS::arrayProtoFuncSlice): |
| (KJS::arrayProtoFuncSplice): |
| (KJS::arrayProtoFuncUnShift): |
| (KJS::arrayProtoFuncFilter): |
| (KJS::arrayProtoFuncMap): |
| (KJS::arrayProtoFuncEvery): |
| (KJS::arrayProtoFuncForEach): |
| (KJS::arrayProtoFuncSome): |
| (KJS::arrayProtoFuncIndexOf): |
| (KJS::arrayProtoFuncLastIndexOf): |
| (KJS::ArrayObjectImp::ArrayObjectImp): |
| (KJS::ArrayObjectImp::construct): |
| * kjs/bool_object.cpp: |
| (KJS::BooleanPrototype::BooleanPrototype): |
| (KJS::booleanProtoFuncToString): |
| (KJS::BooleanObjectImp::BooleanObjectImp): |
| (KJS::BooleanObjectImp::construct): |
| * kjs/date_object.cpp: |
| (KJS::formatLocaleDate): |
| (KJS::DatePrototype::DatePrototype): |
| (KJS::DateObjectImp::DateObjectImp): |
| (KJS::DateObjectImp::construct): |
| (KJS::DateObjectImp::callAsFunction): |
| (KJS::DateObjectFuncImp::DateObjectFuncImp): |
| (KJS::DateObjectFuncImp::callAsFunction): |
| (KJS::dateProtoFuncToString): |
| (KJS::dateProtoFuncToUTCString): |
| (KJS::dateProtoFuncToDateString): |
| (KJS::dateProtoFuncToTimeString): |
| (KJS::dateProtoFuncToLocaleString): |
| (KJS::dateProtoFuncToLocaleDateString): |
| (KJS::dateProtoFuncToLocaleTimeString): |
| (KJS::dateProtoFuncValueOf): |
| (KJS::dateProtoFuncGetTime): |
| (KJS::dateProtoFuncGetFullYear): |
| (KJS::dateProtoFuncGetUTCFullYear): |
| (KJS::dateProtoFuncToGMTString): |
| (KJS::dateProtoFuncGetMonth): |
| (KJS::dateProtoFuncGetUTCMonth): |
| (KJS::dateProtoFuncGetDate): |
| (KJS::dateProtoFuncGetUTCDate): |
| (KJS::dateProtoFuncGetDay): |
| (KJS::dateProtoFuncGetUTCDay): |
| (KJS::dateProtoFuncGetHours): |
| (KJS::dateProtoFuncGetUTCHours): |
| (KJS::dateProtoFuncGetMinutes): |
| (KJS::dateProtoFuncGetUTCMinutes): |
| (KJS::dateProtoFuncGetSeconds): |
| (KJS::dateProtoFuncGetUTCSeconds): |
| (KJS::dateProtoFuncGetMilliSeconds): |
| (KJS::dateProtoFuncGetUTCMilliseconds): |
| (KJS::dateProtoFuncGetTimezoneOffset): |
| (KJS::dateProtoFuncSetTime): |
| (KJS::setNewValueFromTimeArgs): |
| (KJS::setNewValueFromDateArgs): |
| (KJS::dateProtoFuncSetYear): |
| (KJS::dateProtoFuncGetYear): |
| * kjs/error_object.cpp: |
| (KJS::ErrorPrototype::ErrorPrototype): |
| (KJS::errorProtoFuncToString): |
| (KJS::ErrorObjectImp::ErrorObjectImp): |
| (KJS::ErrorObjectImp::construct): |
| (KJS::NativeErrorPrototype::NativeErrorPrototype): |
| (KJS::NativeErrorImp::NativeErrorImp): |
| (KJS::NativeErrorImp::construct): |
| * kjs/function.cpp: |
| (KJS::FunctionImp::lengthGetter): |
| (KJS::FunctionImp::construct): |
| (KJS::Arguments::Arguments): |
| (KJS::ActivationImp::createArgumentsObject): |
| (KJS::encode): |
| (KJS::decode): |
| (KJS::globalFuncParseInt): |
| (KJS::globalFuncParseFloat): |
| (KJS::globalFuncEscape): |
| (KJS::globalFuncUnescape): |
| (KJS::PrototypeFunction::PrototypeFunction): |
| (KJS::PrototypeReflexiveFunction::PrototypeReflexiveFunction): |
| * kjs/function_object.cpp: |
| (KJS::FunctionPrototype::FunctionPrototype): |
| (KJS::functionProtoFuncToString): |
| (KJS::FunctionObjectImp::FunctionObjectImp): |
| (KJS::FunctionObjectImp::construct): |
| * kjs/internal.cpp: |
| (KJS::StringImp::toObject): |
| * kjs/internal.h: |
| (KJS::StringImp::StringImp): |
| (KJS::NumberImp::operator new): |
| * kjs/lookup.h: |
| (KJS::staticFunctionGetter): |
| (KJS::cacheGlobalObject): |
| * kjs/math_object.cpp: |
| (KJS::MathObjectImp::getValueProperty): |
| (KJS::mathProtoFuncAbs): |
| (KJS::mathProtoFuncACos): |
| (KJS::mathProtoFuncASin): |
| (KJS::mathProtoFuncATan): |
| (KJS::mathProtoFuncATan2): |
| (KJS::mathProtoFuncCeil): |
| (KJS::mathProtoFuncCos): |
| (KJS::mathProtoFuncExp): |
| (KJS::mathProtoFuncFloor): |
| (KJS::mathProtoFuncLog): |
| (KJS::mathProtoFuncMax): |
| (KJS::mathProtoFuncMin): |
| (KJS::mathProtoFuncPow): |
| (KJS::mathProtoFuncRandom): |
| (KJS::mathProtoFuncRound): |
| (KJS::mathProtoFuncSin): |
| (KJS::mathProtoFuncSqrt): |
| (KJS::mathProtoFuncTan): |
| * kjs/nodes.cpp: |
| (KJS::Node::handleException): |
| (KJS::NumberNode::evaluate): |
| (KJS::StringNode::evaluate): |
| (KJS::ArrayNode::evaluate): |
| (KJS::PostIncResolveNode::evaluate): |
| (KJS::PostIncLocalVarNode::evaluate): |
| (KJS::PostDecResolveNode::evaluate): |
| (KJS::PostDecLocalVarNode::evaluate): |
| (KJS::PostDecLocalVarNode::inlineEvaluateToNumber): |
| (KJS::PostIncBracketNode::evaluate): |
| (KJS::PostDecBracketNode::evaluate): |
| (KJS::PostIncDotNode::evaluate): |
| (KJS::PostDecDotNode::evaluate): |
| (KJS::typeStringForValue): |
| (KJS::LocalVarTypeOfNode::evaluate): |
| (KJS::TypeOfResolveNode::evaluate): |
| (KJS::TypeOfValueNode::evaluate): |
| (KJS::PreIncLocalVarNode::evaluate): |
| (KJS::PreIncResolveNode::evaluate): |
| (KJS::PreDecLocalVarNode::evaluate): |
| (KJS::PreDecResolveNode::evaluate): |
| (KJS::PreIncConstNode::evaluate): |
| (KJS::PreDecConstNode::evaluate): |
| (KJS::PostIncConstNode::evaluate): |
| (KJS::PostDecConstNode::evaluate): |
| (KJS::PreIncBracketNode::evaluate): |
| (KJS::PreDecBracketNode::evaluate): |
| (KJS::PreIncDotNode::evaluate): |
| (KJS::PreDecDotNode::evaluate): |
| (KJS::NegateNode::evaluate): |
| (KJS::BitwiseNotNode::evaluate): |
| (KJS::MultNode::evaluate): |
| (KJS::DivNode::evaluate): |
| (KJS::ModNode::evaluate): |
| (KJS::addSlowCase): |
| (KJS::add): |
| (KJS::AddNumbersNode::evaluate): |
| (KJS::AddStringsNode::evaluate): |
| (KJS::AddStringLeftNode::evaluate): |
| (KJS::AddStringRightNode::evaluate): |
| (KJS::SubNode::evaluate): |
| (KJS::LeftShiftNode::evaluate): |
| (KJS::RightShiftNode::evaluate): |
| (KJS::UnsignedRightShiftNode::evaluate): |
| (KJS::BitXOrNode::evaluate): |
| (KJS::BitOrNode::evaluate): |
| (KJS::valueForReadModifyAssignment): |
| (KJS::ForInNode::execute): |
| (KJS::TryNode::execute): |
| (KJS::FuncDeclNode::makeFunction): |
| (KJS::FuncExprNode::evaluate): |
| * kjs/number_object.cpp: |
| (KJS::NumberPrototype::NumberPrototype): |
| (KJS::numberProtoFuncToString): |
| (KJS::numberProtoFuncToLocaleString): |
| (KJS::numberProtoFuncToFixed): |
| (KJS::numberProtoFuncToExponential): |
| (KJS::numberProtoFuncToPrecision): |
| (KJS::NumberObjectImp::NumberObjectImp): |
| (KJS::NumberObjectImp::getValueProperty): |
| (KJS::NumberObjectImp::construct): |
| (KJS::NumberObjectImp::callAsFunction): |
| * kjs/object.cpp: |
| (KJS::JSObject::defineGetter): |
| (KJS::JSObject::defineSetter): |
| (KJS::JSObject::putDirect): |
| (KJS::Error::create): |
| * kjs/object.h: |
| * kjs/object_object.cpp: |
| (KJS::ObjectPrototype::ObjectPrototype): |
| (KJS::objectProtoFuncToLocaleString): |
| (KJS::objectProtoFuncToString): |
| (KJS::ObjectObjectImp::ObjectObjectImp): |
| (KJS::ObjectObjectImp::construct): |
| * kjs/regexp_object.cpp: |
| (KJS::RegExpPrototype::RegExpPrototype): |
| (KJS::regExpProtoFuncToString): |
| (KJS::RegExpImp::getValueProperty): |
| (KJS::RegExpObjectImp::RegExpObjectImp): |
| (KJS::RegExpObjectImp::arrayOfMatches): |
| (KJS::RegExpObjectImp::getBackref): |
| (KJS::RegExpObjectImp::getLastParen): |
| (KJS::RegExpObjectImp::getLeftContext): |
| (KJS::RegExpObjectImp::getRightContext): |
| (KJS::RegExpObjectImp::getValueProperty): |
| (KJS::RegExpObjectImp::createRegExpImp): |
| * kjs/regexp_object.h: |
| * kjs/string_object.cpp: |
| (KJS::StringInstance::StringInstance): |
| (KJS::StringInstance::lengthGetter): |
| (KJS::StringInstance::indexGetter): |
| (KJS::stringInstanceNumericPropertyGetter): |
| (KJS::StringPrototype::StringPrototype): |
| (KJS::replace): |
| (KJS::stringProtoFuncCharAt): |
| (KJS::stringProtoFuncCharCodeAt): |
| (KJS::stringProtoFuncConcat): |
| (KJS::stringProtoFuncIndexOf): |
| (KJS::stringProtoFuncLastIndexOf): |
| (KJS::stringProtoFuncMatch): |
| (KJS::stringProtoFuncSearch): |
| (KJS::stringProtoFuncReplace): |
| (KJS::stringProtoFuncSlice): |
| (KJS::stringProtoFuncSplit): |
| (KJS::stringProtoFuncSubstr): |
| (KJS::stringProtoFuncSubstring): |
| (KJS::stringProtoFuncToLowerCase): |
| (KJS::stringProtoFuncToUpperCase): |
| (KJS::stringProtoFuncToLocaleLowerCase): |
| (KJS::stringProtoFuncToLocaleUpperCase): |
| (KJS::stringProtoFuncLocaleCompare): |
| (KJS::stringProtoFuncBig): |
| (KJS::stringProtoFuncSmall): |
| (KJS::stringProtoFuncBlink): |
| (KJS::stringProtoFuncBold): |
| (KJS::stringProtoFuncFixed): |
| (KJS::stringProtoFuncItalics): |
| (KJS::stringProtoFuncStrike): |
| (KJS::stringProtoFuncSub): |
| (KJS::stringProtoFuncSup): |
| (KJS::stringProtoFuncFontcolor): |
| (KJS::stringProtoFuncFontsize): |
| (KJS::stringProtoFuncAnchor): |
| (KJS::stringProtoFuncLink): |
| (KJS::StringObjectImp::StringObjectImp): |
| (KJS::StringObjectImp::construct): |
| (KJS::StringObjectImp::callAsFunction): |
| (KJS::StringObjectFuncImp::StringObjectFuncImp): |
| (KJS::StringObjectFuncImp::callAsFunction): |
| * kjs/string_object.h: |
| (KJS::StringInstanceThatMasqueradesAsUndefined::StringInstanceThatMasqueradesAsUndefined): |
| * kjs/testkjs.cpp: |
| (GlobalObject::GlobalObject): |
| (functionGC): |
| (functionRun): |
| (functionReadline): |
| (kjsmain): |
| * kjs/ustring.h: |
| * kjs/value.cpp: |
| (KJS::JSCell::operator new): |
| (KJS::jsString): |
| (KJS::jsOwnedString): |
| (KJS::jsNumberCell): |
| * kjs/value.h: |
| (KJS::jsNaN): |
| (KJS::jsNumber): |
| (KJS::jsNumberFromAnd): |
| (KJS::JSCell::marked): |
| (KJS::JSCell::mark): |
| (KJS::JSValue::toJSNumber): |
| Removed collectOnMainThreadOnly, as this is the only way to collect now. Replaced calls to |
| static Collector methods with calls to per-thread Heap ones. |
| |
| 2008-05-02 Dan Bernstein <mitz@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| - Mac build fix |
| |
| * wtf/StrHash.h: Added header guards and removed #include "config.h". |
| |
| 2008-05-01 Ada Chan <adachan@apple.com> |
| |
| #include <wtf/StrHash.h> in identifier.cpp. |
| |
| Reviewed by Maciej. |
| |
| * kjs/identifier.cpp: |
| |
| 2008-05-01 Steve Falkenburg <sfalken@apple.com> |
| |
| Build fix. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| |
| 2008-05-01 Sam Weinig <sam@webkit.org> |
| |
| Fix build. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2008-05-01 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Darin. |
| |
| <rdar://problem/5770054> JavaScript profiler (10928) |
| - Fix "sample" output so that it can be imported into Instruments |
| - Also keep track of number of times a function is profiled. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: Add StrHash.h which needed |
| to be pulled out of identifier.cpp so that it could be used by the |
| profiler and identifiers. |
| * kjs/identifier.cpp: Ditto. |
| * profiler/FunctionCallProfile.cpp: |
| (KJS::FunctionCallProfile::printDataInspectorStyle): Inspector style |
| printing should show microseconds. |
| (KJS::FunctionCallProfile::printDataSampleStyle): Sample style printing |
| now counts the number of times a function is in the stack tree and does |
| not print microseconds since that does not make sense for a sampler. |
| * profiler/FunctionCallProfile.h: Keep track of number of times a |
| function is profiled. |
| (KJS::FunctionCallProfile::numberOfCalls): |
| * profiler/Profiler.cpp: |
| (KJS::functionNameCountPairComparator): Comparator for sort function in |
| printDataSampleStyle. |
| (KJS::Profiler::printDataSampleStyle): Print the number of times that a |
| function is listed in the stack tree in order of most times listed. |
| * wtf/HashCountedSet.h: Added copyToVector since it didn't exist and is |
| a more standard way to copy a HashSet to a Vector. I added on variant |
| that takes a pair as the Vector's type and so the HashCountedSet simply |
| fills in that pair with its internal pair, and another variant that |
| takes a Vector of the type of the HashCountedSet and only fills in the |
| Vector with the first element of the pair. |
| (WTF::copyToVector): |
| * wtf/StrHash.h: Added. |
| (WTF::): |
| |
| 2008-04-29 David Kilzer <ddkilzer@apple.com> |
| |
| BUILD FIX for ENABLE(DASHBOARD_SUPPORT) |
| |
| * wtf/Platform.h: Defined ENABLE(DASHBOARD_SUPPORT) to 1 only for |
| PLATFORM(MAC) and PLATFORM(WIN). Changed default to 0 for other |
| ports. |
| |
| 2008-04-29 Greg Bolsinga <bolsinga@apple.com> |
| |
| Reviewed by Darin. |
| |
| Wrapped Dashboard code with ENABLE(DASHBOARD_SUPPORT) |
| |
| * wtf/Platform.h: |
| |
| 2008-04-29 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Geoff. |
| |
| -<rdar://problem/5770054> JavaScript profiler (10928) |
| -Keep call count. |
| |
| * profiler/FunctionCallProfile.cpp: |
| (KJS::FunctionCallProfile::FunctionCallProfile): |
| (KJS::FunctionCallProfile::didExecute): Implements call count and fixed a bug where a stackIndex |
| of 0 was causing the assert to be hit. |
| (KJS::FunctionCallProfile::stopProfiling): |
| (KJS::FunctionCallProfile::endAndRecordCall): |
| * profiler/FunctionCallProfile.h: |
| |
| 2008-04-29 Simon Hausmann <hausmann@webkit.org> |
| |
| Qt/Windows build fix. The externally declared hash tables are actually |
| declared const and the const is mangled in the symbol name, so when |
| importing they also need to be marked const. |
| |
| When compiling without MULTIPLE_THREADS use a const HashTable& |
| instead of a HashTable& in ThreadClassInfoHashTables to avoid |
| initializing the latter with a const reference. |
| |
| * kjs/JSGlobalObject.cpp: |
| |
| 2008-04-28 Alexey Proskuryakov <ap@webkit.org> |
| |
| Windows build fix. |
| |
| * kjs/ExecState.h: For whatever reason, MSVC couldn't generate a default constructor for |
| a struct that had a "const List" member. Removing the const qulifier makes the problem go away. |
| |
| 2008-04-28 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Fix run-webkit-tests --threading |
| and provisionally fix <https://bugs.webkit.org/show_bug.cgi?id=18661> |
| Proxy server issue in Sunday's Nightly |
| |
| Changed ClassInfo objects for built-in objects to hold a getter function returning |
| a per-thread instance. This makes it safe to share these ClassInfo objects between threads - |
| and these are the only ones that need to be shared. |
| |
| * kjs/lexer.cpp: |
| (KJS::Lexer::Lexer): |
| (KJS::Lexer::~Lexer): |
| * kjs/lexer.h: |
| Made mainTable a member of Lexer, so that it no longer needs to be shared between threads. |
| |
| * kjs/object.cpp: |
| (KJS::JSObject::deleteProperty): |
| (KJS::JSObject::findPropertyHashEntry): |
| (KJS::JSObject::propertyIsEnumerable): |
| (KJS::JSObject::getPropertyAttributes): |
| (KJS::JSObject::getPropertyNames): |
| * kjs/object.h: |
| (KJS::ClassInfo::propHashTable): |
| Added a new classPropHashTableGetterFunction field to ClassInfo. If it is non-zero, the |
| static table is not used. |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::ThreadClassInfoHashTables::ThreadClassInfoHashTables): This new class holds per-thread |
| HashTables for built-in classes. The old static structs are copied to create per-thread |
| instances. |
| (KJS::JSGlobalObject::threadClassInfoHashTables): An accessor/initializer for the above. |
| (KJS::JSGlobalObject::init): Copy per-thread data into a single structure for faster access. |
| Also, construct globalExec. |
| (KJS::JSGlobalObject::reset): Adapted for globalExec now being an OwnPtr. |
| (KJS::JSGlobalObject::mark): Ditto. |
| (KJS::JSGlobalObject::globalExec): Ditto. |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::JSGlobalObjectData::JSGlobalObjectData): Made JSGlobalObject::JSGlobalObjectData::globalExec an OwnPtr, so that it can |
| be initialized from JSGlobalObject::init() after them. Otherwise, ExecState constructor was |
| trying to access half-initialized JSGlobalObject to make its own copy of these table |
| references, and failed. |
| (KJS::JSGlobalObject::JSGlobalObject): Pass "this" value to init() to create globalExec. |
| (KJS::JSGlobalObject::perThreadData): An accessor for per-thread data. |
| |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::ExecState): |
| * kjs/ExecState.h: |
| (KJS::ExecState::propertyNames): |
| (KJS::ExecState::emptyList): |
| (KJS::ExecState::arrayTable): |
| (KJS::ExecState::dateTable): |
| (KJS::ExecState::mathTable): |
| (KJS::ExecState::numberTable): |
| (KJS::ExecState::RegExpImpTable): |
| (KJS::ExecState::RegExpObjectImpTable): |
| (KJS::ExecState::stringTable): |
| * kjs/ExecStateInlines.h: |
| (KJS::ExecState::ExecState): |
| Each ExecState holds its own reference to per-thread data, for even faster access. Moved |
| m_emptyList and m_propertyNames to the same structure, making ExecState faster to construct |
| and take less space on the stack. |
| |
| * kjs/InitializeThreading.cpp: (KJS::initializeThreading): Initialize thread-static data |
| added to JSGlobalObject. |
| |
| * API/JSCallbackConstructor.cpp: |
| * API/JSCallbackFunction.cpp: |
| * API/JSCallbackObject.cpp: |
| * JavaScriptCore.exp: |
| * kjs/JSVariableObject.cpp: |
| (KJS::JSVariableObject::getPropertyAttributes): |
| * kjs/JSVariableObject.h: |
| * kjs/array_instance.cpp: |
| * kjs/array_object.cpp: |
| (KJS::ArrayPrototype::getOwnPropertySlot): |
| * kjs/bool_object.cpp: |
| * kjs/create_hash_table: |
| * kjs/date_object.cpp: |
| (KJS::DatePrototype::getOwnPropertySlot): |
| (KJS::DateObjectImp::DateObjectImp): |
| * kjs/error_object.cpp: |
| * kjs/function.cpp: |
| * kjs/function_object.cpp: |
| (KJS::FunctionPrototype::FunctionPrototype): |
| * kjs/internal.cpp: |
| * kjs/lookup.h: |
| * kjs/math_object.cpp: |
| (KJS::MathObjectImp::getOwnPropertySlot): |
| * kjs/number_object.cpp: |
| (KJS::NumberObjectImp::getOwnPropertySlot): |
| * kjs/object_object.cpp: |
| (KJS::ObjectPrototype::ObjectPrototype): |
| * kjs/regexp_object.cpp: |
| (KJS::RegExpPrototype::RegExpPrototype): |
| (KJS::RegExpImp::getOwnPropertySlot): |
| (KJS::RegExpImp::put): |
| (KJS::RegExpObjectImp::getOwnPropertySlot): |
| (KJS::RegExpObjectImp::put): |
| * kjs/string_object.cpp: |
| (KJS::StringPrototype::getOwnPropertySlot): |
| Adjust for the above changes. |
| |
| 2008-04-28 Darin Adler <darin@apple.com> |
| |
| Reviewed by Adam. |
| |
| - make sure RefPtr's default hash doesn't ref/deref when computing the hash |
| - remove remnants of the hash table storage type optimization |
| |
| * wtf/HashFunctions.h: Used "using" to get the hash and equal functions |
| from PtrHash<P*> into PtrHash<RefPtr<P>>. |
| |
| * wtf/HashMap.h: Replaced uses of PairBaseHashTraits with PairHashTraits. |
| Eliminated storage-related typedefs. Removed constructor, destructor, |
| copy constructor, and destructor since the compiler-generated ones are |
| fine. Removed refAll and derefAll. Took out unnnecessary typecasts. |
| Removed use of RefCounter. |
| |
| * wtf/HashSet.h: Eliminated storage-related typedefs. Removed constructor, |
| destructor, copy constructor, and destructor since the compiler-generated |
| ones are fine. Removed refAll and derefAll. Removed unneeded template |
| arguents from HashSetTranslatorAdapter. Eliminated unneeded HashSetTranslator |
| template. |
| |
| * wtf/HashTable.h: Tweaked formatting. Removed NeedsRef, RefCounterBase, |
| RefCounter, HashTableRefCounterBase, HashTableRefCounter, and Assigner |
| class templates. |
| |
| * wtf/HashTraits.h: Removed StorageTraits, needsRef, PairBaseHashTraits, |
| and HashKeyStorageTraits. |
| |
| * wtf/RefPtrHashMap.h: Made all the same fixes as in HashMap. Also made |
| the corresponding changes to RefPtrHashMapRawKeyTranslator. |
| |
| 2008-04-28 Darin Adler <darin@apple.com> |
| |
| Reviewed by Mitz. |
| |
| - fix assertion hit every time you view www.apple.com |
| |
| * kjs/PropertyNameArray.cpp: |
| (KJS::PropertyNameArray::add): Changed assertion to allow null and empty strings. |
| Now to find out why we have a property named "" and if that's a bug! |
| |
| 2008-04-27 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Fix crash inside PtrHash::hash when loading a page. |
| |
| * wtf/HashFunctions.h: Explicitly use the superclass implementation of hash to avoid infinite recursion. |
| |
| 2008-04-27 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - fix <rdar://problem/5657459> REGRESSION: JavaScriptCore no longer builds with |
| GCC 4.2 due to pointer aliasing warnings |
| |
| Fix this by removing the HashTable optimizations that allowed us to share a back end |
| implementation between hash tables with integers, pointers, RefPtr, and String objects |
| as keys. The way it worked was incompatible with strict aliasing. |
| |
| This increases code size. On Mac OS X we'll have to regenerate .order files to avoid |
| slowing down Safari startup times. |
| |
| This creates a slight slowdown in SunSpider, mitigated by the following four speedups: |
| |
| - speed up array put slightly by moving a branch (was already done for get) |
| |
| - speed up symbol table access by adding a function named inlineGet to HashMap |
| and using that in symbolTableGet/Put |
| |
| - speed up PropertyNameArray creation by reducing the amount of reference count |
| churn and uniqueness checking when adding names and not doing any allocation at |
| all when building small arrays |
| |
| - speed up conversion of strings to floating point numbers by eliminating the |
| malloc/free of the buffer for the ASCII copy of the string; a way to make |
| things even faster would be to change strtod to take a UTF-16 string |
| |
| Note that there is considerable unused complexity now in HashSet/Map/Table to support |
| "storage types", which is no longer used. Will do in a separate patch. |
| |
| * API/JSCallbackObjectFunctions.h: |
| (KJS::JSCallbackObject<Base>::getPropertyNames): Removed explicit cast to Identifier to |
| take advantage of the new PropertyNameArray::add overload and avoid reference count churn. |
| * API/JSObjectRef.cpp: |
| (JSPropertyNameAccumulatorAddName): Ditto. |
| * JavaScriptCore.exp: Updated PropertyNameArray::add entry point name. |
| |
| * kjs/JSVariableObject.cpp: Removed now-unneeded IdentifierRepHashTraits::nullRepPtr |
| definition (see below). |
| (KJS::JSVariableObject::getPropertyNames): Removed explicit cast to Identifier. |
| |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::symbolTableGet): Use inlineGet for speed. Also changed to do |
| early exit instead of nesting the body inside an if. |
| (KJS::JSVariableObject::symbolTablePut): Ditto. |
| |
| * kjs/PropertyNameArray.cpp: |
| (KJS::PropertyNameArray::add): Changed implementation to take a raw pointer instead of |
| a reference to an identifier. Do uniqueness checking by searching the vector when the |
| vector is short, only building the set once the vector is large enough. |
| |
| * kjs/PropertyNameArray.h: Added an overload of add for a raw pointer, and made the old |
| add function call that one. Added an addKnownUnique function for use when the new |
| name is known to be different from any other in the array. Changed the vector to have |
| an inline capacity of 20. |
| |
| * kjs/SymbolTable.h: Changed IdentifierRepHash to inherit from the default hash for |
| a RefPtr so we don't have to define so much. Added an overload of the hash function for |
| a raw pointer as required by the new RefPtrHashMap. Got rid of the now-unneeded |
| IdentifierRepHashTraits -- the default traits now work fine. Added a definition of |
| empthValueIsZero to SymbolTableIndexHashTraits; not having it was incorrect, but harmless. |
| |
| * kjs/array_instance.cpp: |
| (KJS::ArrayInstance::put): Move the maxArrayIndex check inside the branch that checks |
| the index against the length, as done in the get function. |
| |
| * kjs/function.cpp: |
| (KJS::globalFuncKJSPrint): Changed to use the new getCString instead of cstring. |
| |
| * kjs/internal.cpp: Removed printInfo debugging function, a client of cstring. |
| If we need a debugging function we can easily make a better one and we haven't |
| used this one in a long time. |
| * kjs/internal.h: Ditto. |
| |
| * kjs/object.cpp: |
| (KJS::JSObject::getPropertyNames): Removed explicit cast to Identifier. |
| * kjs/property_map.cpp: |
| (KJS::PropertyMap::getEnumerablePropertyNames): Ditto. Also added a special case for |
| the case where the propertyNames array is empty -- in that case we know we're adding |
| a set of names that are non-overlapping so we can use addKnownUnique. |
| * kjs/ustring.cpp: |
| (KJS::UString::getCString): Replaces cstring. Puts the C string into a CStringBuffer, |
| which is a char Vector with an inline capacity. Also returns a boolean to indicate if |
| the converion was lossy, which eliminates the need for a separate is8Bit call. |
| (KJS::UString::toDouble): Changed to call getCString instead of cstring. |
| * kjs/ustring.h: Ditto. |
| |
| * wtf/HashFunctions.h: Overload the hash and equal functions for RefPtr's default |
| hash to take raw pointers. This works with the changes to RefPtrHashMap to avoid |
| introducing refcount churn. |
| |
| * wtf/HashMap.h: Removed special code to convert the deleted value to the empty value |
| when writing a new value into the map. This is now handled elsewhere. |
| (WTF::HashMap::get): Removed code that checks for an empty hash table before calling |
| HashTable::lookup; it's slightly more efficient to do this check inside lookup. |
| |
| * wtf/HashTable.h: |
| (WTF::HashTable::isDeletedBucket): Changed to use isDeletedValue instead of using |
| deletedValue and the equality operator. |
| (WTF::HashTable::deleteBucket): Changed to use constructDeletedValue instead of |
| using deletedValue and the assignment operator. |
| (WTF::HashTable::checkKey): Added. Factors out the check for values that are empty |
| or deleted keys that's used in various functions below. |
| (WTF::HashTable::lookup): Changed to use checkKey, check for a 0 table, and also |
| made public for use by RefPtrHashMap. |
| (WTF::HashTable::lookupForWriting): Changed to use checkKey. |
| (WTF::HashTable::fullLookupForWriting): Changed to use checkKey. |
| (WTF::HashTable::add): Changed to use checkKey, and call initializeBucket on a |
| deleted bucket before putting a new entry into it. |
| (WTF::HashTable::addPassingHashCode): Ditto. |
| (WTF::HashTable::deallocateTable): Check isDeletedBucket before calling ~ValueType. |
| |
| * wtf/HashTraits.h: Got ridd of all the HashTraits specialization for the integer |
| types, since GeneicHashTraitsBase already deals with integers separately. Put the |
| deleted value support into GenericHashTraitsBase. Changed FloatHashTraits to |
| inherit from GenericHashTraits, and define construct/isDeletedValue rather than |
| deletedValue. Removed the ref and deref functions from RefPtr's HashTraits, and |
| defined construct/isDeletedValue. Eliminated DeletedValueAssigner. Changed |
| PairHashTraits to define construct/isDeletedValue, and also merged |
| PairBaseHashTraits in with PairHashTraits. Got rid of all specialization of |
| HashKeyStorageTraits. We'll remove that, and the needsRef data member, later. |
| |
| * wtf/RefPtr.h: Added HashTableDeletedValueType, an enum type with a single value, |
| HashTableDeletedValue. Used that type to make a new constructor to construct |
| deleted values and also added an isHashTableDeletedValue function. |
| |
| * wtf/RefPtrHashMap.h: Added RefPtrHashMapRawKeyTranslator and used it to implement |
| the raw pointer functions. This is a way to continue to avoid refcount thrash. We |
| can't use the old way because it depended on the underlying map using a non-RefPtr |
| type. |
| (WTF::HashMap::find): Use find with RefPtrHashMapRawKeyTranslator. |
| (WTF::HashMap::contains): Use contains with RefPtrHashMapRawKeyTranslator. |
| (WTF::HashMap::inlineAdd): Use add with RefPtrHashMapRawKeyTranslator. |
| (WTF::HashMap::get): Removed code that checks for an empty hash table before calling |
| HashTable::lookup; it's slightly more efficient to do this check inside lookup. |
| (WTF::HashMap::inlineGet): Added. Just like get, but marked inline for use in the |
| symbol table code. |
| |
| 2008-04-25 Sam Weinig <sam@webkit.org> |
| |
| Rubber-stamped by Mark Rowe. |
| |
| Remove SavedBuiltins and SavedProperties classes and the methods used to |
| save data to them. The CachedPage now stores a the JSGlobalObject in full. |
| |
| * JavaScriptCore.exp: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/JSGlobalObject.cpp: |
| * kjs/JSGlobalObject.h: |
| * kjs/JSVariableObject.cpp: |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::localStorage): |
| * kjs/SavedBuiltins.h: Removed. |
| * kjs/object.h: |
| * kjs/property_map.cpp: |
| * kjs/property_map.h: |
| |
| 2008-04-25 Mark Rowe <mrowe@apple.com> |
| |
| Rubber-stamped by Sam Weinig. |
| |
| Add some content to an empty ICU header file to prevent verification errors. |
| |
| * icu/unicode/utf_old.h: |
| |
| 2008-04-25 David Kilzer <ddkilzer@apple.com> |
| |
| <rdar://problem/5819422> REGRESSION: Wrong line number passed to -willLeaveCallFrame |
| |
| Patch by George Dicker and Michael Kahl. Reviewed by Darin. |
| |
| When -[NSObject(WebScriptDebugDelegate) webView:willLeaveCallFrame:sourceId:line:forWebFrame:] |
| is invoked, the first line number of the function is returned instead of the last |
| line number. This regressed in r28458. |
| |
| * kjs/nodes.cpp: |
| (KJS::FunctionBodyNodeWithDebuggerHooks::execute): Pass lastLine() instead of lineNo() |
| when calling Debugger::returnEvent(). |
| |
| 2008-04-25 Darin Adler <darin@apple.com> |
| |
| Done with Stephanie Lewis. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: Prepare for compilation with gcc 4.2 by |
| adding -fno-strict-aliasing to CollatorICU.cpp. |
| |
| 2008-04-24 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Geoffrey Garen. |
| |
| Add a #define to easily enable collecting on every allocation to aid |
| debugging GC bugs. |
| |
| * kjs/collector.cpp: |
| (KJS::Collector::heapAllocate): |
| |
| 2008-04-24 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Adam and Sam. |
| |
| -<rdar://problem/5770054> JavaScript profiler (10928) |
| -Only profile the page group that starts profiling to avoid profiling |
| tools that shouldn't be profiled unless explicitly requested to. |
| |
| * JavaScriptCore.exp: Export new signature. |
| * kjs/JSGlobalObject.cpp: Add unique identifiers to the JSGlobalObject. |
| (KJS::JSGlobalObject::init): |
| * kjs/JSGlobalObject.h: Ditto. |
| (KJS::JSGlobalObject::setPageGroupIdentifier): |
| (KJS::JSGlobalObject::pageGroupIdentifier): |
| * profiler/Profiler.cpp: Check the identifier of the page group of the |
| lexical global exec state and only profile if it matches the given page |
| group identifier. |
| (KJS::Profiler::startProfiling): |
| (KJS::Profiler::willExecute): |
| (KJS::Profiler::didExecute): |
| * profiler/Profiler.h: Ditto. |
| (KJS::Profiler::Profiler): |
| |
| 2008-04-24 Julien Chaffraix <jchaffraix@webkit.org> |
| |
| Reviewed by Simon. |
| |
| Bug 15940: Implement threading API for Qt |
| https://bugs.webkit.org/show_bug.cgi?id=15940 |
| |
| Original patch by Justin Haygood, tweaked by me. |
| |
| * JavaScriptCore.pri: |
| * wtf/ThreadingQt.cpp: Added. |
| (WTF::threadMapMutex): |
| (WTF::threadMap): |
| (WTF::establishIdentifierForThread): |
| (WTF::clearThreadForIdentifier): |
| (WTF::threadForIdentifier): |
| (WTF::initializeThreading): |
| (WTF::ThreadPrivate::getReturnValue): |
| (WTF::ThreadPrivate::ThreadPrivate): |
| (WTF::ThreadPrivate::run): |
| (WTF::createThread): |
| (WTF::waitForThreadCompletion): return !res to return |
| 0 on success (to match the pthreads implementation). |
| (WTF::detachThread): |
| (WTF::identifierByQthreadHandle): |
| (WTF::currentThread): |
| (WTF::Mutex::Mutex): |
| (WTF::Mutex::~Mutex): |
| (WTF::Mutex::lock): |
| (WTF::Mutex::tryLock): |
| (WTF::Mutex::unlock): |
| (WTF::ThreadCondition::ThreadCondition): |
| (WTF::ThreadCondition::~ThreadCondition): |
| (WTF::ThreadCondition::wait): |
| (WTF::ThreadCondition::timedWait): |
| (WTF::ThreadCondition::signal): |
| |
| 2008-04-22 Darin Adler <darin@apple.com> |
| |
| Reviewed by Anders. |
| |
| - simplify use of HashTraits to prepare for some upcoming hash table changes |
| |
| * kjs/SymbolTable.h: Made SymbolTableIndexHashTraits derive from HashTraits<size_t> |
| and specialize only the empty value. |
| |
| 2008-04-23 Holger Hans Peter Freyther <zecke@selfish.org> |
| |
| Reviewed by Simon. |
| |
| Removed the #define for USE_SYSTEM_MALLOC that we set in WebKit.pri |
| already. |
| |
| * wtf/Platform.h: |
| |
| 2008-04-21 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Adam. |
| |
| <rdar://problem/5770054> JavaScript profiler (10928) |
| - When stop profiling is called we need to stop the timers on all the |
| functions that are still running. |
| |
| * profiler/FunctionCallProfile.cpp: |
| (KJS::FunctionCallProfile::didExecute): |
| (KJS::FunctionCallProfile::stopProfiling): |
| * profiler/FunctionCallProfile.h: |
| * profiler/Profiler.cpp: |
| (KJS::Profiler::stopProfiling): |
| |
| 2008-04-21 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Move collector main thread initialization from WebKit/win to KJS::initializeThreading. |
| |
| * kjs/InitializeThreading.cpp: |
| (KJS::initializeThreading): |
| |
| 2008-04-21 Adam Roben <aroben@apple.com> |
| |
| MSVC build fix |
| |
| Reviewed by Alexey Proskuryakov. |
| |
| * kjs/ustring.h: |
| (KJS::UString::cost): Disable a warning about assigning a 32-bit |
| size_t into a 31-bit size_t. |
| |
| 2008-04-21 Simon Hausmann <hausmann@webkit.org> |
| |
| Reviewed by Lars. |
| |
| Made convertValueToQVariant accessible from within WebKit/qt/Api |
| |
| * bindings/qt/qt_runtime.h: |
| |
| 2008-04-21 Holger Hans Peter Freyther <holger.freyther@trolltech.com> |
| |
| Reviewed by Simon. |
| |
| Build fix for Qt 4.3 |
| |
| * When building WebCore/internal make sure the QT_[BEGIN,END]_NAMESPACE is |
| always defined. Do this by adding defines to the compiler line |
| * For users of our API this is not feasible. Every public header file should |
| include qwebkitglobal.h. Define the QT_BEGIN_NAMESPACE and QT_END_NAMESPACE |
| when we are building everything < 4.4.0 and don't have them defined. |
| |
| * kjs/testkjs.pro: |
| |
| 2008-04-19 Matt Lilek <webkit@mattlilek.com> |
| |
| Not reviewed, Windows build fix - copy the profiler headers in all |
| configurations, not just Debug_Internal. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| |
| 2008-04-19 Mike Hommey <glandium@debian.org> |
| |
| Reviewed by Alp Toker. |
| |
| Don't build testkjs with rpath. |
| |
| * GNUmakefile.am: |
| |
| 2008-04-18 Kevin Ollivier <kevino@theolliviers.com> |
| |
| wx build fixes. Rename LocalStorage.h to LocalStorageEntry.h |
| to avoid header detection issues between WebCore/storage/LocalStorage.h |
| and it, and add $(PROFILER_SOURCES) to the wx JSCore build. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * jscore.bkl: |
| * kjs/ExecState.h: |
| * kjs/JSVariableObject.h: |
| * kjs/LocalStorage.h: Removed. |
| * kjs/LocalStorageEntry.h: Copied from JavaScriptCore/kjs/LocalStorage.h. |
| * kjs/function.h: |
| |
| 2008-04-18 Jan Michael Alonzo <jmalonzo@unpluggable.com> |
| |
| Reviewed by Alp Toker. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=16620 |
| [GTK] Autotools make dist and make check support |
| |
| Cleanups. |
| |
| * GNUmakefile.am: |
| |
| 2008-04-18 Jon Honeycutt <jhoneycutt@apple.com> |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Windows |
| build fix. |
| |
| 2008-04-11 Mark Rowe <mrowe@apple.com> |
| |
| Rubber-stamped by Antti Koivisto. |
| |
| Silence GCC 4.3 warnings by removing extraneous consts. |
| |
| * kjs/ustring.cpp: |
| * kjs/ustring.h: |
| |
| 2008-04-18 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Sam. |
| |
| -<rdar://problem/5770054> JavaScript profiler (10928) |
| - Use Deque instead of Vector since the profiler uses prepend a lot |
| and deque is faster at that. |
| |
| * profiler/FunctionCallProfile.h: |
| (KJS::FunctionCallProfile::milliSecs): Corrected the name to match |
| its output. |
| * wtf/Deque.h: |
| (WTF::deleteAllValues): |
| |
| 2008-04-18 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Sam and Adam. |
| |
| -<rdar://problem/5770054> JavaScript profiler (10928) |
| - Cleaned up the header file and made some functions static, added |
| a new, sane, printing function, and fixed a few minor bugs. |
| |
| * JavaScriptCore.exp: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * profiler/FunctionCallProfile.cpp: |
| (KJS::FunctionCallProfile::didExecute): Removed assertion that time is |
| > 0 because at ms resolution that may not be true and only cross- |
| platform way to get time differences is in ms. |
| (KJS::FunctionCallProfile::printDataInspectorStyle): Added a new |
| printing function for dumping data in a sane style. |
| (KJS::FunctionCallProfile::printDataSampleStyle): Fixed a bug where we |
| displayed too much precision when printing our floats. Also added logic |
| to make sure we don't display 0 because that doesn't make sense for a |
| sampling profile. |
| * profiler/FunctionCallProfile.h: |
| * profiler/Profiler.cpp: Moved functions that could be static into the |
| implementation, and chaned the ASSERTs to early returns. I did this |
| because console.profile() is a JS function and so was being profiled |
| but asserting because the profiler had not been started! In the future |
| I would like to put the ASSERTs back and not profile the calls to |
| console.profile() and console.profileEnd(). |
| (KJS::Profiler::willExecute): |
| (KJS::Profiler::didExecute): |
| (KJS::getStackNames): Fixed a bug where the wrong ExecState was being |
| used. |
| (KJS::getFunctionName): |
| (KJS::Profiler::printDataInspectorStyle): |
| * profiler/Profiler.h: |
| |
| 2008-04-18 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Fix leaks during plugin tests (which actually excercise background JS), and potential |
| PAC brokenness that was not reported, but very likely. |
| |
| The leaks shadowed a bigger problem with Identifier destruction. Identifier::remove involves |
| an IdentifierTable lookup, which is now a per-thread instance. Since garbage collection can |
| currently happen on a different thread than allocation, a wrong table was used. |
| |
| No measurable change on SunSpider total, ~1% variation on individual tests. |
| |
| * kjs/ustring.cpp: |
| (KJS::UString::Rep::create): |
| (KJS::UString::Rep::destroy): |
| * kjs/ustring.h: |
| Replaced isIdentifier with a pointer to IdentifierTable, so that destruction can be done |
| correctly. Took one bit from reportedCost, to avoid making UString::Rep larger (performance |
| effect was measurable on SunSpider). |
| |
| * kjs/identifier.cpp: |
| (KJS::IdentifierTable::IdentifierTable): |
| (KJS::IdentifierTable::~IdentifierTable): |
| (KJS::IdentifierTable::add): |
| (KJS::IdentifierTable::remove): |
| Make IdentifierTable a real class. Its destructor needs to zero out outstanding references, |
| because some identifiers may briefly outlive it during thread destruction, and we don't want |
| them to use their stale pointers. |
| |
| (KJS::LiteralIdentifierTable): |
| (KJS::Identifier::add): |
| Now that LiteralIdentifierTable is per-thread and can be destroyed not just during application |
| shutdown, it is not appropriate to simply bump refcount for strings that get there; changed |
| the table to hold RefPtrs. |
| |
| (KJS::CStringTranslator::translate): |
| (KJS::UCharBufferTranslator::translate): |
| (KJS::Identifier::addSlowCase): |
| (KJS::Identifier::remove): |
| * kjs/identifier.h: |
| (KJS::Identifier::add): |
| Use and update UString::Rep::identifierTable as appropriate. Updating it is now done in |
| IdentifierTable::add, not in translators. |
| |
| 2008-04-18 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Get rid of static compareWithCompareFunctionArguments in array_instance.cpp. |
| |
| No change on SunSpider, CelticKane or iBench JavaScript. It is probable that in some cases, |
| merge sort is still faster, but more investigation is needed to determine a new cutoff. |
| Or possibly, it would be better to do what FIXME says (change to tree sort). |
| |
| Also, made arguments a local variable - not sure why it was a member of |
| CompareWithCompareFunctionArguments. |
| |
| * kjs/array_instance.cpp: |
| (KJS::CompareWithCompareFunctionArguments::CompareWithCompareFunctionArguments): |
| (KJS::CompareWithCompareFunctionArguments::operator()): |
| (KJS::ArrayInstance::sort): |
| |
| 2008-04-18 Simon Hausmann <hausmann@webkit.org> |
| |
| Build fix for gcc 4.3. Include stdio.h for printf. |
| |
| * profiler/FunctionCallProfile.cpp: |
| * profiler/Profiler.cpp: |
| |
| 2008-04-17 Jon Honeycutt <jhoneycutt@apple.com> |
| |
| Reviewed by mrowe. |
| |
| * wtf/Platform.h: Add HAVE_ACCESSIBILITY to Platform.h. |
| |
| 2008-04-17 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Thread static data destructors are not guaranteed to be called in any particular order; |
| turn ThreadSpecific into a phoenix-style singleton to avoid accessing freed memory when |
| deleted objects are interdependent (e.g. CommonIdentifiers and internal identifier tables). |
| |
| No change on SunSpider. |
| |
| * wtf/ThreadSpecific.h: |
| (WTF::ThreadSpecific::Data::Data): |
| (WTF::::get): |
| (WTF::::set): |
| (WTF::::destroy): |
| |
| 2008-04-15 Srinivas Rao. M Hamse <msrinirao@gmail.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| - gcc 3.x build fix |
| |
| * kjs/nodes.h: CallerType definition made public for gcc 3.x compilation |
| |
| 2008-04-16 Brady Eidson <beidson@apple.com> |
| |
| Reviewed by Sam Weinig |
| |
| Change ThreadSafeShared to act like RefCounted by starting out with a single ref by default |
| |
| * wtf/Threading.h: |
| (WTF::ThreadSafeShared::ThreadSafeShared): |
| |
| 2008-04-16 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Geoffrey Garen. |
| |
| - To keep the behavior of the WebKit and JavaScriptCore API's the same, |
| we need to hide the fact that the global object and the window object |
| are no longer the same thing, and the the global object now changes on |
| navigations. To do this, only the wrapper should ever be exposed. This |
| fixes the two remaining spots where the internal global object is exposed, |
| the windowScriptObject returned from [WebFrame windowObject] and the object |
| return by calling JSContextGetGlobalObject on [WebFrame globalContext]. |
| |
| * API/JSContextRef.cpp: |
| (JSContextGetGlobalObject): |
| This is a bit of a hack, this returns the "this" representation of the globalObject |
| which will be the WrapperWindow for WebCore and the globalObject for non-WebCore. |
| |
| * API/JSObjectRef.cpp: |
| (JSObjectSetProperty): |
| Call the new putWithAttributes method instead of relying on lower-level calls. |
| This is needed so that the window wrapper can forward the calls. |
| |
| * JavaScriptCore.exp: |
| * kjs/Activation.h: |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::putWithAttributes): |
| * kjs/JSGlobalObject.h: |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::symbolTablePutWithAttributes): |
| * kjs/function.cpp: |
| (KJS::ActivationImp::putWithAttributes): |
| * kjs/nodes.cpp: |
| (KJS::ConstDeclNode::handleSlowCase): |
| (KJS::ConstDeclNode::evaluateSingle): |
| (KJS::EvalNode::processDeclarations): |
| * kjs/object.cpp: |
| (KJS::JSObject::putWithAttributes): |
| * kjs/object.h: |
| Rename initializeVariable to putWithAttributes and move it down to JSObject so it |
| can be used for JSObjectSetProperty. |
| |
| 2008-04-16 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Sam and Geoff. |
| |
| -<rdar://problem/5770054> JavaScript profiler (10928) |
| Inital profiler prototype |
| |
| * GNUmakefile.am: Added new files to project |
| * JavaScriptCore.pri: Ditto |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Ditto |
| * JavaScriptCore.xcodeproj/project.pbxproj: Ditto |
| * JavaScriptCoreSources.bkl: Ditto |
| * kjs/config.h: Put compiling flag in here. |
| * kjs/function.cpp: Instrument calling the function eval(). |
| (KJS::eval): |
| * kjs/interpreter.cpp: Instrument evaluating global scopes. |
| (KJS::Interpreter::evaluate): |
| * kjs/object.cpp: Instrument JS function calls. |
| (KJS::JSObject::call): |
| * profiler: Added. |
| * profiler/FunctionCallProfile.cpp: Added. |
| (KJS::FunctionCallProfile::FunctionCallProfile): |
| (KJS::FunctionCallProfile::~FunctionCallProfile): |
| (KJS::FunctionCallProfile::willExecute): Call right before the JS function or executing context is executed to start the profiler's timer. |
| (KJS::FunctionCallProfile::didExecute): Call right after the JS function or executing context is executed to stop the profiler's timer. |
| (KJS::FunctionCallProfile::addChild): Add a child to the current FunctionCallProfile if it isn't already a child of the current FunctionalCallProfile. |
| (KJS::FunctionCallProfile::findChild): Return the child that matches the given name if there is one. |
| (KJS::FunctionCallProfile::printDataSampleStyle): Print the current profiled information in a format that matches sample's output. |
| * profiler/FunctionCallProfile.h: Added. |
| (KJS::FunctionCallProfile::FunctionCallProfile): |
| (KJS::FunctionCallProfile::~FunctionCallProfile): |
| (KJS::FunctionCallProfile::functionName): |
| (KJS::FunctionCallProfile::microSecs): |
| * profiler/Profiler.cpp: Added. |
| (KJS::Profiler::profiler): |
| (KJS::Profiler::sharedProfiler): Return global singleton (may change due to multi-threading concerns) |
| (KJS::Profiler::startProfiling): Don't start collecting profiling information until the user starts the profiler. Also don't clear old prfiled data until the profiler is restarted. |
| (KJS::Profiler::stopProfiling): Stop collecting profile information. |
| (KJS::Profiler::willExecute): Same as above. |
| (KJS::Profiler::didExecute): Same as above. |
| (KJS::Profiler::insertStackNamesInTree): Follow the stack of the given names and if a sub-stack is not in the current tree, add it. |
| (KJS::Profiler::getStackNames): Get the names from the different passed in parameters and order them as a stack. |
| (KJS::Profiler::getFunctionName): Get the function name from the given parameter. |
| (KJS::Profiler::printDataSampleStyle): Print the current profiled information in a format that matches sample's output. |
| (KJS::Profiler::debugLog): |
| * profiler/Profiler.h: Added. |
| (KJS::Profiler::Profiler): |
| |
| 2008-04-16 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Darin Adler. |
| |
| - Remove kjs_ prefix from strtod, dtoa, and freedtoa and put it |
| in the KJS namespace. |
| - Make strtod, dtoa, and freedtoa c++ functions instead of extern "C". |
| - Remove mode switching from dtoa. ~2% improvement on test 26. |
| - Removes all unnecessary #defines from dtoa code. |
| |
| * JavaScriptCore.exp: |
| * kjs/dtoa.cpp: |
| (KJS::ulp): |
| (KJS::b2d): |
| (KJS::d2b): |
| (KJS::ratio): |
| (KJS::strtod): |
| (KJS::freedtoa): |
| (KJS::dtoa): |
| * kjs/dtoa.h: |
| * kjs/function.cpp: |
| (KJS::parseInt): |
| * kjs/lexer.cpp: |
| (KJS::Lexer::lex): |
| * kjs/number_object.cpp: |
| (KJS::integer_part_noexp): |
| (KJS::numberProtoFuncToExponential): |
| * kjs/ustring.cpp: |
| (KJS::UString::from): |
| (KJS::UString::toDouble): |
| |
| 2008-04-16 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Get rid of static execForCompareByStringForQSort in array_instance.cpp. |
| |
| No change on SunSpider, CelticKane or iBench JavaScript. |
| |
| * kjs/array_instance.cpp: |
| (KJS::ArraySortComparator::ArraySortComparator): |
| (KJS::ArraySortComparator::operator()): |
| (KJS::ArrayInstance::sort): |
| Switch slow case to std::sort, so that ExecState can be passed in a comparator. |
| |
| 2008-04-16 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Adam Roben. |
| |
| MSVC build fix. |
| |
| * kjs/CommonIdentifiers.cpp: |
| * kjs/CommonIdentifiers.h: |
| * kjs/Parser.cpp: |
| * kjs/Parser.h: |
| * kjs/identifier.cpp: |
| * kjs/lexer.h: |
| * wtf/ThreadSpecific.h: |
| |
| 2008-04-16 Alexey Proskuryakov <ap@webkit.org> |
| |
| Build fix. |
| |
| * kjs/date_object.cpp: |
| * kjs/date_object.h: |
| Don't include DateMath.h from date_object.h, as the latter is used from WebCore, while |
| where the former is not available. |
| |
| 2008-04-16 Holger Hans Peter Freyther <zecke@selfish.org> |
| |
| Unreviewed build fix for MSVC. It does not want to have |
| WTF in the KJS namespace. |
| |
| * kjs/CommonIdentifiers.h: |
| |
| 2008-04-16 Holger Hans Peter Freyther <zecke@selfish.org> |
| |
| Unreviewed build fix for gcc. |
| |
| ::msToGregorianDateTime is not known to it. |
| |
| * kjs/date_object.cpp: |
| (KJS::DateInstance::msToGregorianDateTime): |
| |
| 2008-04-16 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Oliver Hunt. |
| |
| Initialize threadMapMutex safely (as already done in ThreadingWin). |
| |
| * wtf/ThreadingGtk.cpp: |
| (WTF::threadMapMutex): |
| (WTF::initializeThreading): |
| * wtf/ThreadingPthreads.cpp: |
| (WTF::threadMapMutex): |
| (WTF::initializeThreading): |
| |
| 2008-04-16 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Adam Roben. |
| |
| Cache Gregorian date/time structure on DateInstance objects for 1.027x SunSpider speedup |
| (1.65x on date-format-xparb, 1.13x on date-format-tofte). |
| |
| * kjs/DateMath.h: |
| (KJS::GregorianDateTime::copyFrom): Added. It presumably makes sense to keep GregorianDateTime |
| Noncopyable, so it's not just operator=. |
| |
| * kjs/date_object.h: Added a per-object cache. |
| |
| * kjs/date_object.cpp: |
| (KJS::DateInstance::DateInstance): |
| (KJS::DateInstance::msToGregorianDateTime): |
| (KJS::dateProtoFuncToString): |
| (KJS::dateProtoFuncToUTCString): |
| (KJS::dateProtoFuncToDateString): |
| (KJS::dateProtoFuncToTimeString): |
| (KJS::dateProtoFuncToLocaleString): |
| (KJS::dateProtoFuncToLocaleDateString): |
| (KJS::dateProtoFuncToLocaleTimeString): |
| (KJS::dateProtoFuncGetFullYear): |
| (KJS::dateProtoFuncGetUTCFullYear): |
| (KJS::dateProtoFuncToGMTString): |
| (KJS::dateProtoFuncGetMonth): |
| (KJS::dateProtoFuncGetUTCMonth): |
| (KJS::dateProtoFuncGetDate): |
| (KJS::dateProtoFuncGetUTCDate): |
| (KJS::dateProtoFuncGetDay): |
| (KJS::dateProtoFuncGetUTCDay): |
| (KJS::dateProtoFuncGetHours): |
| (KJS::dateProtoFuncGetUTCHours): |
| (KJS::dateProtoFuncGetMinutes): |
| (KJS::dateProtoFuncGetUTCMinutes): |
| (KJS::dateProtoFuncGetSeconds): |
| (KJS::dateProtoFuncGetUTCSeconds): |
| (KJS::dateProtoFuncGetTimezoneOffset): |
| (KJS::setNewValueFromTimeArgs): |
| (KJS::setNewValueFromDateArgs): |
| (KJS::dateProtoFuncSetYear): |
| (KJS::dateProtoFuncGetYear): |
| Use the cache when converting. |
| |
| 2008-04-16 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Implement an abstraction for thread-specific storage, use it to get rid of some static objects. |
| |
| SunSpider results were not conclusive, possibly up to 0.2% slowdown. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCore.vcproj/WTF/WTF.vcproj: |
| Added ThreadSpecific.h |
| |
| * wtf/ThreadSpecific.h: Added. |
| (WTF::::ThreadSpecific): |
| (WTF::::~ThreadSpecific): |
| (WTF::::get): |
| (WTF::::set): |
| (WTF::::destroy): |
| (WTF::T): |
| (WTF::::operator): |
| Only implemented for platforms that use pthreads. |
| |
| * kjs/CommonIdentifiers.cpp: |
| (KJS::CommonIdentifiers::shared): |
| * kjs/CommonIdentifiers.h: |
| * kjs/InitializeThreading.cpp: |
| (KJS::initializeThreading): |
| * kjs/Parser.cpp: |
| (KJS::parser): |
| * kjs/Parser.h: |
| * kjs/identifier.cpp: |
| (KJS::identifierTable): |
| (KJS::literalIdentifierTable): |
| (KJS::Identifier::initializeIdentifierThreading): |
| * kjs/identifier.h: |
| * kjs/lexer.cpp: |
| (KJS::lexer): |
| * kjs/lexer.h: |
| Make static instances per-thread. |
| |
| 2008-04-15 Anders Carlsson <andersca@apple.com> |
| |
| Reviewed by Adam. |
| |
| Add ENABLE_OFFLINE_WEB_APPLICATIONS to FEATURE_DEFINES. |
| |
| * Configurations/JavaScriptCore.xcconfig: |
| |
| 2008-04-15 Andre Poenitz <andre.poenitz@trolltech.com> |
| |
| Reviewed by Simon. |
| |
| Fix compilation with Qt namespaces |
| |
| Qt can be configured to have all of its classes inside a specified namespaces. |
| This is for example used in plugin/component environments like Eclipse. |
| |
| This change makes it possible to let the Qt port compile against a namespaced |
| Qt by the use of macros Qt provides to properly forward declare Qt classes in |
| the namespace. |
| |
| * wtf/unicode/qt4/UnicodeQt4.h: |
| |
| 2008-04-14 Anders Carlsson <andersca@apple.com> |
| |
| Reviewed by Adam. |
| |
| Don't leak the prototype class. |
| |
| * API/JSClassRef.cpp: |
| (OpaqueJSClass::create): |
| |
| 2008-04-14 Steve Falkenburg <sfalken@apple.com> |
| |
| Fix build. |
| |
| * wtf/ThreadingWin.cpp: |
| |
| 2008-04-14 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Adam Roben. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=18488 |
| FastMalloc doesn't release thread-specific data on Windows |
| |
| * wtf/ThreadingWin.cpp: |
| (WTF::threadMapMutex): (WTF::initializeThreading): Call threadMapMutex once to initialize the static safely. |
| (WTF::ThreadFunctionInvocation::ThreadFunctionInvocation): Added a structure to wrap thread entry point and arguments. |
| (WTF::wtfThreadEntryPoint): Make sure to end all WTF threads with pthread_exit(), to give pthreads-win32 a chance to call |
| destructors of thread-specific data. |
| (WTF::createThread): Use _beginthreadex instead of CreateThread, because MSDN says so. Also removed a call to CreateEvent, |
| for which I could see no reason at all. |
| |
| 2008-04-14 Alexey Proskuryakov <ap@webkit.org> |
| |
| Touched a file to make JavaScriptCore.vcproj rebuild. |
| |
| * wtf/MathExtras.h: |
| |
| 2008-04-14 Adam Roben <aroben@apple.com> |
| |
| Windows build fix |
| |
| Rubberstamped by Alexey Proskuryakov. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Disable |
| the "potentially uninitialized variable" warning for grammar.cpp, as |
| it seems to be incorrect. yylval gets initialized by the lexer, but |
| MSVC doesn't seem to understand this. |
| |
| 2008-04-11 Antti Koivisto <antti@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Add default hash for pairs of hashable types. |
| |
| * wtf/HashFunctions.h: |
| (WTF::PairHash::hash): |
| (WTF::PairHash::equal): |
| (WTF::): |
| |
| 2008-04-11 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Geoff. |
| |
| Make DateMath.cpp thread safe. |
| |
| No measurable change on SunSpider (should be a very small speedup). |
| |
| * kjs/DateMath.cpp: |
| (KJS::mimimumYearForDST): (KJS::equivalentYearForDST): Got rid of double caching of the |
| same precomputed value. |
| (KJS::calculateUTCOffset): (KJS::getUTCOffset): Factored actual UTC offset calculation code |
| out of getUTCOffset(), and notification setup into initDateMath(). |
| |
| (KJS::initDateMath): Added. |
| |
| * kjs/DateMath.h: |
| * kjs/InitializeThreading.cpp: |
| (KJS::initializeThreading): |
| Added initDateMath(). |
| |
| 2008-04-11 Alexey Proskuryakov <ap@webkit.org> |
| |
| Windows build fix. |
| |
| * kjs/grammar.y: |
| |
| 2008-04-11 Alexey Proskuryakov <ap@webkit.org> |
| |
| Tiger build fix. Forward declaring a union didn't work for whatever reason, make the |
| parameters void*. |
| |
| * kjs/grammar.y: |
| * kjs/lexer.cpp: |
| (kjsyylex): |
| (KJS::Lexer::lex): |
| * kjs/lexer.h: |
| |
| 2008-04-11 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Geoff. |
| |
| Generate a pure (re-entrant) parser with Bison. |
| |
| No change on SunSpider. |
| |
| * kjs/Parser.cpp: |
| (KJS::Parser::parse): |
| * kjs/grammar.y: |
| * kjs/lexer.cpp: |
| (kjsyylex): |
| (KJS::Lexer::lex): |
| * kjs/lexer.h: |
| Pass state as function arguments, instead of global data. Don't call lexer() as often as |
| before, as this function is about to become slower due to thread-specific storage. |
| |
| * kjs/function.cpp: |
| (KJS::isStrWhiteSpace): Don't call isSeparatorSpace() for 8-bit characters, as these are |
| already taken care of. This is a small speedup, compensating for a small slowdown caused |
| by switching Bison mode. |
| |
| 2008-04-10 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Geoff. |
| |
| https://bugs.webkit.org/show_bug.cgi?id=18402 |
| REGRESSION: visited element handling is incorrect in nested join/toString calls |
| |
| No change on SunSpider total, possibly a tiny improvement (about 0.1%). |
| |
| Test: fast/js/array-tostring-and-join.html |
| |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::visitedElements): Store visited elements HashSet here, making it |
| common to toString/toLocalizedString/join again. |
| |
| * kjs/array_object.cpp: |
| (KJS::arrayProtoFuncToString): |
| (KJS::arrayProtoFuncToLocaleString): |
| (KJS::arrayProtoFuncJoin): |
| Got rid of static variables. Replaced UString with Vector to avoid O(n^2) behavior and |
| regain performance. |
| |
| * wtf/Vector.h: |
| (WTF::::resize): |
| (WTF::::grow): |
| (WTF::::reserveCapacity): |
| (WTF::::append): |
| (WTF::::insert): |
| Added null checks, so that Vector methods don't crash when out of memory. The caller should |
| check that data pointer is not null before proceeding. |
| |
| 2008-04-10 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Fix https://bugs.webkit.org/show_bug.cgi?id=18367 and the many dupes. |
| Bug 18367: Crash during celtic kane js speed 2007 test |
| |
| GCC 4.2 on x86_64 Linux decided to reorder the local variables in markCurrentThreadConservatively's |
| stack frame. This lead to the range of addresses the collector treated as stack to exclude the |
| contents of volatile registers that markCurrentThreadConservatively forces onto the stack. This was |
| leading to objects being prematurely collected if the only reference to them was via a register at |
| the time a collection occurred. |
| |
| The fix for this is to move the calculation of the top of the stack into a NEVER_INLINE function |
| that is called from markCurrentThreadConservatively. This forces the dummy variable we use for |
| determining the top of stack to be in a different stack frame which prevents the compiler from |
| reordering it relative to the registers that markCurrentThreadConservatively forces onto the stack. |
| |
| * kjs/collector.cpp: |
| (KJS::Collector::markCurrentThreadConservativelyInternal): |
| (KJS::Collector::markCurrentThreadConservatively): |
| * kjs/collector.h: |
| |
| 2008-04-10 Adam Roben <aroben@apple.com> |
| |
| VC++ Express build fix |
| |
| * JavaScriptCore.vcproj/WTF/WTF.vcproj: Link against user32.lib so |
| that anyone who links against WTF.lib will get user32.lib |
| automatically. |
| |
| 2008-04-09 Adam Roben <aroben@apple.com> |
| |
| VC++ Express build fix |
| |
| * JavaScriptCore.vcproj/testkjs/testkjs.vcproj: Link against |
| user32.lib. |
| |
| 2008-04-09 Adam Roben <aroben@apple.com> |
| |
| Build fix |
| |
| * JavaScriptCore.exp: Export isMainThread. |
| |
| 2008-04-09 Adam Roben <aroben@apple.com> |
| |
| Build fix |
| |
| * wtf/AlwaysInline.h: Make sure to #include Platform.h before using |
| the macros it defines. |
| |
| 2008-04-08 Mark Rowe <mrowe@apple.com> |
| |
| Export WTF::initializeThreading() from JavaScriptCore. |
| |
| * JavaScriptCore.exp: |
| |
| 2008-04-04 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Geoffrey Garen. |
| |
| First step in implementing the "split window" |
| |
| - Add a GlobalThisValue to ExecState which should be used |
| in places that used to implement the "use the global object |
| as this if null" rule. |
| - Factor out lookupGetter/lookupSetter into virtual methods |
| on JSObject so that they can be forwarded. |
| - Make defineGetter/defineSetter virtual methods for the same |
| reason. |
| - Have PrototypeReflexiveFunction store the globalObject used |
| to create it so that it can be used to get the correct thisObject |
| for eval. |
| |
| * API/JSObjectRef.cpp: |
| (JSObjectCallAsFunction): |
| * JavaScriptCore.exp: |
| * kjs/Activation.h: |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::ExecState): |
| (KJS::GlobalExecState::GlobalExecState): |
| * kjs/ExecState.h: |
| (KJS::ExecState::globalThisValue): |
| * kjs/ExecStateInlines.h: |
| (KJS::ExecState::ExecState): |
| (KJS::FunctionExecState::FunctionExecState): |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::reset): |
| (KJS::JSGlobalObject::toGlobalObject): |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::JSGlobalObjectData::JSGlobalObjectData): |
| (KJS::JSGlobalObject::JSGlobalObject): |
| * kjs/array_instance.cpp: |
| (KJS::CompareWithCompareFunctionArguments::CompareWithCompareFunctionArguments): |
| (KJS::compareWithCompareFunctionForQSort): |
| * kjs/array_object.cpp: |
| (KJS::arrayProtoFuncSort): |
| (KJS::arrayProtoFuncFilter): |
| (KJS::arrayProtoFuncMap): |
| (KJS::arrayProtoFuncEvery): |
| (KJS::arrayProtoFuncForEach): |
| (KJS::arrayProtoFuncSome): |
| * kjs/function.cpp: |
| (KJS::FunctionImp::callAsFunction): |
| (KJS::ActivationImp::toThisObject): |
| (KJS::globalFuncEval): |
| (KJS::PrototypeReflexiveFunction::PrototypeReflexiveFunction): |
| (KJS::PrototypeReflexiveFunction::mark): |
| * kjs/function.h: |
| (KJS::PrototypeReflexiveFunction::cachedGlobalObject): |
| * kjs/function_object.cpp: |
| (KJS::functionProtoFuncApply): |
| (KJS::functionProtoFuncCall): |
| * kjs/nodes.cpp: |
| (KJS::ExpressionNode::resolveAndCall): |
| (KJS::FunctionCallValueNode::evaluate): |
| (KJS::LocalVarFunctionCallNode::inlineEvaluate): |
| (KJS::ScopedVarFunctionCallNode::inlineEvaluate): |
| (KJS::FunctionCallBracketNode::evaluate): |
| (KJS::FunctionCallDotNode::inlineEvaluate): |
| * kjs/object.cpp: |
| (KJS::JSObject::call): |
| (KJS::JSObject::put): |
| (KJS::tryGetAndCallProperty): |
| (KJS::JSObject::lookupGetter): |
| (KJS::JSObject::lookupSetter): |
| (KJS::JSObject::toThisObject): |
| (KJS::JSObject::toGlobalObject): |
| (KJS::JSObject::fillGetterPropertySlot): |
| * kjs/object.h: |
| * kjs/object_object.cpp: |
| (KJS::objectProtoFuncLookupGetter): |
| (KJS::objectProtoFuncLookupSetter): |
| * kjs/string_object.cpp: |
| (KJS::replace): |
| |
| 2008-04-08 Brady Eidson <beidson@apple.com> |
| |
| Encourage Windows to rebuild - AGAIN... |
| |
| * kjs/DateMath.cpp: |
| |
| 2008-04-08 Adam Roben <aroben@apple.com> |
| |
| Mac build fix |
| |
| * JavaScriptCore.exp: Add callOnMainThread, and sorted the list. |
| |
| 2008-04-08 Brady Eidson <beidson@apple.com> |
| |
| Rubberstamped by Adam Roben |
| |
| Touch some files to *strongly* encourage Windows to rebuilt with DOM_STORAGE enabled |
| |
| * kjs/DateMath.cpp: |
| |
| 2008-04-08 Adam Roben <aroben@apple.com> |
| |
| Move callOnMainThread to WTF |
| |
| Reviewed by Alexey Proskuryakov. |
| |
| * GNUmakefile.am: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/WTF/WTF.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| Added new files. |
| |
| * wtf/MainThread.cpp: |
| * wtf/MainThread.h: |
| * wtf/gtk/MainThreadGtk.cpp: |
| * wtf/mac/MainThreadMac.mm: |
| * wtf/qt/MainThreadQt.cpp: |
| * wtf/win/MainThreadWin.cpp: |
| * wtf/wx/MainThreadWx.cpp: |
| Moved here from WebCore/platform. Replaced all instances of "WebCore" |
| with "WTF". |
| |
| * kjs/bool_object.cpp: Touched to force JavaScriptCore.vcproj to |
| build. |
| to the WTF namespace. |
| * wtf/ThreadingWin.cpp: |
| (WTF::initializeThreading): Call initializeMainThread. |
| |
| 2008-04-07 Brady Eidson <beidson@apple.com> |
| |
| Add "ENABLE_DOM_STORAGE" to keep in sync with the rest of the project |
| |
| * Configurations/JavaScriptCore.xcconfig: |
| |
| 2008-04-07 Adam Roben <aroben@apple.com> |
| |
| Windows build fix |
| |
| * wtf/ThreadingWin.cpp: Back out some changes I didn't mean to land. |
| |
| 2008-04-07 Adam Roben <aroben@apple.com> |
| |
| Add WTF::isMainThread |
| |
| Reviewed by Alexey Proskuryakov. |
| |
| * wtf/Threading.h: Declare the new function. |
| * wtf/ThreadingGtk.cpp: |
| (WTF::initializeThreading): Initialize the main thread identifier. |
| (WTF::isMainThread): Added. |
| * wtf/ThreadingNone.cpp: Ditto ThreadingGtk.cpp. |
| (WTF::initializeThreading): |
| (WTF::isMainThread): |
| * wtf/ThreadingPthreads.cpp: Ditto. |
| (WTF::initializeThreading): |
| (WTF::isMainThread): |
| * wtf/ThreadingWin.cpp: Ditto. |
| (WTF::initializeThreading): |
| (WTF::isMainThread): |
| |
| 2008-04-06 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Make UString thread-safe. |
| |
| No change on SunSpider total, although individual tests have changed a lot, up to 3%. |
| |
| * kjs/InitializeThreading.cpp: (KJS::initializeThreading): Call UString::null() to initialize |
| a static. |
| |
| * kjs/identifier.cpp: |
| (KJS::CStringTranslator::translate): |
| (KJS::UCharBufferTranslator::translate): |
| Use "true" for a boolean value instead of 1, because it's C++. |
| |
| * kjs/ustring.h: |
| (KJS::CString::adopt): Added a method to create from a char* buffer without copying. |
| (KJS::UString::Rep::ref): Removed an assertion for JSLock::lockCount, as it's no longer |
| necessary to hold JSLock when working with strings. |
| (KJS::UString::Rep::deref): Ditto. |
| (KJS::UString::Rep::isStatic): Added a field to quickly determine that this is an empty |
| or null static string. |
| |
| * kjs/ustring.cpp: |
| (KJS::): Removed normalStatBufferSize and statBufferSize, as there is no reason to have such |
| an advanced implementation of a debug-only ascii() method. Removed a long-obsolete comment |
| about UChar. |
| (KJS::UString::Rep::createCopying): Removed an assertion for JSLock::lockCount. |
| (KJS::UString::Rep::create): Ditto. |
| (KJS::UString::Rep::destroy): Ditto. Do not do anything for static null and empty strings, |
| as refcounting is not reliable for those. Reordered branches for a noticeable speed gain - |
| apparently this functiton is hot enough for SunSpider to see an effect from this! |
| (KJS::UString::null): Moved a star, added a comment. |
| (KJS::UString::cstring): Reimplemented to not call ascii(), which is not thread-safe. |
| (KJS::UString::ascii): Simplified statBuffer handling logic. |
| (KJS::UString::toDouble): Use cstring() instead of ascii(). |
| |
| 2008-04-02 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Ensure that debug symbols are generated for x86_64 and ppc64 builds. |
| |
| * Configurations/Base.xcconfig: |
| |
| 2008-04-01 Christian Dywan <christian@imendio.com> |
| |
| Build fix for GCC 4.3. |
| |
| * wtf/unicode/icu/CollatorICU.cpp: include string.h |
| |
| 2008-04-01 Alexey Proskuryakov <ap@webkit.org> |
| |
| Rubber-stamped by Darin. |
| |
| Turn off using 64-bit arithmetic on 32-bit hardware, as dtoa own code is faster than |
| compiler-provided emulation. |
| |
| 1% speedup on Acid3 test 26. |
| |
| * kjs/dtoa.cpp: |
| |
| 2008-04-01 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Make MathExtras.h thread safe. |
| |
| * kjs/math_object.cpp: |
| (KJS::mathProtoFuncRandom): If threading is enabled, rely on initializeThreading to call |
| wtf_random_init(). |
| |
| * wtf/Threading.h: |
| * wtf/ThreadingGtk.cpp: |
| (WTF::initializeThreading): |
| * wtf/ThreadingNone.cpp: |
| (WTF::initializeThreading): |
| * wtf/ThreadingPthreads.cpp: |
| (WTF::initializeThreading): |
| * wtf/ThreadingWin.cpp: |
| (WTF::initializeThreading): |
| Call wtf_random_init(); made the function non-inline to avoid having to include too many |
| headers in Threading.h. |
| |
| 2008-03-31 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by darin. |
| |
| Make matching of regexps using ^ much faster |
| http://bugs.webkit.org/show_bug.cgi?id=18086 |
| |
| * pcre/pcre_compile.cpp: |
| (compileBranch): |
| (branchNeedsLineStart): |
| * pcre/pcre_exec.cpp: |
| (match): |
| (jsRegExpExecute): |
| * pcre/pcre_internal.h: |
| |
| 2008-03-29 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Oliver Hunt. |
| |
| <rdar://problem/5829556> REGRESSION: Leak in KJS::initializeThreading() |
| |
| * kjs/InitializeThreading.cpp: (KJS::initializeThreading): There is no guarantee that |
| initializeThreading() is called only once; check that the mutex hasn't been already allocated. |
| |
| 2008-03-29 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Bug 17924: Crash in KJS::ConstDeclNode::evaluate with |with| and |const| |
| <http://bugs.webkit.org/show_bug.cgi?id=17924> |
| <rdar://problem/5806933> |
| |
| It turns out this is trivially avoidable if we just match firefox's |
| semantics and ensure that an assignment in a const declaration always |
| writes to the variable object. |
| |
| * kjs/nodes.cpp: |
| (KJS::ConstDeclNode::handleSlowCase): |
| |
| 2008-03-28 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Sam Weinig. |
| |
| Fix a dtoa thread safety issue. |
| |
| WebCore can call kjs_strtod without holding JS lock, but we didn't have thread safety |
| compiled in for dtoa. |
| |
| This is a 0.5% regression on SunSpider, which Sam Weinig has volunteered to cover with |
| his recent improvement. |
| |
| * kjs/dtoa.cpp: |
| (Bigint::Balloc): |
| (Bigint::Bfree): |
| Changed to use fastMalloc/fastDelete - they are much faster than the dtoa custom version was |
| in the presence of locking (but somewhat slower in single-threaded case). |
| (Bigint::pow5mult): Got rid of the dreaded double-checked locking anti-pattern (had to |
| restructure the code to avoid significant performance implications). |
| (Bigint::lshift): Rewrote to avoid an allocation, if possible. |
| |
| (Bigint::rv_alloc): |
| (Bigint::kjs_freedtoa): |
| (Bigint::kjs_dtoa): |
| Check for USE(MULTIPLE_THREADS), not dtoa legacy MULTIPLE_THREADS. |
| |
| * kjs/InitializeThreading.cpp: Added. |
| (KJS::initializeThreading): |
| * kjs/InitializeThreading.h: Added. |
| Initialize threading at KJS level, if enabled. |
| |
| * kjs/dtoa.h: Expose dtoa mutex for KJS::initializeThreading. |
| |
| * kjs/testkjs.cpp: (kjsmain): Call initializeThreading. |
| |
| * JavaScriptCore.exp: Export KJS::initializeThreading. |
| |
| * GNUmakefile.am: |
| * JavaScriptCore.exp: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCoreSources.bkl: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| Added InitializeThreading.{h,cpp}. |
| |
| * wtf/Threading.h: Removed a using directive for WTF::initializeThreading - it is only |
| to be called from KJS::initializeThreading, and having it in the global namespace is useless. |
| |
| 2008-03-28 Brady Eidson <beidson@apple.com> |
| |
| Reviewed by Darin |
| |
| Export Unicode/UTF8.h and convertUTF16ToUTF8() for more flexible conversion in WebCore |
| |
| * JavaScriptCore.exp: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2008-03-27 Darin Adler <darin@apple.com> |
| |
| Reviewed by Mark Rowe. |
| |
| <rdar://problem/5826236> Regular expressions with large nested repetition counts can have their |
| compiled length calculated incorrectly. |
| |
| * pcre/pcre_compile.cpp: |
| (multiplyWithOverflowCheck): |
| (calculateCompiledPatternLength): Check for overflow when dealing with nested repetition counts |
| and bail with an error rather than returning incorrect results. |
| |
| 2008-03-26 Mark Rowe <mrowe@apple.com> |
| |
| Rubber-stamped by Brady Eidson. |
| |
| Update FEATURE_DEFINES to be consistent with the other locations in which it is defined. |
| |
| * Configurations/JavaScriptCore.xcconfig: |
| |
| 2008-03-26 Adam Roben <aroben@apple.com> |
| |
| Fix Bug 18060: Assertion failure (JSLock not held) beneath |
| JSCallbackObject<Base>::toString |
| |
| <http://bugs.webkit.org/show_bug.cgi?id=18060> |
| |
| Reviewed by Geoff Garen. |
| |
| Bug fix: |
| |
| * API/JSCallbackObjectFunctions.h: |
| (KJS::JSCallbackObject<Base>::toString): Make the DropAllLocks |
| instance only be in scope while calling convertToType. |
| |
| Test: |
| |
| * API/testapi.c: |
| (MyObject_convertToType): Implement type conversion to string. |
| * API/testapi.js: Add a test for type conversion to string. |
| |
| 2008-03-26 Adam Roben <aroben@apple.com> |
| |
| Windows build fix |
| |
| * kjs/array_instance.cpp: Touched this. |
| * wtf/HashFunctions.h: |
| (WTF::intHash): Added 8- and 16-bit versions of intHash. |
| |
| 2008-03-26 Adam Roben <aroben@apple.com> |
| |
| Force JSC headers to be copied by touching a file |
| |
| * kjs/array_instance.cpp: |
| (KJS::ArrayInstance::getPropertyNames): |
| |
| 2008-03-26 Adam Roben <aroben@apple.com> |
| |
| Windows build fix after r31324 |
| |
| Written with Darin. |
| |
| Added HashTable plumbing to support using wchar_t as a key type. |
| |
| * wtf/HashFunctions.h: |
| * wtf/HashTraits.h: |
| (WTF::): |
| |
| 2008-03-26 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Darin. |
| |
| - JSC part of fix for "SVG multichar glyph matching matches longest instead of first (affects Acid3 test 79)" |
| http://bugs.webkit.org/show_bug.cgi?id=18118 |
| |
| * wtf/HashFunctions.h: |
| (WTF::): |
| * wtf/HashTraits.h: |
| (WTF::): |
| |
| 2008-03-26 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Cache C string identifiers by address, not value, assuming that C strings can only |
| be literals. |
| |
| 1% speedup on Acid3 test 26. |
| |
| * kjs/identifier.cpp: |
| (KJS::literalIdentifierTable): |
| (KJS::Identifier::add): |
| Added a new table to cache UString::Reps created from C strings by address. Elements are |
| never removed from this cache, as only predefined identifiers can get there. |
| |
| * kjs/identifier.h: |
| (KJS::Identifier::Identifier): Added a warning. |
| |
| 2008-03-26 Alexey Proskuryakov <ap@webkit.org> |
| |
| Rubber-stamped by Maciej. |
| |
| An assertion was failing in function-toString-object-literals.html when parsing 1e-500. |
| The condition existed before, and got uncovered by turning compiled-out dtoa checks into |
| ASSERTs. |
| |
| The assertion was verifying that the caller wasn't constructing a Bigint from 0. |
| This might have had some reason behind it originally, but I couldn't find any, |
| and this doesn't look like a reasonable requirement. |
| |
| * kjs/dtoa.cpp: (d2b): Removed the assertion (two copies in different code paths). |
| |
| 2008-03-25 Adam Roben <aroben@apple.com> |
| |
| Fix Bug 18077: Integrate testapi.c into the Windows build |
| |
| <http://bugs.webkit.org/show_bug.cgi?id=18077> |
| |
| Reviewed by Steve Falkenburg. |
| |
| * JavaScriptCore.vcproj/testapi/testapi.vcproj: Added. |
| |
| 2008-03-25 Adam Roben <aroben@apple.com> |
| |
| Make testapi.c compile under MSVC |
| |
| Currently you must compile testapi.c as C++ code since MSVC does not |
| support many C features that GCC does. |
| |
| Reviewed by Steve Falkenburg. |
| |
| * API/testapi.c: |
| (nan): Added an implementation of this for MSVC. |
| (assertEqualsAsUTF8String): Use malloc instead of dynamically-sized |
| stack arrays. |
| (assertEqualsAsCharactersPtr): Ditto. |
| (print_callAsFunction): Ditto. |
| (main): Ditto, and explicitly cast from UniChar* to JSChar*. |
| |
| 2008-03-25 Adam Roben <aroben@apple.com> |
| |
| Stop using JavaScriptCore's custom stdbool.h and stdint.h on Windows |
| |
| We can't remove the os-win32 directory yet because other ports (at |
| least wx) are still relying on it. |
| |
| Reviewed by Steve Falkenburg. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| - Made all the include paths match the one for the Debug |
| configuration (these got out of sync in r30797) |
| - Removed os-win32 from the include path |
| - Removed os-win32 from the directories we copy to $WebKitOutputDir. |
| - Removed stdint.h from the project |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCoreGenerated.make: |
| Delete the files that we may have previously copied from the os-win32 |
| directory. |
| |
| 2008-03-25 Alexey Proskuryakov <ap@webkit.org> |
| |
| Windows build fix. |
| |
| * kjs/dtoa.cpp: Include stdint.h. |
| |
| 2008-03-25 Alexey Proskuryakov <ap@webkit.org> |
| |
| Rubber-stamped by Darin. |
| |
| Cleanup dtoa.cpp style. |
| |
| * kjs/dtoa.cpp: |
| (Bigint::Balloc): |
| (Bigint::Bfree): |
| (Bigint::multadd): |
| (Bigint::s2b): |
| (Bigint::hi0bits): |
| (Bigint::lo0bits): |
| (Bigint::i2b): |
| (Bigint::mult): |
| (Bigint::pow5mult): |
| (Bigint::lshift): |
| (Bigint::cmp): |
| (Bigint::diff): |
| (Bigint::ulp): |
| (Bigint::b2d): |
| (Bigint::d2b): |
| (Bigint::ratio): |
| (Bigint::): |
| (Bigint::match): |
| (Bigint::hexnan): |
| (Bigint::kjs_strtod): |
| (Bigint::quorem): |
| (Bigint::rv_alloc): |
| (Bigint::nrv_alloc): |
| (Bigint::kjs_freedtoa): |
| (Bigint::kjs_dtoa): |
| * kjs/dtoa.h: |
| |
| 2008-03-24 Darin Adler <darin@apple.com> |
| |
| Reviewed by Sam. |
| |
| - convert a JavaScript immediate number to a string more efficiently |
| |
| 2% speedup of Acid3 test 26 |
| |
| * kjs/JSImmediate.cpp: |
| (KJS::JSImmediate::toString): Take advantage of the fact that all immediate |
| numbers are integers, and use the faster UString function for formatting integers |
| instead of the slower one that works for floating point. I think this is a leftover |
| from when immediate numbers were floating point. |
| |
| 2008-03-23 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Darin Adler. |
| |
| Fix http://bugs.webkit.org/show_bug.cgi?id=18048 |
| The "thisObject" parameter to JSEvaluateScript is not used properly |
| |
| Making passing a thisObject to JSEvaluateScript actually set the thisObject of the created |
| ExecState. |
| |
| * API/testapi.c: |
| (main): Add tests for setting the thisObject when calling JSEvaluateScript. |
| |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::ExecState): Assign the thisObject to m_thisValue and remove the comment. |
| |
| 2008-03-22 Jesse Ruderman <jruderman@gmail.com> |
| |
| Reviewed by Sam Weinig. Landed by eseidel. |
| |
| Make testkjs flush stdout after printing. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/testkjs.cpp: |
| (functionPrint): |
| |
| 2008-03-21 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Optimise lookup of Math, undefined, NaN and Infinity |
| |
| Added a method to JSVariableObject to allow us to inject DontDelete properties |
| into the symbol table and localStorage. This results in a 0.4% progression in |
| SunSpider, with a 8% gain in math-partial-sums. |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::reset): |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::symbolTableInsert): |
| |
| 2008-03-21 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff Garen. |
| |
| Global properties that use LocalStorage are not correctly listed as enumerable. |
| |
| The problem was caused by JSObject::getPropertyAttributes not being aware |
| of the JSVariableObject SymbolTable. The fix is to make getPropertyAttributes |
| virtual and override in JSVariableObject. This does not produce any performance |
| regression. |
| |
| * JavaScriptCore.exp: |
| * kjs/JSVariableObject.cpp: |
| (KJS::JSVariableObject::getPropertyNames): |
| (KJS::JSVariableObject::getPropertyAttributes): |
| * kjs/JSVariableObject.h: |
| * kjs/object.h: |
| |
| 2008-03-21 Arkadiusz Miskiewicz <arekm@maven.pl> |
| |
| Webkit does not build on linux powerpc |
| |
| <http://bugs.webkit.org/show_bug.cgi?id=17019> |
| |
| Reviewed by David Kilzer. |
| |
| * wtf/TCSpinLock.h: |
| (TCMalloc_SpinLock::Unlock): |
| |
| 2008-03-21 Rodney Dawes <dobey@wayofthemonkey.com> |
| |
| Reviewed by Holger. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=17981 |
| |
| Add javascriptcore_cppflags to Programs_minidom_CPPFLAGS. |
| |
| * GNUmakefile.am: |
| |
| 2008-03-21 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Oliver Hunt. |
| |
| Consolidate static identifier initializers within CommonIdentifiers. |
| |
| No reliably measurable change on SunSpider; maybe a tiny improvement (within 0.2%). |
| |
| * kjs/CommonIdentifiers.h: Added static identifiers that were lazily initialized |
| throughout the code. |
| |
| * kjs/date_object.cpp: |
| (KJS::DateObjectImp::DateObjectImp): |
| * kjs/function_object.cpp: |
| (KJS::FunctionPrototype::FunctionPrototype): |
| * kjs/object_object.cpp: |
| (KJS::ObjectPrototype::ObjectPrototype): |
| * kjs/regexp_object.cpp: |
| (KJS::RegExpPrototype::RegExpPrototype): |
| Use the values from CommonIdentifiers. |
| |
| * kjs/lookup.h: Caching the identifier in a static wasn't a win on SunSpider, removed it. |
| |
| * kjs/value.h: |
| (KJS::jsNaN): We already have a shared NaN value, no need for a duplicate here. |
| |
| * wtf/MathExtras.h: |
| (wtf_atan2): Having local variables for numeric_limits constants is good for readability, |
| but there is no reason to keep them static. |
| |
| * JavaScriptCore.exp: Don't needlessly export JSGlobalObject::s_head. |
| |
| 2008-03-20 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Fix for leak introduced by inline ScopeChainNode use |
| |
| To avoid any extra branches when managing an inline ScopeChainNode |
| in the ScopeChain the inline node gets inserted with a refcount of |
| 2. This meant than when the ScopeChain was destroyed the ScopeChainNodes |
| above the inline node would be leaked. |
| |
| We resolve this by manually popping the inline node in the |
| FunctionExecState destructor. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/ExecStateInlines.h: |
| (KJS::FunctionExecState::~FunctionExecState): |
| * kjs/scope_chain.h: |
| (KJS::ScopeChain::popInlineScopeNode): |
| |
| 2008-03-20 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Ensure that the defines in FEATURE_DEFINES are sorted so that they will match the default settings of build-webkit. |
| This will prevent the world from being rebuilt if you happen to switch between building in Xcode and with build-webkit on the |
| command-line. |
| |
| * Configurations/JavaScriptCore.xcconfig: |
| |
| 2008-03-20 David Krause <david.krause@gmail.com> |
| |
| Reviewed by David Kilzer. |
| |
| Fix http://bugs.webkit.org/show_bug.cgi?id=17923 |
| Bug 17923: ARM platform endian defines inaccurate |
| |
| * wtf/Platform.h: |
| Replaced !defined(__ARMEL__) check with !defined(__VFP_FP__) |
| for PLATFORM(MIDDLE_ENDIAN) |
| |
| 2008-03-20 Maciej Stachowiak <mjs@apple.com> |
| |
| - fix build |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: install Activation.h as private |
| |
| 2008-03-20 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - reduce function call overhead for 1.014x speedup on SunSpider |
| |
| I moved some functions from ExecState.cpp to ExecStateInline.h and |
| from JSGlobalObject.cpp to JSGlobalObject.h, and declared them |
| inline; machine function call overhead for these was hurting JS |
| funcion call overhead. |
| |
| * kjs/ExecState.cpp: |
| * kjs/ExecStateInlines.h: Added. |
| (KJS::ExecState::ExecState): |
| (KJS::ExecState::~ExecState): |
| (KJS::FunctionExecState::FunctionExecState): |
| (KJS::FunctionExecState::~FunctionExecState): |
| * kjs/JSGlobalObject.cpp: |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::pushActivation): |
| (KJS::JSGlobalObject::checkActivationCount): |
| (KJS::JSGlobalObject::popActivation): |
| * kjs/function.cpp: |
| |
| 2008-03-19 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Avoid heap allocating the root scope chain node for eval and closure free functions |
| |
| Maciej suggested using an inline ScopeChainNode for functions that don't use eval |
| or closures as they are unable to ever capture the scope chain. This gives us a 2.4% |
| win in sunspider, a 15% win in controlflow-recursive, and big (>5%) wins in a number |
| of other tests. |
| |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::ExecState): |
| * kjs/ExecState.h: |
| * kjs/scope_chain.h: |
| (KJS::ScopeChain::push): |
| |
| 2008-03-19 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Fix release build. |
| |
| * kjs/JSGlobalObject.cpp: Add missing #include. |
| |
| 2008-03-19 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Anders Carlsson. |
| |
| Fix for <rdar://problem/5785694> |
| Crash occurs at KJS::Collector::collect() when loading web clip widgets with a PAC file |
| |
| Make the activeExecStates stack per JSGlobalObject instead of static to ensure |
| thread safety. |
| |
| * JavaScriptCore.exp: |
| * kjs/ExecState.cpp: |
| (KJS::InterpreterExecState::InterpreterExecState): |
| (KJS::InterpreterExecState::~InterpreterExecState): |
| (KJS::EvalExecState::EvalExecState): |
| (KJS::EvalExecState::~EvalExecState): |
| (KJS::FunctionExecState::FunctionExecState): |
| (KJS::FunctionExecState::~FunctionExecState): |
| * kjs/ExecState.h: |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::mark): |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::activeExecStates): |
| * kjs/collector.cpp: |
| (KJS::Collector::collect): |
| (KJS::Collector::reportOutOfMemoryToAllExecStates): Iterate all JSGlobalObjects and report |
| the OutOfMemory condition to all the ExecStates in each. |
| |
| 2008-03-19 Jasper Bryant-Greene <jasper@unix.geek.nz> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Fix http://bugs.webkit.org/show_bug.cgi?id=17941 |
| Bug 17941: C++-style comments in JavaScriptCore API |
| |
| * API/JSBase.h: |
| Remove C++-style comments from public JavaScriptCore API, replacing |
| with standard C90 block comments. |
| |
| 2008-03-19 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fix http://bugs.webkit.org/show_bug.cgi?id=17939 |
| Bug 17939: Crash decompiling "const a = 1, b;" |
| |
| * kjs/nodes2string.cpp: |
| (KJS::ConstDeclNode::streamTo): Null-check the correct variable. |
| |
| 2008-03-18 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Mark Rowe. |
| |
| Bug 17929: Incorrect decompilation with |const|, comma |
| http://bugs.webkit.org/show_bug.cgi?id=17929 |
| |
| There were actually two bugs here. First we weren't correctly handling const |
| nodes with multiple declarations. The second issue was caused by us not |
| giving the correct precedence to the initialisers. |
| |
| * kjs/nodes2string.cpp: |
| (KJS::ConstDeclNode::streamTo): |
| |
| 2008-03-18 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - Speed up JavaScript built-in properties by changing the |
| hash table to take advantage of the identifier objects |
| |
| 5% speedup for Acid3 test 26 |
| |
| * JavaScriptCore.exp: Updated. |
| * kjs/create_hash_table: Compute size of hash table large enough so that there |
| are no collisions, but don't generate the hash table. |
| * kjs/identifier.h: Made the add function that returns a PassRefPtr public. |
| * kjs/lexer.cpp: |
| (KJS::Lexer::lex): Updated for change to HashTable interface. |
| * kjs/lookup.cpp: |
| (KJS::HashTable::changeKeysToIdentifiers): Added. Finds the identifier for |
| each property so the equality comparision can be done with pointer comparision. |
| * kjs/lookup.h: Made the key be a union of char* with UString::Rep* so it can |
| hold identifiers. Added a keysAreIdentifiers flag to the HashTable. Changed |
| the Lookup functions to be member functions of HashTable instead. |
| * kjs/object.cpp: |
| (KJS::JSObject::deleteProperty): Update for change to HashTable. |
| (KJS::JSObject::findPropertyHashEntry): Ditto. |
| (KJS::JSObject::getPropertyAttributes): Ditto. |
| (KJS::JSObject::getPropertyNames): Ditto. |
| |
| 2008-03-18 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fix http://bugs.webkit.org/show_bug.cgi?id=17925 and http://bugs.webkit.org/show_bug.cgi?id=17927. |
| - Bug 17925: Crash in KJS::JSObject::put after setting this.__proto__ |
| - Bug 17927: Hang after attempting to create circular __proto__ |
| |
| * kjs/object.cpp: |
| (KJS::JSObject::put): Silently ignore attempts to set __proto__ to a non-object, non-null value. |
| Return after setting the exception when an attempt to set a cyclic __proto__ is detected so that |
| the cyclic value is not set. |
| |
| 2008-03-18 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - inline ActivationImp::init for 0.8% SunSpider speedup |
| |
| * kjs/Activation.h: |
| (KJS::ActivationImp::init): Moved here from function.cpp |
| * kjs/function.cpp: |
| |
| 2008-03-18 Simon Hausmann <hausmann@webkit.org> |
| |
| Fix the Qt build. |
| |
| Including config.h like in the other .cpp files gets the #ifdeffery |
| correct for rand_s. |
| |
| * kjs/JSWrapperObject.cpp: |
| |
| 2008-03-17 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| JavaScriptCore changes to support a WebCore speedup. |
| |
| * JavaScriptCore.exp: Export the UString::Rep::computeHash function. |
| * wtf/HashSet.h: Added a find and contains function that take a translator, |
| like the add function. |
| |
| 2008-03-18 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - a few micro-optimizations for 1.2% SunSpider speedup |
| |
| * kjs/function.cpp: |
| (KJS::FunctionImp::callAsFunction): check for Return completion before Throw, |
| it is more likely. |
| * kjs/object.cpp: |
| (KJS::JSObject::put): When walking prototype chain, instead of |
| checking isObject (a virtual call), compare to jsNull (compare to |
| a constant) since null is the only non-object that can be in a |
| prototype chain. |
| |
| 2008-03-17 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Optimise multi-scope function call resolution |
| |
| Refactor multiscope variable resolution and use to add |
| optimised FunctionCallResolveNode subclasses. |
| |
| 2.6% gain in sunspider performance, *25%* gain in controlflow-recursive |
| |
| * kjs/nodes.cpp: |
| (KJS::getSymbolTableEntry): |
| (KJS::ResolveNode::optimizeVariableAccess): |
| (KJS::getNonLocalSymbol): |
| (KJS::ExpressionNode::resolveAndCall): |
| (KJS::FunctionCallResolveNode::optimizeVariableAccess): |
| (KJS::FunctionCallResolveNode::inlineEvaluate): |
| (KJS::ScopedVarFunctionCallNode::inlineEvaluate): |
| (KJS::ScopedVarFunctionCallNode::evaluate): |
| (KJS::ScopedVarFunctionCallNode::evaluateToNumber): |
| (KJS::ScopedVarFunctionCallNode::evaluateToBoolean): |
| (KJS::ScopedVarFunctionCallNode::evaluateToInt32): |
| (KJS::ScopedVarFunctionCallNode::evaluateToUInt32): |
| (KJS::NonLocalVarFunctionCallNode::inlineEvaluate): |
| (KJS::NonLocalVarFunctionCallNode::evaluate): |
| (KJS::NonLocalVarFunctionCallNode::evaluateToNumber): |
| (KJS::NonLocalVarFunctionCallNode::evaluateToBoolean): |
| (KJS::NonLocalVarFunctionCallNode::evaluateToInt32): |
| (KJS::NonLocalVarFunctionCallNode::evaluateToUInt32): |
| * kjs/nodes.h: |
| (KJS::ScopedVarFunctionCallNode::): |
| (KJS::NonLocalVarFunctionCallNode::): |
| |
| 2008-03-17 David Kilzer <ddkilzer@apple.com> |
| |
| Don't define PLATFORM(MIDDLE_ENDIAN) on little endian ARM. |
| |
| Reviewed by Darin. |
| |
| See <http://bugs.webkit.org/show_bug.cgi?id=15416#c13>. |
| |
| * wtf/Platform.h: Added check for !defined(__ARMEL__) when defining |
| PLATFORM(MIDDLE_ENDIAN). |
| |
| 2008-03-17 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff, Darin and Weinig. |
| |
| Add fast multi-level scope lookup |
| |
| Add logic and AST nodes to provide rapid variable resolution across |
| static scope boundaries. This also adds logic that allows us to skip |
| any static scopes that do not contain the variable to be resolved. |
| |
| This results in a ~2.5% speedup in SunSpider, and gives a 25-30% speedup |
| in some simple and ad hoc closure and global variable access tests. |
| |
| * JavaScriptCore.exp: |
| * kjs/Activation.h: |
| * kjs/JSGlobalObject.cpp: |
| * kjs/JSGlobalObject.h: |
| * kjs/JSVariableObject.cpp: |
| * kjs/JSVariableObject.h: |
| * kjs/function.cpp: |
| (KJS::ActivationImp::isDynamicScope): |
| * kjs/nodes.cpp: |
| (KJS::ResolveNode::optimizeVariableAccess): |
| (KJS::ScopedVarAccessNode::inlineEvaluate): |
| (KJS::ScopedVarAccessNode::evaluate): |
| (KJS::ScopedVarAccessNode::evaluateToNumber): |
| (KJS::ScopedVarAccessNode::evaluateToBoolean): |
| (KJS::ScopedVarAccessNode::evaluateToInt32): |
| (KJS::ScopedVarAccessNode::evaluateToUInt32): |
| (KJS::NonLocalVarAccessNode::inlineEvaluate): |
| (KJS::NonLocalVarAccessNode::evaluate): |
| (KJS::NonLocalVarAccessNode::evaluateToNumber): |
| (KJS::NonLocalVarAccessNode::evaluateToBoolean): |
| (KJS::NonLocalVarAccessNode::evaluateToInt32): |
| (KJS::NonLocalVarAccessNode::evaluateToUInt32): |
| (KJS::IfElseNode::optimizeVariableAccess): |
| (KJS::ScopeNode::optimizeVariableAccess): |
| * kjs/nodes.h: |
| (KJS::ScopedVarAccessNode::): |
| (KJS::NonLocalVarAccessNode::): |
| * kjs/object.h: |
| |
| 2008-03-16 weihongzeng <weihong.zeng@hotmail.com> |
| |
| Reviewed by Darin Adler. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=15416 |
| Add support for mixed-endian processors |
| |
| * kjs/dtoa.cpp: Add IEEE_ARM, triggered by PLATFORM(MIDDLE_ENDIAN). |
| |
| 2008-03-16 Kevin Ollivier <kevino@theolliviers.com> |
| |
| Rubber stamped by Darin. |
| |
| Add set-webkit-configuration support for wx port, and centralize |
| build dir location setting. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=17790 |
| |
| * jscore.bkl: |
| |
| 2008-03-14 Steve Falkenburg <sfalken@apple.com> |
| |
| PGO build fixes. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| |
| 2008-03-14 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Add logic to track whether a function uses a locally scoped eval or requires a closure |
| |
| Now that we limit eval we can track those uses of eval that operate |
| in the local scope and functions that require a closure. We track |
| this information during initial parsing to avoid yet another tree |
| walk. |
| |
| * JavaScriptCore.exp: |
| * kjs/NodeInfo.h: |
| * kjs/Parser.cpp: |
| (KJS::Parser::didFinishParsing): |
| * kjs/Parser.h: |
| (KJS::Parser::parse): |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::ScopeNode::ScopeNode): |
| (KJS::ProgramNode::ProgramNode): |
| (KJS::ProgramNode::create): |
| (KJS::EvalNode::EvalNode): |
| (KJS::EvalNode::create): |
| (KJS::FunctionBodyNode::FunctionBodyNode): |
| (KJS::FunctionBodyNode::create): |
| * kjs/nodes.h: |
| (KJS::ScopeNode::): |
| (KJS::ScopeNode::usesEval): |
| (KJS::ScopeNode::needsClosure): |
| |
| 2008-03-14 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Beth Dakin. |
| |
| Fixed another problem with Vector::shrinkCapacity. |
| |
| moveOverlapping isn't good enough for the case where the buffer hasn't |
| changed, because it still destroys the contents of the buffer. |
| |
| * wtf/Vector.h: |
| (WTF::::shrinkCapacity): Changed to explicitly check whether the call |
| to allocateBuffer produced a new buffer. If it didn't, there's no need |
| to move. |
| |
| 2008-03-14 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Beth Dakin. |
| |
| Fixed a few problems with Vector::shrinkCapacity that I noticed in testing. |
| |
| * wtf/Vector.h: |
| (WTF::VectorBufferBase::deallocateBuffer): Clear our m_buffer pointer |
| when we deallocate m_buffer, in case we're not asked to reallocate a new |
| buffer. (Otherwise, we would use a stale m_buffer if we were asked to |
| perform any operations after shrinkCapacity was called.) |
| |
| (WTF::VectorBuffer::allocateBuffer): Made VectorBuffer with inline |
| capacity aware that calls to allocateBuffer might be shrinks, rather |
| than grows, so we shouldn't allocate a new buffer on the heap unless |
| our inline buffer is too small. |
| |
| (WTF::::shrinkCapacity): Call resize() instead of just setting m_size, |
| so destructors run. Call resize before reallocating the buffer to make |
| sure that we still have access to the objects we need to destroy. Call |
| moveOverlapping instead of move, since a call to allocateBuffer on an |
| inline buffer may produce identical storage. |
| |
| 2008-03-14 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Get rid of a localime() call on platforms that have better alternatives. |
| |
| * kjs/DateMath.h: Added getLocalTime(); |
| |
| * kjs/DateMath.cpp: |
| (KJS::getLocalTime): |
| (KJS::getDSTOffsetSimple): |
| Implementation moved from getDSTOffsetSimple(). |
| |
| * kjs/date_object.cpp: |
| (KJS::DateObjectImp::callAsFunction): Switched to getLocalTime(). |
| |
| 2008-03-14 David D. Kilzer <ddkilzer@apple.com> |
| |
| Unify concept of enabling the Mac Java bridge. |
| |
| Reviewed by Darin and Anders. |
| |
| * wtf/Platform.h: Define ENABLE_MAC_JAVA_BRIDGE here. |
| |
| 2008-03-13 Mark Mentovai <mark@moxienet.com> |
| |
| Reviewed by eseidel. Landed by eseidel. |
| |
| * wtf/FastMalloc.cpp: #include <wtf/HashSet.h> outside of any |
| namespaces. |
| |
| 2008-03-13 Mark Mentovai <mark@moxienet.com> |
| |
| Reviewed by eseidel. Landed by eseidel. |
| |
| * pcre/pcre_exec.cpp: Fix misnamed variable, allowing -DDEBUG build |
| to succeed. |
| * wtf/ThreadingPthreads.cpp: #include <sys/time.h> for gettimeofday |
| in non-pch build. |
| |
| 2008-03-13 Steve Falkenburg <sfalken@apple.com> |
| |
| PGO build fixes. |
| |
| Disable PGO for normal release builds. |
| Added work-in-progress Release_PGOInstrument/Release_PGOOptimize targets. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| |
| 2008-03-13 Beth Dakin <bdakin@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Adding new functionality to Vector. Currently all of the shrink and |
| resize functions on Vector only shrink the size of the Vector, not |
| the capacity. For the Vector to take up as little memory as |
| possible, though, it is necessary to be able to shrink the capacity |
| as well. So this patch adds that functionality. |
| |
| I need this for a speed up I am working on, and Geoff wants to use |
| it in a speed up he is working on also, so he asked me to commit it |
| now. |
| |
| * wtf/Vector.h: |
| (WTF::VectorBufferBase::allocateBuffer): |
| (WTF::::shrinkCapacity): |
| |
| 2008-03-13 Simon Hausmann <hausmann@webkit.org> |
| |
| Reviewed by Adam Roben. |
| |
| Attempt at fixing the Qt/Windows build bot. Quote using double-quotes |
| instead of single quotes. |
| |
| * pcre/dftables: |
| |
| 2008-03-12 Steve Falkenburg <sfalken@apple.com> |
| |
| Build fix. |
| |
| * JavaScriptCore.vcproj/WTF/WTF.vcproj: |
| |
| 2008-03-12 Alp Toker <alp@atoker.com> |
| |
| Another autotools testkjs build fix attempt. |
| |
| * GNUmakefile.am: |
| |
| 2008-03-12 Alp Toker <alp@atoker.com> |
| |
| Attempt to fix the autotools testkjs build on systems with |
| non-standard include paths. |
| |
| * GNUmakefile.am: |
| |
| 2008-03-11 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| <rdar://problem/5787743> REGRESSION: Crash at WTF::Collator::CreateCollator() running fast/js/kde/StringObject.html on Windows |
| |
| * wtf/unicode/icu/CollatorICU.cpp: |
| (WTF::Collator::createCollator): Check for null (== user default) m_locale before calling strcmp. |
| |
| 2008-03-11 Steve Falkenburg <sfalken@apple.com> |
| |
| Disable LTCG/PGO for grammar.cpp and nodes.cpp. |
| PGO on these files causes us to hang. |
| |
| Copy newer vsprops files from relative WebKitLibraries path to environment variable based path. |
| |
| Reviewed by Oliver. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCoreGenerated.make: |
| |
| 2008-03-10 Darin Adler <darin@apple.com> |
| |
| - Windows build fix |
| |
| * kjs/function.cpp: (KJS::decode): Initialize variable. |
| |
| 2008-03-10 Brent Fulgham <bfulgham@gmail.com> |
| |
| Windows build fix |
| |
| Reviewed by Adam. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCoreGenerated.make: |
| Set the PATH to include Cygwin before running touch. |
| |
| 2008-03-10 Eric Seidel <eric@webkit.org> |
| |
| Build fix for JSC on windows. |
| |
| * API/JSStringRefCF.cpp: |
| (JSStringCreateWithCFString): |
| * kjs/function.cpp: |
| (KJS::decode): |
| * kjs/nodes2string.cpp: |
| (KJS::escapeStringForPrettyPrinting): |
| |
| 2008-03-10 Eric Seidel <eric@webkit.org> |
| |
| No review, build fix only. |
| |
| Attempt to fix the windows build? |
| |
| * kjs/ustring.h: change unsigned short to UChar |
| |
| 2008-03-10 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Remove KJS::UChar, use ::UChar instead |
| http://bugs.webkit.org/show_bug.cgi?id=17017 |
| |
| * API/JSStringRef.cpp: |
| (JSStringCreateWithCharacters): |
| (JSStringCreateWithUTF8CString): |
| * API/JSStringRefCF.cpp: |
| (JSStringCreateWithCFString): |
| * JavaScriptCore.exp: |
| * kjs/Parser.h: |
| * kjs/function.cpp: |
| (KJS::decode): |
| (KJS::parseInt): |
| (KJS::parseFloat): |
| (KJS::globalFuncEscape): |
| (KJS::globalFuncUnescape): |
| * kjs/function_object.cpp: |
| (KJS::FunctionObjectImp::construct): |
| * kjs/identifier.cpp: |
| (KJS::Identifier::equal): |
| (KJS::CStringTranslator::translate): |
| * kjs/interpreter.h: |
| * kjs/lexer.cpp: |
| (KJS::Lexer::setCode): |
| (KJS::Lexer::shift): |
| (KJS::Lexer::lex): |
| (KJS::Lexer::convertUnicode): |
| (KJS::Lexer::makeIdentifier): |
| * kjs/lookup.cpp: |
| (KJS::keysMatch): |
| * kjs/nodes2string.cpp: |
| (KJS::escapeStringForPrettyPrinting): |
| (KJS::SourceStream::operator<<): |
| * kjs/regexp.cpp: |
| (KJS::RegExp::RegExp): |
| (KJS::RegExp::match): |
| * kjs/string_object.cpp: |
| (KJS::substituteBackreferences): |
| (KJS::stringProtoFuncCharCodeAt): |
| (KJS::stringProtoFuncToLowerCase): |
| (KJS::stringProtoFuncToUpperCase): |
| (KJS::stringProtoFuncToLocaleLowerCase): |
| (KJS::stringProtoFuncToLocaleUpperCase): |
| * kjs/ustring.cpp: |
| (KJS::UString::Rep::computeHash): |
| (KJS::UString::UString): |
| (KJS::UString::append): |
| (KJS::UString::ascii): |
| (KJS::UString::operator=): |
| (KJS::UString::is8Bit): |
| (KJS::UString::toStrictUInt32): |
| (KJS::UString::find): |
| (KJS::operator==): |
| (KJS::operator<): |
| (KJS::compare): |
| (KJS::UString::UTF8String): |
| * kjs/ustring.h: |
| * pcre/pcre.h: |
| |
| 2008-03-09 Steve Falkenburg <sfalken@apple.com> |
| |
| Stop Windows build if an error occurs in a prior project. |
| |
| Rubber stamped by Darin. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCoreGenerated.make: |
| * JavaScriptCore.vcproj/WTF/WTF.vcproj: |
| * JavaScriptCore.vcproj/testkjs/testkjs.vcproj: |
| |
| 2008-03-09 J¸rg Billeter <j@bitron.ch> |
| |
| Reviewed by Alp Toker. |
| |
| Conditionalise ICU for Unicode in the GTK+ port. |
| |
| * wtf/Platform.h: |
| |
| 2008-03-07 David D. Kilzer <ddkilzer@apple.com> |
| |
| Unify concept of enabling Netscape Plug-in API (NPAPI). |
| |
| Reviewed by Darin. |
| |
| * wtf/Platform.h: Define ENABLE_NETSCAPE_PLUGIN_API here. |
| |
| 2008-03-07 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Fixed <rdar://problem/5689093> Stricter (ES4) eval semantics |
| |
| The basic rule is: |
| |
| - "eval(s)" is treated as an operator that gives the ES3 eval behavior. |
| ... but only if there is no overriding declaration of "eval" in scope. |
| - All other invocations treat eval as a function that evaluates a |
| script in the context of its "this" object. |
| ... but if its "this" object is not the global object it was |
| originally associated with, eval throws an exception. |
| |
| Because only expressions of the form "eval(s)" have access to local |
| scope, the compiler can now statically determine whether a function |
| needs local scope to be dynamic. |
| |
| * kjs/nodes.h: Added FunctionCallEvalNode. It works just like |
| FuncationCallResolveNode, except it statically indicates that the node |
| may execute eval in the ES3 way. |
| * kjs/nodes.cpp: |
| * kjs/nodes2string.cpp: |
| |
| * tests/mozilla/expected.html: This patch happens to fix a Mozilla JS |
| test, but it's a bit of a pyrrhic victory. The test intends to test |
| Mozilla's generic API for calling eval on any object, but, in reality, |
| we only support calling eval on the global object. |
| |
| 2008-03-06 Steve Falkenburg <sfalken@apple.com> |
| |
| Build fix. |
| |
| * JavaScriptCore.vcproj/testkjs/testkjs.vcproj: |
| |
| 2008-03-06 Steve Falkenburg <sfalken@apple.com> |
| |
| Build fix. |
| |
| * JavaScriptCore.vcproj/WTF/WTF.vcproj: |
| |
| 2008-03-06 Alp Toker <alp@atoker.com> |
| |
| Fix the build fix in r30845 to support out-of-tree builds. |
| |
| * GNUmakefile.am: |
| |
| 2008-03-06 Steve Falkenburg <sfalken@apple.com> |
| |
| Build fix. |
| |
| * wtf/ThreadingWin.cpp: |
| (WTF::ThreadCondition::timedWait): |
| |
| 2008-03-06 Darin Adler <darin@apple.com> |
| |
| - another small step towards fixing the Qt build |
| |
| * JavaScriptCore.pri: Remove more references to the now-obsolete bindings directory. |
| |
| 2008-03-06 Darin Adler <darin@apple.com> |
| |
| - a small step towards fixing the Qt build |
| |
| * JavaScriptCore.pri: Remove references to files no longer present in JavaScriptCore/bindings. |
| |
| 2008-03-06 Brady Eidson <beidson@apple.com> |
| |
| Gtk Build fix |
| |
| * wtf/ThreadingGtk.cpp: |
| (WTF::ThreadCondition::timedWait): |
| |
| 2008-03-06 Alexey Proskuryakov <ap@webkit.org> |
| |
| Wx build fix. |
| |
| * wtf/unicode/icu/CollatorICU.cpp: |
| (WTF::Collator::userDefault): Put ICU workaround under both PLATFORM(DARWIN) and |
| PLATFORM(CF) checks, so that each port can decide if it wants to use CF on Mac for it. |
| |
| 2008-03-06 Brady Eidson <beidson@apple.com> |
| |
| Reviewed by Darin |
| |
| Add a timedWait() method to ThreadCondition |
| |
| * JavaScriptCore.exp: |
| |
| * wtf/Threading.h: |
| |
| * wtf/ThreadingGtk.cpp: |
| (WTF::ThreadCondition::timedWait): |
| |
| * wtf/ThreadingNone.cpp: |
| (WTF::ThreadCondition::timedWait): |
| |
| * wtf/ThreadingPthreads.cpp: |
| (WTF::ThreadCondition::timedWait): |
| |
| * wtf/ThreadingWin.cpp: |
| (WTF::ThreadCondition::timedWait): Needs implementation |
| |
| 2008-03-06 Alexey Proskuryakov <ap@webkit.org> |
| |
| More build fixes. |
| |
| * jscore.bkl: Add the wtf/unicode directory. |
| * wtf/unicode/CollatorDefault.cpp: |
| (WTF::Collator::userDefault): Use a constructor that does exist. |
| * wtf/unicode/icu/CollatorICU.cpp: Mac build fix for case-sensitive file systems. |
| |
| 2008-03-06 Darin Adler <darin@apple.com> |
| |
| - try to fix the Qt build |
| |
| * JavaScriptCore.pri: Add the wtf/unicode directory. |
| |
| 2008-03-06 Darin Adler <darin@apple.com> |
| |
| - try to fix the GTK build |
| |
| * GNUmakefile.am: Add a -I for the wtf/unicode directory. |
| |
| 2008-03-06 Darin Adler <darin@apple.com> |
| |
| - try to fix the Mac build |
| |
| * icu/unicode/parseerr.h: Copied from ../WebCore/icu/unicode/parseerr.h. |
| * icu/unicode/ucol.h: Copied from ../WebCore/icu/unicode/ucol.h. |
| * icu/unicode/uloc.h: Copied from ../WebCore/icu/unicode/uloc.h. |
| * icu/unicode/unorm.h: Copied from ../WebCore/icu/unicode/unorm.h. |
| * icu/unicode/uset.h: Copied from ../WebCore/icu/unicode/uset.h. |
| |
| 2008-03-06 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| <rdar://problem/5687269> Need to create a Collator abstraction for WebCore and JavaScriptCore |
| |
| * wtf/Threading.h: |
| (WTF::initializeThreading): |
| * wtf/ThreadingGtk.cpp: |
| (WTF::initializeThreading): |
| * wtf/ThreadingNone.cpp: |
| * wtf/ThreadingPthreads.cpp: |
| * wtf/ThreadingWin.cpp: |
| Added AtomicallyInitializedStatic. |
| |
| * kjs/string_object.cpp: (KJS::localeCompare): Changed to use Collator. |
| |
| * GNUmakefile.am: |
| * JavaScriptCore.exp: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/WTF/WTF.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| Added new fiiles to projects. |
| |
| * wtf/unicode/Collator.h: Added. |
| (WTF::Collator::): |
| * wtf/unicode/CollatorDefault.cpp: Added. |
| (WTF::Collator::Collator): |
| (WTF::Collator::~Collator): |
| (WTF::Collator::setOrderLowerFirst): |
| (WTF::Collator::collate): |
| * wtf/unicode/icu/CollatorICU.cpp: Added. |
| (WTF::cachedCollatorMutex): |
| (WTF::Collator::Collator): |
| (WTF::Collator::~Collator): |
| (WTF::Collator::setOrderLowerFirst): |
| (WTF::Collator::collate): |
| (WTF::Collator::createCollator): |
| (WTF::Collator::releaseCollator): |
| |
| 2008-03-05 Kevin Ollivier <kevino@theolliviers.com> |
| |
| Fix the wx build after the bindings move. |
| |
| * JavaScriptCoreSources.bkl: |
| * jscore.bkl: |
| |
| 2008-03-05 Alp Toker <alp@atoker.com> |
| |
| GTK+ build fix for breakage introduced in r30800. |
| |
| Track moved bridge sources from JavaScriptCore to WebCore. |
| |
| * GNUmakefile.am: |
| |
| 2008-03-05 Brent Fulgham <bfulgham@gmail.com> |
| |
| Reviewed by Adam Roben. |
| |
| Remove definition of WTF_USE_SAFARI_THEME from wtf/Platform.h |
| because the PLATFORM(CG) flag is not set until config.h has |
| already included this file. |
| |
| * wtf/Platform.h: Remove useless definition of WTF_USE_SAFARI_THEME |
| |
| 2008-03-05 Brady Eidson <beidson@apple.com> |
| |
| Reviewed by Alexey and Mark Rowe |
| |
| Fix for <rdar://problem/5778247> - Reproducible crash on storage/execute-sql-args.html |
| |
| DatabaseThread::unscheduleDatabaseTasks() manually filters through a MessageQueue, |
| removing particular items for Databases that were shutting down. |
| |
| This filtering operation is not atomic, and therefore causes a race condition with the |
| MessageQueue waking up and reading from the message queue. |
| |
| The end result was an attempt to dereference a null DatabaseTask. Timing-wise, this never |
| seemed to happen in a debug build, otherwise an assertion would've caught it. Replacing that |
| assertion with a crash in a release build is what revealed this bug. |
| |
| * wtf/MessageQueue.h: |
| (WTF::::waitForMessage): Tweak the waiting logic to check the queue's empty state then go back |
| to sleep if the queue was empty - checking m_killed each time it wakes up. |
| |
| 2008-03-05 David D. Kilzer <ddkilzer@apple.com> |
| |
| Remove unused header includes from interpreter.cpp. |
| |
| Reviewed by Darin. |
| |
| * kjs/interpreter.cpp: Remove unused header includes. |
| |
| 2008-03-05 Anders Carlsson <andersca@apple.com> |
| |
| Reviewed by Sam. |
| |
| Remove bindings/. |
| |
| * bindings: Removed. |
| |
| 2008-03-05 Anders Carlsson <andersca@apple.com> |
| |
| Don't build bindings/ anymore. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| |
| 2008-03-05 Anders Carlsson <andersca@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Don't build JavaScriptCore/bindings. |
| |
| * JavaScriptCore.exp: |
| Export a couple of new functions. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| Remove bindings/ |
| |
| * kjs/config.h: |
| No need to define HAVE_JNI anymore. |
| |
| * kjs/interpreter.cpp: |
| Remove unnecessary include. |
| |
| 2008-03-05 David D. Kilzer <ddkilzer@apple.com> |
| |
| Allow override of default script file name using command-line argument. |
| |
| Reviewed by Adele. |
| |
| * API/minidom.c: |
| (main): Allow first command-line argument to override the default script |
| file name of "minidom.js". |
| * API/testapi.c: |
| (main): Allow first command-line argument to override the default script |
| file name of "testapi.js". |
| |
| 2008-03-04 Mark Rowe <mrowe@apple.com> |
| |
| Mac build fix. |
| |
| * JavaScriptCore.exp: Add new symbol to exports file. |
| |
| 2008-03-03 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Anders. |
| |
| Make ForInNode check for the timeout interrupt |
| |
| * kjs/nodes.cpp: |
| (KJS::ForInNode::execute): |
| |
| 2008-03-02 Brent Fulgham <bfulgham@gmail.com> |
| |
| Reviewed by Alp Toker. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=17415 |
| GTK Build (using autotools) on Mac OS (DarwinPorts) Fails |
| |
| Add -lstdc++ to link flags for minidom program. This corrects |
| a build error for the GTK+ on Mac OS. |
| |
| * GNUmakefile.am: |
| |
| 2008-03-01 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Tim Hatcher. |
| |
| Update Xcode configuration to support building debug and release from the mysterious future. |
| |
| * Configurations/Base.xcconfig: |
| * Configurations/DebugRelease.xcconfig: |
| |
| 2008-02-29 Brent Fulgham <bfulgham@gmail.com> |
| |
| http://bugs.webkit.org/show_bug.cgi?id=17483 |
| Implement scrollbars on Windows (Cairo) |
| |
| Reviewed by Adam Roben. |
| |
| * wtf/Platform.h: |
| |
| 2008-02-29 Adam Roben <aroben@apple.com> |
| |
| Remove unused DebuggerImp::abort and DebuggerImp::aborted |
| |
| Reviewed by Tim and Sam. |
| |
| * kjs/function_object.cpp: |
| (KJS::FunctionObjectImp::construct): |
| * kjs/internal.h: |
| (KJS::DebuggerImp::DebuggerImp): |
| * kjs/nodes.cpp: |
| (KJS::Node::handleException): |
| (KJS::FunctionBodyNodeWithDebuggerHooks::execute): |
| |
| 2008-02-28 Eric Christopher <echristo@apple.com> |
| |
| Reviewed by Geoffrey Garen. |
| |
| ** TOTAL **: 1.005x as fast 2867.6ms +/- 0.4% 2853.2ms +/- 0.3% significant |
| |
| * kjs/nodes.cpp: Tell the compiler that exceptions are unexpected (for |
| the sake of branch prediction and code organization). |
| |
| 2008-02-27 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Sam Weinig. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=17030 |
| Small buffer overflow within initialization |
| |
| * kjs/date_object.cpp: |
| (KJS::DateObjectFuncImp::callAsFunction): |
| (KJS::parseDate): |
| Remove unnecessary and incorrect memset() calls - GregorianDateTime can initialize itself. |
| |
| 2008-02-25 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Dan Bernstein. |
| |
| - Add a variant of remove that takes a position and a length. |
| |
| * wtf/Vector.h: |
| (WTF::Vector::remove): |
| |
| 2008-02-25 Mark Mentovai <mark@moxienet.com> |
| |
| Reviewed by Mark Rowe. |
| |
| Enable CollectorHeapIntrospector to build by itself, as well as in an AllInOneFile build. |
| http://bugs.webkit.org/show_bug.cgi?id=17538 |
| |
| * kjs/CollectorHeapIntrospector.cpp: Provide "using" declaration for |
| WTF::RemoteMemoryReader. |
| * kjs/collector.h: Move CollectorHeap declaration here... |
| * kjs/collector.cpp: ... from here. |
| |
| 2008-02-25 Darin Adler <darin@apple.com> |
| |
| Reviewed by Adam. |
| |
| * JavaScriptCore.exp: Sort the contents of this file. |
| |
| 2008-02-25 Adam Roben <aroben@apple.com> |
| |
| MSVC build fix |
| |
| * kjs/testkjs.cpp: |
| (functionQuit): Don't add a return statement after exit(0) for MSVC. |
| |
| 2008-02-24 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Mark Rowe. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=17529 |
| Add support for reading from stdin from testkjs |
| |
| * kjs/testkjs.cpp: |
| (GlobalObject::GlobalObject): Add readline function to global object. |
| (functionReadline): Added. Reads characters from stdin until a '\n' or |
| EOF is encountered. The input is returned as a String to the caller. |
| |
| 2008-02-24 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Mark Rowe. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=17528 |
| Give testkjs a bath |
| |
| * JavaScriptCore.exp: |
| * JavaScriptCore.xcodeproj/project.pbxproj: Make the testkjs.cpp use 4 space indentation. |
| * kjs/testkjs.cpp: |
| (StopWatch::getElapsedMS): |
| (GlobalObject::className): |
| (GlobalObject::GlobalObject): |
| Rename GlobalImp to GlobalObject and setup the global functions |
| in the GlobalObject's constructor. Also, use static functions for |
| the implementation so we can use the standard PrototypeFunction |
| class and remove TestFunctionImp. |
| (functionPrint): Move print() functionality here. |
| (functionDebug): Move debug() functionality here. |
| (functionGC): Move gc() functionality here. |
| (functionVersion): Move version() functionality here. |
| (functionRun): Move run() functionality here. |
| (functionLoad): Move load() functionality here. |
| (functionQuit): Move quit() functionality here. |
| (prettyPrintScript): Fix indentation. |
| (runWithScripts): Since all the functionality of createGlobalObject is |
| now in the GlobalObject constructor, just call new here. |
| (parseArguments): Fix indentation. |
| (kjsmain): Ditto |
| (fillBufferWithContentsOfFile): Ditto. |
| |
| 2008-02-24 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Oliver Hunt and Mark Rowe. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=17505 |
| Add support for getting command line arguments in testkjs |
| |
| - This slightly changes the behavior of parsing arguments by requiring |
| a '-f' before all files. |
| |
| * kjs/testkjs.cpp: |
| (createGlobalObject): Add a global property called 'arguments' which |
| contains an array with the parsed arguments as strings. |
| (runWithScripts): Pass in the arguments vector so that it can be passed |
| to the global object. |
| (parseArguments): Change parsing rules to require a '-f' before any script |
| file. After all '-f' and '-p' arguments have been parsed, the remaining |
| are added to the arguments vector and exposed to the script. If there is a |
| chance of ambiguity (the user wants to pass the string '-f' to the script), |
| the string '--' can be used separate the options from the pass through |
| arguments. |
| (kjsmain): |
| |
| 2008-02-24 Dan Bernstein <mitz@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=17511 |
| REGRESSION: Reproducible crash in SegmentedSubstring::SegmentedSubstring(SegmentedSubstring const&) |
| |
| * wtf/Deque.h: |
| (WTF::::expandCapacityIfNeeded): Fixed the case where m_start and m_end |
| are both zero but the buffer capacity is non-zero. |
| (WTF::::prepend): Added validity checks. |
| |
| 2008-02-23 Jan Michael Alonzo <jmalonzo@unpluggable.com> |
| |
| Rubber stamped by Darin. |
| |
| Add separator '\' after libJavaScriptCore_la_LIBADD and cleanup |
| whitespaces introduced in the previous commit. |
| |
| * GNUmakefile.am: |
| |
| 2008-02-23 Jan Michael Alonzo <jmalonzo@unpluggable.com> |
| |
| * GNUmakefile.am: Add GLOBALDEPS for testkjs and minidom. |
| |
| 2008-02-23 Darin Adler <darin@apple.com> |
| |
| Reviewed by Anders. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=17496 |
| make Deque use a circular array; add iterators |
| |
| * wtf/Deque.h: Wrote an all-new version of this class that uses a circular |
| buffer. Growth policy is identical to vector. Added iterators. |
| |
| * wtf/Vector.h: Made two small refinements while using this to implement |
| Deque: Made VectorBufferBase derive from Noncopyable, which would have |
| saved me some debugging time if it had been there. Renamed Impl and |
| m_impl to Buffer and m_buffer. |
| |
| 2008-02-23 Darin Adler <darin@apple.com> |
| |
| Reviewed by Anders. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=17067 |
| eliminate attributes parameter from JSObject::put for speed/clarity |
| |
| * API/JSCallbackObject.h: Removed attribute arguments. |
| * API/JSCallbackObjectFunctions.h: |
| (KJS::JSCallbackObject<Base>::put): Ditto. |
| * API/JSObjectRef.cpp: |
| (JSObjectSetProperty): Use initializeVariable or putDirect when necessary |
| to set attribute values. |
| * JavaScriptCore.exp: Updated. |
| * bindings/objc/objc_runtime.h: Removed attribute arguments. |
| * bindings/objc/objc_runtime.mm: |
| (ObjcFallbackObjectImp::put): Ditto. |
| * bindings/runtime_array.cpp: |
| (RuntimeArray::put): Ditto. |
| * bindings/runtime_array.h: Ditto. |
| * bindings/runtime_object.cpp: |
| (RuntimeObjectImp::put): Ditto. |
| * bindings/runtime_object.h: Ditto. Also removed canPut which was only |
| called from one place in WebCore that can use hasProperty instead. |
| |
| * kjs/Activation.h: Removed attribute argument from put and added the new |
| initializeVariable function that's used to put variables in variable objects. |
| Also made isActivationObject a const member. |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::put): Removed attribute argument. |
| (KJS::JSGlobalObject::initializeVariable): Added. Used to give variables |
| their initial values, which can include the read-only property. |
| (KJS::JSGlobalObject::reset): Removed obsolete comments about flags. |
| Removed Internal flag, which is no longer needed. |
| * kjs/JSGlobalObject.h: More of the same. |
| |
| * kjs/JSVariableObject.h: Added pure virtual initializeVariable function. |
| (KJS::JSVariableObject::symbolTablePut): Removed checkReadOnly flag; we always |
| check read-only. |
| (KJS::JSVariableObject::symbolTableInitializeVariable): Added. |
| |
| * kjs/array_instance.cpp: |
| (KJS::ArrayInstance::put): Removed attribute argument. |
| * kjs/array_instance.h: Ditto. |
| |
| * kjs/function.cpp: |
| (KJS::FunctionImp::put): Ditto. |
| (KJS::Arguments::put): Ditto. |
| (KJS::ActivationImp::put): Ditto. |
| (KJS::ActivationImp::initializeVariable): Added. |
| * kjs/function.h: Removed attribute arguments. |
| |
| * kjs/function_object.cpp: |
| (KJS::FunctionObjectImp::construct): Removed Internal flag. |
| |
| * kjs/lookup.h: |
| (KJS::lookupPut): Removed attributes argument. Also changed to use putDirect |
| instead of calling JSObject::put. |
| (KJS::cacheGlobalObject): Ditto. |
| |
| * kjs/nodes.cpp: |
| (KJS::ConstDeclNode::handleSlowCase): Call initializeVariable to initialize |
| the constant. |
| (KJS::ConstDeclNode::evaluateSingle): Ditto. |
| (KJS::TryNode::execute): Use putDirect to set up the new object. |
| (KJS::FunctionBodyNode::processDeclarations): Removed Internal. |
| (KJS::ProgramNode::processDeclarations): Ditto. |
| (KJS::EvalNode::processDeclarations): Call initializeVariable to initialize |
| the variables and functions. |
| (KJS::FuncDeclNode::makeFunction): Removed Internal. |
| (KJS::FuncExprNode::evaluate): Ditto. |
| |
| * kjs/object.cpp: Removed canPut, which was only being used in one code path, |
| not the normal high speed one. |
| (KJS::JSObject::put): Removed attribute argument. Moved the logic from |
| canPut here, in the one code ath that was still using it. |
| * kjs/object.h: Removed Internal attribute, ad canPut function. Removed the |
| attributes argument to the put function. Made isActivationObject const. |
| |
| * kjs/regexp_object.cpp: |
| (KJS::RegExpImp::put): Removed attributes argument. |
| (KJS::RegExpImp::putValueProperty): Ditto. |
| (KJS::RegExpObjectImp::put): Ditto. |
| (KJS::RegExpObjectImp::putValueProperty): Ditto. |
| * kjs/regexp_object.h: Ditto. |
| |
| * kjs/string_object.cpp: |
| (KJS::StringInstance::put): Removed attributes argument. |
| * kjs/string_object.h: Ditto. |
| |
| 2008-02-23 Jan Michael Alonzo <jmalonzo@unpluggable.com> |
| |
| Not reviewed, Gtk build fix. |
| |
| * kjs/testkjs.pro: |
| |
| 2008-02-23 Alexey Proskuryakov <ap@webkit.org> |
| |
| Windows build fix - move ThreadCondition implementation from WebCore to WTF. |
| |
| * wtf/ThreadingWin.cpp: |
| (WTF::ThreadCondition::ThreadCondition): |
| (WTF::ThreadCondition::~ThreadCondition): |
| (WTF::ThreadCondition::wait): |
| (WTF::ThreadCondition::signal): |
| (WTF::ThreadCondition::broadcast): |
| |
| 2008-02-23 Alexey Proskuryakov <ap@webkit.org> |
| |
| Touch some files, hoping that Windows build bot will create JSC headers. |
| |
| * kjs/AllInOneFile.cpp: |
| * kjs/array_instance.cpp: |
| * wtf/HashTable.cpp: |
| |
| 2008-02-23 Alexey Proskuryakov <ap@webkit.org> |
| |
| Qt/Wx build fix - this file was still in a wrong namespace, too. |
| |
| * wtf/ThreadingNone.cpp: |
| |
| 2008-02-23 Alexey Proskuryakov <ap@webkit.org> |
| |
| More build fixing - fix mismatched braces. |
| |
| * JavaScriptCore.pri: |
| |
| 2008-02-23 Alexey Proskuryakov <ap@webkit.org> |
| |
| Wx and Gtk build fixes. |
| |
| * JavaScriptCore.pri: Don't try to compile ThreadingPthreads. |
| * wtf/ThreadingGtk.cpp: Use a correct namespace. |
| |
| 2008-02-23 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Move basic threading support from WebCore to WTF. |
| |
| Added mutex protection to MessageQueue::killed() for paranoia sake. |
| |
| * GNUmakefile.am: |
| * JavaScriptCore.exp: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/WTF/WTF.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * wtf/Locker.h: Copied from WebCore/platform/Locker.h. |
| * wtf/MessageQueue.h: Copied from WebCore/platform/MessageQueue.h. |
| (WTF::::killed): |
| * wtf/Threading.h: Copied from WebCore/platform/Threading.h. |
| * wtf/ThreadingGtk.cpp: Copied from WebCore/platform/gtk/ThreadingGtk.cpp. |
| (WebCore::createThread): |
| * wtf/ThreadingNone.cpp: Copied from WebCore/platform/ThreadingNone.cpp. |
| * wtf/ThreadingPthreads.cpp: Copied from WebCore/platform/pthreads/ThreadingPthreads.cpp. |
| (WTF::createThread): |
| * wtf/ThreadingWin.cpp: Copied from WebCore/platform/win/ThreadingWin.cpp. |
| (WTF::createThread): |
| (WTF::Mutex::Mutex): |
| (WTF::Mutex::~Mutex): |
| (WTF::Mutex::lock): |
| (WTF::Mutex::tryLock): |
| (WTF::Mutex::unlock): |
| |
| 2008-02-22 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Partial fix for <rdar://problem/5744037> Gmail out of memory (17455) |
| |
| I'm removing KJS_MEM_LIMIT for the following reasons: |
| |
| - We have a few reports of KJS_MEM_LIMIT breaking important web |
| applications, like GMail and Google Reader. (For example, if you |
| simply open 12 GMail tabs, tab #12 will hit the limit.) |
| |
| - Firefox has no discernable JS object count limit, so any limit, even |
| a large one, is a potential compatibility problem. |
| |
| - KJS_MEM_LIMIT does not protect against malicious memory allocation, |
| since there are many ways to maliciously allocate memory without |
| increasing the JS object count. |
| |
| - KJS_MEM_LIMIT is already mostly broken, since it only aborts the |
| script that breaches the limit, not any subsequent scripts. |
| |
| - We've never gotten bug reports about websites that would have |
| benefited from an unbroken KJS_MEM_LIMIT. The initial check-in of |
| KJS_MEM_LIMIT (KJS revision 80061) doesn't mention a website that |
| needed it. |
| |
| - Any website that brings you anywhere close to crashing due to the |
| number of live JS objects will almost certainly put up the "slow |
| script" dialog at least 20 times beforehand. |
| |
| * kjs/collector.cpp: |
| (KJS::Collector::collect): |
| * kjs/collector.h: |
| * kjs/nodes.cpp: |
| (KJS::TryNode::execute): |
| |
| 2008-02-22 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Alexey P. |
| |
| <rdar://problem/5759327> REGRESSION: while(NaN) acts like while(true) |
| |
| Fix yet another case where we incorrectly relied on implicit double |
| to bool coercion. |
| |
| * kjs/nodes.cpp: |
| (KJS::PostDecLocalVarNode::evaluateToBoolean): |
| |
| 2008-02-20 Michael Knaup <michael.knaup@mac.com> |
| |
| Reviewed by Darin. |
| |
| Fix for Bug 16753: date set methods with no args should result in NaN (Acid3 bug) |
| The set values result in NaN now when called with no args, NaN or +/- inf values. |
| The setYear, setFullYear and setUTCFullYear methods used on NaN dates work as |
| descripted in the standard. |
| |
| * kjs/date_object.cpp: |
| (KJS::fillStructuresUsingTimeArgs): |
| (KJS::fillStructuresUsingDateArgs): |
| (KJS::setNewValueFromTimeArgs): |
| (KJS::setNewValueFromDateArgs): |
| (KJS::dateProtoFuncSetYear): |
| |
| 2008-02-19 Anders Carlsson <andersca@apple.com> |
| |
| Reviewed by Darin. |
| |
| Change OpaqueJSClass and RootObject to start with a ref count of 1. |
| |
| * API/JSClassRef.cpp: |
| (OpaqueJSClass::OpaqueJSClass): |
| (OpaqueJSClass::createNoAutomaticPrototype): |
| (OpaqueJSClass::create): |
| * API/JSClassRef.h: |
| * API/JSObjectRef.cpp: |
| (JSClassCreate): |
| * bindings/runtime_root.cpp: |
| (KJS::Bindings::RootObject::create): |
| (KJS::Bindings::RootObject::RootObject): |
| |
| 2008-02-19 Darin Adler <darin@apple.com> |
| |
| Rubber stamped by Anders. |
| |
| - removed explicit initialization to 1 for RefCounted; that's now the default |
| |
| * kjs/regexp.cpp: |
| (KJS::RegExp::RegExp): Removed RefCounted initializer. |
| |
| 2008-02-19 Darin Adler <darin@apple.com> |
| |
| Reviewed by Anders. |
| |
| - next step for http://bugs.webkit.org/show_bug.cgi?id=17257 |
| start ref counts at 1 instead of 0 for speed |
| |
| * wtf/RefCounted.h: |
| (WTF::RefCounted::RefCounted): Have refcounts default to 1. This allows us to start |
| removing the explicit initialization of RefCounted from classes and eventually we |
| can remove the ability to have the initial count of 0 entirely. |
| |
| 2008-02-18 Samuel Weinig <sam@webkit.org> |
| |
| Reviewed by Geoff Garen. |
| |
| Fix for http://bugs.webkit.org/show_bug.cgi?id=17419 |
| Remove CompatMode from JavaScriptCore as it is never set to anything other than NativeMode |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::init): |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::setDebugger): |
| * kjs/date_object.cpp: |
| (KJS::dateProtoFuncGetYear): |
| |
| 2008-02-18 Darin Adler <darin@apple.com> |
| |
| Reviewed by Sam. |
| |
| * wtf/ASCIICType.h: |
| (WTF::toASCIIHexValue): Added. |
| |
| 2008-02-17 Darin Adler <darin@apple.com> |
| |
| * wtf/ListHashSet.h: (WTF::swap): Removed stray return statement. |
| |
| 2008-02-15 Adam Roben <aroben@apple.com> |
| |
| Make JavaScriptCore's FEATURE_DEFINES match WebCore's |
| |
| Reviewed by Mark. |
| |
| * Configurations/JavaScriptCore.xcconfig: |
| |
| 2008-02-14 Stephanie Lewis <slewis@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Update order files. |
| |
| * JavaScriptCore.order: |
| |
| 2008-02-14 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Fixed <rdar://problem/5737835> nee http://bugs.webkit.org/show_bug.cgi?id=17329 |
| Crash in JSGlobalObject::popActivation when inserting hyperlink in Wordpress (17329) |
| |
| Don't reset the "activations" stack in JSGlobalObject::reset, since we |
| might be executing a script during the call to reset, and the script |
| needs to safely run to completion. |
| |
| Instead, initialize the "activations" stack when the global object is |
| created, and subsequently rely on pushing and popping during normal |
| execution to maintain the stack's state. |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::init): |
| (KJS::JSGlobalObject::reset): |
| |
| 2008-02-13 Bernhard Rosenkraenzer <bero@arklinux.org> |
| |
| Reviewed by Darin. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=17339 |
| JavaScriptCore does not build with gcc 4.3 |
| |
| * kjs/interpreter.cpp: Add include of <unistd.h>, since that's where |
| getpid() comes from. |
| |
| 2008-02-13 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Alexey P. |
| |
| <rdar://problem/5737003> REGRESSION (r27747): can't browse pictures on fastcupid.com |
| |
| When converting numeric values to booleans we need to account for NaN |
| |
| * kjs/nodes.cpp: |
| (KJS::MultNode::evaluateToBoolean): |
| (KJS::ModNode::evaluateToBoolean): |
| |
| 2008-02-08 Samuel Weinig <sam@webkit.org> |
| |
| Reviewed by Brady Eidson. |
| |
| <rdar://problem/5659216> REGRESSION: PLT 0.3% slower due to r28868 (caching ClassNodeList and NamedNodeList) |
| |
| - Tweak the statements in isASCIISpace to account for the statistical distribution of |
| usage in the PLT. |
| |
| .4% speedup on my machine. Stephanie's machine shows this as .3% speedup. |
| |
| * wtf/ASCIICType.h: |
| (WTF::isASCIISpace): |
| |
| 2008-02-11 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Anders Carlsson. |
| |
| Fixes for: |
| <rdar://problem/5735497> Match Firefox's cross-domain model more accurately by return the built-in version of functions even if they have been overridden |
| <rdar://problem/5735443> Crash when setting the Window objects prototype to a custom Object and then calling a method on it |
| |
| - Expose the native Object.prototype.toString implementation so that it can be used for cross-domain |
| toString calling. |
| |
| * JavaScriptCore.exp: |
| * kjs/object_object.cpp: |
| * kjs/object_object.h: |
| |
| 2008-02-10 Darin Adler <darin@apple.com> |
| |
| Rubber stamped by Eric. |
| |
| * kjs/ExecState.h: |
| (KJS::ExecState::takeException): Added. |
| |
| 2008-02-10 Darin Adler <darin@apple.com> |
| |
| Reviewed by Eric. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=17256 |
| eliminate default ref. count of 0 in RefCounted class |
| |
| * wtf/RefCounted.h: |
| (WTF::RefCounted::RefCounted): Remove default of 0. |
| |
| 2008-02-10 Darin Adler <darin@apple.com> |
| |
| Reviewed by Eric. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=17256 |
| Make clients of RefCounted explicitly set the count to 0. |
| |
| * API/JSClassRef.cpp: |
| (OpaqueJSClass::OpaqueJSClass): |
| * bindings/runtime_root.cpp: |
| (KJS::Bindings::RootObject::RootObject): |
| |
| 2008-02-09 Darin Adler <darin@apple.com> |
| |
| Reviewed by Mitz. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=17256 |
| Change RegExp to start its ref count at 1, not 0 |
| |
| We'll want to do this to every RefCounted class, one at a time. |
| |
| * kjs/nodes.h: |
| (KJS::RegExpNode::RegExpNode): Use RegExp::create instead of new RegExp. |
| * kjs/regexp.cpp: |
| (KJS::RegExp::RegExp): Marked inline, set initial ref count to 1. |
| (KJS::RegExp::create): Added. Calls new RegExp then adopts the initial ref. |
| * kjs/regexp.h: Reformatted. Made the constructors private. Added static |
| create functions that return objects already wrapped in PassRefPtr. |
| * kjs/regexp_object.cpp: |
| (KJS::regExpProtoFuncCompile): Use RegExp::create instead of new RegExp. |
| (KJS::RegExpObjectImp::construct): Ditto. |
| * kjs/string_object.cpp: |
| (KJS::stringProtoFuncMatch): Ditto. |
| (KJS::stringProtoFuncSearch): Ditto. |
| |
| 2008-02-08 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| <rdar://problem/5731773> REGRESSION (r28973): Extraneous parentheses in function.toString() |
| https://bugs.webkit.org/show_bug.cgi?id=17214 |
| |
| Make a subclass of CommaNode to provide the correct precedence for each expression in |
| a variable declaration list. |
| |
| * kjs/grammar.y: |
| * kjs/nodes.h: |
| (KJS::VarDeclCommaNode::): |
| |
| 2008-02-08 Darin Adler <darin@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=17247 |
| Labelled continue/break can fail in some cases |
| |
| Test: fast/js/continue-break-multiple-labels.html |
| |
| * kjs/nodes.h: |
| (KJS::StatementNode::pushLabel): Made this virtual. |
| (KJS::LabelNode::pushLabel): Forward pushLabel calls to the statement inside. |
| |
| 2008-02-08 Darin Adler <darin@apple.com> |
| |
| Reviewed by Eric. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=15003 |
| Function.prototype.constructor should not be DontDelete/ReadOnly (Acid3 bug) |
| |
| Test: fast/js/constructor-attributes.html |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::reset): Remove unwanted attributes from "constructor". |
| * kjs/function_object.cpp: |
| (KJS::FunctionObjectImp::construct): Ditto. |
| * kjs/nodes.cpp: |
| (KJS::FuncDeclNode::makeFunction): Ditto. |
| (KJS::FuncExprNode::evaluate): Ditto. |
| |
| 2008-02-06 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Added an ASSERT to catch refCount underflow, since it caused a leak in |
| my last check-in. |
| |
| * wtf/RefCounted.h: |
| (WTF::RefCounted::deref): |
| |
| 2008-02-06 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| PLT speedup related to <rdar://problem/5659272> REGRESSION: PLT .4% |
| slower due to r28884 (global variable symbol table optimization) |
| |
| Tweaked RefCounted::deref() to be a little more efficient. |
| |
| 1% - 1.5% speedup on my machine. .7% speedup on Stephanie's machine. |
| |
| * wtf/RefCounted.h: |
| (WTF::RefCounted::deref): Don't modify m_refCount if we're just going |
| to delete the object anyway. Also, use a simple == test, which might be |
| faster than <= on some hardware. |
| |
| 2008-02-06 Darin Adler <darin@apple.com> |
| |
| Reviewed by Sam. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=17094 |
| Array.prototype functions create length properties with DontEnum/DontDelete |
| |
| Test results match Gecko with very few obscure exceptions that seem to be |
| bugs in Gecko. |
| |
| Test: fast/js/array-functions-non-arrays.html |
| |
| * kjs/array_object.cpp: |
| (KJS::arrayProtoFuncConcat): Removed DontEnum and DontDelete from the call |
| to set length. |
| (KJS::arrayProtoFuncPop): Ditto. Also added missing call to deleteProperty, |
| which is not needed for real arrays, but is needed for non-arrays. |
| (KJS::arrayProtoFuncPush): Ditto. |
| (KJS::arrayProtoFuncShift): Ditto. |
| (KJS::arrayProtoFuncSlice): Ditto. |
| (KJS::arrayProtoFuncSort): Removed incorrect call to set length when |
| the array has no elements. |
| (KJS::arrayProtoFuncSplice): Removed DontEnum and DontDelete from the call |
| to set length. |
| (KJS::arrayProtoFuncUnShift): Ditto. Also added a check for 0 arguments to |
| make behavior match the specification in that case. |
| * kjs/nodes.cpp: |
| (KJS::ArrayNode::evaluate): Removed DontEnum and DontDelete from the call |
| to set length. |
| |
| 2008-02-06 Darin Adler <darin@apple.com> |
| |
| Reviewed by Sam. |
| |
| - replace calls to put to set up properties with calls to putDirect, to |
| prepare for a future change where put won't take attributes any more, |
| and for a slight performance boost |
| |
| * API/JSObjectRef.cpp: |
| (JSObjectMakeConstructor): Use putDirect instead of put. |
| * kjs/CommonIdentifiers.h: Removed lastIndex. |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::reset): Use putDirect instead of put. |
| * kjs/array_object.cpp: |
| (KJS::arrayProtoFuncConcat): Took out extra call to get length (unused). |
| (KJS::ArrayObjectImp::ArrayObjectImp): Use putDirect instead of put. |
| * kjs/error_object.cpp: |
| (KJS::ErrorPrototype::ErrorPrototype): Use putDirect instead of put. |
| * kjs/function.cpp: |
| (KJS::Arguments::Arguments): Use putDirect instead of put. |
| (KJS::PrototypeFunction::PrototypeFunction): Use putDirect instead of put. |
| * kjs/function_object.cpp: |
| (KJS::FunctionObjectImp::construct): Use putDirect instead of put. |
| * kjs/nodes.cpp: |
| (KJS::FuncDeclNode::makeFunction): Use putDirect instead of put. |
| (KJS::FuncExprNode::evaluate): Use putDirect instead of put. |
| * kjs/regexp_object.cpp: |
| (KJS::regExpProtoFuncCompile): Use setLastIndex instead of put(lastIndex). |
| (KJS::RegExpImp::match): Get and set lastIndex by using m_lastIndex instead of |
| calling get and put. |
| * kjs/regexp_object.h: |
| (KJS::RegExpImp::setLastIndex): Added. |
| * kjs/string_object.cpp: |
| (KJS::stringProtoFuncMatch): Use setLastIndex instead of put(lastIndex). |
| |
| 2008-02-05 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Anders Carlsson. |
| |
| Fix for http://bugs.webkit.org/show_bug.cgi?id=8080 |
| NodeList (and other DOM lists) items are not enumeratable using for..in |
| |
| * JavaScriptCore.exp: |
| |
| 2008-02-05 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Update versioning to support the mysterious future. |
| |
| * Configurations/Version.xcconfig: Add SYSTEM_VERSION_PREFIX_1060. |
| |
| 2008-02-04 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fixes Bug 16889: REGRESSION (r29425): Canvas-based graphing calculator fails to run |
| Bug 17015: REGRESSION (r29414-29428): www.fox.com "shows" menu fails to render |
| Bug 17164: REGRESSION: JavaScript pop-up menu appears at wrong location when hovering image at http://news.chinatimes.com/ |
| |
| <http://bugs.webkit.org/show_bug.cgi?id=16889> |
| <rdar://problem/5696255> |
| |
| <http://bugs.webkit.org/show_bug.cgi?id=17015> |
| |
| <http://bugs.webkit.org/show_bug.cgi?id=17164> |
| <rdar://problem/5720947> |
| |
| The ActivationImp tear-off (r29425) introduced a problem with ReadModify |
| nodes that first resolve a slot, call valueForReadModifyNode(), and then |
| store a value in the previously resolved slot. Since valueForReadModifyNode() |
| may cause a tear-off, the slot needs to be resolved again, but this was |
| not happening with the existing code. |
| |
| * kjs/nodes.cpp: |
| (KJS::ReadModifyLocalVarNode::evaluate): |
| (KJS::ReadModifyResolveNode::evaluate): |
| |
| 2008-02-04 Cameron McCormack <cam@mcc.id.au> |
| |
| Reviewed by Geoff Garen. |
| |
| Remove some unneccesary UNUSED_PARAMs. Clarify ownership rule of return value of JSObjectCopyPropertyNames. |
| |
| * API/JSNode.c: |
| (JSNode_appendChild): |
| (JSNode_removeChild): |
| (JSNode_replaceChild): |
| (JSNode_getNodeType): |
| (JSNode_getFirstChild): |
| * API/JSNodeList.c: |
| (JSNodeList_length): |
| * API/JSObjectRef.h: |
| |
| 2008-02-04 Rodney Dawes <dobey@wayofthemonkey.com> |
| |
| Reviewed by Alp Toker and Mark Rowe. |
| |
| Fix http://bugs.webkit.org/show_bug.cgi?id=17175. |
| Bug 17175: Use of C++ compiler flags in CFLAGS |
| |
| * GNUmakefile.am: Use global_cxxflags as well as global_cflags in CXXFLAGS. |
| |
| 2008-02-04 Alp Toker <alp@atoker.com> |
| |
| Rubber-stamped by Mark Rowe. |
| |
| Remove all trailing whitespace in the GTK+ port and related |
| components. |
| |
| * GNUmakefile.am: |
| |
| 2008-02-02 Darin Adler <darin@apple.com> |
| |
| Reviewed by Geoff Garen. |
| |
| PLT speedup related to <rdar://problem/5659272> REGRESSION: PLT .4% |
| slower due to r28884 (global variable symbol table optimization) |
| |
| Geoff's theory is that the slowdown was due to copying hash tables when |
| putting things into the back/forward cache. If that's true, then this |
| should fix the problem. |
| |
| (According to Geoff's measurements, in a PLT that exaggerates the |
| importance of symbol table saving during cached page creation, this |
| patch is a ~3X speedup in cached page creation, and a 9% speedup overall.) |
| |
| * JavaScriptCore.exp: Updated. |
| |
| * kjs/JSVariableObject.cpp: |
| (KJS::JSVariableObject::saveLocalStorage): Updated for changes to SavedProperty, |
| which has been revised to avoid initializing each SavedProperty twice when building |
| the array. Store the property names too, so we don't have to store the symbol table |
| separately. Do this by iterating the symbol table instead of the local storage vector. |
| (KJS::JSVariableObject::restoreLocalStorage): Ditto. Restore the symbol table as |
| well as the local storage vector. |
| |
| * kjs/JSVariableObject.h: Removed save/restoreSymbolTable and do that work inside |
| save/restoreLocalStorage instead. Made restoreLocalStorage a non-const member function |
| that takes a const reference to a SavedProperties object. |
| |
| * kjs/LocalStorage.h: Changed attributes to be unsigned instead of int to match |
| other declarations of attributes elsewhere. |
| |
| * kjs/property_map.cpp: |
| (KJS::SavedProperties::SavedProperties): Updated for data member name change. |
| (KJS::PropertyMap::save): Updated for data member name change and to use the new |
| inline init function instead of setting the fields directly. This allows us to |
| skip initializing the SavedProperty objects when first allocating the array, and |
| just do it when we're actually setting up the individual elements. |
| (KJS::PropertyMap::restore): Updated for SavedProperty changes. |
| |
| * kjs/property_map.h: Changed SavedProperty from a struct to a class. Set it up so |
| it does not get initialized at construction time to avoid initializing twice when |
| creating an array of SavedProperty. Removed the m_ prefixes from the members of |
| the SavedProperties struct. Generally we use m_ for class members and not struct. |
| |
| 2008-02-02 Tony Chang <idealisms@gmail.com> |
| |
| Reviewed by darin. Landed by eseidel. |
| |
| Add #define guards for WIN32_LEAN_AND_MEAN and _CRT_RAND_S. |
| |
| * kjs/config.h: |
| * wtf/FastMalloc.cpp: |
| * wtf/TCSpinLock.h: |
| |
| 2008-01-28 Sam Weinig <sam@webkit.org> |
| |
| Rubber-stamped by Darin Adler. |
| |
| - Fix whitespace in nodes.h/cpp and nodes2string.cpp. |
| |
| (NOTE: Specific changed functions elided for space and clarity) |
| * kjs/nodes.cpp: |
| * kjs/nodes.h: |
| * kjs/nodes2string.cpp: |
| |
| 2008-01-27 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Oliver Hunt. |
| |
| Patch for http://bugs.webkit.org/show_bug.cgi?id=17025 |
| nodes.h/cpp has been rolling around in the mud - lets hose it down |
| |
| - Rename member variables to use the m_ prefix. |
| |
| (NOTE: Specific changed functions elided for space and clarity) |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| * kjs/nodes.h: |
| * kjs/nodes2string.cpp: |
| |
| 2008-01-27 Darin Adler <darin@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fix <rdar://problem/5657450> REGRESSION: const is broken |
| |
| Test: fast/js/const.html |
| |
| SunSpider said this was 0.3% slower. And I saw some Shark samples in |
| JSGlobalObject::put -- not a lot but a few. We may be able to regain the |
| speed, but for now we will take that small hit for correctness sake. |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::put): Pass the checkReadOnly flag in to symbolTablePut |
| instead of passing attributes. |
| |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::symbolTablePut): Removed the code to set attributes |
| here, since we only set attributes when creating a property. Added the code |
| to check read-only here, since we need that to implement const! |
| |
| * kjs/function.cpp: |
| (KJS::ActivationImp::put): Pass the checkReadOnly flag in to symbolTablePut |
| instead of passing attributes. |
| |
| * kjs/nodes.cpp: |
| (KJS::isConstant): Added. |
| (KJS::PostIncResolveNode::optimizeVariableAccess): Create a PostIncConstNode |
| if optimizing for a local variable and the variable is constant. |
| (KJS::PostDecResolveNode::optimizeVariableAccess): Ditto. But PostDecConstNode. |
| (KJS::PreIncResolveNode::optimizeVariableAccess): Ditto. But PreIncConstNode. |
| (KJS::PreDecResolveNode::optimizeVariableAccess): Ditto. But PreDecConstNode. |
| (KJS::PreIncConstNode::evaluate): Return the value + 1. |
| (KJS::PreDecConstNode::evaluate): Return the value - 1. |
| (KJS::PostIncConstNode::evaluate): Return the value converted to a number. |
| (KJS::PostDecConstNode::evaluate): Ditto. |
| (KJS::ReadModifyResolveNode::optimizeVariableAccess): Create a ReadModifyConstNode |
| if optimizing for a local variable and the variable is constant. |
| (KJS::AssignResolveNode::optimizeVariableAccess): Ditto. But AssignConstNode. |
| (KJS::ScopeNode::optimizeVariableAccess): Pass the local storage to the |
| node optimizeVariableAccess functions, since that's where we need to look to |
| figure out if a variable is constant. |
| (KJS::FunctionBodyNode::processDeclarations): Moved the call to |
| optimizeVariableAccess until after localStorage is set up. |
| (KJS::ProgramNode::processDeclarations): Ditto. |
| |
| * kjs/nodes.h: Fixed the IsConstant and HasInitializer values. They are used |
| as flag masks, so a value of 0 will not work for IsConstant. Changed the |
| first parameter to optimizeVariableAccess to be a const reference to a symbol |
| table and added a const reference to local storage. Added classes for const |
| versions of local variable access: PostIncConstNode, PostDecConstNode, |
| PreIncConstNode, PreDecConstNode, ReadModifyConstNode, and AssignConstNode. |
| |
| * kjs/object.cpp: |
| (KJS::JSObject::put): Tweaked comments a bit, and changed the checkReadOnly |
| expression to match the form used at the two other call sites. |
| |
| 2008-01-27 Darin Adler <darin@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=16498 |
| ''.constructor.toString() gives [function] |
| |
| Test: fast/js/function-names.html |
| |
| * kjs/array_object.cpp: |
| (KJS::ArrayObjectImp::ArrayObjectImp): Use the class name as the constructor's function name. |
| * kjs/bool_object.cpp: |
| (KJS::BooleanObjectImp::BooleanObjectImp): Ditto. |
| * kjs/date_object.cpp: |
| (KJS::DateObjectImp::DateObjectImp): Ditto. |
| * kjs/error_object.cpp: |
| (KJS::ErrorPrototype::ErrorPrototype): Make the error object be an Error. |
| (KJS::ErrorObjectImp::ErrorObjectImp): Use the class name as the constructor's function name. |
| (KJS::NativeErrorPrototype::NativeErrorPrototype): Take const UString&. |
| (KJS::NativeErrorImp::NativeErrorImp): Use the prototype's name as the constructor's function |
| name. |
| * kjs/error_object.h: Change ErrorPrototype to inherit from ErrorInstance. Change the |
| NativeErrorImp constructor to take a NativeErrorPrototype pointer for its prototype. |
| * kjs/function.h: Removed unneeded constructor for internal functions without names. |
| We want to avoid those! |
| * kjs/function_object.cpp: |
| (KJS::functionProtoFuncToString): Removed code that writes out just [function] for functions |
| that have no names. There's no reason to do that. |
| (KJS::FunctionObjectImp::FunctionObjectImp): Use the class name as the constructor's |
| function name. |
| * kjs/internal.cpp: Removed the unused constructor. |
| * kjs/number_object.cpp: |
| (KJS::fractionalPartToString): Marked static for internal linkage. |
| (KJS::exponentialPartToString): Ditto. |
| (KJS::numberProtoFuncToPrecision): Removed an unneeded else. |
| (KJS::NumberObjectImp::NumberObjectImp): Use the class name as the constructor's |
| function name. |
| (KJS::NumberObjectImp::getValueProperty): Tweaked formatting. |
| * kjs/object_object.cpp: |
| (KJS::ObjectObjectImp::ObjectObjectImp): Use "Object" for the function name. |
| * kjs/regexp_object.cpp: |
| (KJS::RegExpObjectImp::RegExpObjectImp): Use "RegExp" for the function name. |
| * kjs/string_object.cpp: |
| (KJS::StringObjectImp::StringObjectImp): Use the class name as the constructor's |
| function name. |
| |
| 2008-01-26 Darin Adler <darin@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=17027 |
| Incorrect Function.toString behaviour with read/modify/write operators performed on negative numbers |
| |
| Test: fast/js/function-toString-parentheses.html |
| |
| The problem here was that a NumberNode with a negative number in it had the wrong |
| precedence. It's not a primary expression, it's a unary operator with a primary |
| expression after it. |
| |
| Once the precedence of NumberNode was fixed, the cases from bug 17020 were also |
| fixed without trying to treat bracket nodes like dot nodes. That wasn't needed. |
| The reason we handle numbers before dot nodes specially is that the dot is a |
| legal character in a number. The same is not true of a bracket. Eventually we |
| could get smarter, and only add the parentheses when there is actual ambiguity. |
| There is none if the string form of the number already has a dot in it, or if |
| it's a number with a alphabetic name like infinity or NAN. |
| |
| * kjs/nodes.h: Renamed back from ObjectAccess to DotExpr. |
| (KJS::NumberNode::precedence): Return PrecUnary for negative numbers, since |
| they serialize as a unary operator, not a primary expression. |
| * kjs/nodes2string.cpp: |
| (KJS::SourceStream::operator<<): Clear m_numberNeedsParens if this adds |
| parens; one set is enough. |
| (KJS::bracketNodeStreamTo): Remove unneeded special flag here. Normal |
| operator precedence suffices. |
| (KJS::NewExprNode::streamTo): Ditto. |
| |
| 2008-01-26 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej and Darin. |
| |
| Fix for http://bugs.webkit.org/show_bug.cgi?id=17020 |
| Function.toString does not parenthesise numbers for the bracket accessor |
| |
| It turns out that logic was there for all of the dot accessor nodes to make numbers be |
| parenthesised properly, so it was a trivial extension to extend that to the bracket nodes. |
| I renamed the enum type to reflect the fact that it is now used for both dot and bracket |
| accessors. |
| |
| * kjs/nodes2string.cpp: |
| (KJS::bracketNodeStreamTo): |
| (KJS::BracketAccessorNode::streamTo): |
| |
| 2008-01-26 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Darin. |
| |
| Fix Bug 17018: Incorrect code generated from Function.toString for get/setters in object literals |
| |
| Don't quote getter and setter names during output, as that is simply wrong. |
| |
| * kjs/nodes2string.cpp: |
| (KJS::PropertyNode::streamTo): |
| |
| 2008-01-26 Darin Adler <darin@apple.com> |
| |
| Reviewed by Eric Seidel. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=16860 |
| a bit of cleanup after the Activation optimization |
| |
| * JavaScriptCore.exp: Export the GlobalExecState constructor instead of |
| the global flavor of the ExecState constructor. It'd probably be cleaner |
| to not export either one, but JSGlobalObject inlines the code that |
| constructs the ExecState. If we changed that, we could remove this export. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: Re-sorted a few things and |
| put the new source files into the kjs group rather than at the top level. |
| |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::ExecState): Marked inline and updated for data member |
| name changes. This is now only for use for the derived classes. Also removed |
| code that sets the unused m_savedExec data member for the global case. That |
| data member is only used for the other two types. |
| (KJS::ExecState::~ExecState): Marked inline and removed all the code. |
| The derived class destructors now inclde the appropriate code. |
| (KJS::ExecState::lexicalGlobalObject): Removed unneeded special case for |
| an empty scope chain. The bottom function already returns 0 for that case, |
| so the general case code handles it fine. Also changed to use data members |
| directly rather than calling functions. |
| (KJS::GlobalExecState::GlobalExecState): Added. Calls through to the base |
| class constructor. |
| (KJS::GlobalExecState::~GlobalExecState): Added. |
| (KJS::InterpreterExecState::InterpreterExecState): Added. Moved code to |
| manipulate activeExecStates here since we don't want to have to check for the |
| special case of globalExec. |
| (KJS::InterpreterExecState::~InterpreterExecState): Added. |
| (KJS::EvalExecState::EvalExecState): Added. |
| (KJS::EvalExecState::~EvalExecState): Added. |
| (KJS::FunctionExecState::FunctionExecState): Added. |
| (KJS::FunctionExecState::~FunctionExecState): Added. |
| |
| * kjs/ExecState.h: Tweaked the header, includes, and declarations a bit. |
| Made ExecState inherit from Noncopyable. Reformatted some comments and |
| made them a bit more brief. Rearranged declarations a little bit and removed |
| unused savedExec function. Changed seenLabels function to return a reference |
| rather than a pointer. Made constructors and destructor protected, and also |
| did the same with all data members. Renamed m_thisVal to m_thisValue and |
| ls to m_labelStack. Added three new derived classes for each of the |
| types of ExecState. The primary goal here was to remove a branch from the |
| code in the destructor, but it's also clearer than overloading the arguments |
| to the ExecState constructor. |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::getCurrentTime): Fixed formatting. |
| (KJS::JSGlobalObject::pushActivation): Removed parentheses that don't make |
| the expression clearer -- other similar sites didn't have these parentheses, |
| even the one a couple lines earlier that sets stackEntry. |
| (KJS::JSGlobalObject::tearOffActivation): Got rid of unneeded static_cast |
| (I think I mentioned this during patch review) and used an early exit so that |
| the entire contents of the function aren't nested inside an if statement. |
| Also removed the check of codeType, instead checking Activation for 0. |
| For now, I kept the codeType check, but inside an assertion. |
| |
| * kjs/JSGlobalObject.h: Changed type of globalExec to GlobalExecState. |
| * kjs/function.cpp: |
| (KJS::FunctionImp::callAsFunction): Changed type to FunctionExecState. |
| (KJS::GlobalFuncImp::callAsFunction): Changed type to EvalExecState. |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::evaluate): Changed type to GlobalExecState. |
| |
| * kjs/nodes.cpp: |
| (KJS::ContinueNode::execute): Changed code since seenLabels() returns a |
| reference now instead of a pointer. |
| (KJS::BreakNode::execute): Ditto. |
| (KJS::LabelNode::execute): Ditto. |
| |
| 2008-01-26 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Mark Rowe. |
| |
| Cleanup node2string a little. |
| - Remove some unnecessary branching. |
| - Factor out bracket and dot streaming into static inline functions. |
| |
| * kjs/nodes.h: |
| * kjs/nodes2string.cpp: |
| (KJS::bracketNodeStreamTo): |
| (KJS::dotNodeStreamTo): |
| (KJS::FunctionCallBracketNode::streamTo): |
| (KJS::FunctionCallDotNode::streamTo): |
| (KJS::PostIncBracketNode::streamTo): |
| (KJS::PostDecBracketNode::streamTo): |
| (KJS::PostIncDotNode::streamTo): |
| (KJS::PostDecDotNode::streamTo): |
| (KJS::DeleteBracketNode::streamTo): |
| (KJS::DeleteDotNode::streamTo): |
| (KJS::PreIncBracketNode::streamTo): |
| (KJS::PreDecBracketNode::streamTo): |
| (KJS::PreIncDotNode::streamTo): |
| (KJS::PreDecDotNode::streamTo): |
| (KJS::ReadModifyBracketNode::streamTo): |
| (KJS::AssignBracketNode::streamTo): |
| (KJS::ReadModifyDotNode::streamTo): |
| (KJS::AssignDotNode::streamTo): |
| (KJS::WhileNode::streamTo): |
| |
| 2008-01-26 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Fix http://bugs.webkit.org/show_bug.cgi?id=17001 |
| Bug 17001: Build error with Gtk port on Mac OS X |
| |
| If both XP_MACOSX and XP_UNIX are defined then X11.h and Carbon.h will both be included. |
| These provide conflicting definitions for a type named 'Cursor'. As XP_UNIX is set by |
| the build system when targeting X11, it doesn't make sense for XP_MACOSX to also be set |
| in this instance. |
| |
| * bindings/npapi.h: Don't define XP_MACOSX if XP_UNIX is defined. |
| |
| 2008-01-26 Darin Adler <darin@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=17013 |
| JSC can't round trip certain for-loops |
| |
| Test: fast/js/toString-for-var-decl.html |
| |
| * kjs/nodes.h: Added PlaceholderTrueNode so we can put nodes into |
| for loops without injecting the word "true" into them (nice, but not |
| the bug fix). Fixed ForNode constructor so expr1WasVarDecl is set |
| only when there is an expression, since it's common for the actual |
| variable declaration to be moved by the parser. |
| |
| * kjs/nodes2string.cpp: |
| (KJS::PlaceholderTrueNode::streamTo): Added. Empty. |
| |
| 2008-01-25 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Fix for bug 17012: REGRESSION: JSC can't round trip an object literal |
| |
| Add logic to ensure that object literals and function expressions get |
| parentheses when necessary. |
| |
| * kjs/nodes.h: |
| * kjs/nodes2string.cpp: |
| (KJS::SourceStream::operator<<): |
| |
| 2008-01-24 Steve Falkenburg <sfalken@apple.com> |
| |
| Build fix. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore.sln: |
| |
| 2008-01-24 Steve Falkenburg <sfalken@apple.com> |
| |
| Build fix. |
| |
| * JavaScriptCore.vcproj/JavaScriptCoreSubmit.sln: |
| |
| 2008-01-24 Michael Goddard <michael.goddard@trolltech.com> |
| |
| Reviewed by Simon. |
| |
| Fix QDateTime to JS Date conversion. |
| Several conversion errors (some UTC related, some month |
| offset related) and the conversion distance for Date |
| to DateTime conversion weights were fixed (it should never |
| be better to convert a JS Number into a Date rather than |
| an int). |
| |
| * bindings/qt/qt_runtime.cpp: |
| (KJS::Bindings::convertValueToQVariant): |
| (KJS::Bindings::convertQVariantToValue): |
| |
| 2008-01-24 Michael Goddard <michael.goddard@trolltech.com> |
| |
| Reviewed by Simon. |
| |
| Add support for calling QObjects. |
| Add support for invokeDefaultMethod (via a call to |
| a specific slot), and also allow using it as a |
| constructor, like QtScript. |
| |
| |
| * bindings/qt/qt_class.cpp: |
| (KJS::Bindings::QtClass::fallbackObject): |
| * bindings/qt/qt_instance.cpp: |
| (KJS::Bindings::QtRuntimeObjectImp::construct): |
| (KJS::Bindings::QtInstance::QtInstance): |
| (KJS::Bindings::QtInstance::~QtInstance): |
| (KJS::Bindings::QtInstance::implementsCall): |
| (KJS::Bindings::QtInstance::invokeDefaultMethod): |
| * bindings/qt/qt_instance.h: |
| * bindings/qt/qt_runtime.cpp: |
| (KJS::Bindings::findMethodIndex): |
| (KJS::Bindings::QtRuntimeMetaMethod::QtRuntimeMetaMethod): |
| (KJS::Bindings::QtRuntimeMetaMethod::callAsFunction): |
| * bindings/qt/qt_runtime.h: |
| |
| 2008-01-24 Michael Goddard <michael.goddard@trolltech.com> |
| |
| Reviewed by Simon. |
| |
| Code style cleanups. |
| Add spaces before/after braces in inline function. |
| |
| * bindings/qt/qt_instance.h: |
| |
| 2008-01-24 Michael Goddard <michael.goddard@trolltech.com> |
| |
| Reviewed by Simon. |
| |
| Code style cleanups. |
| Remove spaces and unneeded declared parameter names. |
| |
| * bindings/qt/qt_instance.cpp: |
| (KJS::Bindings::QtRuntimeObjectImp::removeFromCache): |
| |
| 2008-01-24 Michael Goddard <michael.goddard@trolltech.com> |
| |
| Reviewed by Simon. |
| |
| Clear stale RuntimeObjectImps. |
| Since other objects can have refs to the QtInstance, |
| we can't rely on the QtInstance being deleted when the |
| RuntimeObjectImp is invalidate or deleted. This |
| could result in a stale JSObject being returned for |
| a valid Instance. |
| |
| * bindings/qt/qt_instance.cpp: |
| (KJS::Bindings::QtRuntimeObjectImp::QtRuntimeObjectImp): |
| (KJS::Bindings::QtRuntimeObjectImp::~QtRuntimeObjectImp): |
| (KJS::Bindings::QtRuntimeObjectImp::invalidate): |
| (KJS::Bindings::QtRuntimeObjectImp::removeFromCache): |
| (KJS::Bindings::QtInstance::getRuntimeObject): |
| * bindings/runtime.cpp: |
| (KJS::Bindings::Instance::createRuntimeObject): |
| * bindings/runtime.h: |
| |
| 2008-01-23 Alp Toker <alp@atoker.com> |
| |
| Rubber-stamped by Mark Rowe. |
| |
| Remove whitespace after -I in automake include lists. |
| |
| * GNUmakefile.am: |
| |
| 2008-01-23 Michael Goddard <michael.goddard@trolltech.com> |
| |
| Reviewed by Lars Knoll <lars@trolltech.com>. |
| |
| Reworked the JavaScriptCore Qt bindings: |
| |
| * Add initial support for string and variant arrays, as well |
| as sub QObjects in the JS bindings. |
| |
| * Don't expose fields marked as not scriptable by moc. |
| |
| * Add support for dynamic properties and accessing named |
| QObject children of an object (like QtScript and older |
| IE DOM style JS). |
| * Add support for custom toString methods. |
| |
| * Fine tune some bindings to be closer to QtScript. |
| Make void functions return undefined, and empty/ |
| null QStrings return a zero length string. |
| |
| * Create framework for allowing more direct method calls. |
| Since RuntimeMethod doesn't allow us to add additional |
| methods/properties to a function, add these classes. |
| Start prototyping object.signal.connect(...). |
| |
| * Add signal support to the Qt bindings. |
| Allow connecting to signals (object.signal.connect(slot)), |
| disconnecting, and emitting signals. Currently chooses |
| the first signal that matches the name, so this will need |
| improvement. |
| |
| * Add property names, and resolve signals closer to use. |
| Enumerating properties now returns some of the Qt properties |
| and signals. Slots and methods aren't quite present. Also, |
| resolve signal connections etc. closer to the time of use, so |
| we can do more dynamic resolution based on argument type etc. |
| Still picks the first one with the same name, at the moment. |
| |
| * Make signature comparison code consistent. |
| Use the same code for checking meta signatures in |
| the method and fallback getters, and avoid a |
| QByteArray construction when we can. |
| |
| * Fix minor memory leak, and handle pointers better. |
| Delete the private object in the dtors, and use RefPtrs |
| for holding Instances etc. |
| |
| * Handle method lookup better. |
| Allow invocation time method lookup based on the arguments, |
| which is closer to QtScript behaviour. Also, cache the |
| method lists and delete them in the QtClass dtor (stops |
| a memory leak). |
| |
| * Improve JS to Qt data type conversions. |
| Add some support for Date & RegExp JS objects, |
| and provide some metrics on the quality of the |
| conversion. |
| |
| * A couple of fixes for autotest failures. |
| Better support for converting lists, read/write only |
| QMetaProperty support, modified slot search order...) |
| |
| * bindings/qt/qt_class.cpp: |
| (KJS::Bindings::QtClass::QtClass): |
| (KJS::Bindings::QtClass::~QtClass): |
| (KJS::Bindings::QtClass::name): |
| (KJS::Bindings::QtClass::fallbackObject): |
| (KJS::Bindings::QtClass::methodsNamed): |
| (KJS::Bindings::QtClass::fieldNamed): |
| * bindings/qt/qt_class.h: |
| * bindings/qt/qt_instance.cpp: |
| (KJS::Bindings::QtInstance::QtInstance): |
| (KJS::Bindings::QtInstance::~QtInstance): |
| (KJS::Bindings::QtInstance::getRuntimeObject): |
| (KJS::Bindings::QtInstance::getClass): |
| (KJS::Bindings::QtInstance::implementsCall): |
| (KJS::Bindings::QtInstance::getPropertyNames): |
| (KJS::Bindings::QtInstance::invokeMethod): |
| (KJS::Bindings::QtInstance::invokeDefaultMethod): |
| (KJS::Bindings::QtInstance::stringValue): |
| (KJS::Bindings::QtInstance::booleanValue): |
| (KJS::Bindings::QtInstance::valueOf): |
| (KJS::Bindings::QtField::name): |
| (KJS::Bindings::QtField::valueFromInstance): |
| (KJS::Bindings::QtField::setValueToInstance): |
| * bindings/qt/qt_instance.h: |
| (KJS::Bindings::QtInstance::getBindingLanguage): |
| (KJS::Bindings::QtInstance::getObject): |
| * bindings/qt/qt_runtime.cpp: |
| (KJS::Bindings::QWKNoDebug::QWKNoDebug): |
| (KJS::Bindings::QWKNoDebug::~QWKNoDebug): |
| (KJS::Bindings::QWKNoDebug::operator<<): |
| (KJS::Bindings::): |
| (KJS::Bindings::valueRealType): |
| (KJS::Bindings::convertValueToQVariant): |
| (KJS::Bindings::convertQVariantToValue): |
| (KJS::Bindings::QtRuntimeMethod::QtRuntimeMethod): |
| (KJS::Bindings::QtRuntimeMethod::~QtRuntimeMethod): |
| (KJS::Bindings::QtRuntimeMethod::codeType): |
| (KJS::Bindings::QtRuntimeMethod::execute): |
| (KJS::Bindings::QtRuntimeMethodData::~QtRuntimeMethodData): |
| (KJS::Bindings::QtRuntimeMetaMethodData::~QtRuntimeMetaMethodData): |
| (KJS::Bindings::QtRuntimeConnectionMethodData::~QtRuntimeConnectionMethodData): |
| (KJS::Bindings::QtMethodMatchType::): |
| (KJS::Bindings::QtMethodMatchType::QtMethodMatchType): |
| (KJS::Bindings::QtMethodMatchType::kind): |
| (KJS::Bindings::QtMethodMatchType::isValid): |
| (KJS::Bindings::QtMethodMatchType::isVariant): |
| (KJS::Bindings::QtMethodMatchType::isMetaType): |
| (KJS::Bindings::QtMethodMatchType::isUnresolved): |
| (KJS::Bindings::QtMethodMatchType::isMetaEnum): |
| (KJS::Bindings::QtMethodMatchType::enumeratorIndex): |
| (KJS::Bindings::QtMethodMatchType::variant): |
| (KJS::Bindings::QtMethodMatchType::metaType): |
| (KJS::Bindings::QtMethodMatchType::metaEnum): |
| (KJS::Bindings::QtMethodMatchType::unresolved): |
| (KJS::Bindings::QtMethodMatchType::typeId): |
| (KJS::Bindings::QtMethodMatchType::name): |
| (KJS::Bindings::QtMethodMatchData::QtMethodMatchData): |
| (KJS::Bindings::QtMethodMatchData::isValid): |
| (KJS::Bindings::QtMethodMatchData::firstUnresolvedIndex): |
| (KJS::Bindings::indexOfMetaEnum): |
| (KJS::Bindings::findMethodIndex): |
| (KJS::Bindings::findSignalIndex): |
| (KJS::Bindings::QtRuntimeMetaMethod::QtRuntimeMetaMethod): |
| (KJS::Bindings::QtRuntimeMetaMethod::mark): |
| (KJS::Bindings::QtRuntimeMetaMethod::callAsFunction): |
| (KJS::Bindings::QtRuntimeMetaMethod::getOwnPropertySlot): |
| (KJS::Bindings::QtRuntimeMetaMethod::lengthGetter): |
| (KJS::Bindings::QtRuntimeMetaMethod::connectGetter): |
| (KJS::Bindings::QtRuntimeMetaMethod::disconnectGetter): |
| (KJS::Bindings::QtRuntimeConnectionMethod::QtRuntimeConnectionMethod): |
| (KJS::Bindings::QtRuntimeConnectionMethod::callAsFunction): |
| (KJS::Bindings::QtRuntimeConnectionMethod::getOwnPropertySlot): |
| (KJS::Bindings::QtRuntimeConnectionMethod::lengthGetter): |
| (KJS::Bindings::QtConnectionObject::QtConnectionObject): |
| (KJS::Bindings::QtConnectionObject::~QtConnectionObject): |
| (KJS::Bindings::QtConnectionObject::metaObject): |
| (KJS::Bindings::QtConnectionObject::qt_metacast): |
| (KJS::Bindings::QtConnectionObject::qt_metacall): |
| (KJS::Bindings::QtConnectionObject::execute): |
| (KJS::Bindings::QtConnectionObject::match): |
| (KJS::Bindings::::QtArray): |
| (KJS::Bindings::::~QtArray): |
| (KJS::Bindings::::rootObject): |
| (KJS::Bindings::::setValueAt): |
| (KJS::Bindings::::valueAt): |
| * bindings/qt/qt_runtime.h: |
| (KJS::Bindings::QtField::): |
| (KJS::Bindings::QtField::QtField): |
| (KJS::Bindings::QtField::fieldType): |
| (KJS::Bindings::QtMethod::QtMethod): |
| (KJS::Bindings::QtMethod::name): |
| (KJS::Bindings::QtMethod::numParameters): |
| (KJS::Bindings::QtArray::getLength): |
| (KJS::Bindings::QtRuntimeMethod::d_func): |
| (KJS::Bindings::QtRuntimeMetaMethod::d_func): |
| (KJS::Bindings::QtRuntimeConnectionMethod::d_func): |
| (KJS::Bindings::): |
| * bindings/runtime.cpp: |
| (KJS::Bindings::Instance::createBindingForLanguageInstance): |
| (KJS::Bindings::Instance::createRuntimeObject): |
| (KJS::Bindings::Instance::reallyCreateRuntimeObject): |
| * bindings/runtime.h: |
| |
| 2008-01-22 Anders Carlsson <andersca@apple.com> |
| |
| Reviewed by Darin and Adam. |
| |
| <rdar://problem/5688975> |
| div element on microsoft site has wrong left offset. |
| |
| Return true even if NPN_GetProperty returns null or undefined. This matches Firefox |
| (and is what the Silverlight plug-in expects). |
| |
| * bindings/NP_jsobject.cpp: |
| (_NPN_GetProperty): |
| |
| 2008-01-21 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Fixed http://bugs.webkit.org/show_bug.cgi?id=16909 |
| REGRESSION: Amazon.com crash (ActivationImp) |
| |
| (and a bunch of other crashes) |
| |
| Plus, a .7% SunSpider speedup to boot. |
| |
| Replaced the buggy currentExec and savedExec mechanisms with an |
| explicit ExecState stack. |
| |
| * kjs/collector.cpp: |
| (KJS::Collector::collect): Explicitly mark the ExecState stack. |
| |
| (KJS::Collector::reportOutOfMemoryToAllExecStates): Slight change in |
| behavior: We no longer throw an exception in any global ExecStates, |
| since global ExecStates are more like pseudo-ExecStates, and aren't |
| used for script execution. (It's unclear what would happen if you left |
| an exception waiting around in a global ExecState, but it probably |
| wouldn't be good.) |
| |
| 2008-01-21 Jan Michael Alonzo <jmalonzo@unpluggable.com> |
| |
| Reviewed by Alp Toker. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=16955 |
| Get errors when cross-compile webkit-gtk |
| |
| * GNUmakefile.am: removed ICU_CFLAGS |
| |
| 2008-01-18 Kevin McCullough <kmccullough@apple.com> |
| |
| - Build fix. |
| |
| * kjs/ustring.h: |
| |
| 2008-01-18 Kevin McCullough <kmccullough@apple.com> |
| |
| - Build fix. |
| |
| * kjs/ustring.cpp: |
| * kjs/ustring.h: |
| (KJS::UString::cost): |
| |
| 2008-01-18 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - Correctly report cost of appended strings to trigger GC. |
| |
| * kjs/ustring.cpp: |
| (KJS::UString::Rep::create): |
| (KJS::UString::UString): Don't create unnecssary objects. |
| (KJS::UString::cost): Report cost if necessary but also keep track of |
| reported cost. |
| * kjs/ustring.h: |
| |
| 2008-01-18 Simon Hausmann <hausmann@webkit.org> |
| |
| Reviewed by Holger. |
| |
| Fix return type conversions from Qt slots to JS values. |
| |
| This also fixes fast/dom/open-and-close-by-DOM.html, which called |
| layoutTestController.windowCount(). |
| |
| When constructing the QVariant that holds the return type we cannot |
| use the QVarian(Type) constuctor as that will create a null variant. |
| We have to use the QVariant(Type, void *) constructor instead, just |
| like in QMetaObject::read() for example. |
| |
| |
| * bindings/qt/qt_instance.cpp: |
| (KJS::Bindings::QtInstance::getRuntimeObject): |
| |
| 2008-01-18 Prasanth Ullattil <prasanth.ullattil@trolltech.com> |
| |
| Reviewed by Simon Hausmann <hausmann@webkit.org>. |
| |
| Fix compilation on Win64(2): Implemented currentThreadStackBase on X86-64 on Windows |
| |
| |
| * kjs/collector.cpp: |
| (KJS::Collector::heapAllocate): |
| |
| 2008-01-18 Prasanth Ullattil <prasanth.ullattil@trolltech.com> |
| |
| Reviewed by Simon Hausmann <hausmann@webkit.org>. |
| |
| Fix compilation on Win64(1): Define WTF_PLATFORM_X86_64 correctly on Win64. |
| |
| |
| * wtf/Platform.h: |
| |
| 2008-01-17 Antti Koivisto <antti@apple.com> |
| |
| Fix Windows build. |
| |
| * kjs/regexp_object.cpp: |
| (KJS::regExpProtoFuncToString): |
| |
| 2008-01-16 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Fix for http://bugs.webkit.org/show_bug.cgi?id=16901 |
| Convert remaining JS function objects to use the new PrototypeFunction class |
| |
| - Moves Boolean, Function, RegExp, Number, Object and Global functions to their |
| own static function implementations so that they can be used with the |
| PrototypeFunction class. SunSpider says this is 1.003x as fast. |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::reset): |
| * kjs/array_object.h: |
| * kjs/bool_object.cpp: |
| (KJS::BooleanInstance::BooleanInstance): |
| (KJS::BooleanPrototype::BooleanPrototype): |
| (KJS::booleanProtoFuncToString): |
| (KJS::booleanProtoFuncValueOf): |
| (KJS::BooleanObjectImp::BooleanObjectImp): |
| (KJS::BooleanObjectImp::implementsConstruct): |
| (KJS::BooleanObjectImp::construct): |
| (KJS::BooleanObjectImp::callAsFunction): |
| * kjs/bool_object.h: |
| (KJS::BooleanInstance::classInfo): |
| * kjs/error_object.cpp: |
| (KJS::ErrorPrototype::ErrorPrototype): |
| (KJS::errorProtoFuncToString): |
| * kjs/error_object.h: |
| * kjs/function.cpp: |
| (KJS::globalFuncEval): |
| (KJS::globalFuncParseInt): |
| (KJS::globalFuncParseFloat): |
| (KJS::globalFuncIsNaN): |
| (KJS::globalFuncIsFinite): |
| (KJS::globalFuncDecodeURI): |
| (KJS::globalFuncDecodeURIComponent): |
| (KJS::globalFuncEncodeURI): |
| (KJS::globalFuncEncodeURIComponent): |
| (KJS::globalFuncEscape): |
| (KJS::globalFuncUnEscape): |
| (KJS::globalFuncKJSPrint): |
| (KJS::PrototypeFunction::PrototypeFunction): |
| * kjs/function.h: |
| * kjs/function_object.cpp: |
| (KJS::FunctionPrototype::FunctionPrototype): |
| (KJS::functionProtoFuncToString): |
| (KJS::functionProtoFuncApply): |
| (KJS::functionProtoFuncCall): |
| * kjs/function_object.h: |
| * kjs/number_object.cpp: |
| (KJS::NumberPrototype::NumberPrototype): |
| (KJS::numberProtoFuncToString): |
| (KJS::numberProtoFuncToLocaleString): |
| (KJS::numberProtoFuncValueOf): |
| (KJS::numberProtoFuncToFixed): |
| (KJS::numberProtoFuncToExponential): |
| (KJS::numberProtoFuncToPrecision): |
| * kjs/number_object.h: |
| (KJS::NumberInstance::classInfo): |
| (KJS::NumberObjectImp::classInfo): |
| (KJS::NumberObjectImp::): |
| * kjs/object_object.cpp: |
| (KJS::ObjectPrototype::ObjectPrototype): |
| (KJS::objectProtoFuncValueOf): |
| (KJS::objectProtoFuncHasOwnProperty): |
| (KJS::objectProtoFuncIsPrototypeOf): |
| (KJS::objectProtoFuncDefineGetter): |
| (KJS::objectProtoFuncDefineSetter): |
| (KJS::objectProtoFuncLookupGetter): |
| (KJS::objectProtoFuncLookupSetter): |
| (KJS::objectProtoFuncPropertyIsEnumerable): |
| (KJS::objectProtoFuncToLocaleString): |
| (KJS::objectProtoFuncToString): |
| * kjs/object_object.h: |
| * kjs/regexp_object.cpp: |
| (KJS::RegExpPrototype::RegExpPrototype): |
| (KJS::regExpProtoFuncTest): |
| (KJS::regExpProtoFuncExec): |
| (KJS::regExpProtoFuncCompile): |
| (KJS::regExpProtoFuncToString): |
| * kjs/regexp_object.h: |
| |
| 2008-01-16 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej & Darin. |
| |
| Fixes Bug 16868: Gmail crash |
| and Bug 16871: Crash when loading apple.com/startpage |
| |
| <http://bugs.webkit.org/show_bug.cgi?id=16868> |
| <rdar://problem/5686108> |
| |
| <http://bugs.webkit.org/show_bug.cgi?id=16871> |
| <rdar://problem/5686670> |
| |
| Adds ActivationImp tear-off for cross-window eval() and fixes an |
| existing garbage collection issue exposed by the ActivationImp tear-off |
| patch (r29425) that can occur when an ExecState's m_callingExec is |
| different than its m_savedExec. |
| |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::mark): |
| * kjs/function.cpp: |
| (KJS::GlobalFuncImp::callAsFunction): |
| |
| 2008-01-16 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Oliver. |
| |
| Clean up MathObjectImp, it needed a little scrubbing. |
| |
| * kjs/math_object.cpp: |
| (KJS::MathObjectImp::MathObjectImp): |
| (KJS::MathObjectImp::getOwnPropertySlot): |
| (KJS::MathObjectImp::getValueProperty): |
| (KJS::mathProtoFuncACos): |
| (KJS::mathProtoFuncASin): |
| (KJS::mathProtoFuncATan): |
| (KJS::mathProtoFuncATan2): |
| (KJS::mathProtoFuncCos): |
| (KJS::mathProtoFuncExp): |
| (KJS::mathProtoFuncLog): |
| (KJS::mathProtoFuncSin): |
| (KJS::mathProtoFuncSqrt): |
| (KJS::mathProtoFuncTan): |
| * kjs/math_object.h: |
| (KJS::MathObjectImp::classInfo): |
| (KJS::MathObjectImp::): |
| |
| 2008-01-16 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Geoffrey Garen. |
| |
| Rename Lexer variable bol to atLineStart. |
| |
| * kjs/lexer.cpp: |
| (KJS::Lexer::Lexer): |
| (KJS::Lexer::setCode): |
| (KJS::Lexer::nextLine): |
| (KJS::Lexer::lex): |
| * kjs/lexer.h: |
| |
| 2008-01-16 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Geoffrey Garen and Anders Carlsson. |
| |
| Remove uses of KJS_PURE_ECMA as we don't ever build with it defined, |
| and we have many features that are not included in the ECMA spec. |
| |
| * kjs/lexer.cpp: |
| (KJS::Lexer::Lexer): |
| (KJS::Lexer::setCode): |
| (KJS::Lexer::nextLine): |
| (KJS::Lexer::lex): |
| * kjs/lexer.h: |
| * kjs/string_object.cpp: |
| * kjs/string_object.h: |
| |
| 2008-01-15 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Geoffrey Garen. |
| |
| Fix <rdar://problem/5595552> r27608 introduced a 20% increase in JS binary size, 4% increase in WebCore binary size |
| |
| - This changes the way JS functions that use Lookup tables are handled. Instead of using |
| one class per function, which allowed specialization of the virtual callAsFunction |
| method, we now use one class, PrototypeFunction, which takes a pointer to a static |
| function to use as the implementation. This significantly decreases the binary size |
| of JavaScriptCore (about 145k on an Intel only build) while still keeping some of the |
| speedup r27608 garnered (SunSpider says this is 1.005x as slow, which should leave some |
| wiggle room from the original 1% speedup) and keeps the functions implementations in separate |
| functions to help with optimizations. |
| |
| * JavaScriptCore.exp: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/array_object.cpp: |
| (KJS::arrayProtoFuncToString): |
| (KJS::arrayProtoFuncToLocaleString): |
| (KJS::arrayProtoFuncJoin): |
| (KJS::arrayProtoFuncConcat): |
| (KJS::arrayProtoFuncPop): |
| (KJS::arrayProtoFuncPush): |
| (KJS::arrayProtoFuncReverse): |
| (KJS::arrayProtoFuncShift): |
| (KJS::arrayProtoFuncSlice): |
| (KJS::arrayProtoFuncSort): |
| (KJS::arrayProtoFuncSplice): |
| (KJS::arrayProtoFuncUnShift): |
| (KJS::arrayProtoFuncFilter): |
| (KJS::arrayProtoFuncMap): |
| (KJS::arrayProtoFuncEvery): |
| (KJS::arrayProtoFuncForEach): |
| (KJS::arrayProtoFuncSome): |
| (KJS::arrayProtoFuncIndexOf): |
| (KJS::arrayProtoFuncLastIndexOf): |
| * kjs/array_object.h: |
| * kjs/date_object.cpp: |
| (KJS::DatePrototype::getOwnPropertySlot): |
| (KJS::dateProtoFuncToString): |
| (KJS::dateProtoFuncToUTCString): |
| (KJS::dateProtoFuncToDateString): |
| (KJS::dateProtoFuncToTimeString): |
| (KJS::dateProtoFuncToLocaleString): |
| (KJS::dateProtoFuncToLocaleDateString): |
| (KJS::dateProtoFuncToLocaleTimeString): |
| (KJS::dateProtoFuncValueOf): |
| (KJS::dateProtoFuncGetTime): |
| (KJS::dateProtoFuncGetFullYear): |
| (KJS::dateProtoFuncGetUTCFullYear): |
| (KJS::dateProtoFuncToGMTString): |
| (KJS::dateProtoFuncGetMonth): |
| (KJS::dateProtoFuncGetUTCMonth): |
| (KJS::dateProtoFuncGetDate): |
| (KJS::dateProtoFuncGetUTCDate): |
| (KJS::dateProtoFuncGetDay): |
| (KJS::dateProtoFuncGetUTCDay): |
| (KJS::dateProtoFuncGetHours): |
| (KJS::dateProtoFuncGetUTCHours): |
| (KJS::dateProtoFuncGetMinutes): |
| (KJS::dateProtoFuncGetUTCMinutes): |
| (KJS::dateProtoFuncGetSeconds): |
| (KJS::dateProtoFuncGetUTCSeconds): |
| (KJS::dateProtoFuncGetMilliSeconds): |
| (KJS::dateProtoFuncGetUTCMilliseconds): |
| (KJS::dateProtoFuncGetTimezoneOffset): |
| (KJS::dateProtoFuncSetTime): |
| (KJS::dateProtoFuncSetMilliSeconds): |
| (KJS::dateProtoFuncSetUTCMilliseconds): |
| (KJS::dateProtoFuncSetSeconds): |
| (KJS::dateProtoFuncSetUTCSeconds): |
| (KJS::dateProtoFuncSetMinutes): |
| (KJS::dateProtoFuncSetUTCMinutes): |
| (KJS::dateProtoFuncSetHours): |
| (KJS::dateProtoFuncSetUTCHours): |
| (KJS::dateProtoFuncSetDate): |
| (KJS::dateProtoFuncSetUTCDate): |
| (KJS::dateProtoFuncSetMonth): |
| (KJS::dateProtoFuncSetUTCMonth): |
| (KJS::dateProtoFuncSetFullYear): |
| (KJS::dateProtoFuncSetUTCFullYear): |
| (KJS::dateProtoFuncSetYear): |
| (KJS::dateProtoFuncGetYear): |
| * kjs/date_object.h: |
| * kjs/function.cpp: |
| (KJS::PrototypeFunction::PrototypeFunction): |
| (KJS::PrototypeFunction::callAsFunction): |
| * kjs/function.h: |
| * kjs/lookup.h: |
| (KJS::HashEntry::): |
| (KJS::staticFunctionGetter): |
| * kjs/math_object.cpp: |
| (KJS::mathProtoFuncAbs): |
| (KJS::mathProtoFuncACos): |
| (KJS::mathProtoFuncASin): |
| (KJS::mathProtoFuncATan): |
| (KJS::mathProtoFuncATan2): |
| (KJS::mathProtoFuncCeil): |
| (KJS::mathProtoFuncCos): |
| (KJS::mathProtoFuncExp): |
| (KJS::mathProtoFuncFloor): |
| (KJS::mathProtoFuncLog): |
| (KJS::mathProtoFuncMax): |
| (KJS::mathProtoFuncMin): |
| (KJS::mathProtoFuncPow): |
| (KJS::mathProtoFuncRandom): |
| (KJS::mathProtoFuncRound): |
| (KJS::mathProtoFuncSin): |
| (KJS::mathProtoFuncSqrt): |
| (KJS::mathProtoFuncTan): |
| * kjs/math_object.h: |
| * kjs/string_object.cpp: |
| (KJS::stringProtoFuncToString): |
| (KJS::stringProtoFuncValueOf): |
| (KJS::stringProtoFuncCharAt): |
| (KJS::stringProtoFuncCharCodeAt): |
| (KJS::stringProtoFuncConcat): |
| (KJS::stringProtoFuncIndexOf): |
| (KJS::stringProtoFuncLastIndexOf): |
| (KJS::stringProtoFuncMatch): |
| (KJS::stringProtoFuncSearch): |
| (KJS::stringProtoFuncReplace): |
| (KJS::stringProtoFuncSlice): |
| (KJS::stringProtoFuncSplit): |
| (KJS::stringProtoFuncSubstr): |
| (KJS::stringProtoFuncSubstring): |
| (KJS::stringProtoFuncToLowerCase): |
| (KJS::stringProtoFuncToUpperCase): |
| (KJS::stringProtoFuncToLocaleLowerCase): |
| (KJS::stringProtoFuncToLocaleUpperCase): |
| (KJS::stringProtoFuncLocaleCompare): |
| (KJS::stringProtoFuncBig): |
| (KJS::stringProtoFuncSmall): |
| (KJS::stringProtoFuncBlink): |
| (KJS::stringProtoFuncBold): |
| (KJS::stringProtoFuncFixed): |
| (KJS::stringProtoFuncItalics): |
| (KJS::stringProtoFuncStrike): |
| (KJS::stringProtoFuncSub): |
| (KJS::stringProtoFuncSup): |
| (KJS::stringProtoFuncFontcolor): |
| (KJS::stringProtoFuncFontsize): |
| (KJS::stringProtoFuncAnchor): |
| (KJS::stringProtoFuncLink): |
| * kjs/string_object.h: |
| |
| 2008-01-15 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Adam Roben. |
| |
| Some tweaks to our headerdoc, suggested by David Gatwood on the docs |
| team. |
| |
| * API/JSBase.h: |
| * API/JSObjectRef.h: |
| * API/JSStringRef.h: |
| * API/JSValueRef.h: |
| |
| 2008-01-15 Alp Toker <alp@atoker.com> |
| |
| Rubber-stamped by Anders. |
| |
| Make the HTTP backend configurable in the GTK+ port. curl is currently |
| the only option. |
| |
| * wtf/Platform.h: Don't hard-code WTF_USE_CURL for GTK |
| |
| 2008-01-15 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Beth Dakin. |
| |
| Remove unneeded variable. |
| |
| * kjs/string_object.cpp: |
| (KJS::StringProtoFuncSubstr::callAsFunction): |
| |
| 2008-01-14 Steve Falkenburg <sfalken@apple.com> |
| |
| Use shared vsprops for most vcproj properties. |
| |
| Reviewed by Darin. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Add missing Debug_Internal config. |
| * JavaScriptCore.vcproj/WTF/WTF.vcproj: Add missing Debug_Internal config. |
| * JavaScriptCore.vcproj/testkjs/testkjs.vcproj: |
| |
| 2008-01-14 Adam Roben <aroben@apple.com> |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Added |
| some headers that were missing from the vcproj so their contents will |
| be included in Find in Files. |
| |
| 2008-01-14 Adam Roben <aroben@apple.com> |
| |
| Fix Bug 16871: Crash when loading apple.com/startpage |
| |
| <http://bugs.webkit.org/show_bug.cgi?id=16871> |
| <rdar://problem/5686670> |
| |
| Patch written by Darin, reviewed by me. |
| |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::mark): Call ActivationImp::markChildren if our |
| m_activation is on the stack. This is what ScopeChain::mark also does, |
| but apparently in some cases it's possible for an ExecState's |
| ActivationImp to not be in any ScopeChain. |
| |
| 2008-01-14 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Oliver. |
| |
| -<rdar://problem/5622667> REGRESSION (Leopard-ToT): Endless loading loop |
| trying to view techreport.com comments |
| - We need to set values in the map, because if they are already in the |
| map they will not be reset when we use add(). |
| |
| * kjs/array_instance.cpp: |
| (KJS::ArrayInstance::put): |
| |
| 2008-01-14 Darin Adler <darin@apple.com> |
| |
| Reviewed by Adam. |
| |
| - re-speed-up the page load test (my StringImpl change slowed it down) |
| |
| * wtf/RefCounted.h: |
| (WTF::RefCounted::RefCounted): Allow derived classes to start with a reference |
| count other than 0. Eventually everyone will want to start with a 1. This is a |
| staged change. For now, there's a default of 0, and you can specify 1. Later, |
| there will be no default and everyone will have to specify. And then later, there |
| will be a default of 1. Eventually, we can take away even the option of starting |
| with 0! |
| |
| * wtf/Vector.h: |
| (WTF::Vector::Vector): Sped up creation of non-empty vectors by removing the |
| overhead of first constructing something empty and then calling resize. |
| (WTF::Vector::clear): Sped up the common case of calling clear on an empty |
| vector by adding a check for that case. |
| (WTF::Vector::releaseBuffer): Marked this function inline and removed a branch |
| in the case of vectors with no inline capacity (normal vectors) by leaving out |
| the code to copy the inline buffer in that case. |
| |
| 2008-01-14 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by David Kilzer. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=16787 |
| array.splice() with 1 element not working |
| |
| Test: fast/js/array-splice.html |
| |
| * kjs/array_object.cpp: |
| (KJS::ArrayProtoFuncSplice::callAsFunction): Implement this Mozilla extension, and fix |
| some other edge cases. |
| |
| 2008-01-13 Steve Falkenburg <sfalken@apple.com> |
| |
| Share common files across projects. |
| |
| Unify vsprops files |
| Debug: common.vsprops, debug.vsprops |
| Debug_Internal: common.vsprops, debug.vsprops, debug_internal.vsprops |
| Release: common.vsprops, release.vsprops |
| |
| Shared properties can go into common.vsprops, shared debug settings can go into debug.vsprops. |
| debug_internal.vsprops will be mostly empty except for file path prefix modifiers. |
| |
| Reviewed by Adam Roben. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.vcproj/WTF/WTF.vcproj: |
| * JavaScriptCore.vcproj/debug.vsprops: Removed. |
| * JavaScriptCore.vcproj/debug_internal.vsprops: Removed. |
| * JavaScriptCore.vcproj/release.vsprops: Removed. |
| * JavaScriptCore.vcproj/testkjs/testkjs.vcproj: |
| |
| 2008-01-13 Marius Bugge Monsen <mbm@trolltech.com> |
| |
| Contributions and review by Adriaan de Groot, |
| Simon Hausmann, Eric Seidel, and Darin Adler. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=16590 |
| Compilation fixes for Solaris. |
| |
| * kjs/DateMath.h: |
| (KJS::GregorianDateTime::GregorianDateTime): Use the WIN_OS code path |
| for SOLARIS too, presumably because Solaris also lacks the tm_gtoff and tm_zone |
| fields. |
| (KJS::GregorianDateTime::operator tm): Ditto. |
| |
| * kjs/collector.cpp: |
| (KJS::currentThreadStackBase): Use thr_stksegment on Solaris. |
| |
| * wtf/MathExtras.h: |
| (isfinite): Implement for Solaris. |
| (isinf): Ditto. |
| (signbit): Ditto. But this one is wrong, so I added a FIXME. |
| |
| * wtf/Platform.h: Define PLATFORM(SOLARIS) when "sun" or "__sun" is defined. |
| |
| 2008-01-13 Michael Goddard <michael.goddard@trolltech.com> |
| |
| Reviewed by Anders Carlsson. |
| |
| Add binding language type to Instance. |
| Allows runtime determination of the type of an |
| Instance, to allow safe casting. Doesn't actually |
| add any safe casting yet, though. |
| |
| Add a helper function to get an Instance from a JSObject*. |
| Given an object and the expected binding language, see if |
| the JSObject actually wraps an Instance of the given type |
| and return it. Otherwise return 0. |
| |
| Move RuntimeObjectImp creations into Instance. |
| Make the ctor protected, and Instance a friend class, so |
| that all creation of RuntimeObjectImps goes through |
| one place. |
| |
| Remove copy ctor/assignment operator for QtInstance. |
| Instance itself is Noncopyable, so QtInstance doesn't |
| need to have these. |
| |
| Add caching for QtInstance and associated RuntimeObjectImps. |
| Push any dealings with QtLanguage bindings into QtInstance, |
| and cache them there, rather than in the Instance layer. Add |
| a QtRuntimeObjectImp to help with caching. |
| |
| * JavaScriptCore.exp: |
| * bindings/c/c_instance.h: |
| * bindings/jni/jni_instance.h: |
| * bindings/objc/objc_instance.h: |
| * bindings/qt/qt_instance.cpp: |
| (KJS::Bindings::QtRuntimeObjectImp::QtRuntimeObjectImp): |
| (KJS::Bindings::QtRuntimeObjectImp::~QtRuntimeObjectImp): |
| (KJS::Bindings::QtRuntimeObjectImp::invalidate): |
| (KJS::Bindings::QtRuntimeObjectImp::removeFromCache): |
| (KJS::Bindings::QtInstance::QtInstance): |
| (KJS::Bindings::QtInstance::~QtInstance): |
| (KJS::Bindings::QtInstance::getQtInstance): |
| (KJS::Bindings::QtInstance::getRuntimeObject): |
| * bindings/qt/qt_instance.h: |
| (KJS::Bindings::QtInstance::getBindingLanguage): |
| * bindings/runtime.cpp: |
| (KJS::Bindings::Instance::createBindingForLanguageInstance): |
| (KJS::Bindings::Instance::createRuntimeObject): |
| (KJS::Bindings::Instance::getInstance): |
| * bindings/runtime.h: |
| * bindings/runtime_object.h: |
| (KJS::RuntimeObjectImp::getInternalInstance): |
| |
| 2008-01-12 Alp Toker <alp@atoker.com> |
| |
| Reviewed by Mark Rowe. |
| |
| Hide non-public symbols in GTK+/autotools release builds. |
| |
| * GNUmakefile.am: |
| |
| 2008-01-12 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Mark Rowe. |
| |
| Fix http://bugs.webkit.org/show_bug.cgi?id=16852 |
| Fixes leaking of ActivationStackNode objects. |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::deleteActivationStack): |
| (KJS::JSGlobalObject::~JSGlobalObject): |
| (KJS::JSGlobalObject::init): |
| (KJS::JSGlobalObject::reset): |
| * kjs/JSGlobalObject.h: |
| |
| 2008-01-12 Darin Adler <darin@apple.com> |
| |
| - try to fix Qt Windows build |
| |
| * pcre/dftables: Remove reliance on the list form of Perl pipes. |
| |
| 2008-01-12 Darin Adler <darin@apple.com> |
| |
| - try to fix Qt build |
| |
| * kjs/function.cpp: Added include of scope_chain_mark.h. |
| * kjs/scope_chain_mark.h: Added multiple-include guards. |
| |
| 2008-01-12 Mark Rowe <mrowe@apple.com> |
| |
| Another Windows build fix. |
| |
| * kjs/Activation.h: |
| |
| 2008-01-12 Mark Rowe <mrowe@apple.com> |
| |
| Attempted Windows build fix. Use struct consistently when forward-declaring |
| ActivationStackNode and StackActivation. |
| |
| * kjs/Activation.h: |
| * kjs/JSGlobalObject.h: |
| |
| 2008-01-12 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Fixes a problem with the ActivationImp tear-off patch (r29425) where |
| some of the calls to JSGlobalObject::tearOffActivation() were using |
| the wrong test to determine whether it should leave a relic behind. |
| |
| * kjs/function.cpp: |
| (KJS::FunctionImp::argumentsGetter): |
| (KJS::ActivationImp::getOwnPropertySlot): |
| |
| 2008-01-11 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fixed <rdar://problem/5665251> REGRESSION (r28880-r28886): Global |
| variable access (16644) |
| |
| This bug was caused by var declarations shadowing built-in properties of |
| the global object. |
| |
| To match Firefox, we've decided that var declarations will never shadow |
| built-in properties of the global object or its prototypes. We used to |
| behave more like IE, which allows shadowing, but walking that line got |
| us into trouble with websites that sent us down the Firefox codepath. |
| |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::symbolTableGet): New code to support calling |
| hasProperty before the variable object is fully initialized (so you |
| can call it during initialization). |
| |
| * kjs/nodes.cpp:. |
| (KJS::ProgramNode::initializeSymbolTable): Always do a full hasProperty |
| check when looking for duplicates, not getDirect, since it only checks |
| the property map, and not hasOwnProperty, since it doesn't check |
| prototypes. |
| (KJS::EvalNode::processDeclarations): ditto |
| |
| * kjs/property_slot.h: |
| (KJS::PropertySlot::ungettableGetter): Best function name evar. |
| |
| 2008-01-11 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Maciej. |
| |
| Optimized ActivationImp allocation, so that activation records are now |
| first allocated on an explicitly managed stack and only heap allocated |
| when necessary. Roughly a 5% improvement on SunSpider, and a larger |
| improvement on benchmarks that use more function calls. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/Activation.h: Added. |
| (KJS::ActivationImp::ActivationData::ActivationData): |
| (KJS::ActivationImp::ActivationImp): |
| (KJS::ActivationImp::classInfo): |
| (KJS::ActivationImp::isActivationObject): |
| (KJS::ActivationImp::isOnStack): |
| (KJS::ActivationImp::d): |
| (KJS::StackActivation::StackActivation): |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::ExecState): |
| (KJS::ExecState::~ExecState): |
| * kjs/ExecState.h: |
| (KJS::ExecState::replaceScopeChainTop): |
| (KJS::ExecState::setActivationObject): |
| (KJS::ExecState::setLocalStorage): |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::reset): |
| (KJS::JSGlobalObject::pushActivation): |
| (KJS::JSGlobalObject::checkActivationCount): |
| (KJS::JSGlobalObject::popActivationHelper): |
| (KJS::JSGlobalObject::popActivation): |
| (KJS::JSGlobalObject::tearOffActivation): |
| * kjs/JSGlobalObject.h: |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::JSVariableObjectData::JSVariableObjectData): |
| (KJS::JSVariableObject::JSVariableObject): |
| * kjs/function.cpp: |
| (KJS::FunctionImp::argumentsGetter): |
| (KJS::ActivationImp::ActivationImp): |
| (KJS::ActivationImp::~ActivationImp): |
| (KJS::ActivationImp::init): |
| (KJS::ActivationImp::getOwnPropertySlot): |
| (KJS::ActivationImp::markHelper): |
| (KJS::ActivationImp::mark): |
| (KJS::ActivationImp::ActivationData::ActivationData): |
| (KJS::GlobalFuncImp::callAsFunction): |
| * kjs/function.h: |
| * kjs/nodes.cpp: |
| (KJS::PostIncResolveNode::evaluate): |
| (KJS::PostDecResolveNode::evaluate): |
| (KJS::PreIncResolveNode::evaluate): |
| (KJS::PreDecResolveNode::evaluate): |
| (KJS::ReadModifyResolveNode::evaluate): |
| (KJS::AssignResolveNode::evaluate): |
| (KJS::WithNode::execute): |
| (KJS::TryNode::execute): |
| (KJS::FunctionBodyNode::processDeclarations): |
| (KJS::FuncExprNode::evaluate): |
| * kjs/object.h: |
| * kjs/scope_chain.h: |
| (KJS::ScopeChain::replace): |
| * kjs/scope_chain_mark.h: Added. |
| (KJS::ScopeChain::mark): |
| |
| 2008-01-11 Simon Hausmann <hausmann@webkit.org> |
| |
| Reviewed by Mark Rowe. |
| |
| Fix the (clean) qmake build. For generating chartables.c we don't |
| depend on a separate input source file anymore, the dftables perl |
| script is enough. So use that instead as value for the .input |
| variable, to ensure that qmake also generates a rule to call dftables. |
| |
| * pcre/pcre.pri: |
| |
| 2008-01-10 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by John Sullivan. |
| |
| Fixed some world leak reports: |
| * <rdar://problem/5669436> PLT complains about world leak of 1 JavaScript |
| Interpreter after running cvs-base suite |
| |
| * <rdar://problem/5669423> PLT complains about world leak if browser |
| window is open when PLT starts |
| |
| * kjs/collector.h: Added the ability to distinguish between global |
| objects and GC-protected global objects, since we only consider the |
| latter to be world leaks. |
| * kjs/collector.cpp: |
| |
| 2008-01-11 Mark Rowe <mrowe@apple.com> |
| |
| Silence qmake warning about ctgen lacking input. |
| |
| Rubber-stamped by Alp Toker. |
| |
| * pcre/pcre.pri: |
| |
| 2008-01-10 David Kilzer <ddkilzer@apple.com> |
| |
| dftables should be rewritten as a script |
| |
| <http://bugs.webkit.org/show_bug.cgi?id=16818> |
| <rdar://problem/5681463> |
| |
| Reviewed by Darin. |
| |
| Rewrote the dftables utility in Perl. Attempted to switch all |
| build systems to call the script directly instead of building |
| a binary first. Only the Xcode build was able to be tested. |
| |
| * DerivedSources.make: Added pcre directory to VPATH and changed |
| to invoke dftables directly. |
| * GNUmakefile.am: Removed build information and changed to invoke |
| dftables directly. |
| * JavaScriptCore.vcproj/JavaScriptCore.sln: Removed reference to |
| dftables project. |
| * JavaScriptCore.vcproj/JavaScriptCoreSubmit.sln: Ditto. |
| * JavaScriptCore.vcproj/dftables: Removed. |
| * JavaScriptCore.vcproj/dftables/dftables.vcproj: Removed. |
| * JavaScriptCore.xcodeproj/project.pbxproj: Removed dftables target. |
| * jscore.bkl: Removed dftables executable definition. |
| * pcre/dftables: Copied from JavaScriptCore/pcre/dftables.cpp. |
| * pcre/dftables.cpp: Removed. |
| * pcre/dftables.pro: Removed. |
| * pcre/pcre.pri: Removed references to dftables.cpp and changed to |
| invoke dftables directly. |
| |
| 2008-01-10 Dan Bernstein <mitz@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=16782 |
| <rdar://problem/5675331> REGRESSION(r29266): Reproducible crash in fast/replaced/image-map.html |
| |
| The crash resulted from a native object (DumpRenderTree's |
| EventSender) causing its wrapper to be invalidated (by clicking a |
| link that replaced the document in the window) and consequently |
| deallocated. The fix is to use RefPtrs to protect the native object |
| from deletion by self-invalidation. |
| |
| * bindings/runtime_method.cpp: |
| (RuntimeMethod::callAsFunction): |
| * bindings/runtime_object.cpp: |
| (RuntimeObjectImp::fallbackObjectGetter): |
| (RuntimeObjectImp::fieldGetter): |
| (RuntimeObjectImp::methodGetter): |
| (RuntimeObjectImp::put): |
| (RuntimeObjectImp::defaultValue): |
| (RuntimeObjectImp::callAsFunction): |
| |
| 2008-01-07 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Turn testIsInteger assertions into compile-time asserts and move them into HashTraits.h |
| where possible. |
| |
| * kjs/testkjs.cpp: |
| * wtf/HashTraits.h: |
| |
| 2008-01-07 Nikolas Zimmermann <zimmermann@kde.org> |
| |
| Reviewed by Mark. |
| |
| Enable SVG_FONTS by default. |
| |
| * Configurations/JavaScriptCore.xcconfig: |
| |
| 2008-01-07 Darin Adler <darin@apple.com> |
| |
| Rubber stamped by David Kilzer. |
| |
| - get rid of empty fpconst.cpp |
| |
| * GNUmakefile.am: Remove fpconst.cpp. |
| * JavaScriptCore.pri: Ditto. |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Ditto. |
| * JavaScriptCore.xcodeproj/project.pbxproj: Ditto. |
| * JavaScriptCoreSources.bkl: Ditto. |
| |
| * kjs/fpconst.cpp: Removed. |
| |
| 2008-01-07 Darin Adler <darin@apple.com> |
| |
| Reviewed by David Kilzer. |
| |
| - fix alignment problem with NaN and Inf globals |
| |
| * kjs/fpconst.cpp: Move the contents of this file from here back to |
| value.cpp. The reason this was in a separate file is that the DARWIN |
| version of this used a declaration of the globals with a different |
| type to avoid creating "init routines". That's no longer necessary for |
| DARWIN and was never necessary for the non-DARWIN code path. |
| To make this patch easy to merge, I didn't actually delete this file |
| yet. We'll do that in a separate changeset. |
| |
| * kjs/value.cpp: If C99's NAN and INFINITY are present, then use them, |
| othrewise use the union trick from fpconst.cpp. I think it would be |
| better to eliminate KJS::NaN and KJS::Inf and just use NAN and INFINITY |
| directly or std::numeric_limits<double>::quiet_nan() and |
| std::numeric_limits<double>::infinity(). But when I tried that, it |
| slowed down SunSpider. Someone else could do that cleanup if they |
| could do it without slowing down the engine. |
| |
| 2008-01-07 Adam Roben <aroben@apple.com> |
| |
| Windows build fix |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Added |
| JavaScript.h to the project. |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCoreGenerated.make: |
| Copy JavaScript.h to WEBKITOUTPUTDIR. |
| |
| 2008-01-07 Timothy Hatcher <timothy@apple.com> |
| |
| Reviewed by Darin. |
| |
| Fix Mac build. |
| |
| * API/JSNode.c: |
| * API/JSNode.h: |
| * API/JSNodeList.c: |
| * API/JSNodeList.h: |
| * API/JavaScript.h: |
| * API/JavaScriptCore.h: |
| * API/minidom.c: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2008-01-07 Alp Toker <alp@atoker.com> |
| |
| Reviewed by Darin. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=16029 |
| JavaScriptCore.h is not suitable for platforms other than Mac OS X |
| |
| Introduce a new JavaScriptCore/JavaScript.h public API header. This |
| should be used by all new portable code using the JavaScriptCore API. |
| |
| JavaScriptCore/JavaScriptCore.h will remain for compatibility with |
| existing applications that depend on it including JSStringRefCF.h |
| which isn't portable. |
| |
| Also add minidom to the GTK+/autotools build since we can now support |
| it on all platforms. |
| |
| * API/JSNode.h: |
| * API/JSNodeList.h: |
| * API/JavaScript.h: Added. |
| * API/JavaScriptCore.h: |
| * ForwardingHeaders/JavaScriptCore/JavaScript.h: Added. |
| * GNUmakefile.am: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2008-01-06 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Abstract all DateObject.set* functions in preparation for fixing: |
| http://bugs.webkit.org/show_bug.cgi?id=16753 |
| |
| SunSpider had random changes here and there but was overall a wash. |
| |
| * kjs/date_object.cpp: |
| (KJS::fillStructuresUsingTimeArgs): |
| (KJS::setNewValueFromTimeArgs): |
| (KJS::setNewValueFromDateArgs): |
| (KJS::DateProtoFuncSetMilliSeconds::callAsFunction): |
| (KJS::DateProtoFuncSetUTCMilliseconds::callAsFunction): |
| (KJS::DateProtoFuncSetSeconds::callAsFunction): |
| (KJS::DateProtoFuncSetUTCSeconds::callAsFunction): |
| (KJS::DateProtoFuncSetMinutes::callAsFunction): |
| (KJS::DateProtoFuncSetUTCMinutes::callAsFunction): |
| (KJS::DateProtoFuncSetHours::callAsFunction): |
| (KJS::DateProtoFuncSetUTCHours::callAsFunction): |
| (KJS::DateProtoFuncSetDate::callAsFunction): |
| (KJS::DateProtoFuncSetUTCDate::callAsFunction): |
| (KJS::DateProtoFuncSetMonth::callAsFunction): |
| (KJS::DateProtoFuncSetUTCMonth::callAsFunction): |
| (KJS::DateProtoFuncSetFullYear::callAsFunction): |
| (KJS::DateProtoFuncSetUTCFullYear::callAsFunction): |
| |
| 2008-01-06 Nikolas Zimmermann <zimmermann@kde.org> |
| |
| Reviewed by Dan. |
| |
| Add new helper function isArabicChar - SVG Fonts support needs it. |
| |
| * wtf/unicode/icu/UnicodeIcu.h: |
| (WTF::Unicode::isArabicChar): |
| * wtf/unicode/qt4/UnicodeQt4.h: |
| (WTF::Unicode::isArabicChar): |
| |
| 2008-01-06 Alp Toker <alp@atoker.com> |
| |
| Reviewed by Mark Rowe. |
| |
| Use $(EXEEXT) to account for the .exe extension in the GTK+ Windows |
| build. (This is already done correctly in DerivedSources.make.) Issue |
| noticed by Mikkel when building in Cygwin. |
| |
| Add a missing slash. This was a hack from the qmake build system that |
| isn't necessary with autotools. |
| |
| * GNUmakefile.am: |
| |
| 2008-01-05 Darin Adler <darin@apple.com> |
| |
| * API/JSRetainPtr.h: One more file that needed the change below. |
| |
| 2008-01-05 Darin Adler <darin@apple.com> |
| |
| * wtf/OwnPtr.h: OwnPtr needs the same fix as RefPtr below. |
| |
| 2008-01-05 Adam Roben <aroben@apple.com> |
| |
| Build fix. |
| |
| Reviewed by Maciej. |
| |
| * wtf/RetainPtr.h: Use PtrType instead of T* because of the |
| RemovePointer magic. |
| |
| 2008-01-05 Darin Adler <darin@apple.com> |
| |
| Rubber stamped by Maciej Stachowiak. |
| |
| - cut down own PIC branches by using a pointer-to-member-data instead of a |
| pointer-to-member-function in WTF smart pointers |
| |
| * wtf/OwnArrayPtr.h: |
| * wtf/OwnPtr.h: |
| * wtf/PassRefPtr.h: |
| * wtf/RefPtr.h: |
| * wtf/RetainPtr.h: |
| Use a pointer to the m_ptr member instead of the get member. |
| The GCC compiler generates better code for this idiom. |
| |
| 2008-01-05 Henry Mason <hmason@mac.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=16738 |
| Bug 16738: Collector block offset could be stored as an cell offset instead of a byte offset |
| |
| Gives a 0.4% SunSpider boost and prettier code. |
| |
| * kjs/collector.cpp: Switched to cell offsets from byte offsets |
| (KJS::Collector::heapAllocate): |
| (KJS::Collector::sweep): |
| |
| 2008-01-04 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Have the two malloc zones print useful diagnostics if their free method are unexpectedly invoked. |
| Due to <rdar://problem/5671357> this can happen if an application attempts to free a pointer that |
| was not allocated by any registered malloc zone on the system. |
| |
| * kjs/CollectorHeapIntrospector.h: |
| * wtf/FastMalloc.cpp: |
| |
| 2008-01-04 Alp Toker <alp@atoker.com> |
| |
| GTK+ autotools build fix. Terminate empty rules. |
| |
| * GNUmakefile.am: |
| |
| 2008-01-03 Simon Hausmann <hausmann@webkit.org> |
| |
| Reviewed by Mark Rowe. |
| |
| Fix compilation with gcc 4.3: limits.h is needed for INT_MAX. |
| |
| * pcre/pcre_exec.cpp: |
| |
| 2008-01-03 Darin Adler <darin@apple.com> |
| |
| * tests/mozilla/expected.html: The fix for bug 16696 also fixed a test |
| case, ecma_3/RegExp/perlstress-002.js, so updated results to expect |
| that test to succeed. |
| |
| 2008-01-02 Darin Adler <darin@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=16696 |
| JSCRE fails fails to match Acid3 regexp |
| |
| Test: fast/regex/early-acid3-86.html |
| |
| The problem was with the cutoff point between backreferences and octal |
| escape sequences. We need to determine the cutoff point by counting the |
| total number of capturing brackets, which requires an extra pass through |
| the expression when compiling it. |
| |
| * pcre/pcre_compile.cpp: |
| (CompileData::CompileData): Added numCapturingBrackets. Removed some |
| unused fields. |
| (compileBranch): Use numCapturingBrackets when calling checkEscape. |
| (calculateCompiledPatternLength): Use numCapturingBrackets when calling |
| checkEscape, and also store the bracket count at the end of the compile. |
| (jsRegExpCompile): Call calculateCompiledPatternLength twice -- once to |
| count the number of brackets and then a second time to calculate the length. |
| |
| 2008-01-02 Darin Adler <darin@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=16696 |
| JSCRE fails fails to match Acid3 regexp |
| |
| Test: fast/regex/early-acid3-86.html |
| |
| The problem was with the cutoff point between backreferences and octal |
| escape sequences. We need to determine the cutoff point by counting the |
| total number of capturing brackets, which requires an extra pass through |
| the expression when compiling it. |
| |
| * pcre/pcre_compile.cpp: |
| (CompileData::CompileData): Added numCapturingBrackets. Removed some |
| unused fields. |
| (compileBranch): Use numCapturingBrackets when calling checkEscape. |
| (calculateCompiledPatternLength): Use numCapturingBrackets when calling |
| checkEscape, and also store the bracket count at the end of the compile. |
| (jsRegExpCompile): Call calculateCompiledPatternLength twice -- once to |
| count the number of brackets and then a second time to calculate the length. |
| |
| 2008-01-02 David Kilzer <ddkilzer@webkit.org> |
| |
| Reviewed and landed by Darin. |
| |
| * kjs/nodes.cpp: |
| (KJS::DoWhileNode::execute): Added a missing return. |
| |
| 2008-01-02 Darin Adler <darin@apple.com> |
| |
| - try to fix Qt build |
| |
| * wtf/unicode/qt4/UnicodeQt4.h: |
| (WTF::Unicode::foldCase): Add some missing const. |
| |
| 2008-01-02 Alice Liu <alice.liu@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| need to export ASCIICType.h for use in DRT |
| |
| * JavaScriptCore.vcproj/WTF/WTF.vcproj: |
| * wtf/ASCIICType.h: |
| (WTF::isASCIIUpper): |
| |
| 2008-01-02 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Beth Dakin. |
| |
| Cleanup error_object.h/cpp. |
| |
| * kjs/JSGlobalObject.cpp: |
| (KJS::JSGlobalObject::reset): |
| * kjs/error_object.cpp: |
| (KJS::ErrorInstance::ErrorInstance): |
| (KJS::ErrorPrototype::ErrorPrototype): |
| (KJS::ErrorProtoFuncToString::ErrorProtoFuncToString): |
| (KJS::ErrorProtoFuncToString::callAsFunction): |
| (KJS::ErrorObjectImp::ErrorObjectImp): |
| (KJS::ErrorObjectImp::implementsConstruct): |
| (KJS::ErrorObjectImp::construct): |
| (KJS::ErrorObjectImp::callAsFunction): |
| (KJS::NativeErrorPrototype::NativeErrorPrototype): |
| (KJS::NativeErrorImp::NativeErrorImp): |
| (KJS::NativeErrorImp::implementsConstruct): |
| (KJS::NativeErrorImp::construct): |
| (KJS::NativeErrorImp::callAsFunction): |
| (KJS::NativeErrorImp::mark): |
| * kjs/error_object.h: |
| (KJS::ErrorInstance::classInfo): |
| (KJS::NativeErrorImp::classInfo): |
| |
| 2008-01-02 Mark Rowe <mrowe@apple.com> |
| |
| Rubber-stamped by Alp Toker. |
| |
| * GNUmakefile.am: Add missing dependency on grammar.y. |
| |
| 2008-01-01 Darin Adler <darin@apple.com> |
| |
| Reviewed by Eric. |
| |
| - fix for http://bugs.webkit.org/show_bug.cgi?id=16695 |
| JSC allows non-identifier codepoints in identifiers (affects Acid3) |
| |
| Test: fast/js/kde/parse.html |
| |
| * kjs/lexer.cpp: |
| (KJS::Lexer::lex): Added additional states to distinguish Unicode escapes at the |
| start of identifiers from ones inside identifiers. Rejected characters that don't pass |
| the isIdentStart and isIdentPart tests. |
| (KJS::Lexer::convertUnicode): Removed incorrect FIXME comment. |
| |
| * kjs/lexer.h: Added new states to distinguish \u escapes at the start of identifiers |
| from \u escapes inside identifiers. |
| |
| 2008-01-01 Darin Adler <darin@apple.com> |
| |
| - rolled scope chain optimization out; it was breaking the world |
| |
| 2008-01-01 Darin Adler <darin@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=16685 |
| eliminate List::empty() to cut down on PIC branches |
| |
| Also included one other speed-up -- remove the call to reserveCapacity from |
| FunctionBodyNode::processDeclarations in all but the most unusual cases. |
| |
| Together these make SunSpider 1.016x as fast. |
| |
| * JavaScriptCore.exp: Updated. |
| * kjs/ExecState.cpp: |
| (KJS::globalEmptyList): Added. Called only when creating global ExecState |
| instances. |
| (KJS::ExecState::ExecState): Broke constructor up into three separate functions, |
| for the three separate node types. Also went through each of the three and |
| streamlined as much as possible, removing dead code. This prevents us from having |
| to access the global in the function body version of the constructor. |
| |
| * kjs/ExecState.h: Added emptyList(). Replaced the constructor with a set of |
| three that are specific to the different node types that can create new execution |
| state objects. |
| |
| * kjs/array_object.cpp: |
| (KJS::ArrayProtoFuncToLocaleString::callAsFunction): Use exec->emptyList() instead |
| of List::empty(). |
| (KJS::ArrayProtoFuncConcat::callAsFunction): Ditto. |
| (KJS::ArrayProtoFuncSlice::callAsFunction): Ditto. |
| (KJS::ArrayProtoFuncSplice::callAsFunction): Ditto. |
| (KJS::ArrayProtoFuncFilter::callAsFunction): Ditto. |
| * kjs/function.cpp: |
| (KJS::FunctionImp::callAsFunction): Updated to call new ExecState constructor. |
| (KJS::GlobalFuncImp::callAsFunction): Ditto (for eval). |
| * kjs/function_object.cpp: |
| (FunctionObjectImp::construct): Use exec->emptyList() instead of List::empty(). |
| |
| * kjs/list.cpp: Removed List::empty. |
| * kjs/list.h: Ditto. |
| |
| * kjs/nodes.cpp: |
| (KJS::ElementNode::evaluate): Use exec->emptyList() instead of List::empty(). |
| (KJS::ArrayNode::evaluate): Ditto. |
| (KJS::ObjectLiteralNode::evaluate): Ditto. |
| (KJS::PropertyListNode::evaluate): Ditto. |
| (KJS::FunctionBodyNode::processDeclarations): Another speed-up. Check the capacity |
| before calling reserveCapacity, because it doesn't get inlined the local storage |
| vector is almost always big enough -- saving the function call overhead is a big |
| deal. |
| (KJS::FuncDeclNode::makeFunction): Use exec->emptyList() instead of List::empty(). |
| (KJS::FuncExprNode::evaluate): Ditto. |
| * kjs/object.cpp: |
| (KJS::tryGetAndCallProperty): Ditto. |
| * kjs/property_slot.cpp: |
| (KJS::PropertySlot::functionGetter): Ditto. |
| * kjs/string_object.cpp: |
| (KJS::StringProtoFuncSplit::callAsFunction): Ditto. |
| |
| 2008-01-01 Darin Adler <darin@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=16648 |
| REGRESSION (r28165): Yuku.com navigation prints "jsRegExpExecute failed with result -2" |
| <rdar://problem/5646486> REGRESSION (r28165): Layout test fast/regex/test1 fails intermittently |
| |
| Fixes 34 failing test cases in the fast/regex/test1.html test. |
| |
| Restored the stack which prevents infinite loops for brackets that match the empty |
| string; it had been removed as an optimization. |
| |
| Unfortunately, restoring this stack causes the regular expression test in SunSpider |
| to be 1.095x as slow and the overall test to be 1.004x as slow. Maybe we can find |
| a correct optimization to restore the speed! |
| |
| It's possible the original change was on the right track but just off by one. |
| |
| * pcre/pcre_exec.cpp: Add back eptrblock, but name it BracketChainNode. |
| (MatchStack::pushNewFrame): Add back the logic needed here. |
| (startNewGroup): Ditto. |
| (match): Ditto. |
| |
| 2008-01-01 Darin Adler <darin@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=16683 |
| speed up function calls by making ScopeChain::push cheaper |
| |
| This gives a 1.019x speedup on SunSpider. |
| |
| After doing this, I realized this probably will be obsolete when the optimization |
| to avoid creating an activation object is done. When we do that one we should check |
| if rolling this out will speed things up, since this does add overhead at the time |
| you copy the scope chain. |
| |
| * kjs/object.h: Removed the ScopeChain::release function. It was |
| marked inline, and called in exactly one place, so moved it there. |
| No idea why it was in this header file! |
| |
| * kjs/scope_chain.cpp: Removed the overload of the ScopeChain::push |
| function that takes another ScopeChain. It was unused. I think we used |
| it over in WebCore at one point, but not any more. |
| |
| * kjs/scope_chain.h: Changed ScopeChainNode into a struct rather than |
| a class, got rid of its constructor so we can have one that's uninitialized, |
| and moved the refCount into a derived struct, ScopeChainHeapNode. Made _node |
| mutable so it can be changed in the moveToHeap function. Changed the copy |
| constructor and assignment operator to call moveToHeap, since the top node |
| can't be shared when it's embedded in another ScopeChain object. Updated |
| functions as needed to handle the case where the first object isn't on the |
| heap or to add casts for cases where it's guaranteed to be. Changed the push |
| function to always put the new node into the ScopeChain object; it will get |
| put onto the heap when needed later. |
| |
| 2008-01-01 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Fixed slight logic error in reserveCapacity, where we would reallocate |
| the storage buffer unnecessarily. |
| |
| * wtf/Vector.h: |
| (WTF::::reserveCapacity): No need to grow the buffer if newCapacity is |
| equal to capacity(). |
| |
| 2008-01-01 Darin Adler <darin@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=16684 |
| eliminate debugger overhead from function body execution |
| |
| Speeds SunSpider up 1.003x. That's a small amount, but measurable. |
| |
| * JavaScriptCore.exp: Updated. |
| * kjs/Parser.h: |
| (KJS::Parser::parse): Create the node with a static member function named create() instead |
| of using new explicitly. |
| |
| * kjs/grammar.y: Changed calls to new FunctionBodyNode to use FunctionBodyNode::create(). |
| |
| * kjs/nodes.cpp: |
| (KJS::ProgramNode::create): Added. Calls new. |
| (KJS::EvalNode::create): Ditto. |
| (KJS::FunctionBodyNode::create): Ditto, but creates FunctionBodyNodeWithDebuggerHooks |
| when a debugger is present. |
| (KJS::FunctionBodyNode::execute): Removed debugger hooks. |
| (KJS::FunctionBodyNodeWithDebuggerHooks::FunctionBodyNodeWithDebuggerHooks): Added. |
| (KJS::FunctionBodyNodeWithDebuggerHooks::execute): Calls the debugger, then the code, |
| then the debugger again. |
| |
| * kjs/nodes.h: Added create functions, made the constructors private and protected. |
| |
| 2007-12-30 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| More small cleanup to array_object.cpp |
| |
| * kjs/array_object.cpp: |
| (KJS::ArrayProtoFuncToString::callAsFunction): |
| (KJS::ArrayProtoFuncToLocaleString::callAsFunction): |
| (KJS::ArrayProtoFuncJoin::callAsFunction): |
| (KJS::ArrayProtoFuncConcat::callAsFunction): |
| (KJS::ArrayProtoFuncReverse::callAsFunction): |
| (KJS::ArrayProtoFuncShift::callAsFunction): |
| (KJS::ArrayProtoFuncSlice::callAsFunction): |
| (KJS::ArrayProtoFuncSort::callAsFunction): |
| (KJS::ArrayProtoFuncSplice::callAsFunction): |
| (KJS::ArrayProtoFuncUnShift::callAsFunction): |
| (KJS::ArrayProtoFuncFilter::callAsFunction): |
| (KJS::ArrayProtoFuncMap::callAsFunction): |
| (KJS::ArrayProtoFuncEvery::callAsFunction): |
| |
| 2007-12-30 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Apply wkstyle to array_object.cpp |
| |
| * kjs/array_object.cpp: |
| (KJS::ArrayPrototype::ArrayPrototype): |
| (KJS::ArrayPrototype::getOwnPropertySlot): |
| (KJS::ArrayProtoFuncConcat::callAsFunction): |
| (KJS::ArrayProtoFuncPop::callAsFunction): |
| (KJS::ArrayProtoFuncReverse::callAsFunction): |
| (KJS::ArrayProtoFuncShift::callAsFunction): |
| (KJS::ArrayProtoFuncSlice::callAsFunction): |
| (KJS::ArrayProtoFuncSort::callAsFunction): |
| (KJS::ArrayProtoFuncSplice::callAsFunction): |
| (KJS::ArrayProtoFuncUnShift::callAsFunction): |
| (KJS::ArrayProtoFuncFilter::callAsFunction): |
| (KJS::ArrayProtoFuncMap::callAsFunction): |
| (KJS::ArrayProtoFuncEvery::callAsFunction): |
| (KJS::ArrayProtoFuncLastIndexOf::callAsFunction): |
| (KJS::ArrayObjectImp::ArrayObjectImp): |
| (KJS::ArrayObjectImp::implementsConstruct): |
| (KJS::ArrayObjectImp::construct): |
| (KJS::ArrayObjectImp::callAsFunction): |
| |
| 2007-12-30 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Remove maxInt/minInt, replacing with std:max/min<int>() |
| |
| * kjs/array_object.cpp: |
| (KJS::ArrayProtoFuncSplice::callAsFunction): |
| * kjs/operations.cpp: |
| * kjs/operations.h: |
| |
| 2007-12-30 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Update Number.toString to properly throw exceptions. |
| Cleanup code in Number.toString implementation. |
| |
| * kjs/number_object.cpp: |
| (KJS::numberToString): |
| * kjs/object.cpp: |
| (KJS::Error::create): Remove bogus debug lines. |
| |
| 2007-12-28 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Oliver. |
| |
| ASSERT when debugging via Drosera due to missed var lookup optimization. |
| http://bugs.webkit.org/show_bug.cgi?id=16634 |
| |
| No test case possible. |
| |
| * kjs/nodes.cpp: |
| (KJS::BreakpointCheckStatement::optimizeVariableAccess): |
| * kjs/nodes.h: |
| |
| 2007-12-28 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Oliver. |
| |
| Fix (-0).toFixed() and re-factor a little |
| Fix (-0).toExponential() and printing of trailing 0s in toExponential |
| Fix toPrecision(nan) handling |
| http://bugs.webkit.org/show_bug.cgi?id=16640 |
| |
| * kjs/number_object.cpp: |
| (KJS::numberToFixed): |
| (KJS::fractionalPartToString): |
| (KJS::numberToExponential): |
| (KJS::numberToPrecision): |
| |
| 2007-12-28 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| More changes to make number code readable |
| |
| * kjs/number_object.cpp: |
| (KJS::integer_part_noexp): |
| (KJS::numberToFixed): |
| (KJS::numberToExponential): |
| |
| 2007-12-28 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| More small cleanups to toPrecision |
| |
| * kjs/number_object.cpp: |
| (KJS::numberToPrecision): |
| |
| 2007-12-28 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| More small attempts to make number code readable |
| |
| * kjs/number_object.cpp: |
| (KJS::exponentialPartToString): |
| (KJS::numberToExponential): |
| (KJS::numberToPrecision): |
| |
| 2007-12-28 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Break out callAsFunction implementations into static functions |
| |
| * kjs/number_object.cpp: |
| (KJS::numberToString): |
| (KJS::numberToFixed): |
| (KJS::numberToExponential): |
| (KJS::numberToPrecision): |
| (KJS::NumberProtoFunc::callAsFunction): |
| |
| 2007-12-28 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Apply wkstyle/astyle and fix placement of * |
| |
| * kjs/number_object.cpp: |
| (KJS::NumberInstance::NumberInstance): |
| (KJS::NumberPrototype::NumberPrototype): |
| (KJS::NumberProtoFunc::NumberProtoFunc): |
| (KJS::integer_part_noexp): |
| (KJS::intPow10): |
| (KJS::NumberProtoFunc::callAsFunction): |
| (KJS::NumberObjectImp::NumberObjectImp): |
| (KJS::NumberObjectImp::getOwnPropertySlot): |
| (KJS::NumberObjectImp::getValueProperty): |
| (KJS::NumberObjectImp::implementsConstruct): |
| (KJS::NumberObjectImp::construct): |
| (KJS::NumberObjectImp::callAsFunction): |
| * kjs/object.cpp: |
| (KJS::JSObject::put): |
| |
| 2007-12-27 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| ASSERT in JavaScriptCore while viewing WICD test case |
| http://bugs.webkit.org/show_bug.cgi?id=16626 |
| |
| * kjs/nodes.cpp: |
| (KJS::ForInNode::execute): move KJS_CHECK_EXCEPTION to proper place |
| |
| 2007-12-26 Jan Michael Alonzo <jmalonzo@unpluggable.com> |
| |
| Reviewed by Alp Toker. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=16390 |
| Use autotools or GNU make as the build system for the GTK port |
| |
| * GNUmakefile.am: Added. |
| |
| 2007-12-25 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - Remove unnecessary redundant check from property setting |
| http://bugs.webkit.org/show_bug.cgi?id=16602 |
| |
| 1.3% speedup on SunSpider. |
| |
| * kjs/object.cpp: |
| (KJS::JSObject::put): Don't do canPut check when not needed; let |
| the PropertyMap handle it. |
| (KJS::JSObject::canPut): Don't check the static property |
| table. lookupPut does that already. |
| |
| 2007-12-24 Alp Toker <alp@atoker.com> |
| |
| Fix builds that don't use AllInOneFile.cpp following breakage |
| introduced in r28973. |
| |
| * kjs/grammar.y: |
| |
| 2007-12-24 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Eric. |
| |
| - Optimize variable declarations |
| http://bugs.webkit.org/show_bug.cgi?id=16585 |
| |
| 3.5% speedup on SunSpider. |
| |
| var statements now result in either assignments or empty statements. |
| |
| This allows a couple of optimization opportunities: |
| - No need to branch at runtime to check if there is an initializer |
| - EmptyStatementNodes can be removed entirely (also done in this patch) |
| - Assignment expressions get properly optimized for local variables |
| |
| This patch also includes some code cleanup: |
| - Most of the old VarStatement/VarDecl logic is now only used for const declarations, |
| thus it is renamed appropriately |
| - AssignExprNode is gone |
| |
| * JavaScriptCore.exp: |
| * kjs/NodeInfo.h: |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::SourceElements::append): |
| (KJS::ConstDeclNode::ConstDeclNode): |
| (KJS::ConstDeclNode::optimizeVariableAccess): |
| (KJS::ConstDeclNode::handleSlowCase): |
| (KJS::ConstDeclNode::evaluateSingle): |
| (KJS::ConstDeclNode::evaluate): |
| (KJS::ConstStatementNode::optimizeVariableAccess): |
| (KJS::ConstStatementNode::execute): |
| (KJS::VarStatementNode::optimizeVariableAccess): |
| (KJS::VarStatementNode::execute): |
| (KJS::ForInNode::ForInNode): |
| (KJS::ForInNode::optimizeVariableAccess): |
| (KJS::ForInNode::execute): |
| (KJS::FunctionBodyNode::initializeSymbolTable): |
| (KJS::ProgramNode::initializeSymbolTable): |
| (KJS::FunctionBodyNode::processDeclarations): |
| (KJS::ProgramNode::processDeclarations): |
| (KJS::EvalNode::processDeclarations): |
| * kjs/nodes.h: |
| (KJS::DeclarationStacks::): |
| (KJS::StatementNode::): |
| (KJS::ConstDeclNode::): |
| (KJS::ConstStatementNode::): |
| (KJS::EmptyStatementNode::): |
| (KJS::VarStatementNode::): |
| (KJS::ForNode::): |
| * kjs/nodes2string.cpp: |
| (KJS::ConstDeclNode::streamTo): |
| (KJS::ConstStatementNode::streamTo): |
| (KJS::ScopeNode::streamTo): |
| (KJS::VarStatementNode::streamTo): |
| (KJS::ForNode::streamTo): |
| (KJS::ForInNode::streamTo): |
| |
| 2007-12-21 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| * JavaScriptCore.exp: Remove unused symbol to prevent a weak external symbol |
| being generated in JavaScriptCore.framework. |
| |
| 2007-12-21 Darin Adler <darin@apple.com> |
| |
| Requested by Maciej. |
| |
| * kjs/nodes.h: Use the new NEVER_INLINE here and eliminate the old |
| KJS_NO_INLINE. We don't want to have two, and we figured it was better |
| to keep the one that's in WTF. |
| |
| 2007-12-21 Darin Adler <darin@apple.com> |
| |
| Reviewed by Eric. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=16561 |
| remove debugger overhead from non-debugged JavaScript execution |
| |
| 1.022x as fast on SunSpider. |
| |
| * JavaScriptCore.exp: Updated. |
| |
| * kjs/NodeInfo.h: Renamed SourceElementsStub to SourceElements, |
| since that more accurately describes the role of this object, which |
| is a reference-counted wrapper for a Vector. |
| |
| * kjs/Parser.cpp: |
| (KJS::Parser::didFinishParsing): Changed parameter type to SourceElements, |
| and use plain assignment instead of set. |
| * kjs/Parser.h: Changed parameter type of didFinishParsing to a |
| SourceElements. Also changed m_sourceElements; we now use a RefPtr instead |
| of an OwnPtr as well. |
| |
| * kjs/grammar.y: Got rid of all the calls to release() on SourceElements. |
| That's now handed inside the constructors for various node types, since we now |
| use vector swapping instead. |
| |
| * kjs/nodes.cpp: |
| (KJS::Node::rethrowException): Added NEVER_INLINE, because this was getting inlined |
| and we want exception handling out of the normal code flow. |
| (KJS::SourceElements::append): Moved here from the header. This now handles |
| creating a BreakpointCheckStatement for each statement in the debugger case. |
| That way we can get breakpoint handling without having it in every execute function. |
| (KJS::BreakpointCheckStatement::BreakpointCheckStatement): Added. |
| (KJS::BreakpointCheckStatement::execute): Added. Contains the code that was formerly |
| in the StatementNode::hitStatement function and the KJS_BREAKPOINT macro. |
| (KJS::BreakpointCheckStatement::streamTo): Added. |
| (KJS::ArgumentListNode::evaluateList): Use KJS_CHECKEXCEPTIONVOID since the return |
| type is void. |
| (KJS::VarStatementNode::execute): Removed KJS_BREAKPOINT. |
| (KJS::BlockNode::BlockNode): Changed parameter type to SourceElements. |
| Changed code to use release since the class now contains a vector rather than |
| a vector point. |
| (KJS::BlockNode::optimizeVariableAccess): Updated since member is now a vector |
| rather than a vector pointer. |
| (KJS::BlockNode::execute): Ditto. |
| (KJS::ExprStatementNode::execute): Removed KJS_BREAKPOINT. |
| (KJS::IfNode::execute): Ditto. |
| (KJS::IfElseNode::execute): Ditto. |
| (KJS::DoWhileNode::execute): Ditto. |
| (KJS::WhileNode::execute): Ditto. |
| (KJS::ContinueNode::execute): Ditto. |
| (KJS::BreakNode::execute): Ditto. |
| (KJS::ReturnNode::execute): Ditto. |
| (KJS::WithNode::execute): Ditto. |
| (KJS::CaseClauseNode::optimizeVariableAccess): Updated since member is now a vector |
| rather than a vector pointer. |
| (KJS::CaseClauseNode::executeStatements): Ditto. |
| (KJS::SwitchNode::execute): Removed KJS_BREAKPOINT. |
| (KJS::ThrowNode::execute): Ditto. |
| (KJS::TryNode::execute): Ditto. |
| (KJS::ScopeNode::ScopeNode): Changed parameter type to SourceElements. |
| (KJS::ProgramNode::ProgramNode): Ditto. |
| (KJS::EvalNode::EvalNode): Ditto. |
| (KJS::FunctionBodyNode::FunctionBodyNode): Ditto. |
| (KJS::ScopeNode::optimizeVariableAccess): Updated since member is now a vector |
| rather than a vector pointer. |
| |
| * kjs/nodes.h: Removed hitStatement. Renamed SourceElements to StatementVector. |
| Renamed SourceElementsStub to SourceElements and made it derive from |
| ParserRefCounted rather than from Node, hold a vector rather than a pointer to |
| a vector, and changed the release function to swap with another vector rather |
| than the pointer idiom. Updated BlockNode and CaseClauseNode to hold actual |
| vectors instead of pointers to vectors. Added BreakpointCheckStatement. |
| |
| * kjs/nodes2string.cpp: |
| (KJS::statementListStreamTo): Changed to work on a vector instead of a pointer |
| to a vector. |
| (KJS::BlockNode::streamTo): Ditto. |
| (KJS::CaseClauseNode::streamTo): Ditto. |
| |
| * wtf/AlwaysInline.h: Added NEVER_INLINE. |
| * wtf/PassRefPtr.h: Tweaked formatting. Added clear() function that matches the |
| ones in OwnPtr and auto_ptr. |
| * wtf/RefPtr.h: Ditto. |
| |
| 2007-12-21 Darin Adler <darin@apple.com> |
| |
| - fix broken regression tests |
| |
| The broken tests were fast/js/do-while-expression-value.html and |
| fast/js/while-expression-value.html. |
| |
| * kjs/nodes.cpp: Check in the correct version of this file. I had accidentally landed |
| an old version of my patch for bug 16471. |
| (KJS::statementListExecute): The logic here was backwards. Have to set the value |
| even for non-normal execution results. |
| |
| 2007-12-20 Alexey Proskuryakov <ap@webkit.org> |
| |
| Windows build fix |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Copy npruntime_internal.h |
| to WebKitBuild. |
| |
| 2007-12-20 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by mjs. |
| |
| Split IfNode into IfNode and IfElseNode for speedup. |
| http://bugs.webkit.org/show_bug.cgi?id=16470 |
| |
| SunSpider claims this is 1.003x as fast as before. |
| (This required running with --runs 15 to get consistent enough results to tell!) |
| |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::IfNode::optimizeVariableAccess): |
| (KJS::IfNode::execute): |
| (KJS::IfNode::getDeclarations): |
| (KJS::IfElseNode::optimizeVariableAccess): |
| (KJS::IfElseNode::execute): |
| (KJS::IfElseNode::getDeclarations): |
| * kjs/nodes.h: |
| (KJS::IfNode::): |
| (KJS::IfElseNode::): |
| * kjs/nodes2string.cpp: |
| (KJS::IfNode::streamTo): |
| (KJS::IfElseNode::streamTo): |
| |
| 2007-12-20 Darin Adler <darin@apple.com> |
| |
| Reviewed by Sam. |
| |
| * wtf/OwnPtr.h: |
| (WTF::operator==): Added. |
| (WTF::operator!=): Added. |
| |
| 2007-12-20 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| AST optimization: Avoid NULL-checking ForNode's child nodes. |
| |
| 0.6% speedup on SunSpider. |
| |
| This is a proof of concept patch that demonstrates how to optimize |
| grammar productions with optional components, like |
| |
| for (optional; optional; optional) { |
| ... |
| } |
| |
| The parser emits NULL for an optional component that is not present. |
| |
| Instead of checking for a NULL child at execution time, a node that |
| expects an optional component to be present more often than not checks |
| for a NULL child at construction time, and substitutes a viable |
| alternative node in its place. |
| |
| (We'd like the parser to start emitting NULL a lot more once we teach |
| it to emit NULL for certain no-op productions like EmptyStatement and |
| VariableStatement, so, as a foundation, it's important for nodes with |
| NULL optional components to be fast.) |
| |
| * kjs/Parser.cpp: |
| (KJS::Parser::didFinishParsing): Check for NULL SourceElements. Also, |
| moved didFinishParsing into the .cpp file because adding a branch while |
| it was in the header file caused a substantial and inexplicable |
| performance regression. (Did I mention that GCC is crazy?) |
| |
| * kjs/grammar.y: |
| |
| * kjs/nodes.cpp: |
| (KJS::BlockNode::BlockNode): Check for NULL SourceElements. |
| (KJS::ForNode::optimizeVariableAccess): No need to check for NULL here. |
| (KJS::ForNode::execute): No need to check for NULL here. |
| * kjs/nodes.h: |
| (KJS::ForNode::): Check for NULL SourceElements. Substitute a TrueNode |
| because it's semantically harmless, and it evaluates to boolean in an |
| efficient manner. |
| |
| 2007-12-20 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Slight logic reordering in JSImmediate::from(double) |
| |
| This gives a 0.6% improvement in SunSpider. |
| |
| * kjs/JSImmediate.h: |
| (KJS::JSImmediate::from): |
| |
| 2007-12-20 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by mjs. |
| |
| Fix major Array regression introduced by 28899. |
| |
| SunSpider claims this is at least 1.37x as fast as pre-regression. :) |
| |
| * kjs/array_instance.cpp: make Arrays fast again! |
| |
| 2007-12-20 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Geoff, then re-rubber-stamped by Geoff after final search/replace and testing. |
| |
| Small reworking of Date code for 4% speedup on Date tests (0.2% overall) |
| http://bugs.webkit.org/show_bug.cgi?id=16537 |
| |
| Make msToYear human-readable |
| Make msToDayInMonth slightly more readable and avoid recalculating msToYear |
| Remove use of isInLeapYear to avoid calling msToYear |
| Remove dayInYear call by changing msToDayInMonth to dayInMonthFromDayInYear |
| Remove more duplicate calls to dayInYear and getUTCOffset for further speedup |
| |
| * kjs/DateMath.cpp: |
| (KJS::daysFrom1970ToYear): |
| (KJS::msToYear): |
| (KJS::monthFromDayInYear): |
| (KJS::checkMonth): |
| (KJS::dayInMonthFromDayInYear): |
| (KJS::dateToDayInYear): |
| (KJS::getDSTOffsetSimple): |
| (KJS::getDSTOffset): |
| (KJS::gregorianDateTimeToMS): |
| (KJS::msToGregorianDateTime): |
| |
| 2007-12-20 Rodney Dawes <dobey@wayofthemonkey.com> |
| |
| Reviewed by Darin Adler. |
| |
| Proxy includes of npruntime.h or npapi.h through npruntime_internal.h |
| Include stdio.h in npapi.h for the use of FILE with XP_UNIX defined |
| This is for building with X11, as some type and enum names conflict |
| with #define names in X11 headers. |
| http://bugs.webkit.org/show_bug.cgi?id=15669 |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * bindings/NP_jsobject.h: |
| * bindings/npapi.h: |
| * bindings/npruntime.cpp: |
| * bindings/npruntime_impl.h: |
| * bindings/npruntime_priv.h: |
| * bindings/npruntime_internal.h: |
| * bindings/testbindings.cpp: |
| * bindings/c/c_class.h: |
| * bindings/c/c_runtime.h: |
| * bindings/c/c_utility.h: |
| |
| 2007-12-20 Darin Adler <darin@apple.com> |
| |
| - re-fix http://bugs.webkit.org/show_bug.cgi?id=16471 |
| Completions need to be smaller (or not exist at all) |
| |
| Same patch as last time with the test failures problem fixed. |
| |
| * kjs/function.cpp: |
| (KJS::GlobalFuncImp::callAsFunction): Make sure to check the completion |
| type from newExec to see if the execute raised an exception. |
| |
| 2007-12-20 Darin Adler <darin@apple.com> |
| |
| - roll out that last change -- it was causing test failures; |
| I'll check it back in after fixing them |
| |
| 2007-12-20 Darin Adler <darin@apple.com> |
| |
| Reviewed by Eric. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=16471 |
| Completions need to be smaller (or not exist at all) |
| |
| SuSpider shows 2.4% speedup. |
| |
| Stop using completions in the execution engine. |
| Instead, the completion type and label target are both |
| stored in the ExecState. |
| |
| * API/JSContextRef.cpp: Removed unneeded include of "completion.h". |
| * bindings/runtime_method.cpp: Removed unused execute function. |
| * bindings/runtime_method.h: Ditto. |
| |
| * kjs/ExecState.h: Added completionType, breakOrContinueTarget, |
| setCompletionType, setNormalCompletion, setBreakCompletion, |
| setContinueCompletion, setReturnValueCompletion, setThrowCompletion, |
| setInterruptedCompletion, m_completionType, and m_breakOrContinueTarget. |
| |
| * kjs/completion.h: Removed constructor and getter for target |
| for break and continue from Completion. This class is now only |
| used for the public API to Interpreter and such. |
| |
| * kjs/date_object.h: Removed unused execute function. |
| |
| * kjs/function.cpp: |
| (KJS::FunctionImp::callAsFunction): Removed some unneeded |
| exception processing. Updated to call the new execute function |
| and to get the completion type from the ExecState. Merged in |
| the execute function, which repeated some of the same logic and |
| was called only from here. |
| (KJS::GlobalFuncImp::callAsFunction): More of the same for eval. |
| * kjs/function.h: Removed execute. |
| |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::evaluate): Added code to convert the result of |
| execut into a Completion. |
| |
| * kjs/nodes.cpp: |
| (KJS::Node::setErrorCompletion): Renamed from createErrorCompletion. |
| Now sets the completion type in the ExecState. |
| (KJS::Node::rethrowException): Now sets the completion type in the |
| ExecState. |
| (KJS::StatementNode::hitStatement): Now sets the completion type in |
| the ExecState. |
| (KJS::VarStatementNode::execute): Updated to put completion type in |
| the ExecState instead of a Completion object. |
| (KJS::statementListExecute): Ditto. Also changed the for loop to use |
| indices instead of iterators. |
| (KJS::BlockNode::execute): Updated return type. |
| (KJS::EmptyStatementNode::execute): Updated to put completion type in |
| the ExecState instead of a Completion object. |
| (KJS::ExprStatementNode::execute): Ditto. |
| (KJS::IfNode::execute): Ditto. |
| (KJS::DoWhileNode::execute): Ditto. Also streamlined the logic a little |
| to make the normal case a little faster and moved the end outside the |
| loop so that "break" can do a break. |
| (KJS::WhileNode::execute): Ditto. |
| (KJS::ForNode::execute): Ditto. |
| (KJS::ForInNode::execute): Ditto. |
| (KJS::ContinueNode::execute): Updated to put completion type in |
| the ExecState instead of a Completion object. |
| (KJS::BreakNode::execute): Ditto. |
| (KJS::ReturnNode::execute): Ditto. |
| (KJS::WithNode::execute): Ditto. |
| (KJS::CaseClauseNode::executeStatements): Ditto. Also renamed to have |
| execute in its name to reflect the fact that it's a member of the same |
| family of functions. |
| (KJS::CaseBlockNode::executeBlock): Ditto. |
| (KJS::SwitchNode::execute): Ditto. |
| (KJS::LabelNode::execute): Ditto. |
| (KJS::ThrowNode::execute): Ditto. |
| (KJS::TryNode::execute): Ditto. |
| (KJS::ProgramNode::execute): Ditto. |
| (KJS::EvalNode::execute): Ditto. |
| (KJS::FunctionBodyNode::execute): Ditto. |
| (KJS::FuncDeclNode::execute): Ditto. |
| |
| * kjs/nodes.h: Renamed setErrorCompletion to createErrorCompletion, made |
| hitStatement protected, changed return value of execute to a JSValue, |
| renamed evalStatements to executeStatements, and evalBlock to executeBlock. |
| |
| * kjs/number_object.h: Removed unused execute function. |
| |
| 2007-12-20 Geoffrey Garen <ggaren@apple.com> |
| |
| Added Radar number. |
| |
| * kjs/nodes.cpp: |
| (KJS::ProgramNode::processDeclarations): |
| |
| 2007-12-20 Geoffrey Garen <ggaren@apple.com> |
| |
| Linux build fix: config.h has to come first. |
| |
| * kjs/error_object.cpp: |
| |
| 2007-12-19 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Optimized global access to global variables, using a symbol table. |
| |
| SunSpider reports a 1.5% overall speedup, a 6.2% speedup on 3d-morph, |
| and a whopping 33.1% speedup on bitops-bitwise-and. |
| |
| * API/JSCallbackObjectFunctions.h: Replaced calls to JSObject:: with |
| calls to Base::, since JSObject is not always our base class. This |
| was always a bug, but the bug is even more apparent after some of my |
| changes. |
| |
| (KJS::::staticFunctionGetter): Replaced use of getDirect with call to |
| getOwnPropertySlot. Global declarations are no longer stored in the |
| property map, so a call to getDirect is insufficient for finding |
| override properties. |
| |
| * API/testapi.c: |
| * API/testapi.js: Added test for the getDirect change mentioned above. |
| |
| * kjs/ExecState.cpp: |
| * kjs/ExecState.h: Dialed back the optimization to store a direct |
| pointer to the localStorage buffer. One ExecState can grow the global |
| object's localStorage without another ExecState's knowledge, so |
| ExecState can't store a direct pointer to the localStorage buffer |
| unless/until we invent a way to update all the relevant ExecStates. |
| |
| * kjs/JSGlobalObject.cpp: Inserted the symbol table into get and put |
| operations. |
| (KJS::JSGlobalObject::reset): Reset the symbol table and local storage, |
| too. Also, clear the property map here, removing the need for a |
| separate call. |
| |
| * kjs/JSVariableObject.cpp: |
| * kjs/JSVariableObject.h: Added support for saving localStorage and the |
| symbol table to the back/forward cache, and restoring them. |
| |
| * kjs/function.cpp: |
| (KJS::GlobalFuncImp::callAsFunction): Renamed progNode to evalNode |
| because it's an EvalNode, not a ProgramNode. |
| |
| * kjs/lookup.h: |
| (KJS::cacheGlobalObject): Replaced put with faster putDirect, since |
| that's how the rest of lookup.h works. putDirect is safe here because |
| cacheGlobalObject is only used for objects whose names are not valid |
| identifiers. |
| |
| * kjs/nodes.cpp: The good stuff! |
| |
| (KJS::EvalNode::processDeclarations): Replaced hasProperty with |
| the new hasOwnProperty, which is slightly faster. |
| |
| * kjs/object.h: Nixed clearProperties because clear() does this job now. |
| |
| * kjs/property_map.cpp: |
| * kjs/property_map.h: More back/forward cache support. |
| |
| * wtf/Vector.h: |
| (WTF::::grow): Added fast non-branching grow function. I used it in |
| an earlier version of this patch, even though it's not used anymore. |
| |
| 2007-12-09 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Build fix for non-Mac platforms. Move NodeInfo into its own header so that the YYTYPE |
| declaration in grammar.h is able to declare members of that type. |
| |
| * kjs/NodeInfo.h: Added. |
| (KJS::createNodeInfo): |
| (KJS::mergeDeclarationLists): |
| (KJS::appendToVarDeclarationList): |
| * kjs/grammar.y: |
| * kjs/lexer.cpp: |
| |
| 2007-12-19 Oliver Hunt <oliver@apple.com> |
| |
| Make appendToVarDeclarationList static |
| |
| RS=Weinig. |
| |
| * kjs/grammar.y: |
| |
| 2007-12-18 Oliver Hunt <oliver@apple.com> |
| |
| Remove dead code due to removal of post-parse declaration discovery. |
| |
| RS=Geoff. |
| |
| Due to the removal of the declaration discovery pass after parsing we |
| no longer need any of the logic used for that discovery. |
| |
| * kjs/nodes.cpp: |
| (KJS::Node::Node): |
| (KJS::VarDeclNode::VarDeclNode): |
| (KJS::BlockNode::BlockNode): |
| (KJS::ForInNode::ForInNode): |
| (KJS::CaseBlockNode::CaseBlockNode): |
| * kjs/nodes.h: |
| (KJS::VarStatementNode::): |
| (KJS::IfNode::): |
| (KJS::DoWhileNode::): |
| (KJS::WhileNode::): |
| (KJS::WithNode::): |
| (KJS::LabelNode::): |
| (KJS::TryNode::): |
| (KJS::FuncDeclNode::): |
| (KJS::CaseClauseNode::): |
| (KJS::ClauseListNode::): |
| (KJS::SwitchNode::): |
| |
| 2007-12-18 Oliver Hunt <oliver@apple.com> |
| |
| Replace post-parse pass to find declarations with logic in the parser itself |
| |
| Reviewed by Geoff. |
| |
| Instead of finding declarations in a pass following the initial parsing of |
| a program, we incorporate the logic directly into the parser. This lays |
| the groundwork for further optimisations (such as improving performance in |
| declaration expressions -- var x = y; -- to match that of standard assignment) |
| in addition to providing a 0.4% performance improvement in SunSpider. |
| |
| * JavaScriptCore.exp: |
| * kjs/Parser.cpp: |
| (KJS::Parser::parse): |
| * kjs/Parser.h: |
| (KJS::Parser::didFinishParsing): |
| (KJS::Parser::parse): |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::ParserTracked::ParserTracked): |
| (KJS::ParserTracked::~ParserTracked): |
| (KJS::ParserTracked::ref): |
| (KJS::ParserTracked::deref): |
| (KJS::ParserTracked::refcount): |
| (KJS::ParserTracked::clearNewTrackedObjects): |
| (KJS::Node::Node): |
| (KJS::ScopeNode::ScopeNode): |
| (KJS::ProgramNode::ProgramNode): |
| (KJS::EvalNode::EvalNode): |
| (KJS::FunctionBodyNode::FunctionBodyNode): |
| (KJS::FunctionBodyNode::initializeSymbolTable): |
| (KJS::FunctionBodyNode::processDeclarations): |
| * kjs/nodes.h: |
| (KJS::ParserTracked::): |
| (KJS::Node::): |
| (KJS::ScopeNode::): |
| |
| 2007-12-18 Xan Lopez <xan@gnome.org> |
| |
| Reviewed by Geoff. |
| |
| Fix http://bugs.webkit.org/show_bug.cgi?id=14521 |
| Bug 14521: JavaScriptCore fails to build on Linux/PPC gcc 4.1.2 |
| |
| * wtf/TCSpinLock.h: |
| (TCMalloc_SpinLock::Unlock): |
| |
| Use less strict memory operand constraint on inline asm generation. |
| PLATFORM(DARWIN) left unpatched due to Apple's GCC bug. |
| |
| Patch by David Kilzer <ddkilzer@webkit.org> |
| |
| 2007-12-18 Mark Rowe <mrowe@apple.com> |
| |
| Rubber-stamped by Maciej Stachowiak. |
| |
| Remove outdated and non-functioning project files for the Apollo port. |
| |
| * JavaScriptCore.apolloproj: Removed. |
| |
| 2007-12-18 Darin Adler <darin@apple.com> |
| |
| - fix Windows build |
| |
| * pcre/pcre_exec.cpp: |
| (jsRegExpExecute): Change back from false/true to 0/1 -- I probably should not have |
| deleted MATCH_MATCH and MATCH_NOMATCH, but I'm going to leave them out. |
| |
| 2007-12-18 Darin Adler <darin@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=16458 |
| REGRESSION (r28164): regular expressions can now hang due to lack of a match limit |
| <rdar://problem/5636067> |
| |
| Test: fast/regex/slow.html |
| |
| Slows down SunSpider a bit (about 1.01x); filed a bug to follow up on that: |
| http://bugs.webkit.org/show_bug.cgi?id=16503 |
| |
| * pcre/pcre.h: Changed name of error code to not specifically mention "recursion". |
| * pcre/pcre_exec.cpp: |
| (match): Replaced the depth limit, MATCH_RECURSION_LIMIT, with a total match looping |
| limit, matchLimit. Also eliminated the constants for MATCH_MATCH and MATCH_NOMATCH, |
| since they are just true and false (1 and 0). |
| (jsRegExpExecute): More of the MATCH_MATCH change. |
| |
| 2007-12-17 Darin Adler <darin@apple.com> |
| |
| - speculative build fix for non-gcc platforms |
| |
| * pcre/pcre_exec.cpp: (match): Remove unused cases from return switch. |
| |
| 2007-12-16 Mark Rowe <mrowe@apple.com> |
| |
| Speculative build fix for non-Mac platforms. |
| |
| * pcre/pcre_compile.cpp: Include string.h for memset, memmove, etc. |
| |
| 2007-12-16 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=16438 |
| - removed some more unused code |
| - changed quite a few more names to WebKit-style |
| - moved more things out of pcre_internal.h |
| - changed some indentation to WebKit-style |
| - improved design of the functions for reading and writing |
| 2-byte values from the opcode stream (in pcre_internal.h) |
| |
| * pcre/dftables.cpp: |
| (main): Added the kjs prefix a normal way in lieu of using macros. |
| |
| * pcre/pcre_compile.cpp: Moved some definitions here from pcre_internal.h. |
| (errorText): Name changes, fewer typedefs. |
| (checkEscape): Ditto. Changed uppercase conversion to use toASCIIUpper. |
| (isCountedRepeat): Name change. |
| (readRepeatCounts): Name change. |
| (firstSignificantOpcode): Got rid of the use of OP_lengths, which is |
| very lightly used here. Hard-coded the length of OP_BRANUMBER. |
| (firstSignificantOpcodeSkippingAssertions): Ditto. Also changed to |
| use the advanceToEndOfBracket function. |
| (getOthercaseRange): Name changes. |
| (encodeUTF8): Ditto. |
| (compileBranch): Name changes. Removed unused after_manual_callout and |
| the code to handle it. Removed code to handle OP_ONCE since we never |
| emit this opcode. Changed to use advanceToEndOfBracket in more places. |
| (compileBracket): Name changes. |
| (branchIsAnchored): Removed code to handle OP_ONCE since we never emit |
| this opcode. |
| (bracketIsAnchored): Name changes. |
| (branchNeedsLineStart): More fo the same. |
| (bracketNeedsLineStart): Ditto. |
| (branchFindFirstAssertedCharacter): Removed OP_ONCE code. |
| (bracketFindFirstAssertedCharacter): More of the same. |
| (calculateCompiledPatternLengthAndFlags): Ditto. |
| (returnError): Name changes. |
| (jsRegExpCompile): Ditto. |
| |
| * pcre/pcre_exec.cpp: Moved some definitions here from pcre_internal.h. |
| (matchRef): Updated names. |
| Improved macros to use the do { } while(0) idiom so they expand to single |
| statements rather than to blocks or multiple statements. And refeactored |
| the recursive match macros. |
| (MatchStack::pushNewFrame): Name changes. |
| (getUTF8CharAndIncrementLength): Name changes. |
| (match): Name changes. Removed the ONCE opcode. |
| (jsRegExpExecute): Name changes. |
| |
| * pcre/pcre_internal.h: Removed quite a few unneeded includes. Rewrote |
| quite a few comments. Removed the macros that add kjs prefixes to the |
| functions with external linkage; instead renamed the functions. Removed |
| the unneeded typedefs pcre_uint16, pcre_uint32, and uschar. Removed the |
| dead and not-all-working code for LINK_SIZE values other than 2, although |
| we aim to keep the abstraction working. Removed the OP_LENGTHS macro. |
| (put2ByteValue): Replaces put2ByteOpcodeValueAtOffset. |
| (get2ByteValue): Replaces get2ByteOpcodeValueAtOffset. |
| (put2ByteValueAndAdvance): Replaces put2ByteOpcodeValueAtOffsetAndAdvance. |
| (putLinkValueAllowZero): Replaces putOpcodeValueAtOffset; doesn't do the |
| addition, since a comma is really no better than a plus sign. Added an |
| assertion to catch out of range values and changed the parameter type to |
| int rather than unsigned. |
| (getLinkValueAllowZero): Replaces getOpcodeValueAtOffset. |
| (putLinkValue): New function that most former callers of the |
| putOpcodeValueAtOffset function can use; asserts the value that is |
| being stored is non-zero and then calls putLinkValueAllowZero. |
| (getLinkValue): Ditto. |
| (putLinkValueAndAdvance): Replaces putOpcodeValueAtOffsetAndAdvance. No |
| caller was using an offset, which makes sense given the advancing behavior. |
| (putLinkValueAllowZeroAndAdvance): Ditto. |
| (isBracketOpcode): Added. For use in an assertion. |
| (advanceToEndOfBracket): Renamed from moveOpcodePtrPastAnyAlternateBranches, |
| and removed comments about how it's not well designed. This function takes |
| a pointer to the beginning of a bracket and advances to the end of the |
| bracket. |
| |
| * pcre/pcre_tables.cpp: Updated names. |
| * pcre/pcre_ucp_searchfuncs.cpp: |
| (kjs_pcre_ucp_othercase): Ditto. |
| * pcre/pcre_xclass.cpp: |
| (getUTF8CharAndAdvancePointer): Ditto. |
| (kjs_pcre_xclass): Ditto. |
| * pcre/ucpinternal.h: Ditto. |
| |
| * wtf/ASCIICType.h: |
| (WTF::isASCIIAlpha): Added an int overload, like the one we already have for |
| isASCIIDigit. |
| (WTF::isASCIIAlphanumeric): Ditto. |
| (WTF::isASCIIHexDigit): Ditto. |
| (WTF::isASCIILower): Ditto. |
| (WTF::isASCIISpace): Ditto. |
| (WTF::toASCIILower): Ditto. |
| (WTF::toASCIIUpper): Ditto. |
| |
| 2007-12-16 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=16459 |
| REGRESSION: assertion failure with regexp with \B in a case-ignoring character range |
| <rdar://problem/5646361> |
| |
| The problem was that \B was not handled properly in character classes. |
| |
| Test: fast/js/regexp-overflow.html |
| |
| * pcre/pcre_compile.cpp: |
| (check_escape): Added handling of ESC_b and ESC_B in character classes here. |
| Allows us to get rid of the handling of \b in character classes from all the |
| call sites that handle it separately and to handle \B properly as well. |
| (compileBranch): Remove the ESC_b handling, since it's not needed any more. |
| (calculateCompiledPatternLengthAndFlags): Ditto. |
| |
| 2007-12-16 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Fix http://bugs.webkit.org/show_bug.cgi?id=16448 |
| Bug 16448: [GTK] Celtic Kane JavaScript performance on Array test is slow relative to Mac |
| |
| * kjs/array_instance.cpp: |
| (KJS::compareByStringPairForQSort): |
| (KJS::ArrayInstance::sort): Convert JSValue's to strings once up front and then sort the |
| results. This avoids calling toString twice per comparison, but requires a temporary buffer |
| so we only use this approach in cases where the array being sorted is not too large. |
| |
| 2007-12-16 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler and Maciej Stachowiak. |
| |
| More refactoring to support global variable optimization. |
| |
| Changed SymbolTable to use RefPtr<UString::Rep> as its key instead of |
| UString::Rep*. With globals, the symbol table can outlast the |
| declaration node for any given symbol, so the symbol table needs to ref |
| its symbol names. |
| |
| In support, specialized HashMaps with RefPtr keys to allow lookup |
| via raw pointer, avoiding refcount churn. |
| |
| SunSpider reports a .6% speedup (prolly just noise). |
| |
| * JavaScriptCore.vcproj/WTF/WTF.vcproj: Added new file: wtf/RefPtrHashMap.h |
| * JavaScriptCore.xcodeproj/project.pbxproj: ditto |
| |
| * kjs/JSVariableObject.cpp: |
| (KJS::JSVariableObject::getPropertyNames): Symbol table keys are RefPtrs now. |
| |
| * kjs/SymbolTable.h: Modified key traits to match RefPtr. Added a |
| static Rep* for null, which helps compute the deletedValue() trait. |
| |
| * wtf/HashMap.h: #include the RefPtr specialization so everyone can use it. |
| |
| * wtf/RefPtrHashMap.h: Copied from wtf/HashMap.h. Added overloaded versions |
| of find(), contains(), get(), set(), add(), remove(), and take() that take |
| raw pointers as keys. |
| |
| 2007-12-16 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=16162 |
| Problems with float parsing on Linux (locale-dependent parsing was used). |
| |
| * kjs/dtoa.cpp: Removed USE_LOCALE to reduce future confusion. |
| * kjs/lexer.cpp: (KJS::Lexer::lex): Parse with kjs_strtod, not the system one. |
| |
| 2007-12-14 Alp Toker <alp@atoker.com> |
| |
| Reviewed by Mark Rowe. |
| |
| Enable the AllInOneFile.cpp optimization for the GTK+ port. |
| |
| * JavaScriptCore.pri: |
| |
| 2007-12-14 Mark Rowe <mrowe@apple.com> |
| |
| Unreviewed. Remove commented out fprintf's that were for debugging purposes only. |
| |
| * wtf/FastMalloc.cpp: |
| (WTF::TCMalloc_PageHeap::IncrementalScavenge): |
| |
| 2007-12-14 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Don't use the MADV_DONTNEED code path for now as it has no effect on Mac OS X and is |
| currently untested on other platforms. |
| |
| * wtf/TCSystemAlloc.cpp: |
| (TCMalloc_SystemRelease): Return after releasing memory rather than potentially falling |
| through into another mechanism if multiple are supported. |
| |
| 2007-12-14 Alp Toker <alp@atoker.com> |
| |
| Build fix for GTK+/Qt and ports that don't use AllInOneFile.cpp. |
| |
| Include UnusedParam.h. |
| |
| * wtf/TCSystemAlloc.cpp: |
| |
| 2007-12-14 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Stephanie. |
| |
| Fix build on windows |
| |
| * wtf/FastMalloc.cpp: |
| (WTF::TCMalloc_PageHeap::IncrementalScavenge): |
| |
| 2007-12-14 Dan Bernstein <mitz@apple.com> |
| |
| - try again to fix the Windows build |
| |
| * wtf/TCSystemAlloc.cpp: |
| (TCMalloc_SystemRelease): |
| |
| 2007-12-14 Dan Bernstein <mitz@apple.com> |
| |
| - try to fix the Windows build |
| |
| * wtf/TCSystemAlloc.cpp: |
| (TCMalloc_SystemRelease): |
| |
| 2007-12-14 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Maciej and Oliver. |
| |
| Add final changes to make TCMalloc release memory to the system. |
| This results in a 0.4% regression against ToT, but this is offset |
| against the gains made by the original TCMalloc r38 merge - in fact |
| we retain around 0.3-0.4% progression overall. |
| |
| * wtf/FastMalloc.cpp: |
| (WTF::InitSizeClasses): |
| (WTF::TCMalloc_PageHeap::IncrementalScavenge): |
| * wtf/TCSystemAlloc.cpp: |
| (TCMalloc_SystemRelease): |
| |
| 2007-12-14 Darin Adler <darin@apple.com> |
| |
| Reviewed by Sam. |
| |
| - removed unnecessary includes of "Vector.h" |
| |
| * wtf/HashMap.h: |
| (WTF::copyKeysToVector): Make the type of the vector be a template parameter. |
| This allows copying keys into a vector of a base class or one with an inline capacity. |
| (WTF::copyValuesToVector): Ditto. |
| * wtf/HashSet.h: |
| (WTF::copyToVector): Ditto. |
| |
| 2007-12-14 Anders Carlsson <andersca@apple.com> |
| |
| Reviewed by Darin and Geoff. |
| |
| <rdar://problem/5619295> |
| REGRESSION: 303-304: Embedded YouTube video fails to render- JS errors (16150) (Flash 9) |
| |
| Get rid of unnecessary and incorrect security checks for plug-ins accessing JavaScript objects. |
| |
| The way this used to work was that each NPObject that wrapped a JSObject would have a root object |
| corresponding to the frame object (used for managing the lifecycle) and an origin root object (used for |
| doing security checks). |
| |
| This would prevent a plug-in from accessing a frame's window object if it's security origin was different |
| (some parts of the window, such as the location object, can be accessed from frames with different security |
| origins, and those checks are being done in WebCore). |
| |
| Also, if a plug-in were to access a window object of a frame that later went away, it could lead to that |
| Window JSObject being garbage collected and the NPObject pointing to freed memory. |
| |
| How this works now is that there is no origin root object anymore, and all NPObject wrappers that are created |
| for a plug-in will have the root object of the containing frame of that plug-in. |
| |
| * bindings/NP_jsobject.cpp: |
| (jsDeallocate): |
| Don't free the origin root object. |
| |
| (_NPN_CreateScriptObject): |
| Remove the origin root object parameter. |
| |
| (_NPN_InvokeDefault): |
| (_NPN_Invoke): |
| (_NPN_Evaluate): |
| (_NPN_GetProperty): |
| (_NPN_SetProperty): |
| (_NPN_RemoveProperty): |
| (_NPN_HasProperty): |
| (_NPN_HasMethod): |
| (_NPN_Enumerate): |
| Get rid of all security checks. |
| |
| * bindings/NP_jsobject.h: |
| Remove originRootObject from the JavaScriptObject struct. |
| |
| * bindings/c/c_utility.cpp: |
| (KJS::Bindings::convertValueToNPVariant): |
| Always use the root object from the ExecState. |
| |
| 2007-12-13 Steve Falkenburg <sfalken@apple.com> |
| |
| Move source file generation into its own vcproj to fix build dependencies. |
| |
| Reviewed by Adam. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore.sln: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCoreGenerated.make: Added. |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCoreGenerated.vcproj: Added. |
| * JavaScriptCore.vcproj/JavaScriptCoreSubmit.sln: |
| |
| 2007-12-13 Alp Toker <alp@atoker.com> |
| |
| http://bugs.webkit.org/show_bug.cgi?id=16406 |
| [Gtk] JavaScriptCore needs -lpthread |
| |
| Build fix for Debian and any other platforms that don't implicitly |
| link to pthread. |
| |
| Link to pthread on non-Windows platforms until this dependency is |
| removed from JSC. |
| |
| 2007-12-11 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Build fix: Note some variables that are used only for ASSERTs. |
| |
| * API/testapi.c: |
| (Base_finalize): |
| (globalObject_initialize): |
| (testInitializeFinalize): |
| |
| 2007-12-11 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Fixed: All JS tests crash on Windows. |
| |
| NDEBUG wasn't defined when compiling testkjs in release builds, so the |
| HashTable definition in HashTable.h included an extra data member. |
| |
| The solution was to add NDEBUG to the release testkjs configuration on |
| Windows and Mac. |
| |
| For giggles, I also added other missing #defines to testkjs on Windows. |
| |
| * Configurations/Base.xcconfig: |
| * Configurations/JavaScriptCore.xcconfig: |
| * JavaScriptCore.vcproj/testkjs/testkjs.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/testkjs.cpp: |
| (main): |
| |
| 2007-12-11 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Removed bogus ASSERT. |
| |
| ASSERT should only be used when we know that a code path will not be |
| taken. This code path is taken often during the jsFunFuzz test. |
| |
| * pcre/pcre_exec.cpp: |
| (jsRegExpExecute): |
| |
| 2007-12-11 Darin Adler <darin@apple.com> |
| |
| * wtf/unicode/qt4/UnicodeQt4.h: Try to fix Qt build by adding U16_IS_SINGLE. |
| |
| 2007-12-10 Darin Adler <darin@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=16379 |
| REGRESSION(r28525): Failures in http/tests/xmlhttprequest/response-encoding.html and |
| fast/dom/xmlhttprequest-html-response-encoding.html |
| and <rdar://problem/5640230> REGRESSION (306A4-ToT): Access violation in PCRE function |
| find_firstassertedchar |
| |
| Test: fast/js/regexp-find-first-asserted.html |
| |
| * pcre/pcre_compile.cpp: |
| (compileBracket): Take out unnecessary initialization of out parameters. |
| (branchFindFirstAssertedCharacter): Added. Broke out the half of the function that handles |
| a branch. |
| (bracketFindFirstAssertedCharacter): Renamed from find_firstassertedchar. Also removed the |
| options parameter -- the caller can handle the options. |
| (jsRegExpCompile): Changed call site to call the appropriate bracket or branch version of |
| the find_firstassertedchar function. Also put the REQ_IGNORE_CASE code here instead of |
| passing in the options. |
| |
| 2007-12-10 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Split this: |
| |
| FunctionBodyNode |
| ^ |
| | |
| ProgramNode |
| |
| into this: |
| |
| ScopeNode |
| ^ ^ ^ |
| | | | |
| FunctionBodyNode ProgramNode EvalNode |
| |
| in preparation for specializing each class more while optimizing global |
| variable access. |
| |
| Also removed some cruft from the FunctionBodyNode interface to simplify |
| things. |
| |
| SunSpider says this patch is a .8% speedup, which seems reasonable, |
| since it eliminates a few branches and adds KJS_FAST_CALL in a few |
| places. |
| |
| Layout tests and JS tests pass. Also, this baby builds on Windows! (Qt |
| mileage may vary...) |
| |
| 2007-12-10 Geoffrey Garen <ggaren@apple.com> |
| |
| RS by Mark Rowe. |
| |
| Mac build fix: added some exported symbols, now that Parser::parse is |
| defined in the header. |
| |
| * JavaScriptCore.exp: |
| |
| 2007-12-10 Sam Weinig <sam@webkit.org> |
| |
| Build fix. |
| |
| Template methods need to be in the header. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * kjs/Parser.cpp: |
| * kjs/Parser.h: |
| (KJS::Parser::parse): |
| |
| 2007-12-10 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Merged different implementations of Parser::parse into a single, |
| templatized implementation, in preparation for adding yet another |
| implementation for "eval" code. |
| |
| JS and layout tests pass. |
| |
| 2007-12-10 Timothy Hatcher <timothy@apple.com> |
| |
| Reviewed by Mark Rowe |
| |
| <rdar://problem/5639463> Bundle versions on Tiger should be 4523.x not 523.x |
| |
| * Configurations/Version.xcconfig: Some Tiger versions of Xcode don't set MAC_OS_X_VERSION_MAJOR, |
| so assume Tiger and use a 4 for the SYSTEM_VERSION_PREFIX. |
| |
| 2007-12-10 Mark Rowe <mrowe@apple.com> |
| |
| Tiger build fix. |
| |
| * kjs/grammar.y: Use @1 and @0 in place of @$ where Tiger's bison chokes. |
| |
| 2007-12-10 Darin Adler <darin@apple.com> |
| |
| Reviewed by Mark Rowe. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=16375 |
| REGRESSION: Safari crashes on quit |
| |
| Probably a debug-only issue. |
| |
| * kjs/Parser.cpp: |
| (KJS::parser): Create the parser and never destroy it by using a pointer instead |
| of a global object. |
| |
| 2007-12-09 Darin Adler <darin@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=16369 |
| REGRESSION (r28525): regular expression tests failing due to bad firstByte optimization |
| |
| * pcre/pcre_compile.cpp: Changed some names to use interCaps intead of under_scores. |
| (branchIsAnchored): Broke is_anchored into two separate functions; this one works on a |
| branch and the other on an anchor. The old function would only work on a bracket. |
| Also removed unneeded parameters; the anchored check does not require the bracket |
| map or the options any more because we have a reduced set of features. |
| (bracketIsAnchored): Ditto. |
| (branchNeedsLineStart): Broke canApplyFirstCharOptimization into two functions and gave |
| both a better name. This is the function that was returning the wrong value. The failure |
| was beacuse the old function would only work on a bracket. |
| (bracketNeedsLineStart): Ditto. |
| (jsRegExpCompile): Changed to call the appropriate branch or bracket flavor of the |
| functions based on whether we compiled an outer bracket. Also removed inaccurate comments |
| and unneeded parameters. |
| |
| - other small changes |
| |
| * pcre/pcre.h: Renumbered error codes, in a logical order. First, normal failure, then |
| the recursion limit, then running out of memory, and finally an unexpected internal error. |
| |
| * pcre/pcre_exec.cpp: Fixed indentation. |
| (jsRegExpExecute): Corrected an inaccurate comment. |
| |
| 2007-12-09 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=16370 |
| REGRESSION (r28540): source URL and line number no longer set for outer function/programs |
| |
| Test: fast/js/exception-linenums-in-html-1.html |
| Test: fast/js/exception-linenums-in-html-2.html |
| Test: fast/js/exception-linenums.html |
| |
| By the time the ProgramNode was constructed, the source URL was empty. |
| |
| * kjs/Parser.cpp: |
| (KJS::Parser::parseProgram): Added code to set and clear m_sourceURL, which is now |
| handled here instead of in the lexer; it needs to still be set when we create the |
| program node. Call setLoc to set the first and last line number. |
| (KJS::Parser::parseFunctionBody): Ditto, but for the body. |
| (KJS::Parser::parse): Removed the sourceURL argument. |
| |
| * kjs/Parser.h: Added sourceURL(), m_sourceURL, and m_lastLine. Added a lastLine |
| parameter to didFinishParsing, since the bison grammar knows the last line number |
| and we otherwise do not know it. Removed the sourceURL parameter from parse, since |
| that's now handled at a higher level. |
| |
| * kjs/grammar.y: Pass the last line number to didFinishParsing. |
| |
| * kjs/lexer.cpp: |
| (KJS::Lexer::setCode): Removed the sourceURL argument and the code to set m_sourceURL. |
| (KJS::Lexer::clear): Ditto. |
| * kjs/lexer.h: More of the same. |
| |
| * kjs/nodes.cpp: |
| (KJS::FunctionBodyNode::FunctionBodyNode): Get the source URL from the parser rather |
| than from the lexer. Removed unneeded call to setLoc, since the line numbers already |
| both default to -1. |
| |
| 2007-12-08 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Sam W. |
| |
| Split the ENABLE_SVG_EXPERIMENTAL_FEATURES flag into separate flags. |
| |
| Fixes <rdar://problem/5620249> Must disable SVG animation |
| <rdar://problem/5612772> Disable SVG filters on Mac to match Windows behavior |
| |
| Minor config changes. |
| |
| * Configurations/JavaScriptCore.xcconfig: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2007-12-07 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Darin. |
| |
| - Rename isSafeScript to allowsAccessFrom. |
| |
| * bindings/NP_jsobject.cpp: |
| (_isSafeScript): |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::allowsAccessFrom): Reverse caller/argument of allowsAccessFrom to match |
| the new call. |
| |
| 2007-12-07 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Refactored variable access optimization: Removed the assumption that |
| the FunctionBodyNode holds the symbol table. |
| |
| 2007-12-07 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: added #include. |
| |
| * kjs/nodes.cpp: |
| |
| 2007-12-07 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: added #include. |
| |
| * kjs/interpreter.cpp: |
| |
| 2007-12-07 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: added #include. |
| |
| * kjs/grammar.y: |
| |
| 2007-12-07 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: added #include. |
| |
| * kjs/function_object.cpp: |
| |
| 2007-12-07 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Fixed crash seen running layout tests. |
| |
| Reverted a change I made earlier today. Added a comment to try to |
| discourage myself from making this mistake a third time. |
| |
| * kjs/function.cpp: |
| (KJS::ActivationImp::mark): |
| * kjs/function.h: |
| (KJS::ActivationImp::ActivationImpData::ActivationImpData): |
| |
| 2007-12-07 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Refactored parsing of global code: Removed the assumption that |
| ProgramNode inherits from FunctionBodyNode from the parser. |
| |
| * kjs/Parser.cpp: |
| (KJS::Parser::parseProgram): |
| (KJS::Parser::parseFunctionBody): |
| (KJS::Parser::parse): |
| * kjs/Parser.h: |
| (KJS::Parser::didFinishParsing): |
| * kjs/function.cpp: |
| * kjs/grammar.y: |
| * kjs/nodes.h: |
| |
| 2007-12-07 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: added JSVariableObject.cpp to the .pri file. |
| |
| * JavaScriptCore.pri: |
| |
| 2007-12-07 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: added #include. |
| |
| * kjs/function.cpp: |
| |
| 2007-12-07 Steve Falkenburg <sfalken@apple.com> |
| |
| Re-named our B&I flag from BUILDBOT to PRODUCTION. |
| |
| Reviewed by Sam Weinig. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore.make: |
| * JavaScriptCore.vcproj/testkjs/testkjs.vcproj: |
| |
| 2007-12-07 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: removed stray name qualification. |
| |
| * kjs/function.h: |
| (KJS::ActivationImp::ActivationImp): |
| |
| 2007-12-07 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: moved functions with qualified names outside of class |
| declaration. |
| |
| * kjs/JSVariableObject.h: |
| (KJS::JSVariableObject::symbolTableGet): |
| (KJS::JSVariableObject::symbolTablePut): |
| |
| 2007-12-07 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Next step in refactoring JSGlobalObject: Added JSVariableObject class, |
| and factored symbol-table-related code into it. (JSGlobalObject doesn't |
| use the symbol table code yet, though.) |
| |
| Layout and JS tests, and testapi, pass. SunSpider reports no regression. |
| |
| 2007-12-07 Darin Adler <darin@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=16185 |
| jsRegExpCompile should not add implicit non-capturing bracket |
| |
| While this does not make SunSpider faster, it will make many regular |
| expressions a bit faster. |
| |
| * pcre/pcre_compile.cpp: Moved CompileData struct in here from the |
| header since it's private to this file. |
| (compile_branch): Updated for function name change. |
| (compile_bracket): Renamed from compile_regex, since, for one thing, |
| this does not compile an entire regular expression. |
| (calculateCompiledPatternLengthAndFlags): Removed unused item_count |
| local variable. Renamed CompileData to cd instead of compile_block |
| to be consistent with other functions. Added code to set the |
| needOuterBracket flag if there's at least one "|" at the outer level. |
| (jsRegExpCompile): Renamed CompileData to cd instead of compile_block |
| to be consistent with other functions. Removed unneeded "size" field |
| from the compiled regular expression. If no outer bracket is needed, |
| then use compile_branch to compile the regular expression. |
| |
| * pcre/pcre_internal.h: Removed the CompileData struct, which is now |
| private to pcre_compile.cpp. Removed the size member from JSRegExp. |
| |
| 2007-12-06 Kevin Ollivier <kevino@theolliviers.com> |
| |
| MSVC7 build fix due to a compiler bug with placement new and/or |
| templates and casting. |
| |
| Reviewed by Darin Adler. |
| |
| * wtf/Vector.h: |
| (WTF::::append): |
| |
| 2007-12-06 Darin Adler <darin@apple.com> |
| |
| Reviewed by Eric Seidel. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=16321 |
| new RegExp("[\u0097]{4,6}", "gmy") crashes in DEBUG builds |
| <rdar://problem/5632992> |
| |
| Test: fast/js/regexp-oveflow.html |
| |
| * pcre/pcre_compile.cpp: |
| (calculateCompiledPatternLengthAndFlags): In the case where a single character |
| character class is optimized to not use a character class at all, the preflight |
| code was not setting the lastitemlength variable. |
| |
| 2007-12-05 Mark Rowe <mrowe@apple.com> |
| |
| Qt Windows build fix. Include the time-related headers in the correct place. |
| |
| * kjs/JSGlobalObject.cpp: |
| * kjs/interpreter.cpp: |
| |
| 2007-12-05 Darin Adler <darin@apple.com> |
| |
| Not reviewed; just undoing a previous commit. |
| |
| - remove earlier incorrect fix for http://bugs.webkit.org/show_bug.cgi?id=16220 |
| <rdar://problem/5625221> Crash opening www.news.com (CNet) |
| |
| The real bug was the backwards ?: in the compile function, which Geoff just |
| fixed. Rolling out the incorrect earlier fix. |
| |
| * pcre/pcre_compile.cpp: (calculateCompiledPatternLengthAndFlags): Take out |
| the unneeded preflight change. The regression test proves this is still working |
| fine, so the bug remains fixed. |
| |
| 2007-12-01 Mark Rowe <mrowe@apple.com> |
| |
| Build fix. Include headers before trying to use the things that they declare. |
| |
| * kjs/JSImmediate.cpp: |
| * kjs/nodes.cpp: |
| * kjs/object.cpp: |
| * kjs/object_object.cpp: |
| * kjs/regexp_object.cpp: |
| * kjs/string_object.cpp: |
| |
| 2007-12-05 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: added some #includes. |
| |
| * kjs/JSImmediate.cpp: |
| |
| 2007-12-05 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: added some #includes. |
| |
| * kjs/JSGlobalObject.cpp: |
| * kjs/JSImmediate.cpp: |
| |
| 2007-12-05 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: Fixed #include spelling. |
| |
| * kjs/debugger.cpp: |
| |
| 2007-12-05 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: added #include. |
| |
| * kjs/debugger.cpp: |
| |
| 2007-12-05 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: added a forward declaration. |
| |
| * kjs/debugger.h: |
| |
| 2007-12-05 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: added an #include. |
| |
| * kjs/error_object.cpp: |
| |
| 2007-12-05 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: added an #include. |
| |
| * kjs/bool_object.cpp: |
| |
| 2007-12-05 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Third step in refactoring JSGlobalObject: Moved data members and |
| functions accessing data members from Interpreter to JSGlobalObject. |
| Changed Interpreter member functions to static functions. |
| |
| This resolves a bug in global object bootstrapping, where the global |
| ExecState could be used when uninitialized. |
| |
| This is a big change, but it's mostly code motion and renaming. |
| |
| Layout and JS tests, and testjsglue and testapi, pass. SunSpider reports |
| a .7% regression, but Shark sees no difference related to this patch, |
| and SunSpider reported a .7% speedup from an earlier step in this |
| refactoring, so I think it's fair to call that a wash. |
| |
| 2007-12-05 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. (Or vice versa.) |
| |
| Fixed ASSERT during run-javascriptcore-tests. (Darin just added the |
| ASSERT, but the bug wasn't new.) |
| |
| * pcre/pcre_compile.cpp: |
| (compile_branch): The ?: operator here was backwards, causing us to |
| execute the loop too many times, adding stray KET opcodes to the |
| compiled regular expression. |
| |
| 2007-12-05 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - Wait until local variable data is fully constructed before notifying the debugger of entering |
| or leaving a call frame. |
| |
| * kjs/function.cpp: |
| (KJS::FunctionImp::callAsFunction): |
| * kjs/nodes.cpp: |
| (KJS::FunctionBodyNode::execute): |
| |
| 2007-12-05 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Oliver. |
| |
| Build fix for GCC 4.2. Cast via a union to avoid strict-aliasing issues. |
| |
| * wtf/FastMalloc.cpp: |
| (WTF::): |
| (WTF::getPageHeap): |
| |
| 2007-12-05 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Darin. |
| |
| Fix testkjs in 64-bit. |
| |
| When built for 64-bit the TCMalloc spin lock uses pthread mutexes rather than a custom spin lock |
| implemented in assembly. If we fail to initialize the pthread mutex, attempts to lock or unlock |
| it will fail and trigger a call to abort. |
| |
| * wtf/FastMalloc.cpp: Initialize the spin lock so that we can later lock and unlock it. |
| * wtf/TCSpinLock.h: Add an Init method to the optimised spin lock. |
| |
| 2007-12-04 Oliver Hunt <oliver@apple.com> |
| |
| Fix gtk build. |
| |
| * wtf/TCSystemAlloc.cpp: |
| |
| 2007-12-03 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Mark Rowe and Geoff Garen. |
| |
| Merge TCMalloc r38 |
| |
| It also result in a performance progression between 0.5% and |
| 0.9% depending on the test, however most if not all of this |
| gain will be consumed by the overhead involved in the later |
| change to release memory to the system. |
| |
| * JavaScriptCore.vcproj/WTF/WTF.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * wtf/FastMalloc.cpp: |
| (WTF::KernelSupportsTLS): |
| (WTF::CheckIfKernelSupportsTLS): |
| (WTF::): |
| (WTF::ClassIndex): |
| (WTF::SLL_Next): |
| (WTF::SLL_SetNext): |
| (WTF::SLL_Push): |
| (WTF::SLL_Pop): |
| (WTF::SLL_PopRange): |
| (WTF::SLL_PushRange): |
| (WTF::SLL_Size): |
| (WTF::SizeClass): |
| (WTF::ByteSizeForClass): |
| (WTF::NumMoveSize): |
| (WTF::InitSizeClasses): |
| (WTF::AllocationSize): |
| (WTF::TCMalloc_PageHeap::GetSizeClassIfCached): |
| (WTF::TCMalloc_PageHeap::CacheSizeClass): |
| (WTF::TCMalloc_PageHeap::init): |
| (WTF::TCMalloc_PageHeap::New): |
| (WTF::TCMalloc_PageHeap::AllocLarge): |
| (WTF::TCMalloc_PageHeap::Carve): |
| (WTF::TCMalloc_PageHeap::Delete): |
| (WTF::TCMalloc_PageHeap::IncrementalScavenge): |
| (WTF::PagesToMB): |
| (WTF::TCMalloc_PageHeap::Dump): |
| (WTF::TCMalloc_PageHeap::GrowHeap): |
| (WTF::TCMalloc_PageHeap::Check): |
| (WTF::ReleaseFreeList): |
| (WTF::TCMalloc_PageHeap::ReleaseFreePages): |
| (WTF::TCMalloc_ThreadCache_FreeList::Push): |
| (WTF::TCMalloc_ThreadCache_FreeList::PushRange): |
| (WTF::TCMalloc_ThreadCache_FreeList::PopRange): |
| (WTF::TCMalloc_ThreadCache_FreeList::Pop): |
| (WTF::TCMalloc_Central_FreeList::length): |
| (WTF::TCMalloc_Central_FreeList::tc_length): |
| (WTF::TCMalloc_Central_FreeList::Init): |
| (WTF::TCMalloc_Central_FreeList::ReleaseListToSpans): |
| (WTF::TCMalloc_Central_FreeList::EvictRandomSizeClass): |
| (WTF::TCMalloc_Central_FreeList::MakeCacheSpace): |
| (WTF::TCMalloc_Central_FreeList::ShrinkCache): |
| (WTF::TCMalloc_Central_FreeList::InsertRange): |
| (WTF::TCMalloc_Central_FreeList::RemoveRange): |
| (WTF::TCMalloc_Central_FreeList::FetchFromSpansSafe): |
| (WTF::TCMalloc_Central_FreeList::Populate): |
| (WTF::TCMalloc_ThreadCache::Init): |
| (WTF::TCMalloc_ThreadCache::Cleanup): |
| (WTF::TCMalloc_ThreadCache::Allocate): |
| (WTF::TCMalloc_ThreadCache::Deallocate): |
| (WTF::TCMalloc_ThreadCache::FetchFromCentralCache): |
| (WTF::TCMalloc_ThreadCache::ReleaseToCentralCache): |
| (WTF::TCMalloc_ThreadCache::Scavenge): |
| (WTF::TCMalloc_ThreadCache::PickNextSample): |
| (WTF::TCMalloc_ThreadCache::NewHeap): |
| (WTF::TCMalloc_ThreadCache::GetThreadHeap): |
| (WTF::TCMalloc_ThreadCache::GetCache): |
| (WTF::TCMalloc_ThreadCache::GetCacheIfPresent): |
| (WTF::TCMalloc_ThreadCache::InitTSD): |
| (WTF::TCMalloc_ThreadCache::CreateCacheIfNecessary): |
| (WTF::TCMallocStats::ExtractStats): |
| (WTF::TCMallocStats::DumpStats): |
| (WTF::TCMallocStats::DumpStackTraces): |
| (WTF::TCMallocStats::TCMallocImplementation::MarkThreadIdle): |
| (WTF::TCMallocStats::TCMallocImplementation::ReleaseFreeMemory): |
| (WTF::TCMallocStats::TCMallocGuard::TCMallocGuard): |
| (WTF::TCMallocStats::TCMallocGuard::~TCMallocGuard): |
| (WTF::TCMallocStats::DoSampledAllocation): |
| (WTF::TCMallocStats::CheckCachedSizeClass): |
| (WTF::TCMallocStats::CheckedMallocResult): |
| (WTF::TCMallocStats::SpanToMallocResult): |
| (WTF::TCMallocStats::do_malloc): |
| (WTF::TCMallocStats::do_free): |
| (WTF::TCMallocStats::do_memalign): |
| (WTF::TCMallocStats::do_malloc_stats): |
| (WTF::TCMallocStats::do_mallopt): |
| (WTF::TCMallocStats::do_mallinfo): |
| (WTF::TCMallocStats::realloc): |
| (WTF::TCMallocStats::cpp_alloc): |
| (WTF::TCMallocStats::operator new): |
| (WTF::TCMallocStats::): |
| (WTF::TCMallocStats::operator new[]): |
| (WTF::TCMallocStats::malloc_stats): |
| (WTF::TCMallocStats::mallopt): |
| (WTF::TCMallocStats::mallinfo): |
| * wtf/TCPackedCache.h: Added. |
| (PackedCache::PackedCache): |
| (PackedCache::Put): |
| (PackedCache::Has): |
| (PackedCache::GetOrDefault): |
| (PackedCache::Clear): |
| (PackedCache::EntryToValue): |
| (PackedCache::EntryToUpper): |
| (PackedCache::KeyToUpper): |
| (PackedCache::UpperToPartialKey): |
| (PackedCache::Hash): |
| (PackedCache::KeyMatch): |
| * wtf/TCPageMap.h: |
| (TCMalloc_PageMap2::PreallocateMoreMemory): |
| * wtf/TCSystemAlloc.cpp: |
| (TCMalloc_SystemRelease): |
| * wtf/TCSystemAlloc.h: |
| |
| 2007-12-04 Anders Carlsson <andersca@apple.com> |
| |
| Reviewed by Sam. |
| |
| Make isSafeScript const. |
| |
| * kjs/JSGlobalObject.h: |
| (KJS::JSGlobalObject::isSafeScript): |
| |
| 2007-12-04 Darin Adler <darin@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - fix first part of http://bugs.webkit.org/show_bug.cgi?id=16220 |
| <rdar://problem/5625221> Crash opening www.news.com (CNet) |
| |
| Test: fast/js/regexp-overflow.html |
| |
| * pcre/pcre_compile.cpp: |
| (calculateCompiledPatternLengthAndFlags): Add room for the additional BRA/KET that |
| was generated in the compile code but not taken into account here. |
| |
| 2007-12-03 Darin Adler <darin@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=15618 |
| <rdar://problem/5619353> REGRESSION: Stack overflow/crash in KJS::equal (15618) |
| |
| Test: fast/js/recursion-limit-equal.html |
| |
| * kjs/operations.cpp: (KJS::equal): Check the exception from toPrimitive. |
| |
| 2007-12-03 Dan Bernstein <mitz@apple.com> |
| |
| - fix a copy-and-paste-o |
| |
| * bindings/npruntime.cpp: |
| (_NPN_GetIntIdentifier): |
| |
| 2007-12-03 Dan Bernstein <mitz@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| - fix an ASSERT when getIntIdentifier is called with 0 or -1 |
| |
| * bindings/npruntime.cpp: |
| (_NPN_GetIntIdentifier): We cannot use the hashmap for 0 and -1 since |
| they are the empty value and the deleted value. Instead, keep the |
| identifiers for those two integers in a static array. |
| |
| 2007-12-02 Darin Adler <darin@apple.com> |
| |
| Reviewed by Mitz. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=15848 |
| <rdar://problem/5619330> REGRESSION: Assertion failure viewing comments page on digg.com |
| |
| Test: fast/js/sparse-array.html |
| |
| * kjs/array_instance.cpp: |
| (KJS::ArrayInstance::inlineGetOwnPropertySlot): Check sparse array cutoff before looking |
| in hash map. Can't avoid the branch because we can't look for 0 in the hash. |
| (KJS::ArrayInstance::deleteProperty): Ditto. |
| |
| 2007-12-02 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: added an #include. |
| |
| * kjs/collector.cpp: |
| |
| 2007-12-02 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Eric Seidel. |
| |
| Second step in refactoring JSGlobalObject: moved virtual functions from |
| Interpreter to JSGlobalObject. |
| |
| Layout and JS tests pass. SunSpider reports a .7% speedup -- don't |
| believe his lies. |
| |
| 2007-12-01 Alp Toker <alp@atoker.com> |
| |
| Reviewed by Adam Roben. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=16228 |
| kJSClassDefinitionEmpty is not exported with JS_EXPORT |
| |
| Add JS_EXPORT to kJSClassDefinitionEmpty. |
| |
| Make the gcc compiler check take precedence over the WIN32||_WIN32 |
| check to ensure that symbols are exported on Windows when using gcc. |
| |
| Add a TODO referencing the bug about JS_EXPORT in the Win build |
| (http://bugs.webkit.org/show_bug.cgi?id=16227) |
| |
| Don't define JS_EXPORT as 'extern' when the compiler is unknown since |
| it would result in the incorrect expansion: |
| |
| extern extern const JSClassDefinition kJSClassDefinitionEmpty; |
| |
| (This was something we inherited from CFBase.h that doesn't make sense |
| for JSBase.h) |
| |
| * API/JSBase.h: |
| * API/JSObjectRef.h: |
| |
| 2007-11-30 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Beth Dakin. |
| |
| Reversed the ownership relationship between Interpreter and JSGlobalObject. |
| Now, the JSGlobalObject owns the Interpreter, and top-level objects |
| that need the two to persist just protect the JSGlobalObject from GC. |
| |
| Global object bootstrapping looks a little odd right now, but it will |
| make much more sense soon, after further rounds of refactoring. |
| |
| * bindings/runtime_root.h: Made this class inherit from RefCounted, |
| to avoid code duplication. |
| |
| * kjs/collector.cpp: |
| (KJS::Collector::collect): No need to give special GC treatment to |
| Interpreters, since we mark their global objects, which mark them. |
| |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::mark): No need to mark our global object, since it |
| marks us. |
| * kjs/interpreter.h: Don't inherit from RefCounted -- JSGlobalObject |
| owns us directly. |
| |
| * kjs/testkjs.cpp: Modified to follow the new rules. |
| (createGlobalObject): |
| (runWithScripts): |
| |
| 2007-11-30 Brent Fulgham <bfulgham@gmail.com> |
| |
| Reviewed by Eric. |
| |
| * ChangeLog: |
| * pcre/pcre_compile.cpp: |
| (compile_branch): |
| |
| 2007-11-30 Eric Seidel <eric@webkit.org> |
| |
| No review, build fix only. |
| |
| Fix uninitialized var warnings in release build. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * pcre/pcre_compile.cpp: |
| (compile_regex): |
| |
| 2007-11-30 Darin Adler <darin@apple.com> |
| |
| Reviewed by Adam Roben. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=16207 |
| JavaScript regular expressions should match UTF-16 code units rather than characters |
| |
| SunSpider says this is 5.5% faster on the regexp test, 0.4% faste overall. |
| |
| Test: fast/js/regexp-non-bmp.html |
| |
| Renamed ANY_CHAR to NOT_NEWLINE to more-accurately reflect its meaning. |
| |
| * pcre/pcre_compile.cpp: |
| (compile_branch): Removed calls to the UTF-16 character accessor functions, replacing |
| them with simple pointer dereferences in some cases, and no code at all in others. |
| (calculateCompiledPatternLengthAndFlags): Ditto. |
| |
| * pcre/pcre_exec.cpp: |
| (match): Fixed indentation of some case labels (including all the BEGIN_OPCODE). |
| Removed calls to the UTF-16 character accessor functions, replacing them with simple |
| pointer dereferences in some cases, and no code at all in others. Also removed some |
| explicit UTF-16 support code in a few cases. Removed the unneeded "UTF-8" code path |
| in the ANY_CHAR repeat code, and in another case, eliminated the code to check against |
| end_subject in because it is already done outside the loop. |
| (jsRegExpExecute): |
| |
| * pcre/pcre_internal.h: Removed all the UTF-16 helper functions. |
| |
| 2007-11-30 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by darin. |
| |
| PCRE crashes under GuardMalloc |
| http://bugs.webkit.org/show_bug.cgi?id=16127 |
| check against patternEnd to make sure we don't walk off the end of the string |
| |
| * pcre/pcre_compile.cpp: |
| (compile_branch): |
| (calculateCompiledPatternLengthAndFlags): |
| |
| 2007-11-30 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Fix layout test regressions caused by r28186 |
| http://bugs.webkit.org/show_bug.cgi?id=16195 |
| change first_byte and req_byte back to shorts instead of chars |
| (I think PCRE stuffs information in the high bits) |
| |
| * pcre/pcre_internal.h: |
| |
| 2007-11-29 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej and Darin. |
| |
| Make the JS collector work with multiple threads |
| |
| Under heavy contention it was possible the GC to suspend other |
| threads inside the pthread spinlock, which could lead to the GC |
| thread blocking on the pthread spinlock itself. |
| |
| We now determine and store each thread's stack base when it is |
| registered, thus removing the need for any calls to pthread_get_stackaddr_np |
| that needed the pthread spinlock. |
| |
| * kjs/collector.cpp: |
| (KJS::Collector::Thread::Thread): |
| (KJS::Collector::registerThread): |
| (KJS::Collector::markOtherThreadConservatively): |
| |
| 2007-11-29 Adam Roben <aroben@apple.com> |
| |
| Windows build fix |
| |
| Removed some unreachable code (ironically, the code was some |
| ASSERT_NOT_REACHED()s). |
| |
| * pcre/pcre_compile.cpp: |
| (compile_branch): |
| * pcre/pcre_exec.cpp: |
| (match): |
| |
| 2007-11-29 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Mark Rowe. |
| |
| Fix for --guard crash of fast/js/regexp-charclass-crash introduced by r28151. |
| |
| * pcre/pcre_compile.cpp: |
| (is_anchored): |
| |
| 2007-11-28 Mark Rowe <mrowe@apple.com> |
| |
| Gtk build fix. Rubber-stamped by Eric. |
| |
| * pcre/pcre_exec.cpp: |
| (match): Add braces around the body of the case statement to prevent |
| wanings about jumps across the initialization of a variable. |
| |
| 2007-11-29 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Mark Rowe. |
| |
| Attempt to fix non-mac builds after PCRE cleanup. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCoreSources.bkl: |
| * pcre/pcre.pri: |
| |
| 2007-11-28 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Centralize code for subjectPtr adjustments using inlines, only ever check for a single |
| trailing surrogate (as UTF16 only allows one), possibly fix PCRE bugs involving char |
| classes and garbled UTF16 strings. |
| |
| * pcre/pcre_exec.cpp: |
| (match): |
| (jsRegExpExecute): |
| * pcre/pcre_internal.h: |
| (getPreviousChar): |
| (movePtrToPreviousChar): |
| (movePtrToNextChar): |
| (movePtrToStartOfCurrentChar): |
| |
| 2007-11-28 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| change getChar* functions to return result and push 'c' into local scopes for clarity |
| |
| * pcre/pcre_compile.cpp: |
| (compile_branch): |
| (calculateCompiledPatternLengthAndFlags): |
| * pcre/pcre_exec.cpp: |
| (match): |
| * pcre/pcre_internal.h: |
| (getChar): |
| (getCharAndAdvance): |
| (getCharAndLength): |
| (getCharAndAdvanceIfSurrogate): |
| |
| 2007-11-28 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Comment cleanup |
| |
| * pcre/pcre_exec.cpp: |
| (match): |
| |
| 2007-11-26 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Further cleanups to calculateCompiledPatternLengthAndFlags |
| |
| * pcre/pcre_compile.cpp: |
| (calculateCompiledPatternLengthAndFlags): |
| * pcre/pcre_internal.h: |
| |
| 2007-11-26 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Give consistent naming to the RegExp options/compile flags |
| |
| * pcre/pcre_compile.cpp: |
| (compile_branch): |
| (is_anchored): |
| (find_firstassertedchar): |
| (printCompiledRegExp): |
| (jsRegExpCompile): |
| * pcre/pcre_exec.cpp: |
| (jsRegExpExecute): |
| * pcre/pcre_internal.h: |
| |
| 2007-11-26 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Pull first_byte and req_byte optimizations out into separate static funtions, SunSpider reported this as a win. |
| |
| * pcre/pcre_exec.cpp: |
| (tryFirstByteOptimization): |
| (tryRequiredByteOptimization): |
| (jsRegExpExecute): |
| * pcre/pcre_internal.h: |
| |
| 2007-11-26 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| give PCRE_MULTILINE a better name: OptionMatchAcrossMultipleLines |
| |
| * pcre/pcre_compile.cpp: |
| (compile_branch): |
| (is_anchored): |
| (printCompiledRegExp): |
| (jsRegExpCompile): |
| * pcre/pcre_exec.cpp: |
| (jsRegExpExecute): |
| * pcre/pcre_internal.h: |
| |
| 2007-11-26 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Oliver. |
| |
| Deprecate jsRegExpExecute's offset-vector fallback code |
| |
| * pcre/pcre_exec.cpp: |
| (jsRegExpExecute): |
| |
| 2007-11-26 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Make cur_is_word and prev_is_word locals, and change OP_ANY to OP_ANY_CHAR for clarity |
| |
| * pcre/pcre_compile.cpp: |
| (find_fixedlength): |
| (compile_branch): |
| (canApplyFirstCharOptimization): |
| * pcre/pcre_exec.cpp: |
| (match): |
| * pcre/pcre_internal.h: |
| |
| 2007-11-26 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Mitz & Maciej. |
| |
| Change _NC operators to use _IGNORING_CASE for clarity |
| |
| * pcre/pcre_compile.cpp: |
| (find_fixedlength): |
| (compile_branch): |
| (find_firstassertedchar): |
| * pcre/pcre_exec.cpp: |
| (match): |
| * pcre/pcre_internal.h: |
| |
| 2007-11-26 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Mitz. |
| |
| Remove branch from return |
| |
| * pcre/pcre_compile.cpp: |
| (compile_branch): |
| * pcre/pcre_exec.cpp: |
| (match): |
| |
| 2007-11-26 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Add repeatInformationFromInstructionOffset inline |
| |
| * pcre/pcre_exec.cpp: |
| (repeatInformationFromInstructionOffset): |
| (match): |
| |
| 2007-11-26 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Remove no longer used error code JSRegExpErrorMatchLimit |
| |
| * kjs/regexp.cpp: |
| (KJS::RegExp::match): |
| * pcre/pcre.h: |
| * pcre/pcre_internal.h: |
| |
| 2007-11-26 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Make i locally scoped for better code clarity |
| |
| * pcre/pcre_exec.cpp: |
| (match): |
| |
| 2007-11-26 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Give subjectPtr and instructionPtr sane names, reduce size of MatchFrame for a 0.2% speedup. |
| |
| * pcre/pcre_compile.cpp: |
| (compile_branch): |
| (calculateCompiledPatternLengthAndFlags): |
| * pcre/pcre_exec.cpp: |
| (match_ref): |
| (MatchStack::pushNewFrame): |
| (getUTF8CharAndIncrementLength): |
| (match): |
| * pcre/pcre_internal.h: |
| (getChar): |
| (getCharAndAdvance): |
| (getCharAndLength): |
| (getCharAndAdvanceIfSurrogate): |
| * pcre/pcre_xclass.cpp: |
| (getUTF8CharAndAdvancePointer): |
| |
| 2007-11-26 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Small speedup (0.7%) by simplifying canUseStackBufferForNextFrame() check |
| |
| * pcre/pcre_exec.cpp: |
| (MatchStack::MatchStack): |
| (MatchStack::popCurrentFrame): |
| |
| 2007-11-25 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Lower MATCH_LIMIT_RECURSION to more sane levels to prevent hangs on run-javascriptcore-tests |
| |
| * pcre/pcre_internal.h: |
| |
| 2007-11-25 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Remove match_is_group variable for another 5% speedup |
| |
| * pcre/pcre_compile.cpp: |
| * pcre/pcre_exec.cpp: |
| (startNewGroup): |
| (match): |
| |
| 2007-11-28 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Abstract frame variables into locals and args |
| |
| * pcre/pcre_compile.cpp: |
| (compile_branch): |
| * pcre/pcre_exec.cpp: |
| (match): |
| * pcre/pcre_internal.h: |
| |
| 2007-11-28 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Section off MatchData arguments into args struct |
| |
| * pcre/pcre_exec.cpp: |
| (MatchStack::pushNewFrame): |
| (match): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Remove redundant eptrblock struct |
| |
| * pcre/pcre_exec.cpp: |
| (MatchStack::pushNewFrame): |
| (match): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Remove redundant match_call_count and move recursion check out of super-hot code path |
| SunSpider says this is at least an 8% speedup for regexp. |
| |
| * pcre/pcre_exec.cpp: |
| (MatchStack::MatchStack): |
| (MatchStack::pushNewFrame): |
| (MatchStack::popCurrentFrame): |
| (MatchStack::popAllFrames): |
| (match): |
| (jsRegExpExecute): |
| * pcre/pcre_internal.h: |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Get rid of GETCHAR* macros, replacing them with better named inlines |
| |
| * pcre/pcre_compile.cpp: |
| (compile_branch): |
| (calculateCompiledPatternLengthAndFlags): |
| * pcre/pcre_exec.cpp: |
| (match): |
| * pcre/pcre_internal.h: |
| (getCharAndAdvance): |
| (getCharAndLength): |
| (getCharAndAdvanceIfSurrogate): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Further cleanup GET/PUT inlines |
| |
| * pcre/pcre_internal.h: |
| (putOpcodeValueAtOffset): |
| (getOpcodeValueAtOffset): |
| (putOpcodeValueAtOffsetAndAdvance): |
| (put2ByteOpcodeValueAtOffset): |
| (get2ByteOpcodeValueAtOffset): |
| (put2ByteOpcodeValueAtOffsetAndAdvance): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Give GET, PUT better names, and add (poor) moveOpcodePtrPastAnyAlternateBranches |
| |
| * pcre/pcre_compile.cpp: |
| (firstSignificantOpCodeSkippingAssertions): |
| (find_fixedlength): |
| (complete_callout): |
| (compile_branch): |
| (compile_regex): |
| (is_anchored): |
| (canApplyFirstCharOptimization): |
| (find_firstassertedchar): |
| * pcre/pcre_exec.cpp: |
| (match): |
| * pcre/pcre_internal.h: |
| (putOpcodeValueAtOffset): |
| (getOpcodeValueAtOffset): |
| (putOpcodeValueAtOffsetAndAdvance): |
| (put2ByteOpcodeValueAtOffset): |
| (get2ByteOpcodeValueAtOffset): |
| (moveOpcodePtrPastAnyAlternateBranches): |
| * pcre/pcre_ucp_searchfuncs.cpp: |
| (_pcre_ucp_othercase): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Add inlines for toLowerCase, isWordChar, isSpaceChar for further regexp speedup |
| |
| * pcre/pcre_compile.cpp: |
| (compile_branch): |
| (jsRegExpCompile): |
| * pcre/pcre_exec.cpp: |
| (match): |
| (jsRegExpExecute): |
| * pcre/pcre_internal.h: |
| (toLowerCase): |
| (flipCase): |
| (classBitmapForChar): |
| (charTypeForChar): |
| (isWordChar): |
| (isSpaceChar): |
| (CompileData::CompileData): |
| * pcre/pcre_xclass.cpp: |
| (_pcre_xclass): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| cleanup _pcre_ucp_othercase |
| |
| * pcre/pcre_ucp_searchfuncs.cpp: |
| (_pcre_ucp_othercase): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Use better variable names for case ignoring options |
| |
| * pcre/pcre_compile.cpp: |
| (compile_branch): |
| (find_firstassertedchar): |
| (printCompiledRegExp): |
| (jsRegExpCompile): |
| * pcre/pcre_exec.cpp: |
| (match_ref): |
| (match): |
| (jsRegExpExecute): |
| * pcre/pcre_internal.h: |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| split first_significant_code into two simpler functions |
| |
| * pcre/pcre_compile.cpp: |
| (firstSignificantOpCode): |
| (firstSignificantOpCodeSkippingAssertions): |
| (is_anchored): |
| (canApplyFirstCharOptimization): |
| (find_firstassertedchar): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| clean up is_counted_repeat |
| |
| * pcre/pcre_compile.cpp: |
| (is_counted_repeat): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| clean up check_escape |
| |
| * pcre/pcre_compile.cpp: |
| (check_escape): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Reformat find_fixedlength |
| |
| * pcre/pcre_compile.cpp: |
| (find_fixedlength): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| reformat is_anchored |
| |
| * pcre/pcre_compile.cpp: |
| (is_anchored): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Remove unused function could_be_empty_branch |
| |
| * pcre/pcre_compile.cpp: |
| (first_significant_code): |
| (find_fixedlength): |
| (compile_branch): |
| (canApplyFirstCharOptimization): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Pass around MatchData objects by reference |
| |
| * pcre/pcre_exec.cpp: |
| (pchars): |
| (match_ref): |
| (match): |
| (jsRegExpExecute): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| give PCRE_STARTLINE a better name and rename match_data to MatchData |
| |
| * pcre/pcre_compile.cpp: |
| (compile_branch): |
| (canApplyFirstCharOptimization): |
| (find_firstassertedchar): |
| (printCompiledRegExp): |
| (jsRegExpCompile): |
| * pcre/pcre_exec.cpp: |
| (pchars): |
| (jsRegExpExecute): |
| * pcre/pcre_internal.h: |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Clean up find_firstassertedchar |
| |
| * pcre/pcre_compile.cpp: |
| (get_othercase_range): |
| (find_firstassertedchar): |
| (calculateCompiledPatternLengthAndFlags): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Tim Hatcher. |
| |
| Pass around CompileData& instead of CompileData* |
| |
| * pcre/pcre_compile.cpp: |
| (compile_branch): |
| (jsRegExpCompile): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Clean up compile_branch, move _pcre_ord2utf8, and rename CompileData |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * pcre/pcre_compile.cpp: |
| (_pcre_ord2utf8): |
| (calculateCompiledPatternLengthAndFlags): |
| (jsRegExpCompile): |
| * pcre/pcre_internal.h: |
| * pcre/pcre_ord2utf8.cpp: Removed. |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| removing more macros |
| |
| * pcre/pcre_compile.cpp: |
| (could_be_empty_branch): |
| (compile_branch): |
| (calculateCompiledPatternLengthAndFlags): |
| * pcre/pcre_exec.cpp: |
| (match): |
| (jsRegExpExecute): |
| * pcre/pcre_internal.h: |
| * pcre/pcre_xclass.cpp: |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| clean up formating in compile_branch |
| |
| * pcre/pcre_compile.cpp: |
| (compile_branch): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Fix spacing for read_repeat_counts |
| |
| * pcre/pcre_compile.cpp: |
| (read_repeat_counts): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Get rid of PCRE custom char types |
| |
| * pcre/pcre_compile.cpp: |
| (check_escape): |
| (complete_callout): |
| (compile_branch): |
| (compile_regex): |
| (calculateCompiledPatternLengthAndFlags): |
| (jsRegExpCompile): |
| * pcre/pcre_exec.cpp: |
| (match_ref): |
| (match): |
| (jsRegExpExecute): |
| * pcre/pcre_internal.h: |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| reformat get_othercase_range |
| |
| * pcre/pcre_compile.cpp: |
| (get_othercase_range): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Remove register keyword and more cleanup |
| |
| * pcre/pcre_compile.cpp: |
| (find_fixedlength): |
| (compile_branch): |
| (is_anchored): |
| (is_startline): |
| (find_firstassertedchar): |
| (calculateCompiledPatternLengthAndFlags): |
| (jsRegExpCompile): |
| * pcre/pcre_exec.cpp: |
| (MatchStack::canUseStackBufferForNextFrame): |
| (MatchStack::allocateNextFrame): |
| (MatchStack::pushNewFrame): |
| (MatchStack::frameIsStackAllocated): |
| (MatchStack::popCurrentFrame): |
| (MatchStack::unrollAnyHeapAllocatedFrames): |
| (getUTF8CharAndIncrementLength): |
| (match): |
| (jsRegExpExecute): |
| * pcre/pcre_internal.h: |
| (PUT2INC): |
| (isLeadingSurrogate): |
| (isTrailingSurrogate): |
| (decodeSurrogatePair): |
| (getChar): |
| * pcre/pcre_ord2utf8.cpp: |
| (_pcre_ord2utf8): |
| * pcre/pcre_xclass.cpp: |
| (getUTF8CharAndAdvancePointer): |
| (_pcre_xclass): |
| |
| 2007-11-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Clean up jsRegExpExecute |
| |
| * pcre/pcre_compile.cpp: |
| (returnError): |
| (jsRegExpCompile): |
| * pcre/pcre_exec.cpp: |
| (jsRegExpExecute): |
| * pcre/pcre_internal.h: |
| |
| 2007-11-29 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Geoff. |
| |
| Merging updated system alloc and spinlock code from r38 of TCMalloc. |
| |
| This is needed as a precursor to the merge of TCMalloc proper. |
| |
| * wtf/FastMalloc.cpp: |
| (WTF::TCMalloc_PageHeap::GrowHeap): |
| * wtf/TCSpinLock.h: |
| (TCMalloc_SpinLock::TCMalloc_SpinLock): |
| (TCMalloc_SpinLock::): |
| (TCMalloc_SpinLock::Lock): |
| (TCMalloc_SpinLock::Unlock): |
| (TCMalloc_SpinLock::IsHeld): |
| * wtf/TCSystemAlloc.cpp: |
| (TrySbrk): |
| (TryMmap): |
| (TryVirtualAlloc): |
| (TryDevMem): |
| (TCMalloc_SystemAlloc): |
| * wtf/TCSystemAlloc.h: |
| |
| 2007-11-28 Brady Eidson <beidson@apple.com> |
| |
| Reviewed by Geoff |
| |
| Add copyKeysToVector utility, mirroring copyValuesToVector |
| Also change the copyValuesToVector implementation to be a little more attractive |
| |
| * wtf/HashMap.h: |
| (WTF::copyKeysToVector): |
| (WTF::copyValuesToVector): |
| |
| 2007-11-27 Alp Toker <alp@atoker.com> |
| |
| Reviewed by Mark Rowe. |
| |
| Add a list of public JavaScriptCore headers for installation. |
| |
| This follows the convention used for the Qt and GTK+ header lists. |
| |
| * headers.pri: Added. |
| |
| 2007-11-27 Alp Toker <alp@atoker.com> |
| |
| Prospective MSVC build fix. |
| |
| Roll back dllexport/dllimport support for now. |
| |
| * API/JSBase.h: |
| |
| 2007-11-27 Alp Toker <alp@atoker.com> |
| |
| Reviewed by Maciej. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=15569 |
| [gtk] GTK JavaScriptCore needs to export symbols for JSC API and WTF |
| |
| Introduce JS_EXPORT to mark symbols to be exported as public API. |
| |
| Export all public symbols in the JavaScriptCore C API. |
| |
| This matches conventions for exporting symbols set by the CF and CG |
| frameworks. |
| |
| * API/JSBase.h: |
| * API/JSContextRef.h: |
| * API/JSObjectRef.h: |
| * API/JSStringRef.h: |
| * API/JSStringRefBSTR.h: |
| * API/JSStringRefCF.h: |
| * API/JSValueRef.h: |
| |
| 2007-11-27 Anders Carlsson <andersca@apple.com> |
| |
| Reviewed by Adam. |
| |
| Make PropertyNameArray and ScopeChain COMEnumVariant friendly. |
| |
| * kjs/PropertyNameArray.cpp: |
| (KJS::PropertyNameArray::swap): |
| Implement PropertyNameArray::swap. |
| |
| * kjs/PropertyNameArray.h: |
| Add ValueType typedef. Replace PropertyNameArrayIterator with |
| PropertyNameArray::const_iterator. |
| |
| * kjs/nodes.cpp: |
| (KJS::ForInNode::execute): |
| * kjs/scope_chain.cpp: |
| (KJS::ScopeChain::print): |
| Update for changes to PropertyNameArray. |
| |
| * kjs/scope_chain.h: |
| Add const_iterator and ValueType typedef. |
| |
| 2007-11-27 Anders Carlsson <andersca@apple.com> |
| |
| Reviewed by Darin. |
| |
| Add a ValueType typedef. |
| |
| * wtf/Vector.h: |
| |
| 2007-11-26 Darin Adler <darin@apple.com> |
| |
| Reviewed by Mitz. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=16096 |
| REGRESSION (r26653-r26699): Plaxo.com addressbook does not load in webkit nightlies |
| |
| Test: fast/js/regexp-overflow.html |
| |
| * pcre/pcre_compile.cpp: (calculateCompiledPatternLengthAndFlags): |
| Removed a stray "ptr++" that I added by accident when merging the |
| changes between PCRE 6.4 and 6.5. |
| |
| 2007-11-26 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Kevin McCullough. |
| |
| Fixed <rdar://problem/5597937> REGRESSION (r27126): Drosera does not |
| show variables (can't enumerate ActivationImp properties) |
| |
| Implemented a custom ActivationImp::getPropertyNames, since |
| ActivationImp now uses a custom property storage mechanism for local |
| variables. |
| |
| * kjs/function.cpp: |
| (KJS::ActivationImp::getPropertyNames): |
| * kjs/function.h: |
| |
| 2007-11-26 Alp Toker <alp@atoker.com> |
| |
| GTK+/Qt/Wx build fix for breakage introduced in r28039. |
| |
| * ForwardingHeaders/JavaScriptCore/JSRetainPtr.h: Added. |
| |
| 2007-11-24 Laszlo Gombos <laszlo.gombos@gmail.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Fix minor compiler warning (GCC 4.1.3) |
| |
| * pcre/pcre_internal.h: |
| * pcre/pcre_ucp_searchfuncs.cpp: |
| (_pcre_ucp_othercase): |
| |
| 2007-11-25 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Dan Bernstein. |
| |
| Fix http://bugs.webkit.org/show_bug.cgi?id=16129 |
| Bug 16129: REGRESSION (r27761-r27811): malloc error while visiting http://mysit.es (crashes release build) |
| |
| * pcre/pcre_compile.cpp: Change errorcode to be passed by reference so that any error code is propagated |
| to our caller like they expect. |
| |
| 2007-11-23 Kevin Ollivier <kevino@theolliviers.com> |
| |
| MSVC7 build fix. (rand_s doesn't exist there) |
| |
| Reviewed by Adam Roben. |
| |
| * kjs/config.h: |
| * wtf/MathExtras.h: |
| |
| 2007-11-23 Kevin Ollivier <kevino@theolliviers.com> |
| |
| wx build fix. Move WX_PYTHON logic into project build settings, |
| add WebKitLibraries dirs on Win, and explicitly include JSCore |
| headers in testkjs rather than getting them from a template. |
| (Include dir order of JSCore/WTF and ICU headers is important due |
| to wtf/unicode/utf8.h.) |
| |
| * jscore.bkl: |
| |
| 2007-11-23 Simon Hausmann <hausmann@webkit.org> |
| |
| Reviewed by George Staikos <staikos@kde.org>. |
| |
| Fix make (dist)clean on Windows. |
| |
| OBJECTS_DIR_WTR does not exist anymore, use GENERATED_SOURCES_DIR. |
| |
| |
| * JavaScriptCore.pri: |
| * pcre/pcre.pri: |
| |
| 2007-11-22 Simon Hausmann <hausmann@kde.org> |
| |
| Reviewed by George. |
| |
| Make the directory of where to put the generated sources configurable through the GENERATED_SOURCE_DIR variable |
| |
| * JavaScriptCore.pri: |
| * pcre/pcre.pri: |
| |
| 2007-11-22 Simon Hausmann <hausmann@kde.org> |
| |
| Reviewed by George. |
| |
| Centralize the setup for all the extra compilers in a addExtraCompiler function. |
| |
| This allows adding a "generated_files" target that builds all generated files using "make generated_files". |
| For the build inside Qt we do not generate actual rules for the extra compilers but instead |
| do the variable substitution of compiler.output manually and add the generated sources to SOURCES. |
| |
| * JavaScriptCore.pri: |
| * pcre/pcre.pri: |
| |
| 2007-11-20 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Tim Hatcher. |
| |
| <rdar://problem/5602936> Need to resolve new GCC 4.2 warnings |
| |
| Fix all warnings emitted by GCC 4.2 when building JavaScriptCore. This allows builds with |
| -Werror to succeed. At present they will crash when executed due to code that is not safe |
| under strict aliasing (<rdar://problem/5536806>). |
| |
| * Configurations/Base.xcconfig: Remove the -Wno-long-double flag. |
| * kjs/date_object.cpp: |
| (KJS::formatTime): Test whether the stack-allocated string is empty rather than at a non-null address. |
| * kjs/dtoa.cpp: |
| (Bigint::): Tweak formatting to silence warnings. |
| * pcre/pcre_exec.cpp: |
| (match): Tweak formatting to silence warnings |
| * wtf/Assertions.cpp: Add printf format attribute to functions that warrant it. |
| * wtf/Assertions.h: Ditto. |
| |
| 2007-11-19 Kevin Ollivier <kevino@theolliviers.com> |
| |
| wx port build fix (wx headers include ctype functions). |
| |
| * kjs/config.h: |
| |
| 2007-11-19 Kevin Ollivier <kevino@theolliviers.com> |
| |
| Remove outdated and unused Windows port files. |
| |
| Reviewed by Adam Roben. |
| |
| * Makefile.vc: Removed. |
| * README-Win32.txt: Removed. |
| |
| 2007-11-18 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Oliver. |
| |
| * tests/mozilla/jsDriver.pl: exit non-0 when user aborts test run |
| |
| 2007-11-17 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Fix: <rdar://problem/5607032> REGRESSION: testapi exits with assertion failure in debug build |
| <rdar://problem/5440659> JSGlobalContextCreate throws away globalObjectClass's prototype |
| http://bugs.webkit.org/show_bug.cgi?id=16033 |
| |
| Split Interpreter's initialization into two distinct steps: the creation of the global prototypes |
| and constructors, and storing them on the global object. This allows JSClassRef's passed to |
| JSGlobalContextCreate to be instantiated with the correct prototype. |
| |
| * API/JSCallbackObject.cpp: Assert at compile-time that the custom global object will fit in a collector cell. |
| * API/JSCallbackObject.h: |
| * API/JSCallbackObjectFunctions.h: |
| (KJS::::JSCallbackObject): |
| (KJS::::init): |
| * API/JSContextRef.cpp: |
| (JSGlobalContextCreate): Construct and set the interpreter's global object separately. When globalObjectClass |
| is passed we need to set the interpreter's global object before doing the JSCallbackObject's initialization to |
| prevent any JSObjectInitializeCallback's being invoked before a global object is set. |
| * API/testapi.c: |
| (globalObject_initialize): Test the object passed in is correct and that it has the expected global properties. |
| (globalObject_get): |
| (globalObject_set): |
| (main): |
| * API/testapi.js: Test that any static properties exposed by the global object's custom class are found. |
| * JavaScriptCore.exp: |
| * bindings/testbindings.cpp: |
| (main): Update for changes in Interpreter method signatures. |
| * bindings/testbindings.mm: |
| (main): Ditto. |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::ExecState): |
| (KJS::ExecState::mark): |
| (KJS::ExecState::setGlobalObject): |
| * kjs/ExecState.h: Rename scope to m_scopeChain. |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::Interpreter): |
| (KJS::Interpreter::init): |
| (KJS::Interpreter::globalObject): |
| (KJS::Interpreter::setGlobalObject): |
| (KJS::Interpreter::resetGlobalObjectProperties): |
| (KJS::Interpreter::createObjectsForGlobalObjectProperties): |
| (KJS::Interpreter::setGlobalObjectProperties): Switch to using putDirect to ensure that the global object's put method |
| cannot interfere with setting of the global properties. This prevents a user-written JSClassRef from attempting to |
| call back into JavaScript from the initialization of the global object's members. |
| * kjs/interpreter.h: |
| * kjs/testkjs.cpp: |
| (setupInterpreter): Update for changes in Interpreter method signatures. |
| |
| 2007-11-17 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Prevent testapi from reporting false leaks. Clear out local variables pointing at |
| JSObjectRefs to allow their values to be collected. |
| |
| * API/testapi.c: |
| (main): |
| |
| 2007-11-17 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Prevent testapi from crashing if testapi.js can not be found by nil-checking the result of createStringWithContentsOfFile. |
| |
| * API/testapi.c: |
| (main): |
| |
| 2007-11-17 Alp Toker <alp@atoker.com> |
| |
| Reviewed by Eric. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=16032 |
| JS minidom is not portable |
| |
| Use a plain UTF-8 string instead of a CFString. |
| |
| Print to stdout, not stderr like CFShow() would have done, since that |
| behaviour seems unintentional. |
| |
| * API/minidom.c: |
| (main): |
| |
| 2007-11-17 Steve Falkenburg <sfalken@apple.com> |
| |
| Windows build fix. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| |
| 2007-11-16 Mark Rowe <mrowe@apple.com> |
| |
| Windows build fix. |
| |
| * kjs/lexer.cpp: |
| (KJS::Lexer::record8): |
| |
| 2007-11-16 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Eric. |
| |
| Replace strings, identifier, buffer8 and buffer16 members of Lexer with vectors. |
| SunSpider claims this is a 0.7% speedup. |
| |
| * kjs/lexer.cpp: |
| (KJS::Lexer::Lexer): |
| (KJS::Lexer::lex): |
| (KJS::Lexer::record8): |
| (KJS::Lexer::record16): |
| (KJS::Lexer::scanRegExp): |
| (KJS::Lexer::clear): |
| (KJS::Lexer::makeIdentifier): |
| (KJS::Lexer::makeUString): |
| * kjs/lexer.h: |
| * kjs/ustring.cpp: |
| (KJS::UString::UString): Add a convenience constructor that takes a const Vector<UChar>&. |
| * kjs/ustring.h: |
| |
| 2007-11-16 Adam Roben <aroben@apple.com> |
| |
| Windows build fix |
| |
| * JavaScriptCore.vcproj/testkjs/testkjs.vcproj: Add a new include path |
| and ignore the int -> bool conversion warning. |
| |
| 2007-11-16 Alexey Proskuryakov <ap@webkit.org> |
| |
| Fix Windows debug build. |
| Rubber-stamped by Eric |
| |
| * pcre/pcre_exec.cpp: (match): Removed ASSERT_NOT_REACHED assertions that were making MSVC |
| complain about unreachable code. |
| |
| 2007-11-15 Mark Rowe <mrowe@apple.com> |
| |
| Gtk build fix. |
| |
| * kjs/Parser.cpp: |
| |
| 2007-11-15 Mark Rowe <mrowe@apple.com> |
| |
| Mac build and header search path sanity fix. |
| |
| Reviewed by Sam Weinig and Tim Hatcher. |
| |
| Move base setting for HEADER_SEARCH_PATHS into Base.xcconfig, and extend |
| it in JavaScriptCore.xcconfig. This removes the need to override it on a |
| per-target basis inside the .xcodeproj file. |
| |
| * Configurations/Base.xcconfig: |
| * Configurations/JavaScriptCore.xcconfig: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2007-11-15 Mark Rowe <mrowe@apple.com> |
| |
| Qt build fix. |
| |
| * kjs/Parser.h: |
| |
| 2007-11-15 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Eric Seidel. |
| |
| Another round of grammar / parsing cleanup. |
| |
| 1. Created distinct parser calls for parsing function bodies vs |
| programs. This will help later with optimizing global variable access. |
| |
| 2. Turned Parser into a singleton. Cleaned up Lexer's singleton |
| interface. |
| |
| 3. Modified Lexer to free a little more memory when done lexing. (Added |
| FIXMEs for similar issues that I didn't fix.) |
| |
| 4. Changed Lexer::makeIdentifier and Lexer::makeUString to start |
| respecting the arguments passed to them. (No behavior change, but this |
| problem could have caused serious problems for an unsuspecting user of |
| these functions.) |
| |
| 5. Removed KJS_DEBUG_MEM because it was bit-rotted. |
| |
| 6. Removed Parser::prettyPrint because the same work was simpler to do |
| at the call site. |
| |
| 7. Some renames: |
| |
| "Parser::accept" => "Parser::didFinishParsing" |
| "Parser::sid" => "Parser::m_sourceID" |
| "Lexer::doneParsing" => "Lexer::clear" |
| "sid" => "sourceId" |
| "lineno" => "lineNo" |
| |
| * JavaScriptCore.exp: |
| * kjs/Parser.cpp: |
| (KJS::Parser::Parser): |
| (KJS::Parser::parseProgram): |
| (KJS::Parser::parseFunctionBody): |
| (KJS::Parser::parse): |
| (KJS::Parser::didFinishParsing): |
| (KJS::parser): |
| * kjs/Parser.h: |
| (KJS::Parser::sourceId): |
| * kjs/function.cpp: |
| (KJS::GlobalFuncImp::callAsFunction): |
| * kjs/function_object.cpp: |
| (FunctionObjectImp::construct): |
| * kjs/grammar.y: |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::checkSyntax): |
| (KJS::Interpreter::evaluate): |
| * kjs/interpreter.h: |
| * kjs/lexer.cpp: |
| (kjsyylex): |
| (KJS::lexer): |
| (KJS::Lexer::Lexer): |
| (KJS::Lexer::~Lexer): |
| (KJS::Lexer::scanRegExp): |
| (KJS::Lexer::doneParsing): |
| (KJS::Lexer::makeIdentifier): |
| (KJS::Lexer::makeUString): |
| * kjs/lexer.h: |
| (KJS::Lexer::pattern): |
| (KJS::Lexer::flags): |
| (KJS::Lexer::sawError): |
| * kjs/nodes.cpp: |
| (KJS::Node::Node): |
| (KJS::FunctionBodyNode::FunctionBodyNode): |
| * kjs/nodes.h: |
| * kjs/testkjs.cpp: |
| (prettyPrintScript): |
| (kjsmain): |
| * kjs/ustring.cpp: |
| * kjs/ustring.h: |
| |
| 2007-11-15 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Darin. |
| |
| <rdar://problem/5601548> REGRESSION: All SourceElements and their children leak after a syntax error |
| |
| Add a stub node to maintain the Vector of SourceElements until assignment. |
| |
| * kjs/grammar.y: |
| * kjs/nodes.h: |
| (KJS::SourceElementsStub::SourceElementsStub): |
| (KJS::SourceElementsStub::append): |
| (KJS::SourceElementsStub::release): |
| (KJS::SourceElementsStub::): |
| (KJS::SourceElementsStub::precedence): |
| |
| 2007-11-15 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Abstract most of RMATCH into MatchStack functions. |
| |
| SunSpider claims this, combined with the last 2 patches was a 1% speedup, 10% for dna-regexp. |
| |
| * pcre/pcre_exec.cpp: |
| (MatchStack::canUseStackBufferForNextFrame): |
| (MatchStack::allocateNextFrame): |
| (MatchStack::pushNewFrame): |
| (MatchStack::frameIsStackAllocated): |
| (MatchStack::popCurrentFrame): |
| (MatchStack::unrollAnyHeapAllocatedFrames): |
| (match): |
| |
| 2007-11-15 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Remove RETURN_ERROR, add MatchStack |
| |
| * pcre/pcre_exec.cpp: |
| (MatchStack::MatchStack): |
| (MatchStack::unrollAnyHeapAllocatedFrames): |
| (matchError): |
| (match): |
| |
| 2007-11-15 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Clean up match function to match WebKit style |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * pcre/pcre_exec.cpp: |
| (match): |
| |
| 2007-11-15 Steve Falkenburg <sfalken@apple.com> |
| |
| Windows build fix. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore.make: |
| |
| 2007-11-14 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=15982 |
| Improve JSString UTF-8 decoding |
| |
| * API/JSStringRef.cpp: |
| (JSStringCreateWithUTF8CString): Use strict decoding, return 0 on error. |
| |
| * wtf/unicode/UTF8.cpp: |
| (WTF::Unicode::convertUTF16ToUTF8): |
| (WTF::Unicode::convertUTF8ToUTF16): |
| * wtf/unicode/UTF8.h: |
| Made these function names start with a lower case letter. |
| |
| * kjs/ustring.cpp: (KJS::UString::UTF8String): Updated for the above renaming. |
| |
| * bindings/c/c_utility.cpp: |
| (KJS::Bindings::convertUTF8ToUTF16WithLatin1Fallback): Renamed to highlight the difference |
| from convertUTF8ToUTF16 in wtf/unicode. |
| (KJS::Bindings::convertNPStringToUTF16): Updated for the above renaming. |
| (KJS::Bindings::identifierFromNPIdentifier): Ditto. |
| * bindings/c/c_utility.h: Made convertUTF8ToUTF16WithLatin1Fallback() a file static. |
| |
| 2007-11-14 Sam Weinig <sam@webkit.org> |
| |
| Rubber-stamped by Anders. |
| |
| Fix the Xcode project file after it was messed up in r27402. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2007-11-14 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Oliver. |
| |
| More PCRE style cleanup. |
| |
| * pcre/pcre_compile.cpp: |
| (compile_regex): |
| |
| 2007-11-14 Adam Roben <aroben@apple.com> |
| |
| Clean up the bison conflict checking script |
| |
| Reviewed by Geoff. |
| |
| * DerivedSources.make: |
| |
| 2007-11-14 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Geoff. |
| |
| Another round of PCRE cleanups: inlines |
| |
| SunSpider claims that this, combined with my previous PCRE cleanup were a 0.7% speedup, go figure. |
| |
| * pcre/pcre_compile.cpp: |
| (jsRegExpCompile): |
| * pcre/pcre_exec.cpp: |
| (match): |
| (jsRegExpExecute): |
| * pcre/pcre_internal.h: |
| (PUT): |
| (GET): |
| (PUT2): |
| (GET2): |
| (isNewline): |
| |
| 2007-11-14 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Sam. |
| |
| Give PCRE a (small) bath. |
| Fix some formating and break things off into separate functions |
| http://bugs.webkit.org/show_bug.cgi?id=15993 |
| |
| * pcre/pcre_compile.cpp: |
| (calculateCompiledPatternLengthAndFlags): |
| (printCompiledRegExp): |
| (returnError): |
| (jsRegExpCompile): |
| * pcre/pcre_internal.h: |
| (compile_data::compile_data): |
| |
| 2007-11-14 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Eric Seidel. |
| |
| Cleaned up the JavaScript grammar a bit. |
| |
| 1. Changed BlockNode to always hold a child vector (which may be empty), |
| eliminating a few NULL-check branches in the common execution case. |
| |
| 2. Changed the Block production to correctly report its starting and |
| ending line numbers to the debugger. (It used to report its ending line |
| as its starting line.) Also, removed duplicate line-reporting code |
| inside the BlockNode constructor. |
| |
| 3. Moved curly braces up from FunctionBody production into parent |
| productions. (I had to move the line number reporting code, too, since |
| it depends on the location of the curly braces.) This matches the ECMA |
| spec more closely, and makes some future changes I plan easier. |
| |
| 4. Fixed statementList* convenience functions to deal appropriately with |
| empty Vectors. |
| |
| SunSpider reports a small and statistically insignificant speedup. |
| |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::statementListPushFIFO): |
| (KJS::statementListGetDeclarations): |
| (KJS::statementListInitializeDeclarationStack): |
| (KJS::statementListInitializeVariableAccessStack): |
| (KJS::BlockNode::BlockNode): |
| (KJS::BlockNode::optimizeVariableAccess): |
| (KJS::BlockNode::getDeclarations): |
| (KJS::BlockNode::execute): |
| (KJS::FunctionBodyNode::initializeDeclarationStacks): |
| (KJS::FunctionBodyNode::optimizeVariableAccess): |
| |
| 2007-11-13 Anders Carlsson <andersca@apple.com> |
| |
| Add RefCounted.h (And remove Shared.h) |
| |
| * JavaScriptCore.vcproj/WTF/WTF.vcproj: |
| |
| 2007-11-13 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix. |
| |
| * kjs/regexp.h: |
| |
| 2007-11-13 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Anders Carlsson. |
| |
| Renamed Shared to RefCounted. |
| |
| * API/JSClassRef.h: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/interpreter.h: |
| * kjs/regexp.h: |
| * wtf/RefCounted.h: Copied from JavaScriptCore/wtf/Shared.h. |
| (WTF::RefCounted::RefCounted): |
| * wtf/Shared.h: Removed. |
| |
| 2007-11-13 Adam Roben <aroben@apple.com> |
| |
| Build fix |
| |
| Reviewed by Geoff. |
| |
| * kjs/regexp.h: Added a missing #include. |
| |
| 2007-11-13 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Moved Shared.h into wtf so it could be used in more places. Deployed |
| Shared in places where JSCore previously had hand-rolled ref-counting |
| classes. |
| |
| * API/JSClassRef.cpp: |
| (OpaqueJSClass::OpaqueJSClass): |
| * API/JSClassRef.h: |
| * API/JSObjectRef.cpp: |
| (JSClassRetain): |
| (JSClassRelease): |
| * JavaScriptCore.vcproj/WTF/WTF.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::init): |
| * kjs/interpreter.h: |
| * kjs/regexp.cpp: |
| (KJS::RegExp::RegExp): |
| * kjs/regexp.h: |
| * wtf/Shared.h: Copied from WebCore/platform/Shared.h. |
| |
| 2007-11-13 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Add an ASSERT to getTruncatedInt32 to enforce proper usage. |
| Best part about this patch? It doesn't break the web! |
| |
| * kjs/JSImmediate.h: |
| (KJS::JSImmediate::getTruncatedInt32): |
| (KJS::JSImmediate::toDouble): |
| (KJS::JSImmediate::getUInt32): |
| |
| 2007-11-13 Alexey Proskuryakov <ap@webkit.org> |
| |
| Windows build fix. |
| |
| * bindings/c/c_utility.cpp: |
| (KJS::Bindings::convertUTF8ToUTF16): |
| * kjs/ustring.cpp: |
| (KJS::UString::UTF8String): |
| * wtf/unicode/UTF8.cpp: |
| (WTF::Unicode::ConvertUTF8ToUTF16): |
| |
| 2007-11-13 Darin Adler <darin@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=11231 |
| RegExp bug when handling newline characters |
| and a number of other differences between PCRE behvior |
| and JavaScript regular expressions: |
| |
| + single-digit sequences like \4 should be treated as octal |
| character constants, unless there is a sufficient number |
| of brackets for them to be treated as backreferences |
| |
| + \8 turns into the character "8", not a binary zero character |
| followed by "8" (same for 9) |
| |
| + only the first 3 digits should be considered part of an |
| octal character constant (the old behavior was to decode |
| an arbitrarily long sequence and then mask with 0xFF) |
| |
| + if \x is followed by anything other than two valid hex digits, |
| then it should simply be treated a the letter "x"; that includes |
| not supporting the \x{41} syntax |
| |
| + if \u is followed by anything less than four valid hex digits, |
| then it should simply be treated a the letter "u" |
| |
| + an extra "+" should be a syntax error, rather than being treated |
| as the "possessive quantifier" |
| |
| + if a "]" character appears immediately after a "[" character that |
| starts a character class, then that's an empty character class, |
| rather than being the start of a character class that includes a |
| "]" character |
| |
| + a "$" should not match a terminating newline; we could have gotten |
| PCRE to handle this the way we wanted by passing an appropriate option |
| |
| Test: fast/js/regexp-no-extensions.html |
| |
| * pcre/pcre_compile.cpp: |
| (check_escape): Check backreferences against bracount to catch both |
| overflows and things that should be treated as octal. Rewrite octal |
| loop to not go on indefinitely. Rewrite both hex loops to match and |
| remove \x{} support. |
| (compile_branch): Restructure loops so that we don't special-case a "]" |
| at the beginning of a character class. Remove code that treated "+" as |
| the possessive quantifier. |
| (jsRegExpCompile): Change the "]" handling here too. |
| |
| * pcre/pcre_exec.cpp: (match): Changed CIRC to match the DOLL implementation. |
| Changed DOLL to remove handling of "terminating newline", a Perl concept |
| which we don't need. |
| |
| * tests/mozilla/expected.html: Two tests are fixed now: |
| ecma_3/RegExp/regress-100199.js and ecma_3/RegExp/regress-188206.js. |
| One test fails now: ecma_3/RegExp/perlstress-002.js -- our success before |
| was due to a bug (we treated all 1-character numeric escapes as backreferences). |
| The date tests also now both expect success -- whatever was making them fail |
| before was probably due to the time being close to a DST shift; maybe we need |
| to get rid of those tests. |
| |
| 2007-11-13 Darin Adler <darin@apple.com> |
| |
| * kjs/JSImmediate.h: (KJS::JSImmediate::getTruncatedInt32): |
| Remove too-strong assert that was firing constantly and preventing even basic |
| web browsing from working in a debug build. This function is used in many |
| cases where the immediate value is not a number; the assertion could perhaps |
| be added back later with a bit of reorganization. |
| |
| 2007-11-13 Alp Toker <alp@atoker.com> |
| |
| Build fix for breakage to non-Mac builds introduced in r27746. |
| |
| * kjs/ustring.cpp: |
| |
| 2007-11-13 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Clean up evaluateToBoolean functions to use inlines instead of copy/paste code |
| |
| * kjs/JSImmediate.h: |
| * kjs/nodes.cpp: |
| (KJS::GreaterNode::inlineEvaluateToBoolean): |
| (KJS::GreaterNode::evaluate): |
| (KJS::LessEqNode::inlineEvaluateToBoolean): |
| (KJS::LessEqNode::evaluate): |
| (KJS::GreaterEqNode::inlineEvaluateToBoolean): |
| (KJS::GreaterEqNode::evaluate): |
| (KJS::InNode::evaluateToBoolean): |
| (KJS::EqualNode::inlineEvaluateToBoolean): |
| (KJS::EqualNode::evaluate): |
| (KJS::NotEqualNode::inlineEvaluateToBoolean): |
| (KJS::NotEqualNode::evaluate): |
| (KJS::StrictEqualNode::inlineEvaluateToBoolean): |
| (KJS::StrictEqualNode::evaluate): |
| (KJS::NotStrictEqualNode::inlineEvaluateToBoolean): |
| (KJS::NotStrictEqualNode::evaluate): |
| * kjs/nodes.h: |
| |
| 2007-11-12 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Fixed http://bugs.webkit.org/show_bug.cgi?id=15958 |
| base64 spends 1.1% of total time checking for special Infinity case |
| |
| Use a fast character test instead of calling strncmp. |
| |
| 1.1% speedup on string-base64. SunSpider reports a .4% speedup overall; |
| Sharks reports only .1%. Who are you going to believe? Huh? |
| |
| * kjs/ustring.cpp: |
| (KJS::UString::toDouble): |
| |
| 2007-11-12 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Oliver. |
| |
| Add evaluateToInt32 and evaluateUInt32 methods and deploy them. |
| Fix a few missing evaluateToBoolean methods |
| Deploy all evaluateTo* functions to more nodes to avoid slowdowns |
| http://bugs.webkit.org/show_bug.cgi?id=15950 |
| |
| SunSpider claims this is at least a 1.4% speedup. |
| |
| * kjs/JSImmediate.h: |
| (KJS::JSImmediate::getTruncatedInt32): |
| (KJS::JSImmediate::toDouble): |
| (KJS::JSImmediate::getUInt32): |
| * kjs/nodes.cpp: |
| (KJS::ExpressionNode::evaluateToNumber): |
| (KJS::ExpressionNode::evaluateToInt32): |
| (KJS::ExpressionNode::evaluateToUInt32): |
| (KJS::NumberNode::evaluateToInt32): |
| (KJS::NumberNode::evaluateToUInt32): |
| (KJS::ImmediateNumberNode::evaluateToInt32): |
| (KJS::ImmediateNumberNode::evaluateToUInt32): |
| (KJS::ResolveNode::evaluate): |
| (KJS::ResolveNode::evaluateToNumber): |
| (KJS::ResolveNode::evaluateToBoolean): |
| (KJS::ResolveNode::evaluateToInt32): |
| (KJS::ResolveNode::evaluateToUInt32): |
| (KJS::LocalVarAccessNode::evaluateToInt32): |
| (KJS::LocalVarAccessNode::evaluateToUInt32): |
| (KJS::BracketAccessorNode::evaluateToNumber): |
| (KJS::BracketAccessorNode::evaluateToBoolean): |
| (KJS::BracketAccessorNode::evaluateToInt32): |
| (KJS::BracketAccessorNode::evaluateToUInt32): |
| (KJS::DotAccessorNode::inlineEvaluate): |
| (KJS::DotAccessorNode::evaluate): |
| (KJS::DotAccessorNode::evaluateToNumber): |
| (KJS::DotAccessorNode::evaluateToBoolean): |
| (KJS::DotAccessorNode::evaluateToInt32): |
| (KJS::DotAccessorNode::evaluateToUInt32): |
| (KJS::NewExprNode::inlineEvaluate): |
| (KJS::NewExprNode::evaluate): |
| (KJS::NewExprNode::evaluateToNumber): |
| (KJS::NewExprNode::evaluateToBoolean): |
| (KJS::NewExprNode::evaluateToInt32): |
| (KJS::NewExprNode::evaluateToUInt32): |
| (KJS::FunctionCallResolveNode::inlineEvaluate): |
| (KJS::FunctionCallResolveNode::evaluate): |
| (KJS::FunctionCallResolveNode::evaluateToNumber): |
| (KJS::FunctionCallResolveNode::evaluateToBoolean): |
| (KJS::FunctionCallResolveNode::evaluateToInt32): |
| (KJS::FunctionCallResolveNode::evaluateToUInt32): |
| (KJS::LocalVarFunctionCallNode::evaluate): |
| (KJS::LocalVarFunctionCallNode::evaluateToNumber): |
| (KJS::LocalVarFunctionCallNode::evaluateToBoolean): |
| (KJS::LocalVarFunctionCallNode::evaluateToInt32): |
| (KJS::LocalVarFunctionCallNode::evaluateToUInt32): |
| (KJS::FunctionCallDotNode::evaluate): |
| (KJS::FunctionCallDotNode::evaluateToNumber): |
| (KJS::FunctionCallDotNode::evaluateToBoolean): |
| (KJS::FunctionCallDotNode::evaluateToInt32): |
| (KJS::FunctionCallDotNode::evaluateToUInt32): |
| (KJS::PostDecLocalVarNode::inlineEvaluateToNumber): |
| (KJS::PostDecLocalVarNode::evaluateToNumber): |
| (KJS::PostDecLocalVarNode::evaluateToBoolean): |
| (KJS::PostDecLocalVarNode::evaluateToInt32): |
| (KJS::PostDecLocalVarNode::evaluateToUInt32): |
| (KJS::typeStringForValue): |
| (KJS::UnaryPlusNode::evaluate): |
| (KJS::UnaryPlusNode::evaluateToBoolean): |
| (KJS::UnaryPlusNode::evaluateToNumber): |
| (KJS::UnaryPlusNode::evaluateToInt32): |
| (KJS::BitwiseNotNode::inlineEvaluateToInt32): |
| (KJS::BitwiseNotNode::evaluate): |
| (KJS::BitwiseNotNode::evaluateToNumber): |
| (KJS::BitwiseNotNode::evaluateToBoolean): |
| (KJS::BitwiseNotNode::evaluateToInt32): |
| (KJS::MultNode::evaluateToBoolean): |
| (KJS::MultNode::evaluateToInt32): |
| (KJS::MultNode::evaluateToUInt32): |
| (KJS::DivNode::evaluateToInt32): |
| (KJS::DivNode::evaluateToUInt32): |
| (KJS::ModNode::evaluateToBoolean): |
| (KJS::ModNode::evaluateToInt32): |
| (KJS::ModNode::evaluateToUInt32): |
| (KJS::AddNode::evaluateToNumber): |
| (KJS::AddNode::evaluateToInt32): |
| (KJS::AddNode::evaluateToUInt32): |
| (KJS::AddNumbersNode::evaluateToInt32): |
| (KJS::AddNumbersNode::evaluateToUInt32): |
| (KJS::SubNode::evaluateToInt32): |
| (KJS::SubNode::evaluateToUInt32): |
| (KJS::LeftShiftNode::inlineEvaluateToInt32): |
| (KJS::LeftShiftNode::evaluate): |
| (KJS::LeftShiftNode::evaluateToNumber): |
| (KJS::LeftShiftNode::evaluateToInt32): |
| (KJS::RightShiftNode::inlineEvaluateToInt32): |
| (KJS::RightShiftNode::evaluate): |
| (KJS::RightShiftNode::evaluateToNumber): |
| (KJS::RightShiftNode::evaluateToInt32): |
| (KJS::UnsignedRightShiftNode::inlineEvaluateToUInt32): |
| (KJS::UnsignedRightShiftNode::evaluate): |
| (KJS::UnsignedRightShiftNode::evaluateToNumber): |
| (KJS::UnsignedRightShiftNode::evaluateToInt32): |
| (KJS::LessNode::inlineEvaluateToBoolean): |
| (KJS::LessNode::evaluate): |
| (KJS::LessNode::evaluateToBoolean): |
| (KJS::LessNumbersNode::inlineEvaluateToBoolean): |
| (KJS::LessNumbersNode::evaluate): |
| (KJS::LessNumbersNode::evaluateToBoolean): |
| (KJS::LessStringsNode::inlineEvaluateToBoolean): |
| (KJS::LessStringsNode::evaluate): |
| (KJS::BitAndNode::evaluate): |
| (KJS::BitAndNode::inlineEvaluateToInt32): |
| (KJS::BitAndNode::evaluateToNumber): |
| (KJS::BitAndNode::evaluateToBoolean): |
| (KJS::BitAndNode::evaluateToInt32): |
| (KJS::BitXOrNode::inlineEvaluateToInt32): |
| (KJS::BitXOrNode::evaluate): |
| (KJS::BitXOrNode::evaluateToNumber): |
| (KJS::BitXOrNode::evaluateToBoolean): |
| (KJS::BitXOrNode::evaluateToInt32): |
| (KJS::BitOrNode::inlineEvaluateToInt32): |
| (KJS::BitOrNode::evaluate): |
| (KJS::BitOrNode::evaluateToNumber): |
| (KJS::BitOrNode::evaluateToBoolean): |
| (KJS::BitOrNode::evaluateToInt32): |
| (KJS::ConditionalNode::evaluateToNumber): |
| (KJS::ConditionalNode::evaluateToInt32): |
| (KJS::ConditionalNode::evaluateToUInt32): |
| (KJS::valueForReadModifyAssignment): |
| (KJS::AssignExprNode::evaluate): |
| (KJS::AssignExprNode::evaluateToBoolean): |
| (KJS::AssignExprNode::evaluateToNumber): |
| (KJS::AssignExprNode::evaluateToInt32): |
| (KJS::VarDeclNode::handleSlowCase): |
| * kjs/nodes.h: |
| (KJS::FunctionCallResolveNode::precedence): |
| (KJS::AddNode::precedence): |
| (KJS::AddNode::): |
| (KJS::LessNumbersNode::): |
| (KJS::LessStringsNode::): |
| * kjs/value.cpp: |
| (KJS::JSValue::toInt32SlowCase): |
| (KJS::JSValue::toUInt32SlowCase): |
| * kjs/value.h: |
| (KJS::JSValue::asCell): |
| (KJS::JSValue::toInt32): |
| (KJS::JSValue::toUInt32): |
| |
| 2007-11-12 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=15953 |
| Add UTF-8 encoding/decoding to WTF |
| |
| * kjs/ustring.h: Moved UTF8SequenceLength() and decodeUTF8Sequence() to wtf/unicode. |
| * kjs/ustring.cpp: (KJS::UString::UTF8String): Changed this function to take a strict/lenient |
| parameter. Callers are not interested in getting decoding results in strict mode, so |
| this allows for bailing out as soon as an error is seen. |
| |
| * kjs/function.cpp: |
| (KJS::encode): Updated for new UString::UTF8String() signature. |
| |
| * API/JSStringRef.cpp: |
| (JSStringCreateWithCharacters): Disambiguate UChar. |
| (JSStringCreateWithUTF8CString): Actually use UTF-8 when creating the string! |
| * bindings/c/c_utility.cpp: (KJS::Bindings::convertUTF8ToUTF16): Use ConvertUTF8ToUTF16(). |
| |
| * wtf/unicode/UTF8.cpp: Added. |
| (WTF::Unicode::inlineUTF8SequenceLengthNonASCII): |
| (WTF::Unicode::inlineUTF8SequenceLength): |
| (WTF::Unicode::UTF8SequenceLength): |
| (WTF::Unicode::decodeUTF8Sequence): |
| (WTF::Unicode::): |
| (WTF::Unicode::ConvertUTF16ToUTF8): |
| (WTF::Unicode::isLegalUTF8): |
| (WTF::Unicode::ConvertUTF8ToUTF16): |
| * wtf/unicode/UTF8.h: Added. |
| (WTF::Unicode::): |
| Some code moved from ustring.h, some adapted from unicode.org sources. |
| |
| * JavaScriptCore.exp: |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/WTF/WTF.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| Added UTF8.{h,cpp} |
| |
| 2007-11-12 Josh Aas <joshmoz@gmail.com> |
| |
| Reviewed by Darin. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15946 |
| add NPPValue NPPVpluginDrawingModel (Mozilla bug 403418 compat) |
| |
| * bindings/npapi.h: |
| |
| 2007-11-12 Darin Adler <darin@apple.com> |
| |
| Reviewed by Sam. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15951 |
| REGRESSION: assertion failure in regexp match() when running JS tests |
| |
| Test: fast/js/regexp-many-brackets.html |
| |
| * pcre/pcre_exec.cpp: (match): Added back accidentally-removed case for |
| the BRANUMBER opcode. |
| |
| 2007-11-12 Darin Adler <darin@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - fix use of prefix and config.h, got rid of a few unneeded things in |
| the PCRE code; no behavior changes |
| |
| * API/JSBase.cpp: Added include of config.h. |
| * API/JSCallbackConstructor.cpp: Ditto. |
| * API/JSCallbackFunction.cpp: Ditto. |
| * API/JSCallbackObject.cpp: Ditto. |
| * API/JSClassRef.cpp: Ditto. |
| * API/JSContextRef.cpp: Ditto. |
| * API/JSObjectRef.cpp: Ditto. |
| * API/JSStringRef.cpp: Ditto. |
| * API/JSValueRef.cpp: Ditto. |
| |
| * JavaScriptCorePrefix.h: Removed obsolete <ctype.h> workaround. |
| Moved new/delete macros after includes, as they are in WebCore's prefix. |
| Removed "config.h". |
| |
| * pcre/dftables.cpp: (main): Changed back to not use a separate maketables |
| function. This is needed for PCRE, but not helpful for our use. Also changed |
| the tables to all be 128 entries long instead of 256, since only the first |
| 128 are ever used. |
| |
| * pcre/pcre_compile.cpp: Added include of config.h. Eliminated digitab, |
| which was only being used to check hex digits. Changed all uses of TRUE and |
| FALSE to use the C++ true and false instead. |
| (check_escape): Just the TRUE/FALSE thing. |
| (is_counted_repeat): Ditto. |
| (could_be_empty_branch): Ditto. |
| (get_othercase_range): Ditto. |
| (compile_branch): Ditto. |
| (compile_regex): Ditto. |
| (is_anchored): Ditto. |
| (is_startline): Ditto. |
| (find_firstassertedchar): Ditto. |
| (jsRegExpCompile): Ditto. |
| |
| * pcre/pcre_exec.cpp: Added include of config.h. Changed all uses of TRUE and |
| FALSE to use the C++ true and false instead. |
| (match_ref): Just the TRUE/FALSE thing. |
| (match): Ditto. Removed some unneeded braces. |
| (jsRegExpExecute): Just the TRUE/FALSE thing. |
| |
| * pcre/pcre_internal.h: Moved the constants needed by dftables.cpp to the top |
| of the file instead of the bottom, so they can be used. Also changed the table |
| sizes to 128 instead of 256. Removed macro definitions of FALSE and TRUE. |
| Set array sizes for all the const arrays. Changed _pcre_utf8_table1_size to |
| be a macro instead of a extern int. |
| |
| * pcre/pcre_maketables.cpp: Removed. It's all in dftables.cpp now. |
| |
| * pcre/pcre_tables.cpp: Made table sizes explicit. |
| |
| * pcre/pcre_xclass.cpp: Just the TRUE/FALSE thing. |
| |
| 2007-11-12 Adam Roben <aroben@apple.com> |
| |
| Build fix |
| |
| * wtf/FastMalloc.h: Add missing using statement. |
| |
| 2007-11-11 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Darin. |
| |
| Add special fastZeroedMalloc function to replace a |
| number of fastCalloc calls where one argument was 1. |
| |
| This results in a 0.4% progression in SunSpider, more |
| than making up for the earlier regression caused by |
| additional overflow checks. |
| |
| * JavaScriptCore.exp: |
| * kjs/array_instance.cpp: |
| * kjs/property_map.cpp: |
| * wtf/FastMalloc.cpp: |
| * wtf/FastMalloc.h: |
| * wtf/HashTable.h: |
| |
| 2007-11-11 Adam Roben <aroben@apple.com> |
| |
| Fix <rdar://5578982> ASSERT in HashTable::checkTableConsistencyExceptSize beneath WebNotificationCenter |
| |
| The bug was due to a mismatch between HashMap::remove and |
| HashTable::checkTableConsistency. HashMap::remove can delete the value |
| stored in the HashTable (by derefing it), which is not normally |
| allowed by HashTable. It's OK in this case because the value is about |
| to be removed from the table, but HashTable wasn't aware of this. |
| |
| HashMap::remove now performs the consistency check itself before |
| derefing the value. |
| |
| Darin noticed that the same bug would occur in HashSet, so I've fixed |
| it there as well. |
| |
| Reviewed by Darin. |
| |
| * wtf/HashMap.h: |
| (WTF::HashMap::remove): Perform the HashTable consistency check |
| manually before calling deref. |
| * wtf/HashSet.h: |
| (WTF::HashSet::remove): Ditto. |
| * wtf/HashTable.h: Made checkTableConsistency public so that HashMap |
| and HashSet can call it. |
| (WTF::HashTable::removeAndInvalidateWithoutEntryConsistencyCheck): |
| Added. |
| (WTF::HashTable::removeAndInvalidate): Added. |
| (WTF::HashTable::remove): |
| (WTF::HashTable::removeWithoutEntryConsistencyCheck): Added. |
| |
| 2007-11-11 Mark Rowe <mrowe@apple.com> |
| |
| Build fix. Use the correct filename case. |
| |
| * kjs/nodes.h: |
| |
| 2007-11-11 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Fixed http://bugs.webkit.org/show_bug.cgi?id=15902 |
| 15% of string-validate-input.js is spent compiling the same regular expression |
| |
| Store a compiled representation of the regular expression in the AST. |
| |
| Only a .2% SunSpider speedup overall, but a 10.6% speedup on |
| string-validate-input.js. |
| |
| * kjs/nodes.cpp: |
| (KJS::RegExpNode::evaluate): |
| * kjs/nodes.h: |
| (KJS::RegExpNode::): |
| * kjs/nodes2string.cpp: |
| (KJS::RegExpNode::streamTo): |
| * kjs/regexp.cpp: |
| (KJS::RegExp::flags): |
| * kjs/regexp.h: |
| (KJS::RegExp::pattern): |
| * kjs/regexp_object.cpp: |
| (KJS::RegExpObjectImp::construct): |
| (KJS::RegExpObjectImp::createRegExpImp): |
| * kjs/regexp_object.h: |
| |
| 2007-11-11 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Eric. |
| |
| Partial fix for <rdar://problem/5585334> numfuzz: integer overflows opening malformed SVG file in WebCore::ImageBuffer::create |
| |
| Unfortunately this is a very slight regression, but is unavoidable. |
| |
| * wtf/FastMalloc.cpp: |
| |
| 2007-11-10 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by darin. |
| |
| Add simple type inferencing to the parser, and create custom |
| AddNode and LessNode subclasses based on inferred types. |
| http://bugs.webkit.org/show_bug.cgi?id=15884 |
| |
| SunSpider claims this is at least a 0.5% speedup. |
| |
| * JavaScriptCore.exp: |
| * kjs/grammar.y: |
| * kjs/internal.cpp: |
| (KJS::NumberImp::getPrimitiveNumber): |
| (KJS::GetterSetterImp::getPrimitiveNumber): |
| * kjs/internal.h: |
| * kjs/lexer.cpp: |
| (KJS::Lexer::lex): |
| * kjs/nodes.cpp: |
| (KJS::Node::Node): |
| (KJS::StringNode::evaluate): |
| (KJS::StringNode::evaluateToNumber): |
| (KJS::StringNode::evaluateToBoolean): |
| (KJS::RegExpNode::evaluate): |
| (KJS::UnaryPlusNode::optimizeVariableAccess): |
| (KJS::AddNode::evaluate): |
| (KJS::AddNode::evaluateToNumber): |
| (KJS::AddNumbersNode::inlineEvaluateToNumber): |
| (KJS::AddNumbersNode::evaluate): |
| (KJS::AddNumbersNode::evaluateToNumber): |
| (KJS::AddStringsNode::evaluate): |
| (KJS::AddStringLeftNode::evaluate): |
| (KJS::AddStringRightNode::evaluate): |
| (KJS::lessThan): |
| (KJS::lessThanEq): |
| (KJS::LessNumbersNode::evaluate): |
| (KJS::LessStringsNode::evaluate): |
| * kjs/nodes.h: |
| (KJS::ExpressionNode::): |
| (KJS::RegExpNode::): |
| (KJS::RegExpNode::precedence): |
| (KJS::TypeOfResolveNode::): |
| (KJS::LocalVarTypeOfNode::): |
| (KJS::UnaryPlusNode::): |
| (KJS::UnaryPlusNode::precedence): |
| (KJS::AddNode::): |
| (KJS::AddNode::precedence): |
| (KJS::AddNumbersNode::): |
| (KJS::AddStringLeftNode::): |
| (KJS::AddStringRightNode::): |
| (KJS::AddStringsNode::): |
| (KJS::LessNode::): |
| (KJS::LessNode::precedence): |
| (KJS::LessNumbersNode::): |
| (KJS::LessStringsNode::): |
| * kjs/nodes2string.cpp: |
| (KJS::StringNode::streamTo): |
| * kjs/object.cpp: |
| * kjs/object.h: |
| * kjs/value.h: |
| (KJS::JSValue::getPrimitiveNumber): |
| |
| 2007-11-11 Darin Adler <darin@apple.com> |
| |
| - try another way of fixing dftables builds -- refactor pcre_internal.h a bit |
| |
| * pcre/pcre_internal.h: Make most of this header do nothing when DFTABLES is set. |
| Later we can break it into two files. |
| |
| * JavaScriptCore.vcproj/dftables/dftables.vcproj: Take out now-unneeded include paths. |
| * pcre/dftables.cpp: Set DFTABLES. Use delete instead of free. |
| * pcre/dftables.pro: Take out now-unneeded include paths. |
| * pcre/pcre_maketables.cpp: Use new instead of malloc. |
| |
| 2007-11-11 Darin Adler <darin@apple.com> |
| |
| * pcre/dftables.pro: Try fixing Qt builds (I looked at qt-win) by adding |
| another include path. |
| |
| 2007-11-11 Darin Adler <darin@apple.com> |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: Try fixing Mac Tiger builds |
| by adding another include path. |
| |
| 2007-11-11 Darin Adler <darin@apple.com> |
| |
| Reviewed by Sam. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15924 |
| next round of changes to JSRegExp (formerly PCRE) |
| |
| This is a combination of converting to C++, tweaking the API, and adding |
| some additional optimizations. |
| |
| Future steps will involve getting rid of the use of UTF-8 completely |
| (we'll use UTF-16 exclusively instead), eliminating more source files, |
| and some more speed-ups. |
| |
| SunSpider says the current round is an 0.9% speed-up overall, and a |
| 5.3% speed-up for regexp. |
| |
| * JavaScriptCore.exp: Updated for new entry points. |
| |
| * JavaScriptCore.pri: |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.vcproj/dftables/dftables.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * JavaScriptCoreSources.bkl: |
| * jscore.bkl: |
| Updated for new source file names and ForwardingHeaders. |
| |
| * kjs/regexp.cpp: |
| (KJS::RegExp::RegExp): Changed to use the error message without calling |
| strdup on it and to pass the new types and options. |
| (KJS::RegExp::~RegExp): Removed the now-unneeded free of the error message. |
| (KJS::RegExp::match): Pass the new types and options. |
| * kjs/regexp.h: Update type of m_constructionError. |
| |
| * pcre/AUTHORS: Update to reflect the status of the project -- we don't include |
| the Google parts, and this isn't the PCRE library, per se. |
| * pcre/COPYING: Ditto. |
| |
| * pcre/dftables.cpp: Copied from JavaScriptCore/pcre/dftables.c. |
| (main): Removed unneeded ctype_digit. |
| |
| * pcre/pcre.h: Convert to C++, tweak API a bit. Use UChar instead of JSRegExpChar. |
| |
| * pcre/pcre_compile.cpp: Copied from JavaScriptCore/pcre/pcre_compile.c. |
| Moved a lot of private stuff used only within this file here from pcre_internal.h. |
| Renumbered the error codes. |
| (error_text): Use a single string with embedded nulls for the error text (I got |
| this idea from newer versions of PCRE). |
| (check_escape): Changed return type to be enum instead of int. Replaced ctype_digit |
| uses with isASCIIDigit. |
| (is_counted_repeat): Ditto. |
| (read_repeat_counts): Ditto. |
| (first_significant_code): Ditto. |
| (find_fixedlength): Ditto. |
| (could_be_empty_branch): Ditto. |
| (compile_branch): Ditto. Also removed some code that handles changing options. |
| JavaScript doesn't have any of the features that allow options to change. |
| (compile_regex): Updated for change to options parameter. |
| (is_anchored): Ditto. |
| (find_firstassertedchar): Ditto. |
| (jsRegExpCompile): Changed to take separate flags instead of an options int. |
| Also changed to call new/delete instead of pcre_malloc/free. |
| (jsRegExpFree): Ditto. |
| |
| * pcre/pcre_exec.cpp: Copied from JavaScriptCore/pcre/pcre_exec.c. |
| Added a case that uses computed goto for the opcode loop, but did not turn it on. |
| Changed the RMATCH macro to handle returns more efficiently by putting the where |
| pointer in the new frame instead of the old one, allowing us to branch to the |
| return with a single statement. Switched to new/delete from pcre_malloc/free. |
| Changed many RRETURN callers to not set the return value since it's already |
| set correctly. Replaced the rrc variable with an is_match variable. Values other |
| than "match" and "no match" are now handled differently. This allows us to remove |
| the code to check for those cases in various rules. |
| (match): All the case statements use a macro BEGIN_OPCODE instead. And all the |
| continue statements, or break statements that break out of the outer case use |
| a macro NEXT_OPCODE instead. Replaced a few if statements with assertions. |
| (jsRegExpExecute): Use new/delete instead of pcre_malloc/free. Removed unused |
| start_match field from the match block. |
| |
| * pcre/pcre_internal.h: Moved the last few configuration macros from pcre-config.h |
| in here. Removed various unused types. Converted from JSRegExpChar to UChar. |
| Eliminated pcre_malloc/free. Replaced the opcode enum with a macro that can be |
| used in multiple places. Unfortunately we lose the comments for each opcode; we |
| should find a place to put those back. Removed ctype_digit. |
| |
| * pcre/pcre_maketables.cpp: Copied from JavaScriptCore/pcre/pcre_maketables.c. |
| (pcre_maketables): Got rid of the conditional code that allows this to be compiled |
| in -- it's only used for dftables now (and soon may be obsolete entirely). |
| Changed code for cbit_digit to not use isdigit, and took the "_" case out of the |
| loop. Removed ctype_digit. |
| |
| * pcre/pcre_ord2utf8.cpp: Copied from JavaScriptCore/pcre/pcre_ord2utf8.c. |
| |
| * pcre/pcre_tables.cpp: Copied from JavaScriptCore/pcre/pcre_tables.c. |
| Moved _pcre_OP_lengths out of here into pcre_exec.cpp. |
| |
| * pcre/pcre_ucp_searchfuncs.cpp: Copied from JavaScriptCore/pcre/pcre_ucp_searchfuncs.c. |
| Updated for other file name changes. |
| |
| * pcre/pcre_xclass.cpp: Copied from JavaScriptCore/pcre/pcre_xclass.c. |
| |
| * pcre/ucpinternal.h: Updated header. |
| |
| * pcre/ucptable.cpp: Copied from JavaScriptCore/pcre/ucptable.c. |
| |
| * wtf/ASCIICType.h: (WTF::isASCIIDigit): Removed a branch by changing from && to |
| & for this operation. Also added an overload that takes an int because that's |
| useful for PCRE. Later we could optimize for int and overload other functions in |
| this file; stuck to this simple one for now. |
| |
| * wtf/unicode/icu/UnicodeIcu.h: Removed unused isUpper. |
| * wtf/unicode/qt4/UnicodeQt4.h: Ditto. |
| |
| * pcre/LICENCE: Removed. |
| * pcre/pcre-config.h: Removed. |
| * wtf/FastMallocPCRE.cpp: Removed. |
| |
| * pcre/dftables.c: Renamed to cpp. |
| * pcre/pcre_compile.c: Ditto. |
| * pcre/pcre_exec.c: Ditto. |
| * pcre/pcre_maketables.c: Ditto. |
| * pcre/pcre_ord2utf8.c: Ditto. |
| * pcre/pcre_tables.c: Ditto. |
| * pcre/pcre_ucp_searchfuncs.c: Ditto. |
| * pcre/pcre_xclass.c: Ditto. |
| * pcre/ucptable.c: Ditto. |
| |
| 2007-11-11 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Oliver. |
| |
| Add KJS_CHECKEXCEPTIONBOOLEAN to match rest of nodes.cpp |
| |
| * kjs/nodes.cpp: |
| (KJS::ExpressionNode::evaluateToBoolean): |
| (KJS::LessNode::evaluateToBoolean): |
| (KJS::GreaterNode::evaluateToBoolean): |
| (KJS::LessEqNode::evaluateToBoolean): |
| (KJS::GreaterEqNode::evaluateToBoolean): |
| (KJS::InstanceOfNode::evaluateToBoolean): |
| (KJS::InNode::evaluateToBoolean): |
| (KJS::EqualNode::evaluateToBoolean): |
| (KJS::NotEqualNode::evaluateToBoolean): |
| (KJS::StrictEqualNode::evaluateToBoolean): |
| (KJS::NotStrictEqualNode::evaluateToBoolean): |
| (KJS::LogicalAndNode::evaluateToBoolean): |
| (KJS::LogicalOrNode::evaluateToBoolean): |
| (KJS::ConditionalNode::evaluateToBoolean): |
| |
| 2007-11-10 Darin Adler <darin@apple.com> |
| |
| Reviewed by Sam. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=15927 |
| REGRESSION(r27487): delete a.c followed by __defineGetter__("c", ...) incorrectly deletes another property |
| and <rdar://problem/5586384> REGRESSION (r27487): Can't switch out of Edit HTML Source mode on Leopard Wiki |
| |
| Test: fast/js/delete-then-put.html |
| |
| * kjs/property_map.cpp: |
| (KJS::PropertyMap::put): Added a missing "- 1"; code to find an empty slot was not working. |
| (KJS::PropertyMap::checkConsistency): Added a missing range check that would have caught this |
| problem before. |
| |
| - roll out a last-minute change to my evaluateToBoolean patch that was incorrect. |
| |
| * kjs/nodes.h: (KJS::ExprStatementNode::ExprStatementNode): Take out call to |
| optimizeForUnnecessaryResult, since the result is used in some cases. |
| |
| 2007-11-10 Adam Roben <aroben@apple.com> |
| |
| Windows build fix |
| |
| Roll out some changes that were (seemingly accidentally) checked in |
| with r27664. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| |
| 2007-11-10 Darin Adler <darin@apple.com> |
| |
| Reviewed by Sam. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15915 |
| add an evaluation path for booleans like the one we have for numbers |
| |
| Gives 1.1% on SunSpider. |
| |
| * kjs/grammar.y: Create TrueNode and FalseNode instead of BooleanNode. |
| |
| * kjs/nodes.h: Changed to use Noncopyable. Moved optimizeForUnnecessaryResult |
| down from Node to ExpressionNode. Changed some classes to not inherit from |
| ExpressionNode where not necessary, and removed unnneeded evaluate functions |
| as well as evaluate functions that need not be virtual. Call the |
| optimizeForUnnecessaryResult function on the start of a for loop too. |
| * kjs/nodes.cpp: |
| (KJS::ExpressionNode::evaluateToBoolean): Added. |
| (KJS::FalseNode::evaluate): Added. |
| (KJS::TrueNode::evaluate): Added. |
| (KJS::NumberNode::evaluateToBoolean): Added. |
| (KJS::StringNode::evaluateToBoolean): Added. |
| (KJS::LocalVarAccessNode::evaluateToBoolean): Added. |
| (KJS::BracketAccessorNode::evaluateToBoolean): Added. |
| (KJS::LogicalNotNode::evaluate): Changed to call evaluateToBoolean. |
| (KJS::LogicalNotNode::evaluateToBoolean): Added. |
| (KJS::lessThan): Changed to return bool. |
| (KJS::lessThanEq): Ditto. |
| (KJS::LessNode::evaluate): Changed since lessThan returns bool. |
| (KJS::LessNode::evaluateToBoolean): Added. |
| (KJS::GreaterNode::evaluate): Changed since lessThanEq returns bool. |
| (KJS::GreaterNode::evaluateToBoolean): Added. |
| (KJS::LessEqNode::evaluate): Changed since lessThanEq returns bool. |
| (KJS::LessEqNode::evaluateToBoolean): Added. |
| (KJS::GreaterEqNode::evaluate): Changed since lessThan returns bool. |
| (KJS::GreaterEqNode::evaluateToBoolean): Added. |
| (KJS::InstanceOfNode::evaluateToBoolean): Added. |
| (KJS::InNode::evaluateToBoolean): Added. |
| (KJS::EqualNode::evaluateToBoolean): Added. |
| (KJS::NotEqualNode::evaluateToBoolean): Added. |
| (KJS::StrictEqualNode::evaluateToBoolean): Added. |
| (KJS::NotStrictEqualNode::evaluateToBoolean): Added. |
| (KJS::ConditionalNode::evaluate): Changed to call evaluateToBoolean. |
| (KJS::IfNode::execute): Ditto. |
| (KJS::DoWhileNode::execute): Ditto. |
| (KJS::WhileNode::execute): Ditto. |
| (KJS::ForNode::execute): Ditto. |
| |
| * kjs/nodes2string.cpp: |
| (KJS::FalseNode::streamTo): Added. |
| (KJS::TrueNode::streamTo): Added. |
| |
| 2007-11-09 Adam Roben <aroben@apple.com> |
| |
| Windows build fix |
| |
| Reviewed by Darin. |
| |
| * kjs/value.h: |
| (KJS::jsNumber): Add some explicit casts. |
| |
| 2007-11-08 Darin Adler <darin@apple.com> |
| |
| - fix build |
| |
| * kjs/grammar.y: |
| * kjs/nodes.h: |
| * kjs/property_map.cpp: |
| |
| 2007-11-08 Darin Adler <darin@apple.com> |
| |
| - roll out accidentally-checked in changes |
| |
| * kjs/nodes.cpp: Back to previous version. |
| * kjs/nodes.h: Ditto. |
| * kjs/grammar.y: Ditto. |
| |
| 2007-11-08 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15912 |
| fasta spends a lot of time in qsort |
| |
| * kjs/property_map.cpp: |
| (KJS::PropertyMap::getEnumerablePropertyNames): |
| Use insertion sort instead of qsort for small sets of property names. |
| We can probably do some even-better speedups of for/in, but this nets |
| 0.6% overall and 6.7% on fasta. |
| |
| 2007-11-08 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15906 |
| getting characters by indexing into a string is very slow |
| |
| This fixes one source of the slowness -- the conversion to an unused |
| Identifier as we call the get function from the slot -- but doesn't |
| fix others, such as the fact that we have to allocate a new UString::Rep |
| for every single character. |
| |
| Speeds up string-base64 30%, and at least 0.5% overall. |
| But does slow down access-fannkuch quite a bit. Might be worth |
| revisiting in the future to see what we can do about that (although |
| I did look at a profile for a while). |
| |
| * kjs/property_slot.h: Add a new marker for "numeric" property slots; |
| slots where we don't need to pass the identifier to the get function. |
| (KJS::PropertySlot::getValue): Added code to call the numeric get function. |
| (KJS::PropertySlot::setCustomNumeric): Added. |
| * kjs/string_object.cpp: |
| (KJS::StringInstance::indexGetter): Changed to use substr() instead |
| of constructing a wholly new UString each time. |
| (KJS::stringInstanceNumericPropertyGetter): Added. Like indexGetter, but |
| takes advantage of setCustomNumeric to avoid creating an Identifier. |
| (KJS::StringInstance::getOwnPropertySlot): Changed to use setCustomNumeric. |
| |
| 2007-11-08 Darin Adler <darin@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15904 |
| more speed-ups possible by tightening up int version of JSImmediate |
| |
| 1% improvement of SunSpider |
| |
| * kjs/JSImmediate.h: Eliminate the now-unneeded FPBitValues struct template. |
| (KJS::JSImmediate::from): Overload for most numeric types; many types can |
| do fewer branches and checks. |
| (KJS::JSImmediate::getUInt32): Removed unneeded check for undefined. |
| (KJS::JSImmediate::getTruncatedInt32): Ditto. |
| (KJS::JSImmediate::getTruncatedUInt32): Ditto. There's no difference any more |
| between getUInt32 and getTruncatedUInt32, so that's worth a rename and merge later. |
| |
| * kjs/grammar.y: Update since fromDouble is now just from. |
| * kjs/nodes.h: Ditto. |
| |
| * kjs/value.h: (KJS::jsNumber): Overload for most numeric types. |
| |
| 2007-11-08 Kevin Ollivier <kevino@theolliviers.com> |
| |
| Bakefiles for building JavaScriptCore, needed by wx port. |
| |
| Reviewed by Mark Rowe. |
| |
| * JavaScriptCoreSources.bkl: Added. |
| * jscore.bkl: Added. |
| |
| 2007-11-08 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Fix regression caused by earlier bitwise and optimisation. 1 & undefined != 1. |
| |
| The implementation of JSImmediate::areBothImmediateNumbers relies on |
| (JSImmediate::getTag(immediate1) & JSImmediate::getTag(immediate2)) having |
| a unique result when both immediate values are numbers. |
| |
| The regression was due to UndefinedType & NumberType returning NumberType (3 & 1). |
| By swapping the value of NumberType and UndefinedType this ceases to be a problem. |
| |
| * kjs/JSType.h: |
| |
| 2007-11-08 Darin Adler <darin@apple.com> |
| |
| - fix build |
| |
| * kjs/nodes.h: Add missing parameter name. |
| |
| 2007-11-08 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by darin. |
| |
| Add ExpressionNode subclass of Node, use it. |
| |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::ForInNode::ForInNode): |
| * kjs/nodes.h: |
| (KJS::ExpressionNode::): |
| (KJS::NullNode::): |
| (KJS::NullNode::precedence): |
| (KJS::BooleanNode::): |
| (KJS::BooleanNode::precedence): |
| (KJS::RegExpNode::): |
| (KJS::RegExpNode::precedence): |
| (KJS::ThisNode::): |
| (KJS::ThisNode::precedence): |
| (KJS::ResolveNode::): |
| (KJS::ElementNode::): |
| (KJS::ArrayNode::): |
| (KJS::PropertyNode::): |
| (KJS::PropertyNode::precedence): |
| (KJS::PropertyNode::name): |
| (KJS::PropertyListNode::): |
| (KJS::ObjectLiteralNode::): |
| (KJS::ObjectLiteralNode::precedence): |
| (KJS::BracketAccessorNode::): |
| (KJS::DotAccessorNode::): |
| (KJS::DotAccessorNode::precedence): |
| (KJS::ArgumentListNode::): |
| (KJS::ArgumentsNode::): |
| (KJS::NewExprNode::): |
| (KJS::NewExprNode::precedence): |
| (KJS::FunctionCallValueNode::): |
| (KJS::FunctionCallValueNode::precedence): |
| (KJS::FunctionCallResolveNode::): |
| (KJS::FunctionCallBracketNode::): |
| (KJS::FunctionCallBracketNode::precedence): |
| (KJS::FunctionCallDotNode::): |
| (KJS::FunctionCallDotNode::precedence): |
| (KJS::PrePostResolveNode::): |
| (KJS::PostfixBracketNode::): |
| (KJS::PostfixBracketNode::precedence): |
| (KJS::PostIncBracketNode::): |
| (KJS::PostIncBracketNode::isIncrement): |
| (KJS::PostDecBracketNode::): |
| (KJS::PostDecBracketNode::isIncrement): |
| (KJS::PostfixDotNode::): |
| (KJS::PostfixDotNode::precedence): |
| (KJS::PostIncDotNode::): |
| (KJS::PostIncDotNode::isIncrement): |
| (KJS::PostDecDotNode::): |
| (KJS::PostDecDotNode::isIncrement): |
| (KJS::PostfixErrorNode::): |
| (KJS::PostfixErrorNode::precedence): |
| (KJS::DeleteResolveNode::): |
| (KJS::DeleteBracketNode::): |
| (KJS::DeleteBracketNode::precedence): |
| (KJS::DeleteDotNode::): |
| (KJS::DeleteDotNode::precedence): |
| (KJS::DeleteValueNode::): |
| (KJS::DeleteValueNode::precedence): |
| (KJS::VoidNode::): |
| (KJS::VoidNode::precedence): |
| (KJS::TypeOfResolveNode::): |
| (KJS::TypeOfValueNode::): |
| (KJS::PrefixBracketNode::): |
| (KJS::PrefixBracketNode::precedence): |
| (KJS::PreIncBracketNode::): |
| (KJS::PreIncBracketNode::isIncrement): |
| (KJS::PreDecBracketNode::): |
| (KJS::PreDecBracketNode::isIncrement): |
| (KJS::PrefixDotNode::): |
| (KJS::PrefixDotNode::precedence): |
| (KJS::PreIncDotNode::): |
| (KJS::PreIncDotNode::isIncrement): |
| (KJS::PreDecDotNode::): |
| (KJS::PreDecDotNode::isIncrement): |
| (KJS::PrefixErrorNode::): |
| (KJS::PrefixErrorNode::precedence): |
| (KJS::UnaryPlusNode::): |
| (KJS::UnaryPlusNode::precedence): |
| (KJS::NegateNode::): |
| (KJS::NegateNode::precedence): |
| (KJS::BitwiseNotNode::): |
| (KJS::BitwiseNotNode::precedence): |
| (KJS::LogicalNotNode::): |
| (KJS::LogicalNotNode::precedence): |
| (KJS::AddNode::): |
| (KJS::AddNode::precedence): |
| (KJS::LeftShiftNode::): |
| (KJS::LeftShiftNode::precedence): |
| (KJS::RightShiftNode::): |
| (KJS::RightShiftNode::precedence): |
| (KJS::UnsignedRightShiftNode::): |
| (KJS::UnsignedRightShiftNode::precedence): |
| (KJS::LessNode::): |
| (KJS::LessNode::precedence): |
| (KJS::GreaterNode::): |
| (KJS::GreaterNode::precedence): |
| (KJS::LessEqNode::): |
| (KJS::LessEqNode::precedence): |
| (KJS::GreaterEqNode::): |
| (KJS::GreaterEqNode::precedence): |
| (KJS::InstanceOfNode::): |
| (KJS::InstanceOfNode::precedence): |
| (KJS::InNode::): |
| (KJS::InNode::precedence): |
| (KJS::EqualNode::): |
| (KJS::EqualNode::precedence): |
| (KJS::NotEqualNode::): |
| (KJS::NotEqualNode::precedence): |
| (KJS::StrictEqualNode::): |
| (KJS::StrictEqualNode::precedence): |
| (KJS::NotStrictEqualNode::): |
| (KJS::NotStrictEqualNode::precedence): |
| (KJS::BitAndNode::): |
| (KJS::BitAndNode::precedence): |
| (KJS::BitOrNode::): |
| (KJS::BitOrNode::precedence): |
| (KJS::BitXOrNode::): |
| (KJS::BitXOrNode::precedence): |
| (KJS::LogicalAndNode::): |
| (KJS::LogicalAndNode::precedence): |
| (KJS::LogicalOrNode::): |
| (KJS::LogicalOrNode::precedence): |
| (KJS::ConditionalNode::): |
| (KJS::ConditionalNode::precedence): |
| (KJS::ReadModifyResolveNode::): |
| (KJS::ReadModifyResolveNode::precedence): |
| (KJS::AssignResolveNode::): |
| (KJS::AssignResolveNode::precedence): |
| (KJS::ReadModifyBracketNode::): |
| (KJS::ReadModifyBracketNode::precedence): |
| (KJS::AssignBracketNode::): |
| (KJS::AssignBracketNode::precedence): |
| (KJS::AssignDotNode::): |
| (KJS::AssignDotNode::precedence): |
| (KJS::ReadModifyDotNode::): |
| (KJS::ReadModifyDotNode::precedence): |
| (KJS::AssignErrorNode::): |
| (KJS::AssignErrorNode::precedence): |
| (KJS::CommaNode::): |
| (KJS::CommaNode::precedence): |
| (KJS::AssignExprNode::): |
| (KJS::AssignExprNode::precedence): |
| (KJS::ExprStatementNode::): |
| (KJS::IfNode::): |
| (KJS::DoWhileNode::): |
| (KJS::WhileNode::): |
| (KJS::ReturnNode::): |
| (KJS::WithNode::): |
| (KJS::ThrowNode::): |
| (KJS::ParameterNode::): |
| (KJS::CaseClauseNode::): |
| (KJS::CaseClauseNode::precedence): |
| (KJS::ClauseListNode::): |
| (KJS::SwitchNode::): |
| |
| 2007-11-08 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Sam. |
| |
| Add a fast path for bitwise-and of two immediate numbers for a 0.7% improvement in SunSpider (4% bitop improvement). |
| |
| This only improves bitwise-and performance, as the additional logic required |
| for similar code paths on or, xor, and shifting requires additional operations |
| and branches that negate (and in certain cases, regress) any advantage we might |
| otherwise receive. |
| |
| This improves performance on all bitop tests, the cryptography tests, as well as |
| the string-base64 and string-unpack-code tests. No significant degradation on |
| any other tests. |
| |
| * kjs/JSImmediate.h: |
| (KJS::JSImmediate::areBothImmediateNumbers): |
| (KJS::JSImmediate::andImmediateNumbers): |
| * kjs/nodes.cpp: |
| (KJS::BitAndNode::evaluate): |
| * kjs/value.h: |
| (KJS::jsNumberFromAnd): |
| |
| 2007-11-08 Adam Roben <aroben@apple.com> |
| |
| Stop using KJS inside of MathExtras.h |
| |
| Reviewed by Darin. |
| |
| * wtf/MathExtras.h: Removed an unused header, and a now-unused |
| forward-declaration. |
| (wtf_atan2): Use std::numeric_limits intead of KJS. |
| |
| 2007-11-08 Sam Weinig <sam@webkit.org> |
| |
| Windows build fix. |
| |
| * kjs/date_object.cpp: |
| (KJS::DateProtoFuncToLocaleString::callAsFunction): Fix unused arg warning. |
| (KJS::DateProtoFuncToLocaleDateString::callAsFunction): ditto |
| (KJS::DateProtoFuncToLocaleTimeString::callAsFunction): ditto |
| |
| 2007-11-08 Mark Rowe <mrowe@apple.com> |
| |
| Gtk build fix. |
| |
| * kjs/lookup.h: Add missing include. |
| |
| 2007-11-08 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Darin. |
| |
| Convert JavaScript internal function objects to use one class per |
| function. This avoids a switch statement inside what used to be |
| the shared function classes and will allow Shark to better analyze |
| the code. |
| |
| To make this switch, the value property of the HashEntry was changed |
| to a union of an intptr_t (which is used to continue handle valueGetters) |
| and function pointer which points to a static constructor for the |
| individual new function objects. |
| |
| SunSpider claims this is a 1.0% speedup. |
| |
| * kjs/array_object.cpp: |
| (KJS::ArrayPrototype::getOwnPropertySlot): |
| (KJS::getProperty): |
| (KJS::ArrayProtoFuncToString::callAsFunction): |
| (KJS::ArrayProtoFuncToLocaleString::callAsFunction): |
| (KJS::ArrayProtoFuncJoin::callAsFunction): |
| (KJS::ArrayProtoFuncConcat::callAsFunction): |
| (KJS::ArrayProtoFuncPop::callAsFunction): |
| (KJS::ArrayProtoFuncPush::callAsFunction): |
| (KJS::ArrayProtoFuncReverse::callAsFunction): |
| (KJS::ArrayProtoFuncShift::callAsFunction): |
| (KJS::ArrayProtoFuncSlice::callAsFunction): |
| (KJS::ArrayProtoFuncSort::callAsFunction): |
| (KJS::ArrayProtoFuncSplice::callAsFunction): |
| (KJS::ArrayProtoFuncUnShift::callAsFunction): |
| (KJS::ArrayProtoFuncFilter::callAsFunction): |
| (KJS::ArrayProtoFuncMap::callAsFunction): |
| (KJS::ArrayProtoFuncEvery::callAsFunction): |
| (KJS::ArrayProtoFuncForEach::callAsFunction): |
| (KJS::ArrayProtoFuncSome::callAsFunction): |
| (KJS::ArrayProtoFuncIndexOf::callAsFunction): |
| (KJS::ArrayProtoFuncLastIndexOf::callAsFunction): |
| * kjs/array_object.h: |
| (KJS::ArrayPrototype::classInfo): |
| * kjs/create_hash_table: |
| * kjs/date_object.cpp: |
| (KJS::DatePrototype::getOwnPropertySlot): |
| (KJS::DateProtoFuncToString::callAsFunction): |
| (KJS::DateProtoFuncToUTCString::callAsFunction): |
| (KJS::DateProtoFuncToDateString::callAsFunction): |
| (KJS::DateProtoFuncToTimeString::callAsFunction): |
| (KJS::DateProtoFuncToLocaleString::callAsFunction): |
| (KJS::DateProtoFuncToLocaleDateString::callAsFunction): |
| (KJS::DateProtoFuncToLocaleTimeString::callAsFunction): |
| (KJS::DateProtoFuncValueOf::callAsFunction): |
| (KJS::DateProtoFuncGetTime::callAsFunction): |
| (KJS::DateProtoFuncGetFullYear::callAsFunction): |
| (KJS::DateProtoFuncGetUTCFullYear::callAsFunction): |
| (KJS::DateProtoFuncToGMTString::callAsFunction): |
| (KJS::DateProtoFuncGetMonth::callAsFunction): |
| (KJS::DateProtoFuncGetUTCMonth::callAsFunction): |
| (KJS::DateProtoFuncGetDate::callAsFunction): |
| (KJS::DateProtoFuncGetUTCDate::callAsFunction): |
| (KJS::DateProtoFuncGetDay::callAsFunction): |
| (KJS::DateProtoFuncGetUTCDay::callAsFunction): |
| (KJS::DateProtoFuncGetHours::callAsFunction): |
| (KJS::DateProtoFuncGetUTCHours::callAsFunction): |
| (KJS::DateProtoFuncGetMinutes::callAsFunction): |
| (KJS::DateProtoFuncGetUTCMinutes::callAsFunction): |
| (KJS::DateProtoFuncGetSeconds::callAsFunction): |
| (KJS::DateProtoFuncGetUTCSeconds::callAsFunction): |
| (KJS::DateProtoFuncGetMilliSeconds::callAsFunction): |
| (KJS::DateProtoFuncGetUTCMilliseconds::callAsFunction): |
| (KJS::DateProtoFuncGetTimezoneOffset::callAsFunction): |
| (KJS::DateProtoFuncSetTime::callAsFunction): |
| (KJS::DateProtoFuncSetMilliSeconds::callAsFunction): |
| (KJS::DateProtoFuncSetUTCMilliseconds::callAsFunction): |
| (KJS::DateProtoFuncSetSeconds::callAsFunction): |
| (KJS::DateProtoFuncSetUTCSeconds::callAsFunction): |
| (KJS::DateProtoFuncSetMinutes::callAsFunction): |
| (KJS::DateProtoFuncSetUTCMinutes::callAsFunction): |
| (KJS::DateProtoFuncSetHours::callAsFunction): |
| (KJS::DateProtoFuncSetUTCHours::callAsFunction): |
| (KJS::DateProtoFuncSetDate::callAsFunction): |
| (KJS::DateProtoFuncSetUTCDate::callAsFunction): |
| (KJS::DateProtoFuncSetMonth::callAsFunction): |
| (KJS::DateProtoFuncSetUTCMonth::callAsFunction): |
| (KJS::DateProtoFuncSetFullYear::callAsFunction): |
| (KJS::DateProtoFuncSetUTCFullYear::callAsFunction): |
| (KJS::DateProtoFuncSetYear::callAsFunction): |
| (KJS::DateProtoFuncGetYear::callAsFunction): |
| * kjs/date_object.h: |
| * kjs/lookup.cpp: |
| (KJS::Lookup::find): |
| * kjs/lookup.h: |
| (KJS::HashEntry::): |
| (KJS::staticFunctionGetter): |
| (KJS::staticValueGetter): |
| (KJS::getStaticPropertySlot): |
| (KJS::getStaticFunctionSlot): |
| (KJS::lookupPut): |
| * kjs/math_object.cpp: |
| (KJS::MathObjectImp::getOwnPropertySlot): |
| (KJS::MathProtoFuncAbs::callAsFunction): |
| (KJS::MathProtoFuncACos::callAsFunction): |
| (KJS::MathProtoFuncASin::callAsFunction): |
| (KJS::MathProtoFuncATan::callAsFunction): |
| (KJS::MathProtoFuncATan2::callAsFunction): |
| (KJS::MathProtoFuncCeil::callAsFunction): |
| (KJS::MathProtoFuncCos::callAsFunction): |
| (KJS::MathProtoFuncExp::callAsFunction): |
| (KJS::MathProtoFuncFloor::callAsFunction): |
| (KJS::MathProtoFuncLog::callAsFunction): |
| (KJS::MathProtoFuncMax::callAsFunction): |
| (KJS::MathProtoFuncMin::callAsFunction): |
| (KJS::MathProtoFuncPow::callAsFunction): |
| (KJS::MathProtoFuncRandom::callAsFunction): |
| (KJS::MathProtoFuncRound::callAsFunction): |
| (KJS::MathProtoFuncSin::callAsFunction): |
| (KJS::MathProtoFuncSqrt::callAsFunction): |
| (KJS::MathProtoFuncTan::callAsFunction): |
| * kjs/math_object.h: |
| (KJS::MathObjectImp::classInfo): |
| (KJS::MathObjectImp::): |
| * kjs/string_object.cpp: |
| (KJS::StringPrototype::getOwnPropertySlot): |
| (KJS::StringProtoFuncToString::callAsFunction): |
| (KJS::StringProtoFuncValueOf::callAsFunction): |
| (KJS::StringProtoFuncCharAt::callAsFunction): |
| (KJS::StringProtoFuncCharCodeAt::callAsFunction): |
| (KJS::StringProtoFuncConcat::callAsFunction): |
| (KJS::StringProtoFuncIndexOf::callAsFunction): |
| (KJS::StringProtoFuncLastIndexOf::callAsFunction): |
| (KJS::StringProtoFuncMatch::callAsFunction): |
| (KJS::StringProtoFuncSearch::callAsFunction): |
| (KJS::StringProtoFuncReplace::callAsFunction): |
| (KJS::StringProtoFuncSlice::callAsFunction): |
| (KJS::StringProtoFuncSplit::callAsFunction): |
| (KJS::StringProtoFuncSubstr::callAsFunction): |
| (KJS::StringProtoFuncSubstring::callAsFunction): |
| (KJS::StringProtoFuncToLowerCase::callAsFunction): |
| (KJS::StringProtoFuncToUpperCase::callAsFunction): |
| (KJS::StringProtoFuncToLocaleLowerCase::callAsFunction): |
| (KJS::StringProtoFuncToLocaleUpperCase::callAsFunction): |
| (KJS::StringProtoFuncLocaleCompare::callAsFunction): |
| (KJS::StringProtoFuncBig::callAsFunction): |
| (KJS::StringProtoFuncSmall::callAsFunction): |
| (KJS::StringProtoFuncBlink::callAsFunction): |
| (KJS::StringProtoFuncBold::callAsFunction): |
| (KJS::StringProtoFuncFixed::callAsFunction): |
| (KJS::StringProtoFuncItalics::callAsFunction): |
| (KJS::StringProtoFuncStrike::callAsFunction): |
| (KJS::StringProtoFuncSub::callAsFunction): |
| (KJS::StringProtoFuncSup::callAsFunction): |
| (KJS::StringProtoFuncFontcolor::callAsFunction): |
| (KJS::StringProtoFuncFontsize::callAsFunction): |
| (KJS::StringProtoFuncAnchor::callAsFunction): |
| (KJS::StringProtoFuncLink::callAsFunction): |
| * kjs/string_object.h: |
| |
| 2007-11-08 Adam Roben <aroben@apple.com> |
| |
| Windows build fix |
| |
| Reviewed by Sam and Ada. |
| |
| * wtf/MathExtras.h: Get rid of a circular #include dependency to fix |
| the build. |
| |
| 2007-11-08 Adam Roben <aroben@apple.com> |
| |
| Fix a precedence warning on Windows |
| |
| * kjs/JSImmediate.h: |
| (KJS::JSImmediate::toBoolean): |
| |
| 2007-11-08 Mark Rowe <mrowe@apple.com> |
| |
| Build fix for JavaScriptGlue. |
| |
| * wtf/MathExtras.h: Include stdlib.h for srand and RAND_MAX. |
| |
| 2007-11-08 Darin Adler <darin@apple.com> |
| |
| - Windows build fix |
| |
| * kjs/JSImmediate.h: Include MathExtras.h rather than math.h since this file uses "signbit". |
| |
| 2007-11-08 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Darin. |
| |
| Replace the use of floats for immediate values with the use of integers for a 4.5% improvement in SunSpider. |
| |
| Unfortunately this change results in NaN, +Inf, -Inf, and -0 being heap allocated now, but |
| we should now have faster array access, faster immediate to double conversion, and the |
| potential to further improve bitwise operators in future. |
| |
| This also removes the need for unions to avoid strict aliasing problems when extracting |
| a value from immediates. |
| |
| * kjs/JSImmediate.h: |
| (KJS::JSImmediate::trueImmediate): |
| (KJS::JSImmediate::falseImmediate): |
| (KJS::JSImmediate::undefinedImmediate): |
| (KJS::JSImmediate::nullImmediate): |
| (KJS::JSImmediate::toBoolean): |
| * kjs/value.h: |
| (KJS::jsNaN): |
| |
| 2007-11-07 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Darin and Oliver. |
| |
| Add evaluateToNumber parallel evaluation tree to speed up number operations. |
| Make ImmediateNumberNode a subclass of NumberNode. |
| Share evaluate logic between evaluate and evaluateToNumber using inline functions |
| There is still a lot of improvement to be made here. |
| |
| SunSpider claims this is a 1.0% speedup overall (nbody 7.9%), base64 slowing 2.0% |
| Given the huge win that this prepares us for with simple type inferencing I see the small |
| regression in base64 being worth the substantial overall improvement. |
| |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::Node::evaluateToNumber): |
| (KJS::NumberNode::evaluate): |
| (KJS::NumberNode::evaluateToNumber): |
| (KJS::StringNode::evaluateToNumber): |
| (KJS::LocalVarAccessNode::inlineEvaluate): |
| (KJS::LocalVarAccessNode::evaluate): |
| (KJS::LocalVarAccessNode::evaluateToNumber): |
| (KJS::BracketAccessorNode::inlineEvaluate): |
| (KJS::BracketAccessorNode::evaluate): |
| (KJS::BracketAccessorNode::evaluateToNumber): |
| (KJS::NegateNode::evaluate): |
| (KJS::NegateNode::evaluateToNumber): |
| (KJS::MultNode::inlineEvaluateToNumber): |
| (KJS::MultNode::evaluate): |
| (KJS::MultNode::evaluateToNumber): |
| (KJS::DivNode::inlineEvaluateToNumber): |
| (KJS::DivNode::evaluate): |
| (KJS::DivNode::evaluateToNumber): |
| (KJS::ModNode::inlineEvaluateToNumber): |
| (KJS::ModNode::evaluate): |
| (KJS::ModNode::evaluateToNumber): |
| (KJS::throwOutOfMemoryErrorToNumber): |
| (KJS::addSlowCaseToNumber): |
| (KJS::add): |
| (KJS::addToNumber): |
| (KJS::AddNode::evaluateToNumber): |
| (KJS::SubNode::inlineEvaluateToNumber): |
| (KJS::SubNode::evaluate): |
| (KJS::SubNode::evaluateToNumber): |
| (KJS::valueForReadModifyAssignment): |
| (KJS::ReadModifyLocalVarNode::evaluate): |
| (KJS::ReadModifyResolveNode::evaluate): |
| (KJS::ReadModifyDotNode::evaluate): |
| (KJS::ReadModifyBracketNode::evaluate): |
| * kjs/nodes.h: |
| (KJS::Node::): |
| (KJS::NumberNode::): |
| (KJS::ImmediateNumberNode::): |
| (KJS::AddNode::precedence): |
| * kjs/nodes2string.cpp: |
| (KJS::NumberNode::streamTo): |
| |
| 2007-11-07 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Eric. |
| |
| Fix up initialization after being mangled in r27572, and remove the |
| ternary expression as extraCost will always be zero for the numeric |
| heap. |
| |
| * kjs/collector.cpp: |
| (KJS::Collector::heapAllocate): |
| |
| 2007-11-07 Mark Rowe <mrowe@apple.com> |
| |
| Gtk build fix. |
| |
| * kjs/regexp_object.cpp: |
| |
| 2007-11-07 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Beth Dakin. |
| |
| Eliminated a bogus (though compiled-out) branch in the collector. |
| |
| * kjs/collector.cpp: |
| (KJS::Collector::heapAllocate): |
| |
| 2007-11-06 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Fixed part of http://bugs.webkit.org/show_bug.cgi?id=15861 |
| 5.8% of string-validate-input.js is spent creating RegExpImps |
| |
| Put RegExpImp properties into a static hashtable to avoid a slew of |
| PropertyMap churn when creating a RegExpImp. |
| |
| Factored important bits of regular expression implementation out of |
| RegExpImp (the JS object) and into RegExp (the PCRE wrapper class), |
| making RegExp a ref-counted class. (This will help later.) |
| |
| Removed PCRE_POSIX support because I didn't quite know how to test it |
| and keep it working with these changes. |
| |
| 1.1% SunSpider speedup. 5.8% speedup on string-validate-input.js. |
| |
| * kjs/regexp.h: A few interface changes: |
| 1. Renamed "subpatterns()" => "numSubpatterns()" |
| 2. Made flag enumeration private and replaced it with public getters for |
| specific flags. |
| 3. Made RegExp ref-counted so RegExps can be shared by RegExpImps. |
| 4. Made RegExp take a string of flags instead of an int, eliminating |
| duplicated flag parsing code elsewhere. |
| |
| * kjs/regexp_object.cpp: |
| (KJS::RegExpProtoFunc::callAsFunction): For RegExp.compile: |
| - Fixed a bug where compile(undefined) would throw an exception. |
| - Removed some now-redundant code. |
| - Used RegExp sharing to eliminate an allocation and a bunch of |
| PropertyMap thrash. (Not a big win since compile is a deprecated |
| function. I mainly did this to test the plubming.) |
| |
| 2007-11-07 Simon Hausmann <hausmann@kde.org> |
| |
| Reviewed by nobody, Qt/Windows build fix. |
| |
| JavaScriptCore.pri expects OBJECTS_DIR to be set, so set it in |
| testkjs.pro, too, where it's included from. |
| |
| * kjs/testkjs.pro: |
| |
| 2007-11-07 Simon Hausmann <shausman@trolltech.com> |
| |
| Reviewed by Lars. |
| |
| Fix "nmake clean" for the Qt/Windows build by replacing tmp/ with a variable that ends with the correct type of slash/backslash depending on the choice of compiler/make tool. |
| |
| * JavaScriptCore.pri: |
| * pcre/pcre.pri: |
| |
| 2007-11-07 Lars Knoll <lars@trolltech.com> |
| |
| Reviewed by Simon. |
| |
| fix umemcasecmp |
| |
| Pretty embarrassing bug. Has the potential to fix quite a few test failures. |
| |
| * wtf/unicode/qt4/UnicodeQt4.h: |
| (WTF::Unicode::umemcasecmp): |
| |
| 2007-11-06 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Eric. |
| |
| - only collect when the heap is full, unless we have lots of extra cost garbage |
| |
| 1.1% SunSpider speedup. |
| |
| This shouldn't hit memory use much since the extra space in those |
| blocks hangs around either way. |
| |
| * kjs/collector.cpp: |
| (KJS::Collector::heapAllocate): |
| (KJS::Collector::collect): Fix logic error that reversed the sense of collect's |
| return value. |
| |
| 2007-11-06 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Avoid unnecessarily boxing the result from post inc/decrement for 0.3% gain in sunspider |
| |
| We now convert the common 'for (...; ...; <var>++) ...' to the semantically identical |
| 'for (...; ...; ++<var>) ...'. |
| |
| * kjs/nodes.cpp: |
| (KJS::PostIncResolveNode::optimizeForUnnecessaryResult): |
| (KJS::PostIncLocalVarNode::evaluate): |
| (KJS::PostIncLocalVarNode::optimizeForUnnecessaryResult): |
| (KJS::PostDecResolveNode::optimizeForUnnecessaryResult): |
| (KJS::PostDecLocalVarNode::evaluate): |
| (KJS::PostDecLocalVarNode::optimizeForUnnecessaryResult): |
| * kjs/nodes.h: |
| (KJS::PrePostResolveNode::): |
| (KJS::PostIncResolveNode::): |
| (KJS::PostIncLocalVarNode::): |
| (KJS::PostDecResolveNode::): |
| (KJS::PostDecLocalVarNode::): |
| (KJS::PreIncResolveNode::): |
| (KJS::PreDecResolveNode::): |
| (KJS::ForNode::ForNode): |
| |
| 2007-11-06 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by darin. |
| |
| This fixes a regressed layout test for string + object |
| |
| SunSpider claims this was an overall 0.3% speedup, although some individual tests were slower. |
| |
| * kjs/nodes.cpp: |
| (KJS::add): remove erroneous "fast path" for string + * |
| |
| 2007-11-06 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Eric Seidel. |
| |
| Added toJSNumber, a fast path for converting a JSValue to a JS number, |
| and deployed it in postfix expressions. In the fast case this |
| eliminates a call to jsNumber. |
| |
| 0.4% speedup on SunSpider. |
| |
| * ChangeLog: |
| * kjs/nodes.cpp: |
| (KJS::PostIncResolveNode::evaluate): |
| (KJS::PostIncLocalVarNode::evaluate): |
| (KJS::PostDecResolveNode::evaluate): |
| (KJS::PostDecLocalVarNode::evaluate): |
| (KJS::PostIncBracketNode::evaluate): |
| (KJS::PostDecBracketNode::evaluate): |
| (KJS::PostIncDotNode::evaluate): |
| (KJS::PostDecDotNode::evaluate): |
| (KJS::UnaryPlusNode::evaluate): |
| * kjs/value.h: |
| (KJS::JSValue::toJSNumber): |
| |
| 2007-11-06 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15846 |
| REGRESSION (r27387): Memory corruption when running fast/js/kde/delete.html |
| |
| There was a mistake in the algorithm used to find an empty slot in the property |
| map entries vector; when we were putting in a new property value and not overwriting |
| an existing deleted sentinel, we would enlarge the entries vector, but would not |
| overwrite the stale data that's in the new part. It was easy to pin this down by |
| turning on property map consistency checks -- I never would have landed with this |
| bug if I had run the regression tests once with consistency checks on! |
| |
| * kjs/property_map.cpp: (KJS::PropertyMap::put): Changed logic for the case where |
| foundDeletedElement is false to always use the item at the end of the entries vector. |
| Also allowed me to merge with the logic for the "no deleted sentinels at all" case. |
| |
| 2007-11-06 Oliver Hunt <oliver@apple.com> |
| |
| RS=Darin. |
| |
| Fix previous patch to use a 3 bit shift, a 16 bit shift causes a regression in sunspider. |
| |
| * kjs/nodes.cpp: |
| (KJS::add): |
| |
| 2007-11-06 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Darin. |
| |
| Replace boolean comparisons in AddNode with mask |
| comparisons for a 0.2% improvement in sunspider. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/nodes.cpp: |
| (KJS::add): |
| |
| 2007-11-06 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by darin. |
| |
| SunSpider claims this is a 1.1% speedup. |
| |
| * kjs/nodes.cpp: |
| (KJS::throwOutOfMemoryError): Added, non inline. |
| (KJS::addSlowCase): renamed from add(), non inline. |
| (KJS::add): add fast path for String + String, Number + Number and String + * |
| |
| 2007-11-06 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by mjs. |
| |
| Avoid more UString creation. |
| |
| SunSpider claims this is a 0.4% speedup. |
| |
| * kjs/regexp_object.cpp: |
| (KJS::RegExpObjectImp::construct): use UString::find(UChar) |
| |
| 2007-11-05 Mark Rowe <mrowe@apple.com> |
| |
| Mac build fix. |
| |
| * kjs/array_object.cpp: |
| (KJS::ArrayProtoFunc::callAsFunction): |
| |
| 2007-11-05 Adam Roben <aroben@apple.com> |
| |
| Windows build fix |
| |
| * kjs/list.h: |
| |
| 2007-11-05 Mark Rowe <mrowe@apple.com> |
| |
| Build fix. Add missing #include. |
| |
| * kjs/operations.cpp: |
| |
| 2007-11-05 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by mjs. |
| |
| Remove another call to toString(exec) |
| |
| SunSpider claims this is a 0.5% speedup. |
| |
| * kjs/operations.cpp: |
| (KJS::equal): remove another toString |
| |
| 2007-11-05 Eric Seidel <eric@webkit.org> |
| |
| * kjs/operations.cpp: |
| (KJS::equal): correct broken change. |
| |
| 2007-11-05 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by mjs. |
| |
| Remove one more call to toString(exec). |
| |
| SunSpider claims this is a 0.7% speedup. |
| |
| * kjs/operations.cpp: |
| (KJS::equal): remove a call to toString() |
| |
| 2007-11-05 Mark Rowe <mrowe@apple.com> |
| |
| Gtk build fix. |
| |
| * pcre/pcre.pri: |
| |
| 2007-11-05 Mark Rowe <mrowe@apple.com> |
| |
| Gtk build fix. |
| |
| * kjs/list.cpp: |
| |
| 2007-11-05 Geoffrey Garen <ggaren@apple.com> |
| |
| Touched a file to test my new HTTP access. |
| |
| * kjs/scope_chain.cpp: |
| |
| 2007-11-05 Alp Toker <alp@atoker.com> |
| |
| Unreviewed build fix for qmake-based ports. |
| |
| Someone with a better understanding of qmake still needs to sort out |
| the INCLUDEPATH/DEPENDPATH mess. |
| |
| * JavaScriptCore.pri: |
| |
| 2007-11-05 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=15835 |
| |
| Switched List implementation from a custom heap allocator to an inline |
| Vector, for a disappointing .5% SunSpider speedup. |
| |
| Also renamed List::slice to List::getSlice because "get" is the |
| conventional prefix for functions returning a value through an out |
| parameter. |
| |
| * kjs/array_object.cpp: |
| (KJS::ArrayProtoFunc::callAsFunction): Removed some redundant function |
| calls and memory accesses. |
| |
| * kjs/bool_object.cpp: |
| (BooleanObjectImp::construct): Removed questionable use of iterator. |
| |
| * kjs/list.cpp: |
| * kjs/list.h: New List class, implemented in terms of Vector. Two |
| interesting differences: |
| 1. The inline capacity is 8, not 5. Many of the Lists constructed |
| during a SunSpider run are larger than 5; almost none are larger |
| than 8. |
| |
| 2. The growth factor is 4, not 2. Since we can guarantee that Lists |
| aren't long-lived, we can grow them more aggressively, to avoid |
| excessive copying. |
| |
| * kjs/regexp_object.cpp: |
| (RegExpObjectImp::construct): Removed redundant function calls. |
| |
| * kjs/string_object.cpp: |
| (KJS::StringObjectImp::construct): Removed questionable use of iterator. |
| |
| * wtf/Vector.h: |
| (WTF::::uncheckedAppend): Added a fast, unchecked version of append. |
| |
| 2007-11-05 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Alp Toker. |
| |
| Add DEPENDPATH to JavaScriptCore and pcre to help qmake with dependencies. |
| |
| * JavaScriptCore.pri: |
| * pcre/pcre.pri: |
| |
| 2007-11-04 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15826 |
| optimize opcode loop and case insensitive ASCII compares for a 30% speedup |
| |
| SunSpider says it's 2.6% faster overall, 32.5% in the regular expression tests. |
| |
| * pcre/pcre_internal.h: Added OP_ASCII_CHAR and OP_ASCII_LETTER_NC. |
| |
| * pcre/pcre_compile.c: |
| (find_fixedlength): Added cases for OP_ASCII_CHAR and OP_ASCII_LETTER_NC. Also |
| added OP_NOT since there was no reason it should not be in here. |
| (could_be_empty_branch): Ditto. |
| (compile_branch): Streamlined all the single-character cases; there was a bit of |
| duplicate code. Added cases for OP_ASCII_CHAR and OP_ASCII_LETTER_NC as needed. |
| But in particular, compile to those opcodes when the single character match is |
| ASCII. |
| (find_firstassertedchar): Added cases for OP_ASCII_CHAR and OP_ASCII_LETTER_NC. |
| |
| * pcre/pcre_exec.c: (match): Removed the "min", "minimize", and "op" fields from |
| the matchframe, after I discovered that none of them needed to be saved and restored |
| across recursive match calls. Also eliminated the ignored result field from the |
| matchframe, since I discovered that rrc ("recursive result code") was already the |
| exact same thing. Moved the handling of opcodes higher than OP_BRA into the default |
| statement of the switch instead of doing them before the switch. This removes a |
| branch from each iteration of the opcode interpreter, just as removal of "op" |
| removed at least one store from each iteration. Last, but not least, add the |
| OP_ASCII_CHAR and OP_ASCII_LETTER_NC functions. Neither can ever match a |
| surrogate pair and the letter case can be handled efficiently. |
| |
| 2007-11-04 Darin Adler <darin@apple.com> |
| |
| * pcre/pcre_exec.c: (match): Try to fix the Windows build by removing unreachable code. |
| |
| 2007-11-03 Darin Adler <darin@apple.com> |
| |
| - fix non-Mac builds; remove some more unused PCRE stuff |
| |
| * pcre/pcre_compile.c: |
| (compile_branch): Removed branch chain and some unused ESC values. |
| (compile_regex): Ditto. |
| (jsRegExpCompile): Ditto. |
| * pcre/pcre_exec.c: |
| (match): Removed unused branch targets. Don't use macros any more. |
| (jsRegExpExecute): More of the same. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Update for removed files. |
| * JavaScriptCore.xcodeproj/project.pbxproj: Ditto. |
| * pcre/pcre.pri: Ditto. |
| |
| * pcre/MERGING: Removed. |
| * pcre/pcre_fullinfo.c: Removed. |
| * pcre/pcre_get.c: Removed. |
| * pcre/pcre_internal.h: |
| * pcre/ucp.h: Removed. |
| |
| 2007-11-03 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15821 |
| remove unused PCRE features for speed |
| |
| A first step toward removing the PCRE features we don't use. |
| This gives a 0.8% speedup on SunSpider, and a 6.5% speedup on |
| the SunSpider regular expression test. |
| |
| Replaced the public interface with one that doesn't use the |
| name PCRE. Removed code we don't need for JavaScript and various |
| configurations we don't use. This is in preparation for still |
| more changes in the future. We'll probably switch to C++ and |
| make some even more significant changes to the regexp engine |
| to get some additional speed. |
| |
| There's probably additional unused stuff that I haven't |
| deleted yet. |
| |
| This does mean that our PCRE is now a fork, but I think that's |
| not really a big deal. |
| |
| * JavaScriptCore.exp: Remove the 5 old entry points and add |
| the 3 new entry points for WebCore's direct use of the regular |
| expression engine. |
| |
| * kjs/config.h: Remove the USE(PCRE16) define. I decided to flip |
| its sense and now there's a USE(POSIX_REGEX) instead, which should |
| probably not be set by anyone. Maybe later we'll just get rid of it |
| altogether. |
| |
| * kjs/regexp.h: |
| * kjs/regexp.cpp: |
| (KJS::RegExp::RegExp): Switch to new jsRegExp function names and |
| defines. Cut down on the number of functions used. |
| (KJS::RegExp::~RegExp): Ditto. |
| (KJS::RegExp::match): Ditto. |
| |
| * pcre/dftables.c: (main): Get rid of ctype_letter and ctype_meta, |
| which are unused. |
| |
| * pcre/pcre-config.h: Get rid of EBCIDIC, PCRE_DATA_SCOPE, const, |
| size_t, HAVE_STRERROR, HAVE_MEMMOVE, HAVE_BCOPY, NEWLINE, |
| POSIX_MALLOC_THRESHOLD, NO_RECURSE, SUPPORT_UCP, SUPPORT_UTF8, |
| and JAVASCRIPT. These are all no longer configurable in our copy |
| of the library. |
| |
| * pcre/pcre.h: Remove the macro-based kjs prefix hack, the PCRE |
| version macros, PCRE_UTF16, the code to set up PCRE_DATA_SCOPE, |
| the include of <stdlib.h>, and most of the constants and |
| functions defined in this header. Changed the naming scheme to |
| use a JSRegExp prefix rather than a pcre prefix. In the future, |
| we'll probably change this to be a C++ header. |
| |
| * pcre/pcre_compile.c: Removed all unused code branches, |
| including many whole functions and various byte codes. |
| Kept changes outside of removal to a minimum. |
| (check_escape): |
| (first_significant_code): |
| (find_fixedlength): |
| (find_recurse): |
| (could_be_empty_branch): |
| (compile_branch): |
| (compile_regex): |
| (is_anchored): |
| (is_startline): |
| (find_firstassertedchar): |
| (jsRegExpCompile): Renamed from pcre_compile2 and changed the |
| parameters around a bit. |
| (jsRegExpFree): Added. |
| |
| * pcre/pcre_exec.c: Removed many unused opcodes and variables. |
| Also started tearing down the NO_RECURSE mechanism since it's |
| now the default. In some cases there were things in the explicit |
| frame that could be turned into plain old local variables and |
| other small like optimizations. |
| (pchars): |
| (match_ref): |
| (match): Changed parameters quite a bit since it's now not used |
| recursively. |
| (jsRegExpExecute): Renamed from pcre_exec. |
| |
| * pcre/pcre_internal.h: Get rid of PCRE_DEFINITION, PCRE_SPTR, |
| PCRE_IMS, PCRE_ICHANGED, PCRE_NOPARTIAL, PCRE_STUDY_MAPPED, |
| PUBLIC_OPTIONS, PUBLIC_EXEC_OPTIONS, PUBLIC_DFA_EXEC_OPTIONS, |
| PUBLIC_STUDY_OPTIONS, MAGIC_NUMBER, 16 of the opcodes, |
| _pcre_utt, _pcre_utt_size, _pcre_try_flipped, _pcre_ucp_findprop, |
| and _pcre_valid_utf8. Also moved pcre_malloc and pcre_free here. |
| |
| * pcre/pcre_maketables.c: Changed to only compile in dftables. |
| Also got rid of many of the tables that we don't use. |
| |
| * pcre/pcre_tables.c: Removed the unused Unicode property tables. |
| |
| * pcre/pcre_ucp_searchfuncs.c: Removed everything except for |
| _pcre_ucp_othercase. |
| |
| * pcre/pcre_xclass.c: (_pcre_xclass): Removed uneeded support |
| for classes based on Unicode properties. |
| |
| * wtf/FastMallocPCRE.cpp: Removed unused bits. It would be good |
| to eliminate this completely, but we need the regular expression |
| code to be C++ first. |
| |
| * pcre/pcre_fullinfo.c: |
| * pcre/pcre_get.c: |
| * pcre/ucp.h: |
| Files that are no longer needed. I didn't remove them with this |
| check-in, because I didn't want to modify all the project files. |
| |
| 2007-11-03 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Sam. |
| |
| - remove NaN check from JSImmediate::fromDouble for 0.5% SunSpider speedup |
| |
| It turns out that doing this check costs more than it saves. |
| |
| * kjs/JSImmediate.h: |
| (KJS::JSImmediate::fromDouble): |
| |
| 2007-11-03 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Oliver. |
| |
| Remove dummy variable from ClassInfo reducing the size of the struct by 1 word. |
| The variable had been kept around for binary compatibility, but since nothing |
| else is there is no point in continuing to keep it around. |
| |
| * API/JSCallbackConstructor.cpp: |
| * API/JSCallbackFunction.cpp: |
| * API/JSCallbackObject.cpp: |
| * bindings/objc/objc_runtime.mm: |
| * bindings/runtime_array.cpp: |
| * bindings/runtime_object.cpp: |
| * kjs/array_instance.cpp: |
| * kjs/array_object.cpp: |
| * kjs/bool_object.cpp: |
| * kjs/date_object.cpp: |
| * kjs/error_object.cpp: |
| * kjs/function.cpp: |
| * kjs/internal.cpp: |
| * kjs/lookup.h: |
| * kjs/math_object.cpp: |
| * kjs/number_object.cpp: |
| * kjs/object.h: |
| * kjs/regexp_object.cpp: |
| * kjs/string_object.cpp: |
| |
| 2007-11-03 Kevin McCullough <kmccullough@apple.com> |
| |
| - Updated testkjs results to make the build bots green until we |
| can fix the tests that are failing. The new failures are in DST. |
| |
| * tests/mozilla/expected.html: |
| |
| 2007-11-03 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Adam. |
| |
| - don't print the var twice for ForInNodes with a var declaration |
| |
| * kjs/nodes2string.cpp: |
| (KJS::ForInNode::streamTo): |
| |
| 2007-11-03 Darin Adler <darin@apple.com> |
| |
| * pcre/pcre_compile.c: (check_escape): Windows build fix. Get rid of |
| C-incompatible declaration. |
| |
| 2007-11-03 Mark Rowe <mrowe@apple.com> |
| |
| Gtk build fix. |
| |
| * kjs/nodes.cpp: Add missing include. |
| |
| 2007-11-03 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=15814 |
| <rdar://problem/5536644> fast/js/kde/encode_decode_uri.html fails |
| |
| These changes cause us to match the JavaScript specification and pass the |
| fast/js/kde/encode_decode_uri.html test. |
| |
| * kjs/function.cpp: (KJS::encode): Call the UTF-8 string conversion in its |
| new strict mode, throwing an exception if there are malformed UTF-16 surrogate |
| pairs in the text. |
| |
| * kjs/ustring.h: Added a strict version of the UTF-8 string conversion. |
| * kjs/ustring.cpp: |
| (KJS::decodeUTF8Sequence): Removed code to disallow U+FFFE and U+FFFF; while |
| those might be illegal in some sense, they aren't supposed to get any special |
| handling in the place where this function is currently used. |
| (KJS::UString::UTF8String): Added the strictness. |
| |
| 2007-11-03 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15812 |
| some JavaScript tests (from the Mozilla test suite) are failing |
| |
| Two or three fixes get 7 more of the Mozilla tests passing. |
| This gets us down from 61 failing tests to 54. |
| |
| * kjs/interpreter.h: (KJS::Interpreter::builtinRegExp): |
| Made this inline and gave it a more specific type. Some day we should |
| probably do that for all of these -- might even get a bit of a speed |
| boost from it. |
| * kjs/interpreter.cpp: Removed Interpreter::builtinRegExp now that it's |
| inline in the header. |
| |
| * kjs/regexp_object.h: |
| * kjs/regexp_object.cpp: |
| (KJS::RegExpProtoFunc::callAsFunction): Moved test and exec out of the |
| switch statement into the RegExpImp object, so they can be shared with |
| RegExpImp::callAsFunction. |
| (KJS::RegExpImp::match): Added. Common code used by both test and exec. |
| (KJS::RegExpImp::test): Added. |
| (KJS::RegExpImp::exec): Added. |
| (KJS::RegExpImp::implementsCall): Added. |
| (KJS::RegExpImp::callAsFunction): Added. |
| (KJS::RegExpObjectImpPrivate::RegExpObjectImpPrivate): Initialize |
| lastInput to null rather than empty string -- we take advantage of the |
| difference in RegExpImp::match. |
| (KJS::RegExpObjectImp::input): Added. No reason to go through hash tables |
| just to get at a field like this. |
| |
| * pcre/pcre_compile.c: (check_escape): Changed the \u handling to match |
| the JavaScript specification. If there are not 4 hex digits after the \u, |
| then it's processed as if it wasn't an escape sequence at all. |
| |
| * pcre/pcre_internal.h: Added IS_NEWLINE, with the appropriate definition |
| for JavaScript (4 specific Unicode values). |
| * pcre/pcre_exec.c: |
| (match): Changed all call sites to use IS_NEWLINE. |
| (pcre_exec): Ditto. |
| |
| * tests/mozilla/expected.html: Updated to expect 7 more successful tests. |
| |
| 2007-11-03 David D. Kilzer <ddkilzer@webkit.org> |
| |
| Sort files(...); sections of Xcode project files. |
| |
| Rubber-stamped by Darin. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2007-11-03 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - remove VarDeclListNode and simplify VarDeclNode evaluation for 0.4% SunSpider speedup |
| |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::VarDeclNode::optimizeVariableAccess): |
| (KJS::VarDeclNode::getDeclarations): |
| (KJS::VarDeclNode::handleSlowCase): |
| (KJS::VarDeclNode::evaluateSingle): |
| (KJS::VarDeclNode::evaluate): |
| (KJS::VarStatementNode::execute): |
| * kjs/nodes.h: |
| (KJS::VarDeclNode::): |
| (KJS::VarStatementNode::): |
| * kjs/nodes2string.cpp: |
| (KJS::VarDeclNode::streamTo): |
| |
| 2007-11-03 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=15800 |
| REGRESSION (r27303): RegExp leaks |
| |
| * kjs/regexp_object.h: |
| (KJS::RegExpImp::setRegExp): |
| (KJS::RegExpImp::regExp): |
| (KJS::RegExpImp::classInfo): |
| * kjs/regexp_object.cpp: |
| (RegExpImp::RegExpImp): |
| (RegExpImp::~RegExpImp): |
| Renamed reg member variable to m_regExp, changed it to use OwnPtr. |
| |
| 2007-11-02 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - add SourceElements as a typedef for Vector<RefPtr<StatementNode> >. |
| |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::statementListPushFIFO): |
| (KJS::statementListGetDeclarations): |
| (KJS::statementListInitializeDeclarationStacks): |
| (KJS::statementListInitializeVariableAccessStack): |
| (KJS::statementListExecute): |
| (KJS::BlockNode::BlockNode): |
| (KJS::FunctionBodyNode::FunctionBodyNode): |
| (KJS::ProgramNode::ProgramNode): |
| * kjs/nodes.h: |
| (KJS::CaseClauseNode::): |
| |
| 2007-11-02 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15791 |
| change property map data structure for less memory use, better speed |
| |
| The property map now has an array of indices and a separate array of |
| property map entries. This slightly slows down lookup because of a second |
| memory acess, but makes property maps smaller and faster to iterate in |
| functions like mark(). |
| |
| SunSpider says this is 1.2% faster, although it makes the bitwise-end test |
| more than 10% slower. To fix that we'll need to optimize global variable lookup. |
| |
| * kjs/property_map.cpp: |
| (KJS::PropertyMapEntry::PropertyMapEntry): |
| (KJS::PropertyMapHashTable::entries): |
| (KJS::PropertyMapHashTable::allocationSize): |
| (KJS::SavedProperties::SavedProperties): |
| (KJS::SavedProperties::~SavedProperties): |
| (KJS::PropertyMap::checkConsistency): |
| (KJS::PropertyMap::~PropertyMap): |
| (KJS::PropertyMap::clear): |
| (KJS::PropertyMap::get): |
| (KJS::PropertyMap::getLocation): |
| (KJS::PropertyMap::put): |
| (KJS::PropertyMap::insert): |
| (KJS::PropertyMap::createTable): |
| (KJS::PropertyMap::rehash): |
| (KJS::PropertyMap::remove): |
| (KJS::PropertyMap::mark): |
| (KJS::comparePropertyMapEntryIndices): |
| (KJS::PropertyMap::containsGettersOrSetters): |
| (KJS::PropertyMap::getEnumerablePropertyNames): |
| (KJS::PropertyMap::save): |
| (KJS::PropertyMap::restore): |
| * kjs/property_map.h: |
| |
| 2007-11-02 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15807 |
| HashMap needs a take() function that combines get and remove |
| |
| * wtf/HashMap.h: Added take function. Simplistic implementation for now, |
| but still does only one hash table lookup. |
| |
| * kjs/array_instance.cpp: (KJS::ArrayInstance::put): Use take rather than |
| a find followed by a remove. |
| |
| 2007-11-02 David Carson <dacarson@gmail.com> |
| |
| Reviewed by Darin. |
| |
| Fix compiler warning "warning: suggest parentheses around && within ||" |
| http://bugs.webkit.org/show_bug.cgi?id=15764 |
| |
| * kjs/value.h: (KJS::JSValue::isNumber): Add parentheses. |
| |
| 2007-11-01 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| In preparation for making List a simple stack-allocated Vector: |
| |
| Removed all instances of List copying and/or assignment, and made List |
| inherit from Noncopyable. |
| |
| Functions that used to return a List by copy now take List& out |
| parameters. |
| |
| Layout tests and JS tests pass. |
| |
| * kjs/list.cpp: |
| (KJS::List::slice): Replaced copyTail with a more generic slice |
| alternative. (JavaScriptCore only calls slice(1), but WebCore calls |
| slice(2)). |
| |
| 2007-11-01 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Fixed http://bugs.webkit.org/show_bug.cgi?id=15785 |
| REGRESSION(r27344): Crash on load at finance.yahoo.com |
| |
| Reverted a small portion of my last check-in. (The speedup and the List |
| removal are still there, though.) |
| |
| ActivationImp needs to hold a pointer to its function, and mark that |
| pointer (rather than accessing its function through its ExecState, and |
| counting on the active scope to mark its function) because a closure |
| can cause an ActivationImp to outlive its ExecState along with any |
| active scope. |
| |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::ExecState): |
| * kjs/function.cpp: |
| (KJS::FunctionImp::~FunctionImp): |
| (KJS::ActivationImp::ActivationImp): |
| * kjs/function.h: |
| (KJS::ActivationImp::ActivationImpPrivate::ActivationImpPrivate): |
| |
| Also made HashTable a little more crash-happy in debug builds, so |
| problems like this will show up earlier: |
| |
| * wtf/HashTable.h: |
| (WTF::HashTable::~HashTable): |
| |
| 2007-11-01 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Adam Roben. |
| |
| Addressed some of Darin's review comments. |
| |
| Used perl -p, which is the shorthand while(<>) {}. |
| |
| Made sure not to suppress bison's output. |
| |
| Added line to removed bison_out.txt, since this script removes other |
| intermediate files, too. |
| |
| * DerivedSources.make: |
| |
| 2007-11-01 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Removed List from ActivationImp, in preparation for making all lists |
| stack-allocated. |
| |
| Tests pass. |
| |
| 1.0% speedup on SunSpider, presumably due to reduced List refcount thrash. |
| |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::ExecState): |
| (KJS::ExecState::~ExecState): |
| * kjs/function.cpp: |
| (KJS::ActivationImp::ActivationImp): |
| (KJS::ActivationImp::createArgumentsObject): |
| * kjs/function.h: |
| (KJS::ActivationImp::ActivationImpPrivate::ActivationImpPrivate): |
| |
| 2007-11-01 Adam Roben <aroben@apple.com> |
| |
| Use jsNumberCell instead of jsNumber when converting double constants to JSValues |
| |
| This fixes fast/js/math.html, ecma/Date/15.9.5.10-1.js, and |
| ecma/Date/15.9.5.12-1.js, which were suffering from a bug in MSVC. |
| |
| It also gets rid of an MSVC warning that we previously had to silence. |
| |
| Reviewed by Geoff. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Turn |
| back on the "overflow in constant arithmetic" warning. |
| * kjs/number_object.cpp: |
| (NumberObjectImp::getValueProperty): Use jsNumberCell instead of |
| jsNumber. |
| |
| 2007-10-31 Adam Roben <aroben@apple.com> |
| |
| Windows build fix |
| |
| * kjs/ExecState.h: |
| |
| 2007-10-31 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - shave some cycles off of local storage access for a 1% SunSpider speedup |
| |
| Keep the LocalStorage pointer in the ExecState, instead of getting |
| it from the ActivationImp all the time. |
| |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::updateLocalStorage): |
| * kjs/ExecState.h: |
| (KJS::ExecState::localStorage): |
| * kjs/nodes.cpp: |
| (KJS::LocalVarAccessNode::evaluate): |
| (KJS::LocalVarFunctionCallNode::evaluate): |
| (KJS::PostIncLocalVarNode::evaluate): |
| (KJS::PostDecLocalVarNode::evaluate): |
| (KJS::LocalVarTypeOfNode::evaluate): |
| (KJS::PreIncLocalVarNode::evaluate): |
| (KJS::PreDecLocalVarNode::evaluate): |
| (KJS::ReadModifyLocalVarNode::evaluate): |
| (KJS::AssignLocalVarNode::evaluate): |
| (KJS::FunctionBodyNode::processDeclarationsForFunctionCode): |
| |
| 2007-10-31 Adam Roben <aroben@apple.com> |
| |
| Fix a crash on launch due to a static initializer race |
| |
| We now use fast inline assembler spinlocks which can be statically |
| initialized at compile time. |
| |
| As a side benefit, this speeds up SunSpider by 0.4%. |
| |
| Reviewed by Oliver. |
| |
| * wtf/FastMalloc.cpp: |
| * wtf/TCSpinLock.h: |
| (TCMalloc_SpinLock::Lock): |
| (TCMalloc_SpinLock::Unlock): |
| (TCMalloc_SlowLock): |
| * wtf/TCSystemAlloc.cpp: |
| |
| 2007-10-31 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Sam. |
| |
| - Corrected spelling. |
| |
| * wtf/HashTraits.h: |
| |
| 2007-10-31 Mark Rowe <mrowe@apple.com> |
| |
| Further Gtk build fixage. |
| |
| * kjs/regexp_object.cpp: |
| |
| 2007-10-31 Mark Rowe <mrowe@apple.com> |
| |
| Gtk build fix. |
| |
| * kjs/regexp.h: |
| |
| 2007-10-31 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=15749 |
| RegExp/RegExpObjectImp cause needless UString creation |
| |
| Speeds things up 0.4% according to SunSpider. |
| |
| * kjs/config.h: Define USE(PCRE16) instead of HAVE(PCREPOSIX), |
| because this library doesn't use the real PCRE -- it uses its |
| own PCRE that works on UTF-16. |
| |
| * kjs/regexp.h: Removed a few unused functions. Changed the ifdef. |
| Use Noncopyable. Change the return value of match. |
| * kjs/regexp.cpp: |
| (KJS::RegExp::RegExp): Call pcre_compile2, for a slight speed boost. |
| (KJS::RegExp::~RegExp): PCRE16 rather than PCREPOSIX. |
| (KJS::RegExp::match): Change to return the position as an int and the |
| ovector as a OwnArrayPtr<int> for efficiency and clearer storage management. |
| |
| * kjs/regexp_object.h: Change performMatch and arrayOfMatches to no longer |
| require a result string. |
| * kjs/regexp_object.cpp: |
| (RegExpProtoFunc::callAsFunction): Update for new signature of performMatch. |
| (RegExpObjectImp::performMatch): Change so it doesn't return a string. |
| (RegExpObjectImp::arrayOfMatches): Simplify by unifying the handling of |
| the main result with the backreferences; now it doesn't need to take |
| a result parameter. |
| (RegExpObjectImp::getBackref): Minor tweaks. |
| (RegExpObjectImp::getLastParen): Ditto. |
| (RegExpObjectImp::getLeftContext): Ditto. |
| (RegExpObjectImp::getRightContext): Ditto. |
| (RegExpObjectImp::getValueProperty): Change LastMatch case to call |
| getBackref(0) so we don't need a separate getLastMatch function. |
| |
| * kjs/string_object.cpp: |
| (KJS::replace): Update to use new performMatch, including merging the |
| matched string section with the other substrings. |
| (KJS::StringProtoFunc::callAsFunction): Update functions to use the |
| new performMatch and match. Also change to use OwnArrayPtr. |
| |
| 2007-10-31 Oliver Hunt <oliver@apple.com> |
| |
| * kjs/nodes.h: include OwnPtr.h |
| |
| 2007-10-31 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Remove SourceCodeElement class and replaced with a Vector for a 0.8% gain on sunspider |
| |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::statementListPushFIFO): |
| (KJS::statementListGetDeclarations): |
| (KJS::statementListInitializeDeclarationStacks): |
| (KJS::statementListInitializeVariableAccessStack): |
| (KJS::statementListExecute): |
| (KJS::BlockNode::optimizeVariableAccess): |
| (KJS::BlockNode::BlockNode): |
| (KJS::BlockNode::getDeclarations): |
| (KJS::BlockNode::execute): |
| (KJS::CaseClauseNode::optimizeVariableAccess): |
| (KJS::CaseClauseNode::getDeclarations): |
| (KJS::CaseClauseNode::evalStatements): |
| (KJS::FunctionBodyNode::initializeDeclarationStacks): |
| (KJS::FunctionBodyNode::optimizeVariableAccess): |
| * kjs/nodes.h: |
| * kjs/nodes2string.cpp: |
| (KJS::statementListStreamTo): |
| (KJS::BlockNode::streamTo): |
| (KJS::CaseClauseNode::streamTo): |
| |
| 2007-10-30 Mark Rowe <mrowe@apple.com> |
| |
| * kjs/property_map.cpp: Added a missing using directive to fix the build |
| for non-Mac ports. Mac worked only because it does the AllInOneFile compile. |
| |
| 2007-10-31 Maciej Stachowiak <mjs@apple.com> |
| |
| * kjs/property_map.cpp: Include HashTable.h the right way to fix the build |
| for non-Mac ports. |
| |
| 2007-10-31 Alexey Proskuryakov <ap@webkit.org> |
| |
| Reviewed by Darin. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=11001 |
| WebKit doesn't support RegExp.compile method |
| |
| Test: fast/js/regexp-compile.html |
| |
| * kjs/regexp_object.cpp: |
| (RegExpPrototype::RegExpPrototype): |
| (RegExpProtoFunc::callAsFunction): |
| * kjs/regexp_object.h: |
| (KJS::RegExpProtoFunc::): |
| Added RegExp.compile. |
| |
| * tests/mozilla/expected.html: js1_2/regexp/compile.js now passes. |
| |
| 2007-10-31 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - get rid of integer divide in PropertyMap and HashTable for 1% SunSpider speedup |
| |
| Integer divide sucks. Fortunately, a bunch of shifts and XORs |
| biased towards the high bits is sufficient to provide a good |
| double hash. Besides the SunSpider win, I used the dump statistics |
| mode for both to verify that collisions did not increase and that |
| the longest collision chain is not any longer. |
| |
| * kjs/property_map.cpp: |
| (KJS::doubleHash): |
| (KJS::PropertyMap::get): |
| (KJS::PropertyMap::getLocation): |
| (KJS::PropertyMap::put): |
| (KJS::PropertyMap::insert): |
| (KJS::PropertyMap::remove): |
| (KJS::PropertyMap::checkConsistency): |
| * wtf/HashTable.h: |
| (WTF::doubleHash): |
| (WTF::::lookup): |
| (WTF::::lookupForWriting): |
| (WTF::::fullLookupForWriting): |
| (WTF::::add): |
| |
| 2007-10-30 Adam Roben <aroben@apple.com> |
| |
| * kjs/collector.h: Make HeapType public so it can be used for non-member |
| things like the HeapConstants struct template. Fixes the build on Windows. |
| |
| 2007-10-30 Adam Roben <aroben@apple.com> |
| |
| Change ALWAYS_INLINE and WTF_PRIVATE_INLINE to use __forceinline on Windows |
| |
| Speeds up SunSpider by 0.4%. |
| |
| Reviewed by Steve and Maciej. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Disable |
| a warning during LTCG in release builds about double -> float |
| conversion. |
| * wtf/AlwaysInline.h: |
| * wtf/FastMalloc.h: |
| |
| 2007-10-30 Adam Roben <aroben@apple.com> |
| |
| Use GetCurrentThreadId instead of pthread_self in FastMalloc |
| |
| Speeds up SunSpider by 0.3%. |
| |
| Reviewed by Steve. |
| |
| * wtf/FastMalloc.cpp: |
| (WTF::TCMalloc_ThreadCache::InitTSD): |
| (WTF::TCMalloc_ThreadCache::CreateCacheIfNecessary): |
| |
| 2007-10-30 Adam Roben <aroben@apple.com> |
| |
| Switch to a Win32 critical section implementation of spinlocks |
| |
| Speeds up SunSpider by 0.4%. |
| |
| Reviewed by Steve. |
| |
| * wtf/FastMalloc.cpp: |
| * wtf/TCSpinLock.h: |
| (TCMalloc_SpinLock::TCMalloc_SpinLock): |
| (TCMalloc_SpinLock::Init): |
| (TCMalloc_SpinLock::Finalize): |
| (TCMalloc_SpinLock::Lock): |
| (TCMalloc_SpinLock::Unlock): |
| * wtf/TCSystemAlloc.cpp: |
| |
| 2007-10-30 Adam Roben <aroben@apple.com> |
| |
| Fix Bug 15586: REGRESSION (r26759-r26785): Windows nightly builds crash with Safari 3 Public Beta |
| |
| http://bugs.webkit.org/show_bug.cgi?id=15586 |
| |
| Also fixes: <rdar://5565303> Cannot use regsvr32.exe to register WebKit.dll |
| |
| Use Win32 TLS functions instead of __declspec(thread), which breaks |
| delay-loading. |
| |
| Reviewed by Steve. |
| |
| * wtf/FastMalloc.cpp: |
| (WTF::getThreadHeap): |
| (WTF::TCMalloc_ThreadCache::InitModule): |
| |
| 2007-10-30 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - allocate numbers in half-size cells, for an 0.5% SunSpider speedup |
| http://bugs.webkit.org/show_bug.cgi?id=15772 |
| |
| We do this by using a single mark bit per two number cells, and |
| tweaking marking. |
| |
| Besides being an 0.5% win overall, this is a 7.1% win on morph. |
| |
| * kjs/collector.cpp: |
| (KJS::Collector::heapAllocate): |
| (KJS::Collector::markStackObjectsConservatively): |
| (KJS::Collector::sweep): |
| * kjs/collector.h: |
| (KJS::SmallCollectorCell::): |
| |
| 2007-10-30 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Adam Roben, Sam Weinig. |
| |
| Made conflicts in grammar.y a persistent build failure. |
| |
| * DerivedSources.make: |
| |
| 2007-10-30 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Adam and Geoff. |
| |
| - Added a new cast so all the casts are in the same place. |
| |
| * API/APICast.h: |
| (toGlobalRef): |
| |
| 2007-10-30 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Fixed <rdar://problem/5567504> shift/reduce conflict introduced in r24457 |
| |
| JS tests, including |
| |
| ecma_2/Statements/dowhile-001.js |
| ecma_2/Statements/dowhile-002.js |
| ecma_2/Statements/dowhile-003.js |
| ecma_2/Statements/dowhile-004.js |
| ecma_2/Statements/dowhile-005.js |
| ecma_2/Statements/dowhile-006.js |
| ecma_2/Statements/dowhile-007.js |
| js1_2/statements/do_while.js |
| |
| and layout tests, including |
| |
| do-while-expression-value.html |
| do-while-semicolon.html |
| do-while-without-semicolon.html |
| |
| pass. |
| |
| * kjs/grammar.y: Use the explicit "error" production, as we do with other |
| automatic semicolon insertions, to disambiguate "do { } while();" from |
| "do { } while()" followed by ";" (the empty statement). |
| |
| 2007-10-29 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Debranching remaining assignment nodes, and miscellaneous cleanup |
| |
| Split read-modify code paths out of AssignBracketNode and AssignDotNode |
| Removed now unnecessary check for write-only assignment in ReadModifyLocalVarNode |
| and ReadModifyResolveNode evaluate methods |
| |
| Leads to a 1% gain in SunSpider. |
| |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::ReadModifyLocalVarNode::evaluate): |
| (KJS::ReadModifyResolveNode::evaluate): |
| (KJS::AssignDotNode::evaluate): |
| (KJS::ReadModifyDotNode::optimizeVariableAccess): |
| (KJS::ReadModifyDotNode::evaluate): |
| (KJS::AssignBracketNode::evaluate): |
| (KJS::ReadModifyBracketNode::optimizeVariableAccess): |
| (KJS::ReadModifyBracketNode::evaluate): |
| * kjs/nodes.h: |
| (KJS::AssignBracketNode::): |
| (KJS::AssignBracketNode::precedence): |
| (KJS::AssignDotNode::): |
| (KJS::AssignDotNode::precedence): |
| * kjs/nodes2string.cpp: |
| (KJS::ReadModifyBracketNode::streamTo): |
| (KJS::AssignBracketNode::streamTo): |
| (KJS::ReadModifyDotNode::streamTo): |
| (KJS::AssignDotNode::streamTo): |
| |
| 2007-10-29 Oliver Hunt <oliver@apple.com> |
| |
| Debranching various Node::evaluate implementations |
| |
| Reviewed by Maciej. |
| |
| Split the read-modify-write assignment cases out of AssignResolveNode and into ReadModifyResolveNode |
| Split the increment and decrement cases for Prefix- and Postfix- ResolveNode, BracketNode, and DotNode |
| |
| Gains 1.6% on SunSpider |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::PostIncResolveNode::optimizeVariableAccess): |
| (KJS::PostIncResolveNode::evaluate): |
| (KJS::PostIncLocalVarNode::evaluate): |
| (KJS::PostDecResolveNode::optimizeVariableAccess): |
| (KJS::PostDecResolveNode::evaluate): |
| (KJS::PostDecLocalVarNode::evaluate): |
| (KJS::PostIncBracketNode::evaluate): |
| (KJS::PostDecBracketNode::evaluate): |
| (KJS::PostIncDotNode::evaluate): |
| (KJS::PostDecDotNode::evaluate): |
| (KJS::PreIncResolveNode::optimizeVariableAccess): |
| (KJS::PreIncLocalVarNode::evaluate): |
| (KJS::PreIncResolveNode::evaluate): |
| (KJS::PreDecResolveNode::optimizeVariableAccess): |
| (KJS::PreDecLocalVarNode::evaluate): |
| (KJS::PreDecResolveNode::evaluate): |
| (KJS::PreIncBracketNode::evaluate): |
| (KJS::PreDecBracketNode::evaluate): |
| (KJS::PreIncDotNode::evaluate): |
| (KJS::PreDecDotNode::evaluate): |
| (KJS::ReadModifyResolveNode::optimizeVariableAccess): |
| (KJS::AssignResolveNode::optimizeVariableAccess): |
| (KJS::AssignLocalVarNode::evaluate): |
| (KJS::AssignResolveNode::evaluate): |
| * kjs/nodes.h: |
| (KJS::PostDecResolveNode::): |
| (KJS::PostDecResolveNode::precedence): |
| (KJS::PostDecLocalVarNode::): |
| (KJS::PostfixBracketNode::): |
| (KJS::PostfixBracketNode::precedence): |
| (KJS::PostIncBracketNode::): |
| (KJS::PostIncBracketNode::isIncrement): |
| (KJS::PostDecBracketNode::): |
| (KJS::PostDecBracketNode::isIncrement): |
| (KJS::PostfixDotNode::): |
| (KJS::PostfixDotNode::precedence): |
| (KJS::PostIncDotNode::): |
| (KJS::PostIncDotNode::isIncrement): |
| (KJS::PostDecDotNode::): |
| (KJS::PreIncResolveNode::): |
| (KJS::PreDecResolveNode::): |
| (KJS::PreDecResolveNode::precedence): |
| (KJS::PreDecLocalVarNode::): |
| (KJS::PrefixBracketNode::): |
| (KJS::PrefixBracketNode::precedence): |
| (KJS::PreIncBracketNode::): |
| (KJS::PreIncBracketNode::isIncrement): |
| (KJS::PreDecBracketNode::): |
| (KJS::PreDecBracketNode::isIncrement): |
| (KJS::PrefixDotNode::): |
| (KJS::PrefixDotNode::precedence): |
| (KJS::PreIncDotNode::): |
| (KJS::PreIncDotNode::isIncrement): |
| (KJS::PreDecDotNode::): |
| (KJS::ReadModifyResolveNode::): |
| (KJS::ReadModifyLocalVarNode::): |
| (KJS::AssignResolveNode::): |
| (KJS::AssignResolveNode::precedence): |
| * kjs/nodes2string.cpp: |
| (KJS::PostIncResolveNode::streamTo): |
| (KJS::PostDecResolveNode::streamTo): |
| (KJS::PostfixBracketNode::streamTo): |
| (KJS::PostfixDotNode::streamTo): |
| (KJS::PreIncResolveNode::streamTo): |
| (KJS::PreDecResolveNode::streamTo): |
| (KJS::ReadModifyResolveNode::streamTo): |
| (KJS::AssignResolveNode::streamTo): |
| |
| 2007-10-29 Maciej Stachowiak <mjs@apple.com> |
| |
| Not reviewed, build fix. |
| |
| - Include Vector.h in a way that actually works. |
| |
| * kjs/LocalStorage.h: |
| |
| 2007-10-29 Maciej Stachowiak <mjs@apple.com> |
| |
| Not reviewed, build fix. |
| |
| - Install LocalStorage.h as a private header. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2007-10-29 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Darin. |
| |
| - Define good VectorTraits for LocalStorage entry for 0.5% speed improvement on SunSpider. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/LocalStorage.h: Added. |
| (KJS::LocalStorageEntry::LocalStorageEntry): |
| (WTF::): |
| * kjs/function.h: |
| * kjs/nodes.cpp: |
| (KJS::FunctionBodyNode::processDeclarationsForFunctionCode): |
| |
| 2007-10-29 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Some small tweaks that I notice while reviewing Oliver's last patch. |
| |
| Includes removal of an unnecessary KJS_CHECKEXCEPTIONVALUE. |
| |
| No change in SunSpider because SunSpider doesn't take the code path that |
| would execute the unnecessary KJS_CHECKEXCEPTIONVALUE much. |
| |
| * kjs/nodes.cpp: |
| (KJS::LocalVarPostfixNode::evaluate): |
| (KJS::TypeOfResolveNode::optimizeVariableAccess): |
| (KJS::LocalVarTypeOfNode::evaluate): |
| (KJS::PrefixResolveNode::optimizeVariableAccess): |
| (KJS::LocalVarPrefixNode::evaluate): |
| (KJS::AssignResolveNode::optimizeVariableAccess): |
| (KJS::LocalVarAssignNode::evaluate): |
| * kjs/nodes.h: |
| (KJS::LocalVarTypeOfNode::): |
| (KJS::PrefixResolveNode::): |
| (KJS::LocalVarPrefixNode::): |
| (KJS::AssignResolveNode::): |
| (KJS::LocalVarAssignNode::): |
| |
| 2007-10-29 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| SunSpider claims this was a 0.7% speedup. |
| |
| * kjs/string_object.cpp: |
| (KJS::StringProtoFunc::callAsFunction): avoid mallocing a jsString in the common case |
| |
| 2007-10-29 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Mark. |
| |
| - re-enable asserts for access to empty or deleted keys |
| |
| * wtf/HashTable.h: |
| (WTF::::lookup): |
| (WTF::::lookupForWriting): |
| (WTF::::fullLookupForWriting): |
| (WTF::::add): |
| |
| 2007-10-29 Eric Seidel <eric@webkit.org> |
| |
| Build fix only, no review. |
| |
| * JavaScriptCore.exp: Export symbol for new StringInstance::getOwnPropertySlot |
| |
| 2007-10-29 Mark Rowe <mrowe@apple.com> |
| |
| Gtk build fix. Move struct declarations into nodes.h. |
| |
| * kjs/grammar.y: |
| * kjs/nodes.h: |
| |
| 2007-10-29 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by darin. |
| |
| Give StringInstance a getOwnPropertySlot(ExecState, unsigned, PropertySlot) fastpath, just like Arrays. |
| Make it a compile time error to use toString(ExecState) on a StringInstance |
| |
| SunSpider claims this was a 6.6% speedup overall (22% on string-base64) |
| |
| * kjs/internal.h: |
| (KJS::StringImp::getLength): |
| * kjs/string_object.cpp: |
| (KJS::StringInstance::lengthGetter): |
| (KJS::StringInstance::inlineGetOwnPropertySlot): |
| (KJS::StringInstance::getOwnPropertySlot): |
| * kjs/string_object.h: |
| |
| 2007-10-28 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Darin. |
| |
| Add nodes to allow Assignment, TypeOf, and prefix operators to |
| make use of the new optimised local variable look up. |
| |
| 5% gain on sunspider |
| |
| * kjs/nodes.cpp: |
| (KJS::TypeOfResolveNode::optimizeVariableAccess): |
| (KJS::LocalTypeOfAccessNode::evaluate): |
| (KJS::PrefixResolveNode::optimizeVariableAccess): |
| (KJS::PrefixLocalAccessNode::evaluate): |
| (KJS::AssignResolveNode::optimizeVariableAccess): |
| (KJS::AssignLocalAccessNode::evaluate): |
| * kjs/nodes.h: |
| (KJS::TypeOfResolveNode::): |
| (KJS::TypeOfResolveNode::precedence): |
| (KJS::LocalTypeOfAccessNode::): |
| (KJS::PrefixResolveNode::): |
| (KJS::PrefixResolveNode::precedence): |
| (KJS::PrefixLocalAccessNode::): |
| (KJS::AssignResolveNode::): |
| (KJS::AssignLocalAccessNode::): |
| |
| 2007-10-28 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Darin. |
| |
| - avoid creating and then breaking circular lists in the parser, instead track head and tail pointers at parse time |
| http://bugs.webkit.org/show_bug.cgi?id=15748 |
| |
| Not a significant speedup or slowdown on SunSpider. |
| |
| * kjs/Parser.cpp: |
| (KJS::clearNewNodes): |
| * kjs/Parser.h: |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::BlockNode::BlockNode): |
| (KJS::CaseBlockNode::CaseBlockNode): |
| (KJS::FunctionBodyNode::FunctionBodyNode): |
| (KJS::SourceElementsNode::SourceElementsNode): |
| (KJS::ProgramNode::ProgramNode): |
| * kjs/nodes.h: |
| (KJS::ElementNode::): |
| (KJS::ArrayNode::): |
| (KJS::PropertyListNode::): |
| (KJS::ObjectLiteralNode::): |
| (KJS::ArgumentListNode::): |
| (KJS::ArgumentsNode::): |
| (KJS::VarDeclListNode::): |
| (KJS::VarStatementNode::): |
| (KJS::ForNode::): |
| (KJS::ParameterNode::): |
| (KJS::FuncExprNode::): |
| (KJS::FuncDeclNode::): |
| (KJS::SourceElementsNode::): |
| (KJS::CaseClauseNode::): |
| (KJS::ClauseListNode::): |
| |
| 2007-10-28 Mark Rowe <mrowe@apple.com> |
| |
| Disable assertions in a manner that doesn't break the Qt Windows build. |
| |
| * wtf/HashTable.h: |
| (WTF::::lookup): |
| (WTF::::lookupForWriting): |
| (WTF::::fullLookupForWriting): |
| |
| 2007-10-28 Geoffrey Garen <ggaren@apple.com> |
| |
| Temporarily disabling some ASSERTs I introduced in my last check-in |
| because of http://bugs.webkit.org/show_bug.cgi?id=15747 |
| Lots of layout tests fail the !HashTranslator::equal(KeyTraits::emptyValue() ASSERT |
| |
| * wtf/HashTable.h: |
| (WTF::::lookup): |
| (WTF::::lookupForWriting): |
| (WTF::::fullLookupForWriting): |
| (WTF::::add): |
| |
| 2007-10-28 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Fixed http://bugs.webkit.org/show_bug.cgi?id=15746 |
| #ifndef ASSERT_DISABLED is no good! |
| |
| Replaced with #if !ASSERT_DISABLED. |
| |
| * wtf/HashTable.h: |
| (WTF::::lookup): |
| (WTF::::lookupForWriting): |
| (WTF::::fullLookupForWriting): |
| (WTF::::add): |
| |
| 2007-10-28 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Added FunctionCallResolveNode, PostfixResolveNode, and DeleteResolveNode |
| to the AST transfom that replaces slow resolve nodes with fast local |
| variable alternatives. |
| |
| 2.5% speedup on SunSpider. |
| |
| Also added some missing copyright notices. |
| |
| * kjs/nodes.cpp: |
| (KJS::FunctionCallResolveNode::optimizeVariableAccess): |
| (KJS::FunctionCallResolveNode::evaluate): |
| (KJS::LocalVarFunctionCallNode::evaluate): |
| (KJS::PostfixResolveNode::optimizeVariableAccess): |
| (KJS::PostfixResolveNode::evaluate): |
| (KJS::LocalVarPostfixNode::evaluate): |
| (KJS::DeleteResolveNode::optimizeVariableAccess): |
| (KJS::DeleteResolveNode::evaluate): |
| (KJS::LocalVarDeleteNode::evaluate): |
| * kjs/nodes.h: |
| (KJS::FunctionCallResolveNode::): |
| (KJS::LocalVarFunctionCallNode::LocalVarFunctionCallNode): |
| (KJS::PostfixResolveNode::): |
| (KJS::LocalVarPostfixNode::LocalVarPostfixNode): |
| (KJS::DeleteResolveNode::): |
| (KJS::LocalVarDeleteNode::LocalVarDeleteNode): |
| |
| 2007-10-28 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by darin. |
| |
| Inline UString::Rep::deref() for a 0.8% improvement in SunSpider |
| Add virtual keyword to a few virtual functions previously unmarked. |
| |
| * kjs/internal.h: |
| (KJS::StringImp::type): |
| (KJS::NumberImp::type): |
| * kjs/ustring.h: |
| (KJS::UString::Rep::deref): |
| |
| 2007-10-28 Darin Adler <darin@apple.com> |
| |
| - fix "broken everything" from the storage leak fix |
| |
| * wtf/RefPtr.h: (WTF::RefPtr::RefPtr): Added a PlacementNewAdopt constructor. |
| * kjs/ustring.h: (KJS::UString::UString): Pass PlacementNewAdopt along to RefPtr. |
| |
| 2007-10-28 Darin Adler <darin@apple.com> |
| |
| Reviewed by Adam. |
| |
| - turn on unused parameter waring on Mac OS X because it's already on elsewhere |
| |
| * Configurations/Base.xcconfig: Took out -wno-unused-parameter. |
| |
| * API/JSNode.c: |
| * API/JSNodeList.c: |
| * API/minidom.c: |
| * API/testapi.c: |
| Fixed unused variables by using them or marked them with UNUSED_PARAM. |
| |
| * kjs/CollectorHeapIntrospector.h: (KJS::CollectorHeapIntrospector::zoneCalloc): |
| Removed parameter names to indicate they are unused. |
| |
| 2007-10-28 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - fix a storage leak where we ref the UString every time we replace |
| a ResolveNode with a LocalVarAccessNode |
| |
| * kjs/identifier.h: (KJS::Identifier::Identifier): Added a constructor |
| that takes PlacementNewAdopt. |
| |
| * kjs/nodes.h: (KJS::ResolveNode::ResolveNode): Initialize the ident |
| with PlacementNewAdopt instead of the old value of ident. |
| |
| * kjs/ustring.h: (KJS::UString::UString): Added a constructor that |
| takes PlacementNewAdopt. |
| |
| 2007-10-28 Darin Adler <darin@apple.com> |
| |
| - Windows build fix; get rid of unused parameter |
| |
| * kjs/nodes.cpp: (KJS::ResolveNode::optimizeVariableAccess): Don't pass it. |
| * kjs/nodes.h: (KJS::LocalVarAccessNode::LocalVarAccessNode): Remove it. |
| The assertions weren't all that helpful. |
| |
| 2007-10-28 Mark Rowe <mrowe@apple.com> |
| |
| Gtk build fix. Add include of MathExtras.h. |
| |
| * kjs/string_object.cpp: |
| |
| 2007-10-28 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Maciej and Tim. |
| |
| Replace uses of isNaN and isInf with isnan and isinf, and |
| remove isNaN and isInf. |
| |
| * kjs/config.h: Remove unused HAVE_'s. |
| * kjs/date_object.cpp: |
| (KJS::DateInstance::getTime): |
| (KJS::DateInstance::getUTCTime): |
| (KJS::DateProtoFunc::callAsFunction): |
| (KJS::DateObjectImp::construct): |
| (KJS::DateObjectFuncImp::callAsFunction): |
| * kjs/function.cpp: |
| (KJS::GlobalFuncImp::callAsFunction): |
| * kjs/math_object.cpp: |
| (MathFuncImp::callAsFunction): |
| * kjs/nodes2string.cpp: |
| (KJS::isParserRoundTripNumber): |
| * kjs/number_object.cpp: |
| (NumberProtoFunc::callAsFunction): |
| * kjs/operations.cpp: |
| * kjs/operations.h: |
| * kjs/string_object.cpp: |
| (KJS::StringProtoFunc::callAsFunction): |
| * kjs/ustring.cpp: |
| (KJS::UString::from): |
| * kjs/value.cpp: |
| (KJS::JSValue::toInteger): |
| (KJS::JSValue::toInt32SlowCase): |
| (KJS::JSValue::toUInt32SlowCase): |
| |
| 2007-10-28 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: use the new-fangled missingSymbolMarker(). |
| |
| * kjs/nodes.cpp: |
| (KJS::ResolveNode::optimizeVariableAccess): |
| * kjs/nodes.h: |
| (KJS::LocalVarAccessNode::LocalVarAccessNode): |
| |
| 2007-10-28 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak, Darin Adler. |
| |
| Much supporting work done by Maciej Stachowiak, Maks Orlovich, and |
| Cameron Zwarich. |
| |
| AST transfom to replace slow resolve nodes with fast local variable |
| alternatives that do direct memory access. Currently, only ResolveNode |
| provides a fast local variable alternative. 6 others are soon to come. |
| |
| 16.7% speedup on SunSpider. |
| |
| Most of this patch is just scaffolding to support iterating all the |
| resolve nodes in the AST through optimizeResolveNodes(). In |
| optimizeResolveNodes(), most classes just push their child nodes onto |
| the processing stack, while ResolveNodes actually replace themselves in |
| the tree with more optimized alternatives, if possible. |
| |
| Here are the interesting bits: |
| |
| * kjs/nodes.h: Added PlacementNewAdoptTag, along with implementations |
| in Node and ResolveNode. This tag allows you to use placement new to |
| swap out a base class Node in favor of a subclass copy that holds the |
| same data. (Without this tag, default initialization would NULL out |
| RefPtrs, change line numbers, etc.) |
| |
| * kjs/nodes.cpp: |
| (KJS::ResolveNode::evaluate): Since we're taking the slow path, ASSERT |
| that the fast path is impossible, to make sure we didn't leave anything |
| on the table. |
| |
| (KJS::FunctionBodyNode::optimizeResolveNodes): Here's where the AST |
| transformation happens. |
| |
| (KJS::ResolveNode::optimizeResolveNodes): Here's where the ResolveNode |
| optimization happens. |
| |
| * kjs/function.h: Added symbolTable() accessor for, for the sake of |
| an ASSERT. |
| |
| 2007-10-28 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Fix "AllInOneFile.o has a global initializer in it". |
| |
| Some versions of gcc generate a global initializer for std::numeric_limits<size_t>::max(). |
| We can avoid this by moving it inside an inline function. |
| |
| * kjs/SymbolTable.h: |
| (KJS::missingSymbolMarker): |
| * kjs/function.cpp: |
| (KJS::ActivationImp::getOwnPropertySlot): |
| (KJS::ActivationImp::put): |
| |
| 2007-10-28 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Mark. |
| |
| - Added assertions to protect against adding empty or deleted keys to a HashTable |
| |
| * wtf/HashTable.h: |
| (WTF::HashTable::lookup): |
| (WTF::HashTable::lookupForWriting): |
| (WTF::HashTable::fullLookupForWriting): |
| (WTF::HashTable::add): |
| |
| 2007-10-28 Darin Adler <darin@apple.com> |
| |
| - fix GTK build |
| |
| * kjs/nodes2string.cpp: (KJS::isParserRoundTripNumber): |
| Use isNaN and isInf instead of isnan and isinf. |
| |
| 2007-10-28 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15735 |
| remove GroupNode to simplify AST and possibly get a modest speedup |
| |
| This patch removes 4 node types: GroupNode, PropertyNameNode, |
| FunctionCallParenBracketNode, and FunctionCallParenDotNode. |
| |
| To remove GroupNode, we add knowledge of precedence to the tree nodes, |
| and use that when serializing to determine where parentheses are needed. |
| This means we no longer have to represent parentheses in the tree. |
| |
| The precedence values are named after productions in the grammar from the |
| JavaScript standard. |
| |
| SunSpider says this is an 0.4% speedup. |
| |
| * kjs/function.h: |
| * kjs/function.cpp: Removed escapeStringForPrettyPrinting -- it's part of |
| serialization, so I moved it to the file that takes care of that. |
| |
| * kjs/grammar.y: Changed makeGetterOrSetterPropertyNode to use 0 to |
| indicate failure instead of a separate boolean. Got rid of PropertyNameNode |
| by merging the PropertyName rule into the Property rule (which was easier |
| than figuring out how to pass the Identifier from one node to another). |
| Got rid of GroupNode, nodeInsideAllParens(), FunctionCallParenBracketNode, |
| and FunctionCallParenDotNode. |
| |
| * kjs/nodes.h: Removed unused forward declarations and Operator values. |
| Added Precedence enum, and precedence function to all nodes. Removed |
| nodeInsideAllParens. Added streamBinaryOperator function for serialization. |
| Removed GroupNode and PropertyNameNode. Made PropertyNode store an Identifier. |
| Removed FunctionCallParenBracketNode and FunctionCallParenDotNode. |
| |
| * kjs/nodes.cpp: Removed Node::nodinsideAllParens, GroupNode, and PropertyNameNode. |
| (KJS::PropertyListNode::evaluate): Changed code to get name directly instead |
| of converting it from an Identifier to a jsString then back to a UString |
| then into an Identifier again! |
| |
| * kjs/nodes2string.cpp: Changed special-token implementation to use a separate |
| function for each of Endl, Indent, Unindent, and DotExpr instead of using a |
| single function with a switch. Added a precedence that you can stream in, to |
| cause the next node serialized to add parentheses based on that precedence value. |
| (KJS::operatorString): Moved to the top of the file. |
| (KJS::escapeStringForPrettyPrinting): Moved here from function.cpp. Removed old |
| workaround for snprintf, since StringExtras.h takes care of that. |
| (KJS::operator<<): Made the char and char* versions faster by using UString's |
| character append functions instead of constructing a UString. Added the logic |
| to the Node* version to add parentheses if needed. |
| (KJS::Node::streamLeftAssociativeBinaryOperator): Added helper function. |
| (KJS::ElementNode::streamTo): Use PrecAssignment for the elements. |
| (KJS::BracketAccessorNode::streamTo): Use PrecCall for the expression before |
| the bracket. |
| (KJS::DotAccessorNode::streamTo): Use PrecCall for the expression before the dot. |
| (KJS::ArgumentListNode::streamTo): Use PrecAssignment for the arguments. |
| (KJS::NewExprNode::streamTo): Use PrecMember for the expression. |
| (KJS::FunctionCallValueNode::streamTo): Use PrecCall. |
| (KJS::FunctionCallBracketNode::streamTo): Ditto. |
| (KJS::FunctionCallDotNode::streamTo): Ditto. |
| (KJS::PostfixBracketNode::streamTo): Ditto. |
| (KJS::PostfixDotNode::streamTo): Ditto. |
| (KJS::PostfixErrorNode::streamTo): Use PrecLeftHandSide. |
| (KJS::DeleteBracketNode::streamTo): Use PrecCall. |
| (KJS::DeleteDotNode::streamTo): Ditto. |
| (KJS::DeleteValueNode::streamTo): Use PrecUnary. |
| (KJS::VoidNode::streamTo): Ditto. |
| (KJS::TypeOfValueNode::streamTo): Ditto. |
| (KJS::PrefixBracketNode::streamTo): Use PrecCall. |
| (KJS::PrefixDotNode::streamTo): Ditto. |
| (KJS::PrefixErrorNode::streamTo): Use PrecUnary. |
| (KJS::UnaryPlusNode::streamTo): Ditto. |
| (KJS::NegateNode::streamTo): Ditto. |
| (KJS::BitwiseNotNode::streamTo): Ditto. |
| (KJS::LogicalNotNode::streamTo): Ditto. |
| (KJS::MultNode::streamTo): Use streamLeftAssociativeBinaryOperator. |
| (KJS::DivNode::streamTo): Ditto. |
| (KJS::ModNode::streamTo): Ditto. |
| (KJS::AddNode::streamTo): Ditto. |
| (KJS::SubNode::streamTo): Ditto. |
| (KJS::LeftShiftNode::streamTo): Ditto. |
| (KJS::RightShiftNode::streamTo): Ditto. |
| (KJS::UnsignedRightShiftNode::streamTo): Ditto. |
| (KJS::LessNode::streamTo): Ditto. |
| (KJS::GreaterNode::streamTo): Ditto. |
| (KJS::LessEqNode::streamTo): Ditto. |
| (KJS::GreaterEqNode::streamTo): Ditto. |
| (KJS::InstanceOfNode::streamTo): Ditto. |
| (KJS::InNode::streamTo): Ditto. |
| (KJS::EqualNode::streamTo): Ditto. |
| (KJS::NotEqualNode::streamTo): Ditto. |
| (KJS::StrictEqualNode::streamTo): Ditto. |
| (KJS::NotStrictEqualNode::streamTo): Ditto. |
| (KJS::BitAndNode::streamTo): Ditto. |
| (KJS::BitXOrNode::streamTo): Ditto. |
| (KJS::BitOrNode::streamTo): Ditto. |
| (KJS::LogicalAndNode::streamTo): Ditto. |
| (KJS::LogicalOrNode::streamTo): Ditto. |
| (KJS::ConditionalNode::streamTo): Ditto. |
| (KJS::AssignResolveNode::streamTo): Use PrecAssignment for the right side. |
| (KJS::AssignBracketNode::streamTo): Use PrecCall for the expression before |
| the bracket and PrecAssignment for the right side. |
| (KJS::AssignDotNode::streamTo): Ditto. |
| (KJS::AssignErrorNode::streamTo): Use PrecLeftHandSide for the left side |
| and PrecAssignment for the right side. |
| (KJS::CommaNode::streamTo): Use PrecAssignment for both expressions. |
| (KJS::AssignExprNode::streamTo): Use PrecAssignment. |
| |
| 2007-10-28 Kevin Ollivier <kevino@theolliviers.com> |
| |
| Define wx port and set wx port USE options. |
| |
| Reviewed by Adam Roben. |
| |
| * wtf/Platform.h: |
| |
| 2007-10-28 Mark Rowe <mrowe@apple.com> |
| |
| We don't include "config.h" in headers. |
| |
| * bindings/jni/jni_instance.h: |
| * kjs/regexp.h: |
| * wtf/TCPageMap.h: |
| * wtf/TCSpinLock.h: |
| |
| 2007-10-28 Maciej Stachowiak <mjs@apple.com> |
| |
| Rubber stamped by Mark. |
| |
| - avoid using non-portable SIZE_T_MAX in favor of std::numeric_limits |
| |
| * kjs/SymbolTable.h: |
| (KJS::SymbolTableIndexHashTraits::emptyValue): |
| * kjs/function.cpp: |
| (KJS::ActivationImp::getOwnPropertySlot): |
| (KJS::ActivationImp::put): |
| |
| 2007-10-28 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Eric. |
| |
| - switch SymbolTable to be a HashMap instead of a PropertyMap for 3% SunSpider speedup |
| |
| * kjs/SymbolTable.h: |
| (KJS::IdentifierRepHash::hash): Special hash function for identifier reps. |
| (KJS::IdentifierRepHash::equal): ditto |
| (KJS::SymbolTableIndexHashTraits::emptyValue): Special HashTraits for the index value. |
| (KJS::SymbolTable): change to a typedef for a HashMap. |
| * kjs/function.cpp: |
| (KJS::ActivationImp::getOwnPropertySlot): Adjusted for new SymbolTable API. |
| (KJS::ActivationImp::deleteProperty): ditto |
| (KJS::ActivationImp::put): ditto |
| |
| * kjs/nodes.cpp: |
| (KJS::FunctionBodyNode::initializesymbolTable): Adjusted, since |
| you now have to store a UString::rep, not an identifier. |
| |
| 2007-10-27 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - numerous HashTable performance improvements |
| |
| This does not quite add up to a measurable win on SunSpider, but it allows a |
| follow-on > 3% improvement and probably helps WebCore too. |
| |
| I made the following improvements, among others: |
| |
| - Made HashFunctions note whether it is ok to compare a real value with the equal() function |
| to the empty or deleted value, and used this to optimize the comparisons done in hash lookup. |
| |
| - Specialized lookup so it doesn't have to do so many extra branches and build so many extra |
| std::pairs for cases that don't need them. There are now four versions, one for read-only access, |
| two for writing, and one folded directly into add() (these all were improvments). |
| |
| - Made HashMap::get() use lookup() directly instead of find() to avoid having to build iterators. |
| |
| - Made a special constructor for iterators that knows it points to |
| a valid filled cell and so skips updating itself. |
| |
| - Reordered memory accesses in the various lookup functions for better code generation |
| |
| - Made simple translators avoid passing a hash code around |
| |
| - Other minor tweaks |
| |
| * wtf/HashTable.h: |
| (WTF::): |
| (WTF::HashTableConstIterator::HashTableConstIterator): |
| (WTF::HashTableIterator::HashTableIterator): |
| (WTF::IdentityHashTranslator::translate): |
| (WTF::HashTable::end): |
| (WTF::HashTable::lookup): |
| (WTF::HashTable::lookupForWriting): |
| (WTF::HashTable::makeKnownGoodIterator): |
| (WTF::HashTable::makeKnownGoodConstIterator): |
| (WTF::::lookup): |
| (WTF::::lookupForWriting): |
| (WTF::::fullLookupForWriting): |
| (WTF::::add): |
| (WTF::::addPassingHashCode): |
| (WTF::::reinsert): |
| (WTF::::find): |
| (WTF::::contains): |
| * kjs/identifier.cpp: |
| (WTF::): |
| * wtf/HashFunctions.h: |
| (WTF::): |
| * wtf/HashMap.h: |
| (WTF::): |
| (WTF::::get): |
| * wtf/HashSet.h: |
| (WTF::): |
| (WTF::::add): |
| * wtf/ListHashSet.h: |
| (WTF::ListHashSetTranslator::translate): |
| |
| 2007-10-27 Darin Adler <darin@apple.com> |
| |
| Reviewed by Eric. |
| |
| - fix ASCIICType.h for some Windows compiles |
| |
| * wtf/ASCIICType.h: Check the compiler, not the OS, since it's the |
| compiler/library that has the wchar_t that is just a typedef. |
| |
| 2007-10-27 Kevin McCullough <kmccullough@apple.com> |
| |
| - BuildFix |
| - Forgot to change the build step when I changed the filename. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| |
| 2007-10-27 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Fixed the rest of "ASSERTION FAILED: _hash in KJS::UString::Rep:: |
| computedHash()" |
| http://bugs.webkit.org/show_bug.cgi?id=15718 |
| |
| * kjs/identifier.cpp: Fixed more cases where an Identifier didn't get a |
| hash value. Also changed O(n) strlen to O(1) check for empty string. |
| (KJS::Identifier::add): |
| |
| * kjs/ustring.cpp: Changed O(n) strlens to O(1) checks for empty string. |
| (KJS::UString::UString): |
| (KJS::UString::operator=): |
| |
| 2007-10-27 Darin Adler <darin@apple.com> |
| |
| Reviewed by Eric. |
| |
| - fix pow on Windows |
| |
| * wtf/MathExtras.h: (wtf_pow): Add a special case for MSVC, which has |
| a "pow" function that does not properly handle the case where arg1 is |
| NaN and arg2 is 0. |
| |
| * kjs/math_object.cpp: (MathFuncImp::callAsFunction): Don't explicity |
| specify "::pow" -- just "pow" is fine. |
| |
| 2007-10-27 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15711 |
| force JSImmediate to be inlined for roughly 1.2% SunSpider speedup |
| |
| * kjs/JSImmediate.h: Put ALWAYS_INLINE on everything. |
| |
| * kjs/object.h: Removed redundant includes. |
| * kjs/value.h: Ditto. |
| |
| 2007-10-27 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Mark. |
| |
| - fixed "ASSERTION FAILED: _hash in KJS::UString::Rep::computedHash()" |
| http://bugs.webkit.org/show_bug.cgi?id=15718 |
| |
| * kjs/identifier.cpp: |
| (KJS::Identifier::addSlowCase): Ensure that empty Identifiers have a hash computed, |
| now that we count on all Identifiers already having one. |
| |
| 2007-10-27 Mark Rowe <mrowe@apple.com> |
| |
| Silence a warning. |
| |
| * kjs/SymbolTable.h: |
| |
| 2007-10-27 Mark Rowe <mrowe@apple.com> |
| |
| Gtk build fix. |
| |
| * kjs/function.h: |
| |
| 2007-10-26 Kevin McCullough <kmccullough@apple.com> |
| |
| Rubber stamp by Adam. |
| |
| - Renamed JSStringRefCOM to JSStringRefBSTR since it he only thing the |
| files contain are functions that operate on BSTRs. |
| |
| * API/JSStringRefBSTR.cpp: Copied from API/JSStringRefCOM.cpp. |
| * API/JSStringRefBSTR.h: Copied from API/JSStringRefCOM.h. |
| * API/JSStringRefCOM.cpp: Removed. |
| * API/JSStringRefCOM.h: Removed. |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| |
| 2007-10-26 Kevin McCullough <kmccullough@apple.com> |
| |
| Reviewed by Adam. |
| |
| - Made JSStringCreateWithBSTR capable of handling null BSTRs. |
| |
| * API/JSStringRefCOM.cpp: |
| (JSStringCreateWithBSTR): |
| |
| 2007-10-26 Sam Weinig <sam@webkit.org> |
| |
| Windows build fix. |
| |
| * kjs/SymbolTable.h: Add header gaurd. |
| * kjs/nodes.h: #include "SymbolTable.h" |
| |
| 2007-10-26 Geoffrey Garen <ggaren@apple.com> |
| |
| Suggested by Anders Carlsson. |
| |
| Fixed tyop. |
| |
| * kjs/function.cpp: |
| (KJS::ActivationImp::getOwnPropertySlot): |
| |
| 2007-10-26 Geoffrey Garen <ggaren@apple.com> |
| |
| Suggested by Darin Adler. |
| |
| Use computedHash(), which is safer than just directly accessing _hash. |
| |
| * kjs/lookup.cpp: |
| (KJS::Lookup::findEntry): |
| (KJS::Lookup::find): |
| |
| 2007-10-26 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: svn add SymbolTable.h |
| |
| * kjs/SymbolTable.h: Added. |
| (KJS::SymbolTable::set): |
| (KJS::SymbolTable::get): |
| |
| 2007-10-26 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix: export SymbolTable.h to WebCore. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| |
| 2007-10-26 Geoffrey Garen <ggaren@apple.com> |
| |
| Comment tweak suggested by Maciej. |
| |
| * kjs/function.cpp: |
| (KJS::ActivationImp::getOwnPropertySlot): |
| |
| 2007-10-26 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Tweaked property maps to remove 2 branches. 2.5% speedup on SunSpider. |
| |
| * kjs/property_map.cpp: Use a special no branch accessor to the UString's |
| hash value. Also, return immediately instead of branching to the end |
| of the loop if the value is not found. |
| (KJS::PropertyMap::get): |
| (KJS::PropertyMap::getLocation): |
| (KJS::PropertyMap::put): |
| (KJS::PropertyMap::insert): |
| (KJS::PropertyMap::remove): |
| (KJS::PropertyMap::checkConsistency): |
| |
| * kjs/ustring.h: |
| (KJS::UString::Rep::computedHash): Special no branch accessor to the |
| UString's hash value. Used when the caller knows that the hash value |
| has already been computed. (For example, if the caller got the UString |
| from an Identifier.) |
| |
| 2007-10-26 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Switched ActivationImp to using a symbol table. For now, though, all |
| clients take the slow path. |
| |
| Net .6% speedup on SunSpider. |
| |
| Slowdowns: |
| - ActivationImp now mallocs in its constructor |
| - Local variable hits use an extra level of indirection to retrieve |
| data |
| - Local variable misses do two lookups |
| |
| Speedups: |
| - Fast initialization of local variables upon function entry |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: Added SymbolTable.h |
| |
| * kjs/function.cpp: |
| (KJS::ActivationImp::ActivationImp): Malloc a private structure to hold |
| data that won't fit in a JSCell. |
| (KJS::ActivationImp::argumentsGetter): Use slow symbol table path for |
| lookup. |
| (KJS::ActivationImp::getOwnPropertySlot): ditto |
| (KJS::ActivationImp::deleteProperty): ditto |
| (KJS::ActivationImp::put): ditto |
| (KJS::ActivationImp::createArgumentsObject): ditto |
| |
| (KJS::ActivationImp::mark): Call JSObject::mark first so that one of |
| our properties doesn't try to recursively mark us. (This caused a crash |
| in earlier testing. Not sure why we haven't run into it before.) |
| |
| * kjs/nodes.cpp: Functions now build a symbol table the first time |
| they're called. |
| (KJS::VarDeclNode::evaluate): |
| (KJS::FunctionBodyNode::FunctionBodyNode): |
| (KJS::FunctionBodyNode::initializeSymbolTable): |
| (KJS::FunctionBodyNode::processDeclarations): |
| (KJS::FunctionBodyNode::processDeclarationsForFunctionCode): |
| (KJS::FunctionBodyNode::processDeclarationsForProgramCode): |
| |
| * kjs/nodes.h: |
| (KJS::FunctionBodyNode::symbolTable): |
| |
| * wtf/Forward.h: Added Vector. |
| |
| 2007-10-26 Kevin McCullough <kmccullough@apple.com> |
| |
| - Corrected function name mistake in this changelog. |
| |
| 2007-10-26 Kevin McCullough <kmccullough@apple.com> |
| Reviewed by Sam and Steve. |
| |
| - Added convenience methods for converting between BSTR and JSStringRefs |
| |
| * API/JSStringRefCOM.cpp: Added. |
| (JSStringCreateWithBSTR): |
| (JSStringCopyBSTR): |
| * API/JSStringRefCOM.h: Added. |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| |
| 2007-10-26 Mark Rowe <mrowe@apple.com> |
| |
| Windows build fix. |
| |
| * kjs/collector.cpp: |
| (KJS::Collector::collect): |
| |
| 2007-10-26 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Make the JSC GC use a separate heap for JSNumbers to get a 0.7-1.4% progression in SunSpider. |
| |
| * kjs/CollectorHeapIntrospector.cpp: |
| (KJS::CollectorHeapIntrospector::init): |
| (KJS::CollectorHeapIntrospector::enumerate): |
| * kjs/CollectorHeapIntrospector.h: |
| * kjs/collector.cpp: |
| (KJS::Collector::recordExtraCost): |
| (KJS::Collector::heapAllocate): |
| (KJS::Collector::allocate): |
| (KJS::Collector::allocateNumber): |
| (KJS::Collector::registerThread): |
| (KJS::Collector::markStackObjectsConservatively): |
| (KJS::Collector::markMainThreadOnlyObjects): |
| (KJS::Collector::sweep): |
| (KJS::Collector::collect): |
| * kjs/collector.h: |
| * kjs/internal.h: |
| (KJS::NumberImp::operator new): |
| Force numbers to be allocated in the secondary heap. |
| |
| 2007-10-26 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - encourage GCC a little harder to inline a few hot functions for 1.5% improvement on SunSpider. |
| |
| * kjs/value.h: |
| (KJS::JSValue::getUInt32): |
| (KJS::JSValue::getTruncatedInt32): |
| (KJS::JSValue::toNumber): |
| * wtf/PassRefPtr.h: |
| (WTF::PassRefPtr::~PassRefPtr): |
| * wtf/RefPtr.h: |
| (WTF::RefPtr::operator->): |
| |
| 2007-10-26 Mark Rowe <mrowe@apple.com> |
| |
| Gtk build fix. |
| |
| * kjs/ExecState.h: |
| |
| 2007-10-26 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Mark. |
| |
| - Merge Context class fully into ExecState, since they are always created and used together. |
| |
| No measurable performance impact but this is a useful cleanup. |
| |
| * JavaScriptCore.pri: |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::ExecState): |
| (KJS::ExecState::~ExecState): |
| (KJS::ExecState::mark): |
| (KJS::ExecState::lexicalInterpreter): |
| * kjs/ExecState.h: |
| (KJS::ExecState::dynamicInterpreter): |
| (KJS::ExecState::setException): |
| (KJS::ExecState::clearException): |
| (KJS::ExecState::exception): |
| (KJS::ExecState::exceptionSlot): |
| (KJS::ExecState::hadException): |
| (KJS::ExecState::scopeChain): |
| (KJS::ExecState::callingExecState): |
| (KJS::ExecState::propertyNames): |
| * kjs/collector.cpp: |
| (KJS::Collector::reportOutOfMemoryToAllInterpreters): |
| * kjs/function.cpp: |
| (KJS::FunctionImp::callAsFunction): |
| (KJS::FunctionImp::argumentsGetter): |
| (KJS::FunctionImp::callerGetter): |
| (KJS::GlobalFuncImp::callAsFunction): |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::Interpreter): |
| (KJS::Interpreter::init): |
| (KJS::Interpreter::evaluate): |
| (KJS::Interpreter::mark): |
| * kjs/interpreter.h: |
| (KJS::Interpreter::setCurrentExec): |
| (KJS::Interpreter::currentExec): |
| * kjs/nodes.cpp: |
| (KJS::currentSourceId): |
| (KJS::currentSourceURL): |
| (KJS::ThisNode::evaluate): |
| (KJS::ResolveNode::evaluate): |
| (KJS::FunctionCallResolveNode::evaluate): |
| (KJS::PostfixResolveNode::evaluate): |
| (KJS::DeleteResolveNode::evaluate): |
| (KJS::TypeOfResolveNode::evaluate): |
| (KJS::PrefixResolveNode::evaluate): |
| (KJS::AssignResolveNode::evaluate): |
| (KJS::VarDeclNode::evaluate): |
| (KJS::DoWhileNode::execute): |
| (KJS::WhileNode::execute): |
| (KJS::ForNode::execute): |
| (KJS::ForInNode::execute): |
| (KJS::ContinueNode::execute): |
| (KJS::BreakNode::execute): |
| (KJS::ReturnNode::execute): |
| (KJS::WithNode::execute): |
| (KJS::SwitchNode::execute): |
| (KJS::LabelNode::execute): |
| (KJS::TryNode::execute): |
| (KJS::FunctionBodyNode::processDeclarationsFunctionCode): |
| (KJS::FunctionBodyNode::processDeclarationsProgramCode): |
| (KJS::FunctionBodyNode::processDeclarations): |
| (KJS::FuncDeclNode::makeFunction): |
| (KJS::FuncExprNode::evaluate): |
| |
| 2007-10-26 Mark Rowe <mrowe@apple.com> |
| |
| Windows build fix. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| |
| 2007-10-26 Mark Rowe <mrowe@apple.com> |
| |
| Gtk build fix. |
| |
| * JavaScriptCore.pri: |
| * kjs/ExecState.cpp: |
| |
| 2007-10-26 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - moved Context class into ExecState.{h,cpp} in preparation for merging |
| ExecState and Context classes. |
| |
| * kjs/ExecState.h: Moved CodeType enum and Context class here in |
| preparation for merging ExecState and Context. |
| * kjs/ExecState.cpp: Moved Context class here from Context.cpp. |
| (KJS::Context::Context): |
| (KJS::Context::~Context): |
| (KJS::Context::mark): |
| * kjs/context.h: Removed. |
| * kjs/Context.cpp: Removed. |
| * kjs/function.h: Removed CodeType enum. |
| * kjs/LabelStack.h: Added. Pulled LabelStack class out of internal.h. |
| * kjs/internal.h: Removed LabelStack. |
| * JavaScriptCore.xcodeproj/project.pbxproj: Added new file, removed ones that are gone. |
| * kjs/collector.cpp: Fixed includes. |
| * kjs/function.cpp: ditto |
| * kjs/internal.cpp: ditto |
| * kjs/interpreter.cpp: ditto |
| * kjs/lookup.h: ditto |
| * kjs/nodes.cpp: ditto |
| |
| 2007-10-26 Mark Rowe <mrowe@apple.com> |
| |
| Windows build fix. |
| |
| * kjs/string_object.cpp: |
| (KJS::StringObjectFuncImp::callAsFunction): |
| |
| 2007-10-25 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15703 |
| fix numeric functions -- improve correctness and speed |
| |
| Gives about 1% gain on SunSpider. |
| |
| * kjs/value.h: Added toIntegerPreserveNan, removed toUInt16. |
| (KJS::JSValue::toInt32): Changed to call getTruncatedInt32 in a way that works |
| with both immediate and number values. |
| (KJS::JSValue::toUInt32): Ditto. |
| * kjs/value.cpp: |
| (KJS::JSValue::toInteger): Moved the logic from roundValue here, with a couple |
| differences. One is that it now correctly returns 0 for NaN, and another is that |
| there's no special case for 0 or infinity, since the general case already handles |
| those correctly. |
| (KJS::JSValue::toIntegerPreserveNaN): Added. Like toInteger, but without the |
| check for NaN. |
| (KJS::JSValue::toInt32SlowCase): Call toNumber instead of roundValue. The |
| truncation done by the typecast already does the necessary truncation that |
| roundValue was doing. |
| (KJS::JSValue::toUInt32SlowCase): Ditto. |
| (KJS::JSValue::toUInt16): Removed. |
| |
| * kjs/internal.h: Removed roundValue. |
| * kjs/internal.cpp: Ditto. |
| |
| * kjs/array_object.cpp: (KJS::ArrayProtoFunc::callAsFunction): Remove unneeded |
| code to handle NaN in Array.slice; toInteger now never returns NaN as specified. |
| |
| * kjs/date_object.cpp: |
| (KJS::fillStructuresUsingTimeArgs): Replaced call to roundValue with a call to |
| toNumber as specified. |
| (KJS::DateProtoFunc::callAsFunction): In SetTime case, replaced call to roundValue |
| with a call to toNumber and timeClip as specified. |
| (KJS::DateObjectImp::construct): Removed unnecessary checks of numArgs in cases |
| where the default behavior of toInt32 (returning 0) was already correct. Replaced |
| call to roundValue with a call to toNumber as specified. |
| (KJS::DateObjectFuncImp::callAsFunction): Ditto. |
| |
| * kjs/math_object.cpp: (MathFuncImp::callAsFunction): Removed unnecessary special |
| cases for the pow function that the library already handles correctly. |
| |
| * kjs/number_object.cpp: (NumberProtoFunc::callAsFunction): Changed ToString to |
| call toIntegerPreserveNaN, so we can continue to handle the NaN case differently. |
| The real toInteger now returns 0 for NaN. Took out unneeded special case in |
| ToFixed for undefined; was only needed because our toInteger was wrong. Same |
| thing in ToExponential. Changed ToPrecision to call toIntegerPreserveNaN. |
| |
| * kjs/string_object.cpp: |
| (KJS::StringProtoFunc::callAsFunction): Took out CharAt and CharCodeAt special |
| cases for undefined that were only needed because toInteger was wrong. Same in |
| IndexOf, and was able to remove some special cases. In LastIndexOf, used |
| toIntegerPreserveNaN, but was able to remove some special cases there too. |
| Changed Substr implementation to preserve correct behavior with the change |
| to toInteger and match the specification. Also made sure we weren't converting |
| an out of range double to an int. |
| (KJS::StringObjectFuncImp::callAsFunction): Changed constructor to just use |
| toUInt32, because truncating toUInt32 to 16 bits is the same thing and there's |
| no reason to have toUInt16 as a second, less-optimized function that's only |
| called at this one call site. |
| |
| * wtf/MathExtras.h: Added trunc function for Windows. |
| |
| 2007-10-25 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Tweaked the inner hashtable lookup loop to remove a branch in the "not |
| found" case. .5% speedup on SunSpider. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * wtf/HashTable.h: |
| (WTF::::lookup): |
| |
| 2007-10-25 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - fold together toPrimitive() and toNumber() conversions for 0.5% gain on SunSpider |
| |
| * kjs/nodes.cpp: |
| (KJS::SubNode::evaluate): Subtract directly, since toPrimitive() is not |
| adding any value over toNumber() here. |
| (KJS::valueForReadModifyAssignment): Ditto. |
| (KJS::lessThan): Use new getPrimitiveNumber() method to avoid some virtual calls |
| and branches. |
| (KJS::lessThanEq): Ditto. |
| * JavaScriptCore.exp: Export new functions as needed. |
| * kjs/value.h: |
| (KJS::JSValue::toPrimitive): Fixed formatting. |
| (KJS::JSValue::getPrimitiveNumber): New method - this simultaneously converts |
| to number and tells you whether a toPrimitive() conversion with a Number hint |
| would have given a string. |
| * kjs/internal.cpp: |
| (KJS::StringImp::getPrimitiveNumber): Implemented. |
| (KJS::NumberImp::getPrimitiveNumber): ditto |
| (KJS::GetterSetterImp::getPrimitiveNumber): ditto |
| (KJS::StringImp::toPrimitive): Fixed formatting. |
| (KJS::NumberImp::toPrimitive): ditto |
| (KJS::GetterSetterImp::toPrimitive): ditto |
| * kjs/internal.h: |
| * kjs/object.cpp: |
| (KJS::JSObject::getPrimitiveNumber): Implemented. |
| * kjs/object.h: |
| |
| 2007-10-25 Sam Weinig <sam@webkit.org> |
| |
| Reviewed by Adam Roben. |
| |
| Remove JSStringRefCFHack from windows as it is no longer needed. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| |
| 2007-10-25 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Rolled out my last patch. It turns out that I needed 2 words, not 1, |
| so it didn't help. |
| |
| 2007-10-25 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Oliver Hunt. |
| |
| Fixed http://bugs.webkit.org/show_bug.cgi?id=15694 |
| Shrink the size of an activation object by 1 word |
| |
| This is in preparation for adding a symbol table to the activation |
| object. |
| |
| The basic strategy here is to rely on the mutual exclusion between |
| the arguments object pointer and the function pointer (you only need |
| the latter in order to create the former), and store them in the same |
| place. The LazyArgumentsObject class encapsulates this strategy. |
| |
| Also inlined the ArgumentsImp constructor, for good measure. |
| |
| SunSpider reports no regression. Regression tests pass. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/Context.cpp: |
| (KJS::Context::~Context): |
| * kjs/function.cpp: |
| (KJS::ActivationImp::LazyArgumentsObject::createArgumentsObject): |
| (KJS::ActivationImp::LazyArgumentsObject::mark): |
| (KJS::ActivationImp::argumentsGetter): |
| (KJS::ActivationImp::mark): |
| * kjs/function.h: |
| (KJS::ActivationImp::LazyArgumentsObject::LazyArgumentsObject): |
| (KJS::ActivationImp::LazyArgumentsObject::getOrCreate): |
| (KJS::ActivationImp::LazyArgumentsObject::resetArguments): |
| (KJS::ActivationImp::LazyArgumentsObject::setArgumentsObject): |
| (KJS::ActivationImp::LazyArgumentsObject::argumentsObject): |
| (KJS::ActivationImp::LazyArgumentsObject::setFunction): |
| (KJS::ActivationImp::LazyArgumentsObject::function): |
| (KJS::ActivationImp::LazyArgumentsObject::createdArgumentsObject): |
| (KJS::ActivationImp::LazyArgumentsObject::): |
| (KJS::ActivationImp::ActivationImp::ActivationImp): |
| (KJS::ActivationImp::resetArguments): |
| |
| 2007-10-25 Adam Roben <aroben@apple.com> |
| |
| Change JavaScriptCore.vcproj to use DerivedSources.make |
| |
| We were trying to emulate the logic of make in |
| build-generated-files.sh, but we got it wrong. We now use a |
| build-generated-files very much like the one that WebCore uses to |
| invoke make. |
| |
| We also now only have a Debug configuration of dftables which we build |
| even when doing a Release build of JavaScriptCore. dftables also no |
| longer has the "_debug" name suffix. |
| |
| Changes mostly made by Darin, reviewed by me. |
| |
| * DerivedSources.make: Add a variable to set the extension used for |
| the dftables executable. |
| * JavaScriptCore.vcproj/JavaScriptCore.sln: Updated to use Debug |
| dftables in Release configurations. |
| * JavaScriptCore.vcproj/JavaScriptCoreSubmit.sln: Ditto. |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| - Updated include path to point to the new location of the derived |
| sources. |
| - Modified pre-build event to pass the right arguments to |
| build-generated-files.sh and not call dftables directly. |
| - Added the derived source files to the project. |
| - Removed grammarWrapper.cpp, which isn't needed now that we're |
| compiling grammar.cpp directly. |
| * JavaScriptCore.vcproj/JavaScriptCore/build-generated-files.sh: |
| Slightly modified from the WebCore version. |
| * JavaScriptCore.vcproj/JavaScriptCore/grammarWrapper.cpp: Removed. |
| * JavaScriptCore.vcproj/dftables/dftables.vcproj: |
| - Changed the output location to match Mac. |
| - Removed the Release configuration. |
| - Removed the _debug suffix. |
| |
| 2007-10-25 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Eric Seidel. |
| |
| Slightly elaborated the differences between declaration procesing in |
| Function Code and Program Code. |
| |
| .3% speedup on SunSpider. |
| |
| * kjs/nodes.cpp: |
| (KJS::FunctionBodyNode::processDeclarationsFunctionCode): |
| (KJS::FunctionBodyNode::processDeclarationsProgramCode): Store a |
| minimum set of attributes instead of recomputing all the time. Also, |
| ignore m_parameters, since programs don't have arguments. |
| |
| 2007-10-25 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| More preparation work before adding long-running mode to testkjs. |
| |
| * kjs/testkjs.cpp: |
| (TestFunctionImp::callAsFunction): |
| (prettyPrintScript): |
| (runWithScripts): |
| (parseArguments): |
| (kjsmain): |
| (fillBufferWithContentsOfFile): |
| |
| 2007-10-25 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Bring testkjs code out of the dark ages in preparation for more |
| radical improvements (like long-running testing support!) |
| |
| * kjs/testkjs.cpp: |
| (TestFunctionImp::callAsFunction): |
| (setupInterpreter): |
| (doIt): |
| (fillBufferWithContentsOfFile): |
| |
| 2007-10-25 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Make a fast path for declaration processing inside Function Code. |
| |
| Lifted declaration processing code up from individual declaration nodes |
| and into processDeclarations. |
| |
| Broke out processDeclarations into two cases, depending on the type of |
| code. This eliminates 2 branches, and facilitates more radical |
| divergeance in the future. |
| |
| 2.5% SunSpider speedup. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/nodes.cpp: |
| (KJS::FunctionBodyNode::initializeDeclarationStacks): |
| (KJS::FunctionBodyNode::processDeclarationsFunctionCode): |
| (KJS::FunctionBodyNode::processDeclarationsProgramCode): |
| (KJS::FunctionBodyNode::execute): |
| (KJS::FuncDeclNode::makeFunction): |
| * kjs/nodes.h: |
| |
| 2007-10-25 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Adam. |
| |
| - add header includes needed on platforms that don't use AllInOneFile.cpp |
| |
| * API/JSCallbackObject.cpp: |
| * kjs/Context.cpp: |
| * kjs/ExecState.cpp: |
| * kjs/array_instance.cpp: |
| * kjs/function_object.cpp: |
| * kjs/interpreter.cpp: |
| * kjs/nodes.cpp: |
| |
| 2007-10-25 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Geoff. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: re-mark JSGlobalObject.h as private |
| |
| 2007-10-25 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Fixed http://bugs.webkit.org/show_bug.cgi?id=15683 |
| Re-order declaration initialization to avoid calling hasProperty inside |
| VarDeclNode::processDeclaration |
| |
| .7% speedup on SunSpider. |
| |
| * kjs/function.h: |
| * kjs/function.cpp: Merged parameter processing into FunctionBodyNode's |
| other processing of declared symbols, so the order of execution could |
| change. |
| |
| * kjs/nodes.cpp: |
| (KJS::VarDeclNode::getDeclarations): Added special case for the |
| "arguments" property name, explained in the comment. |
| |
| (KJS::VarDeclNode::processDeclaration): Removed call to hasProperty |
| in the case of function code, since we know the declared symbol |
| management will resolve conflicts between symbols. Yay! |
| |
| (KJS::VarDeclListNode::getDeclarations): Now that VarDeclNode's |
| implementation of getDeclarations is non-trivial, we can't take a |
| short-cut here any longer -- we need to put the VarDecl node on the |
| stack so it gets processed normally. |
| |
| (KJS::FunctionBodyNode::processDeclarations): Changed the order of |
| processing to enforce mutual exclusion rules. |
| |
| * kjs/nodes.h: |
| (KJS::DeclarationStacks::DeclarationStacks): Structure includes an |
| ExecState now, for fast access to the "arguments" property name. |
| |
| 2007-10-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Add a JSGlobalObject class and remove the InterpreterMap |
| http://bugs.webkit.org/show_bug.cgi?id=15681 |
| |
| This required making JSCallbackObject a template class to allow for |
| JSGlobalObjects with JSCallbackObject functionality. |
| |
| SunSpider claims this was a 0.5% speedup. |
| |
| * API/JSCallbackObject.cpp: |
| * API/JSCallbackObject.h: |
| * API/JSCallbackObjectFunctions.h: Copied from API/JSCallbackObject.cpp. |
| (KJS::::JSCallbackObject): |
| (KJS::::init): |
| (KJS::::~JSCallbackObject): |
| (KJS::::initializeIfNeeded): |
| (KJS::::className): |
| (KJS::::getOwnPropertySlot): |
| (KJS::::put): |
| (KJS::::deleteProperty): |
| (KJS::::implementsConstruct): |
| (KJS::::construct): |
| (KJS::::implementsHasInstance): |
| (KJS::::hasInstance): |
| (KJS::::implementsCall): |
| (KJS::::callAsFunction): |
| (KJS::::getPropertyNames): |
| (KJS::::toNumber): |
| (KJS::::toString): |
| (KJS::::setPrivate): |
| (KJS::::getPrivate): |
| (KJS::::inherits): |
| (KJS::::cachedValueGetter): |
| (KJS::::staticValueGetter): |
| (KJS::::staticFunctionGetter): |
| (KJS::::callbackGetter): |
| * API/JSClassRef.cpp: |
| (OpaqueJSClass::prototype): |
| * API/JSContextRef.cpp: |
| (JSGlobalContextCreate): |
| * API/JSObjectRef.cpp: |
| (JSObjectMake): |
| (JSObjectGetPrivate): |
| (JSObjectSetPrivate): |
| * API/JSValueRef.cpp: |
| (JSValueIsObjectOfClass): |
| * JavaScriptCore.exp: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * bindings/c/c_utility.cpp: |
| (KJS::Bindings::convertValueToNPVariant): |
| * bindings/jni/jni_jsobject.cpp: |
| * bindings/objc/objc_utility.mm: |
| (KJS::Bindings::convertValueToObjcValue): |
| * kjs/Context.cpp: |
| (KJS::Context::Context): |
| * kjs/ExecState.cpp: |
| (KJS::ExecState::lexicalInterpreter): |
| * kjs/JSGlobalObject.h: Added. |
| (KJS::JSGlobalObject::JSGlobalObject): |
| (KJS::JSGlobalObject::isGlobalObject): |
| (KJS::JSGlobalObject::interpreter): |
| (KJS::JSGlobalObject::setInterpreter): |
| * kjs/array_instance.cpp: |
| * kjs/context.h: |
| * kjs/function.cpp: |
| (KJS::FunctionImp::callAsFunction): |
| (KJS::GlobalFuncImp::callAsFunction): |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::Interpreter): |
| (KJS::Interpreter::init): |
| (KJS::Interpreter::~Interpreter): |
| (KJS::Interpreter::globalObject): |
| (KJS::Interpreter::initGlobalObject): |
| (KJS::Interpreter::evaluate): |
| * kjs/interpreter.h: |
| * kjs/lookup.h: |
| (KJS::cacheGlobalObject): |
| * kjs/object.h: |
| (KJS::JSObject::isGlobalObject): |
| * kjs/testkjs.cpp: |
| |
| 2007-10-24 Eric Seidel <eric@webkit.org> |
| |
| Build fix for Gtk, no review. |
| |
| * kjs/collector.cpp: #include "context.h" |
| |
| 2007-10-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by Maciej. |
| |
| Stop checking isOutOfMemory after every allocation, instead let the collector |
| notify all ExecStates if we ever hit this rare condition. |
| |
| SunSpider claims this was a 2.2% speedup. |
| |
| * kjs/collector.cpp: |
| (KJS::Collector::collect): |
| (KJS::Collector::reportOutOfMemoryToAllInterpreters): |
| * kjs/collector.h: |
| * kjs/nodes.cpp: |
| (KJS::TryNode::execute): |
| |
| 2007-10-24 Mark Rowe <mrowe@apple.com> |
| |
| Gtk build fix. |
| |
| * kjs/identifier.h: Remove extra qualification. |
| |
| 2007-10-24 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Disable ALWAYS_INLINE in debug builds, since it drives the debugger |
| crazy. |
| |
| * wtf/AlwaysInline.h: |
| |
| 2007-10-24 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Sam Weinig. |
| |
| Inlined the fast path for creating an Identifier from an Identifier. |
| |
| This is a .4% speedup on SunSpider overall, but as big as a 2.5% |
| speedup on certain individual tests. 65% of the Identifiers creating |
| by SunSpider are already Identifiers. |
| |
| (The main reason I'm making this change is that it resolves a large |
| regression in a patch I haven't checked in yet.) |
| |
| * JavaScriptCore.exp: |
| * kjs/identifier.cpp: |
| (KJS::Identifier::addSlowCase): |
| * kjs/identifier.h: |
| (KJS::Identifier::Identifier::add): |
| |
| 2007-10-24 Lars Knoll <lars@trolltech.com> |
| |
| Reviewed by Simon. |
| |
| some changes to the way JS values are converted to Qt values in the script bindings. Added support for converting JS arrays into QStringList's. |
| |
| * bindings/qt/qt_instance.cpp: |
| (KJS::Bindings::QtInstance::invokeMethod): |
| * bindings/qt/qt_runtime.cpp: |
| (KJS::Bindings::convertValueToQVariant): |
| (KJS::Bindings::QtField::setValueToInstance): |
| |
| 2007-10-24 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Darin. |
| |
| Remove old relation method, replace with specialised LessThan and lessThenEq functions for a 0.5-0.6% improvement in SunSpider |
| |
| * kjs/nodes.cpp: |
| (KJS::lessThan): |
| (KJS::lessThanEq): |
| (KJS::LessNode::evaluate): |
| (KJS::GreaterNode::evaluate): |
| (KJS::LessEqNode::evaluate): |
| (KJS::GreaterEqNode::evaluate): |
| * kjs/operations.cpp: |
| * kjs/operations.h: |
| |
| 2007-10-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by darin. |
| |
| * kjs/nodes.h: |
| (KJS::ImmediateNumberNode::): Fix ASSERT correctness (and debug build!) |
| |
| 2007-10-24 Darin Adler <darin@apple.com> |
| |
| Reviewed by Eric. |
| |
| * kjs/object.cpp: (KJS::JSObject::defaultValue): Get rid of a little |
| Identifier ref/deref for what SunSpider claims is a 0.4% speedup. |
| |
| 2007-10-24 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - separate out the code to create a hash table the first time from the code |
| to rehash |
| |
| SunSpider claims this was a 0.7% speedup. |
| |
| * kjs/property_map.cpp: |
| (KJS::PropertyMap::expand): Changed to call either createTable or rehash. |
| (KJS::PropertyMap::createTable): Added. For the case where we had no table. |
| (KJS::PropertyMap::rehash): Removed code needed only in the case where we |
| had no table. |
| * kjs/property_map.h: Added createTable. |
| |
| 2007-10-24 Eric Seidel <eric@webkit.org> |
| |
| Reviewed by darin. |
| |
| Add ImmediateNumberNode to hold a JSValue* instead of a double for numbers |
| which can be represented by JSImmediate. |
| |
| SunSpider claims this was a 0.6% speedup. |
| |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::NumberNode::evaluate): |
| (KJS::ImmediateNumberNode::evaluate): |
| * kjs/nodes.h: |
| (KJS::Node::): |
| (KJS::ImmediateNumberNode::): |
| * kjs/nodes2string.cpp: |
| (ImmediateNumberNode::streamTo): |
| |
| 2007-10-24 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15657 |
| change static hash tables to use powers of two for speed |
| |
| Seems to give 0.7% SunSpider speedup. |
| |
| * kjs/create_hash_table: Updated to generate new format. |
| * kjs/lookup.cpp: |
| (KJS::keysMatch): Took out unneeded typecast. |
| (KJS::findEntry): Updated to expect table type 3 -- changed the printf to a plain old assert. |
| Replaced the modulus with a bit mask. |
| (KJS::Lookup::findEntry): Get the hash directly, since we know identifiers already have computed |
| their hash -- saves a branch. |
| (KJS::Lookup::find): Ditto. |
| * kjs/lookup.h: Changed attr from 2-byte value to one-byte value. Replaced hashSize with hashSizeMask. |
| |
| 2007-10-24 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Darin. |
| |
| - remove KJS_CHECKEXCEPTIONs in places where exceptions can't happen for 0.6% SunSpider speedup |
| |
| * kjs/nodes.cpp: |
| (KJS::DoWhileNode::execute): |
| (KJS::WhileNode::execute): |
| (KJS::ForNode::execute): |
| (KJS::ForInNode::execute): |
| (KJS::SourceElementsNode::execute): |
| |
| 2007-10-23 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| * kjs/JSImmediate.h: (KJS::JSImmediate::getUInt32): |
| Changed an && to an & for a 1% gain in SunSpider. |
| |
| 2007-10-23 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Reduce branching in implementations of some operator implementations, yielding 1.3% boost to SunSpider. |
| |
| * kjs/nodes.cpp: |
| (KJS::MultNode::evaluate): |
| (KJS::DivNode::evaluate): |
| (KJS::ModNode::evaluate): |
| (KJS::add): |
| (KJS::sub): |
| (KJS::AddNode::evaluate): |
| (KJS::SubNode::evaluate): |
| (KJS::valueForReadModifyAssignment): |
| * kjs/operations.cpp: |
| * kjs/operations.h: |
| |
| 2007-10-23 Oliver Hunt <oliver@apple.com> |
| |
| Reviewed by Maciej. |
| |
| Separating all of the simple (eg. non-read-modify-write) binary operators |
| into separate classes in preparation for further JS optimisations. |
| |
| Happily this produces a 0.8% to 1.0% performance increase in SunSpider with |
| no further work. |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (KJS::MultNode::evaluate): |
| (KJS::DivNode::evaluate): |
| (KJS::ModNode::evaluate): |
| (KJS::AddNode::evaluate): |
| (KJS::SubNode::evaluate): |
| (KJS::LeftShiftNode::evaluate): |
| (KJS::RightShiftNode::evaluate): |
| (KJS::UnsignedRightShiftNode::evaluate): |
| (KJS::LessNode::evaluate): |
| (KJS::GreaterNode::evaluate): |
| (KJS::LessEqNode::evaluate): |
| (KJS::GreaterEqNode::evaluate): |
| (KJS::InstanceOfNode::evaluate): |
| (KJS::InNode::evaluate): |
| (KJS::EqualNode::evaluate): |
| (KJS::NotEqualNode::evaluate): |
| (KJS::StrictEqualNode::evaluate): |
| (KJS::NotStrictEqualNode::evaluate): |
| (KJS::BitAndNode::evaluate): |
| (KJS::BitXOrNode::evaluate): |
| (KJS::BitOrNode::evaluate): |
| (KJS::LogicalAndNode::evaluate): |
| (KJS::LogicalOrNode::evaluate): |
| * kjs/nodes.h: |
| (KJS::MultNode::): |
| (KJS::DivNode::): |
| (KJS::ModNode::): |
| (KJS::AddNode::): |
| (KJS::SubNode::): |
| (KJS::LeftShiftNode::): |
| (KJS::RightShiftNode::): |
| (KJS::UnsignedRightShiftNode::): |
| (KJS::LessNode::): |
| (KJS::GreaterNode::): |
| (KJS::LessEqNode::): |
| (KJS::GreaterEqNode::): |
| (KJS::InstanceOfNode::): |
| (KJS::InNode::): |
| (KJS::EqualNode::): |
| (KJS::NotEqualNode::): |
| (KJS::StrictEqualNode::): |
| (KJS::NotStrictEqualNode::): |
| (KJS::BitAndNode::): |
| (KJS::BitOrNode::): |
| (KJS::BitXOrNode::): |
| (KJS::LogicalAndNode::): |
| (KJS::LogicalOrNode::): |
| * kjs/nodes2string.cpp: |
| (MultNode::streamTo): |
| (DivNode::streamTo): |
| (ModNode::streamTo): |
| (AddNode::streamTo): |
| (SubNode::streamTo): |
| (LeftShiftNode::streamTo): |
| (RightShiftNode::streamTo): |
| (UnsignedRightShiftNode::streamTo): |
| (LessNode::streamTo): |
| (GreaterNode::streamTo): |
| (LessEqNode::streamTo): |
| (GreaterEqNode::streamTo): |
| (InstanceOfNode::streamTo): |
| (InNode::streamTo): |
| (EqualNode::streamTo): |
| (NotEqualNode::streamTo): |
| (StrictEqualNode::streamTo): |
| (NotStrictEqualNode::streamTo): |
| (BitAndNode::streamTo): |
| (BitXOrNode::streamTo): |
| (BitOrNode::streamTo): |
| (LogicalAndNode::streamTo): |
| |
| 2007-10-23 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=15639 |
| fix Math.abs(0), Math.ceil(-0), and Math.floor(-0) |
| |
| Test: fast/js/math.html |
| |
| * kjs/math_object.cpp: (MathFuncImp::callAsFunction): |
| Fix abs to look at the sign bit. Add a special case for values in the range |
| between -0 and -1 and a special case for ceil and for -0 for floor. |
| |
| 2007-10-23 Darin Adler <darin@apple.com> |
| |
| Reviewed by Eric. |
| |
| - streamline exception handling code for a >1% speed-up of SunSpider |
| |
| * kjs/nodes.cpp: Changed macros to use functions for everything that's not |
| part of normal execution. We'll take function call overhead when propagating |
| an exception or out of memory. |
| (KJS::createOutOfMemoryCompletion): Added. |
| (KJS::substitute): Use append instead of the relatively inefficient + operator. |
| (KJS::Node::rethrowException): Added. |
| * kjs/nodes.h: Added rethrowException. |
| |
| 2007-10-22 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=15636 |
| some JavaScriptCore regression tests are failing due to numeric conversion |
| |
| This should restore correctness and make speed better too, restoring some |
| of the optimization we lost in my last check-in. |
| |
| * kjs/JSImmediate.h: |
| (KJS::JSImmediate::getTruncatedInt32): Added. Uses the range checking idiom |
| I used in my patch yesterday. |
| (KJS::JSImmediate::getTruncatedUInt32): Ditto. |
| |
| * kjs/internal.h: Removed getInt32 and added getTruncatedInt/UInt32. |
| * kjs/internal.cpp: |
| (KJS::NumberImp::getUInt32): Changed to always use double, since I can't find |
| a way to write this more efficiently for float. |
| (KJS::NumberImp::getTruncatedInt32): Added. |
| (KJS::NumberImp::getTruncatedUInt32): Added. |
| |
| * kjs/value.h: Removed getInt32 and added getTruncatedInt/UInt32. |
| (KJS::JSValue::getUInt32): |
| (KJS::JSValue::getTruncatedInt32): Added. |
| (KJS::JSValue::getTruncatedUInt32): Added. |
| (KJS::JSValue::toInt32): Changed getInt32 call to getTruncatedInt32. |
| (KJS::JSValue::toUInt32): Changed getUInt32 call to getTruncatedUInt32. |
| * kjs/value.cpp: |
| (KJS::JSCell::getTruncatedInt32): Added. |
| (KJS::JSCell::getTruncatedUInt32): Added. |
| (KJS::JSValue::toInteger): Changed getUInt32 call to getTruncatedInt32. |
| (KJS::JSValue::toInt32SlowCase): Removed extra getInt32 call I accidentally |
| had left in here. |
| (KJS::JSValue::toUInt32SlowCase): Ditto. |
| (KJS::JSValue::toUInt16): Changed getUInt32 call to getTruncatedUInt32. |
| |
| * JavaScriptCore.exp: Updated. |
| |
| 2007-10-22 Darin Adler <darin@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=15632 |
| js1_5/Array/array-001.js test failing |
| |
| One of the JavaScriptCore tests was failing; it failed because of |
| my change to NumberImp::getUInt32. The incorrect code I copied was |
| from JSImmediate::getUInt32, and was a pre-existing bug. |
| |
| This patch fixes correctness, but will surely slow down SunSpider. |
| We may be able to code this tighter and get the speed back. |
| |
| * kjs/JSImmediate.h: |
| (KJS::JSImmediate::getInt32): Renamed from toInt32 to more accurately |
| reflect the fact that this function only returns true if the value is |
| accurate (no fractional part, etc.). Changed code so that it returns |
| false when the value has a fraction. |
| (KJS::JSImmediate::getUInt32): Ditto. |
| |
| * kjs/internal.cpp: |
| (KJS::NumberImp::getInt32): Changed code so that it returns false when |
| the value has a fraction. Restores the old behavior. |
| (KJS::NumberImp::getUInt32): Ditto. |
| |
| * kjs/value.h: |
| (KJS::JSValue::getInt32): Updated for name change. |
| (KJS::JSValue::getUInt32): Ditto. |
| (KJS::JSValue::toInt32): Ditto. |
| (KJS::JSValue::toUInt32): Ditto. |
| |
| 2007-10-22 Darin Adler <darin@apple.com> |
| |
| Reviewed by Brady. |
| |
| - fix crash seen when running JavaScriptCore tests |
| |
| * kjs/array_instance.cpp: (KJS::ArrayInstance::mark): |
| Copy and paste error: I accidentally had code here that was |
| making a copy of the HashMap -- that's illegal inside a mark |
| function and was unnecessary. The other callsite was modifying |
| the map as it iterated it, but this function is not. |
| |
| 2007-10-22 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Oliver. |
| |
| - Avoid moving floats into integer registers in jsNumber() for 3% speedup on SunSpider |
| http://bugs.webkit.org/show_bug.cgi?id=15627 |
| |
| * kjs/JSImmediate.h: |
| (KJS::JSImmediate::fromDouble): Avoid moving floats to integer |
| registers since this is very slow. |
| |
| 2007-10-22 Darin Adler <darin@apple.com> |
| |
| Reviewed by Eric Seidel. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15617 |
| improve speed of integer conversions |
| |
| Makes SunSpider 6% faster. |
| |
| * kjs/JSImmediate.h: Added toInt32 and toUInt32, with separate versions for |
| 32-bit and 64-bit. |
| * kjs/value.h: |
| (KJS::JSValue::getUInt32): Call JSImmediate::toUInt32. |
| |
| * kjs/internal.h: Added getInt32. |
| * kjs/internal.cpp: |
| (KJS::NumberImp::getInt32): Added. |
| (KJS::NumberImp::getUInt32): Replaced with more-optimal implementation |
| stolen from JSValue. |
| |
| * kjs/value.h: |
| (KJS::jsNumber): Marked ALWAYS_INLINE, because this wasn't getting |
| inlined. |
| (KJS::JSValue::getInt32): Added. |
| (KJS::JSValue::getUInt32): Changed to call the new JSImmediate::toUInt32 |
| to avoid converting from float to double. |
| (KJS::JSValue::toInt32): Made inline, separated out the slow case. |
| (KJS::JSValue::toUInt32): Ditto. |
| * kjs/value.cpp: |
| (KJS::JSCell::getInt32): Added. |
| (KJS::JSValue::toInt32SlowCase): Renamed from toInt32. Changed to use the |
| new getInt32. Added a faster case for in-range numbers. |
| (KJS::JSValue::toUInt32SlowCase): Ditto. |
| (KJS::JSValue::toUInt16): Added a faster case for in-range numbers. |
| |
| * JavaScriptCore.exp: Updated for changes. |
| |
| 2007-10-22 Adam Roben <aroben@apple.com> |
| |
| Windows build fix |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Turn off |
| warning about implicit conversion to bool. |
| |
| 2007-10-22 Mark Rowe <mrowe@apple.com> |
| |
| Gtk build fix. |
| |
| * kjs/array_instance.cpp: |
| |
| 2007-10-22 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15606 |
| make cut-off for sparse vs. dense arrays smarter for speed with large arrays |
| |
| Makes the morph test in SunSpider 26% faster, and the overall |
| benchmark 3% faster. |
| |
| This also fixes some small problems we had with the distinction |
| between nonexistent and undefined values in arrays. |
| |
| * kjs/array_instance.h: Tweaked formatting and naming. |
| * kjs/array_instance.cpp: Copied from kjs/array_object.cpp. |
| (KJS::storageSize): Added. Computes the size of the storage given a vector length. |
| (KJS::increasedVectorLength): Added. Implements the rule for resizing the vector. |
| (KJS::isDenseEnoughForVector): Added. |
| (KJS::ArrayInstance::ArrayInstance): Initialize the new fields. |
| (KJS::ArrayInstance::~ArrayInstance): Since m_storage is now never 0, delete it. |
| (KJS::ArrayInstance::getItem): Updated for name changes. |
| (KJS::ArrayInstance::lengthGetter): Ditto. |
| (KJS::ArrayInstance::inlineGetOwnPropertySlot): Added. Allows both versions of |
| getOwnPropertySlot to share more code. |
| (KJS::ArrayInstance::getOwnPropertySlot): Just refactored, no code change. |
| (KJS::ArrayInstance::put): Added logic for extending the vector as long as the |
| array is dense enough. Also keep m_numValuesInVector up to date. |
| (KJS::ArrayInstance::deleteProperty): Added code to keep m_numValuesInVector |
| up to date. |
| (KJS::ArrayInstance::getPropertyNames): Fixed bug where this would omit names |
| for array indices with undefined values. |
| (KJS::ArrayInstance::increaseVectorLength): Renamed from resizeStorage. Also |
| simplified to only handle getting larger. |
| (KJS::ArrayInstance::setLength): Added code to update m_numValuesInVector, to |
| zero out the unused part of the vector and to delete the map if it's no longer |
| needed. |
| (KJS::ArrayInstance::mark): Tweaked formatting. |
| (KJS::compareByStringForQSort): Ditto. |
| (KJS::ArrayInstance::sort): Ditto. |
| (KJS::CompareWithCompareFunctionArguments::CompareWithCompareFunctionArguments): |
| Ditto. |
| (KJS::compareWithCompareFunctionForQSort): Ditto. |
| (KJS::ArrayInstance::compactForSorting): Fixed bug where this would turn |
| undefined values into nonexistent values in some cases. |
| |
| * kjs/array_object.h: Removed MAX_ARRAY_INDEX. |
| * kjs/array_object.cpp: Removed ArrayInstance. Moved to a separate file. |
| |
| * JavaScriptCore.pri: Added array_instance.cpp. |
| * JavaScriptCore.xcodeproj/project.pbxproj: Ditto. |
| * kjs/AllInOneFile.cpp: Ditto. |
| |
| 2007-10-22 Andrew Wellington <proton@wiretapped.net> |
| |
| Reviewed by Mark Rowe. |
| |
| Fix for local database support after r26879 |
| Ensure that ENABLE_DATABASE and ENABLE_ICONDATABASE are correctly set |
| |
| * Configurations/JavaScriptCore.xcconfig: |
| |
| 2007-10-22 Simon Hausmann <hausmann@kde.org> |
| |
| Reviewed by Alp. |
| |
| Build fix for the non-qmake builds. |
| |
| * wtf/Platform.h: Default to enabling the database features unless |
| otherwise specified. (similar to ENABLE_ICONDATABASE) |
| |
| 2007-10-22 Holger Freyther <zecke@selfish.org> |
| |
| Reviewed by Simon Hausmann <hausmann@kde.org>. |
| |
| * Do not build testkjs as an application bundle. This is |
| needed for run-javascriptcore-tests on OSX. |
| * Also, based on r26633, allow to test the WebKit/Qt port on OSX. |
| * Set DYLD_LIBRARY_PATH if it was set in the environment. It must be set |
| as we do not have -rpath on OSX. |
| |
| * kjs/testkjs.pro: |
| |
| 2007-10-21 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Alp. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=15575 |
| Bug 15575: [GTK] Implement threading using GThread |
| |
| * wtf/Platform.h: Do not enable pthreads for Gtk. |
| |
| 2007-10-21 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Mitz. |
| |
| Fix http://bugs.webkit.org/show_bug.cgi?id=15603 |
| Bug 15603: Regression(r26847): Crash when sorting an empty array from JavaScript |
| |
| * kjs/array_object.cpp: |
| (KJS::freeStorage): Reinstate null-check that was removed in r26847. |
| |
| 2007-10-21 Darin Adler <darin@apple.com> |
| |
| - fix Windows build |
| |
| * kjs/array_instance.h: Removed unused ExecState parameter. |
| * kjs/array_object.cpp: |
| (KJS::ArrayInstance::put): Ditto. |
| (KJS::ArrayInstance::setLength): Ditto. |
| |
| 2007-10-21 Darin Adler <darin@apple.com> |
| |
| * kjs/array_object.cpp: (KJS::ArrayInstance::put): |
| Add missing assignment that was causing regression test crash. |
| |
| 2007-10-21 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15585 |
| speed up sparse arrays by using a custom map |
| |
| Speeds up SunSpider by 10%. |
| |
| * kjs/array_object.cpp: |
| (allocateStorage): Leave room for an additional pointer. |
| (reallocateStorage): Ditto. |
| (freeStorage): Ditto. |
| (ArrayInstance::~ArrayInstance): Delete the overflow map if present. |
| (ArrayInstance::getItem): Read values from the overflow map if present. |
| Removed the check of length, since it slows down the common case. |
| (ArrayInstance::getOwnPropertySlot): Ditto. Also removed the fallback |
| to the property map. |
| (ArrayInstance::put): Write values into the overflow map as needed. |
| Also create overflow map when needed. |
| (ArrayInstance::deleteProperty): Remove values from the overflow map |
| as appropriate. |
| (ArrayInstance::getPropertyNames): Add a name for each identifier in |
| the property map. This is extremely inefficient. |
| (ArrayInstance::setLength): Remove any values in the overflow map |
| that are past the new length, as we formerly did with the property map. |
| (ArrayInstance::mark): Mark any values in the overflow map. |
| (compareByStringForQSort): Removed unneeded undefined case, since |
| compactForSorting guarantees we will have no undefined values. |
| (compareWithCompareFunctionForQSort): Ditto. |
| (ArrayInstance::compactForSorting): Copy all the values out of the |
| overflow map and destroy it. |
| |
| * kjs/property_map.h: Removed now-unused getSparseArrayPropertyNames. |
| * kjs/property_map.cpp: Ditto. |
| |
| 2007-10-20 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej. |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15579 |
| stop churning identifier reference counts copying Completion objects |
| |
| * kjs/completion.h: Replace the Identifier with an Identifier*. |
| * kjs/nodes.cpp: |
| (ForInNode::execute): Update for change to Completion constructor. |
| (ContinueNode::execute): Ditto. |
| (BreakNode::execute): Ditto. |
| |
| 2007-10-20 Mark Rowe <mrowe@apple.com> |
| |
| Reviewed by Alp. |
| |
| Gtk changes needed to enable HTML 5 client-side database storage. |
| |
| * wtf/Platform.h: Have Gtk use pthreads for now. |
| |
| 2007-10-20 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Fixed http://bugs.webkit.org/show_bug.cgi?id=15570 |
| Store gathered declaration nodes in the function body node. |
| |
| This means that you only have to gather the declaration nodes the first |
| time the function executes. Performance gain of 2.10% on SunSpider, |
| 0.90% on command-line JS iBench. |
| |
| * kjs/nodes.cpp: Split declaration stack initialization code off into |
| initializeDeclarationStacks(). |
| (FunctionBodyNode::FunctionBodyNode): |
| (FunctionBodyNode::initializeDeclarationStacks): |
| (FunctionBodyNode::processDeclarations): |
| |
| * kjs/nodes.h: Changed DeclarationStacks structure to hold references, |
| since the actual Vectors are now stored either on the stack or in the |
| function body node. |
| |
| 2007-10-19 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| http://bugs.webkit.org/show_bug.cgi?id=15559 |
| Moved processDeclarations call into FunctionBodyNode::execute |
| |
| To improve encapsulation, moved processDeclarations call into |
| FunctionBodyNode::execute. Also marked processDeclarations |
| ALWAYS_INLINE, since it has only 1 caller now. This is a .71% speedup |
| on command-line JS iBench. |
| |
| * kjs/function.cpp: |
| (KJS::FunctionImp::callAsFunction): |
| (KJS::GlobalFuncImp::callAsFunction): |
| * kjs/function.h: |
| * kjs/interpreter.cpp: |
| (KJS::Interpreter::evaluate): |
| * kjs/nodes.cpp: |
| (FunctionBodyNode::execute): |
| * kjs/nodes.h: |
| |
| 2007-10-19 Brady Eidson <beidson@apple.com> |
| |
| Reviewed by Sam |
| |
| Queue -> Deque! and small style tweaks |
| |
| * JavaScriptCore.vcproj/WTF/WTF.vcproj: |
| * JavaScriptCore/JavaScriptCore.xcodeproj/project.pbxproj |
| * wtf/Deque.h: Added. |
| (WTF::DequeNode::DequeNode): |
| (WTF::Deque::Deque): |
| (WTF::Deque::~Deque): |
| (WTF::Deque::size): |
| (WTF::Deque::isEmpty): |
| (WTF::Deque::append): |
| (WTF::Deque::prepend): |
| (WTF::Deque::first): |
| (WTF::Deque::last): |
| (WTF::Deque::removeFirst): |
| (WTF::Deque::clear): |
| * wtf/Queue.h: Removed. |
| |
| |
| 2007-10-19 Brady Eidson <beidson@apple.com> |
| |
| Reviewed by Oliver |
| |
| Added a simple LinkedList based Queue to wtf |
| We can make a better, more sophisticated an efficient one later, but have |
| needed one for some time, now! |
| |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| * wtf/Queue.h: Added. |
| (WTF::QueueNode::QueueNode): |
| (WTF::Queue::Queue): |
| (WTF::Queue::~Queue): |
| (WTF::Queue::size): |
| (WTF::Queue::isEmpty): |
| (WTF::Queue::append): |
| (WTF::Queue::prepend): |
| (WTF::Queue::first): |
| (WTF::Queue::last): |
| (WTF::Queue::removeFirst): |
| (WTF::Queue::clear): |
| |
| 2007-10-19 Nikolas Zimmermann <zimmermann@kde.org> |
| |
| Reviewed by Anders. |
| |
| Try to fix Qt/Win build slave, by including windows.h also on Qt/Win. |
| |
| * kjs/testkjs.cpp: Change PLATFORM(WIN) to PLATFORM(WIN_OS) |
| |
| 2007-10-19 Simon Hausmann <hausmann@kde.org> |
| |
| Reviewed by Lars. |
| |
| Fix compilation on Windows when wchar_t is a typedef instead of a native type (triggered by -Zc:wchar_t-). |
| Don't provide the wchar_t overloads then as they conflict with the unsigned short ones. |
| |
| * wtf/ASCIICType.h: |
| (WTF::isASCIIAlpha): |
| (WTF::isASCIIAlphanumeric): |
| (WTF::isASCIIDigit): |
| (WTF::isASCIIHexDigit): |
| (WTF::isASCIILower): |
| (WTF::isASCIISpace): |
| (WTF::toASCIILower): |
| (WTF::toASCIIUpper): |
| |
| 2007-10-19 Simon Hausmann <hausmann@kde.org> |
| |
| Reviewed by Lars. |
| |
| Another build fix for the windows/qt build: Apply the same fix as in revision 26686 also to kjs/config.h to disable the disallowctype feature. |
| |
| * kjs/config.h: |
| |
| 2007-10-18 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Adam. |
| |
| - use __declspec(thread) for fast thread-local storage on Windows |
| |
| - 2.2% speedup on sunspider (on Windows) |
| - 7% speedup on the string section |
| - 6% speedup on JS iBench |
| |
| - fixed <rdar://problem/5473084> PLT on Windows got 2.5% slower between r25406 and r25422 |
| - fixed at least some of <rdar://5527965? i-Bench JS was 14% slower in 310A11 than 310A10 |
| |
| |
| * wtf/FastMalloc.cpp: |
| (WTF::getThreadHeap): |
| (WTF::setThreadHeap): |
| (WTF::TCMalloc_ThreadCache::GetCache): |
| (WTF::TCMalloc_ThreadCache::GetCacheIfPresent): |
| (WTF::TCMalloc_ThreadCache::CreateCacheIfNecessary): |
| |
| 2007-10-17 Darin Adler <darin@apple.com> |
| |
| Reviewed by Mark Rowe. |
| |
| - fix http://bugs.webkit.org/show_bug.cgi?id=15543 |
| <rdar://problem/5545639> REGRESSION (r26697): |
| GoogleDocs: Can't create new documents or open existing ones |
| |
| Test: fast/js/regexp-non-character.html |
| |
| * pcre/pcre_compile.c: (check_escape): Take out the checks for valid characters |
| in the \u sequences -- not needed and actively harmful. |
| |
| 2007-10-17 Anders Carlsson <andersca@apple.com> |
| |
| Reviewed by Oliver. |
| |
| * wtf/Platform.h: |
| #define USE_PTHREADS on Mac. |
| |
| 2007-10-17 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Merged DeclaredFunctionImp into FunctionImp (the base class) because |
| the distinction between the two was unused. |
| |
| Removed codeType() from FunctionImp because FunctionImp and its |
| subclasses all returned FunctionCode, so it was unused, practically |
| speaking. |
| |
| Removed a different codeType() from GlobalFuncImp because it was unused. |
| (Perhaps it was vestigial from a time when GlobalFuncImp used to |
| inherit from FunctionImp.) |
| |
| * bindings/runtime_method.cpp: |
| * bindings/runtime_method.h: |
| * kjs/function.cpp: |
| (KJS::FunctionImp::FunctionImp): |
| (KJS::FunctionImp::callAsFunction): |
| (KJS::FunctionImp::construct): |
| (KJS::FunctionImp::execute): |
| (KJS::FunctionImp::processVarDecls): |
| * kjs/function.h: |
| (KJS::FunctionImp::implementsConstruct): |
| (KJS::FunctionImp::scope): |
| * kjs/function_object.cpp: |
| (FunctionProtoFunc::callAsFunction): |
| (FunctionObjectImp::construct): |
| * kjs/nodes.cpp: |
| (FuncDeclNode::processFuncDecl): |
| (FuncExprNode::evaluate): |
| |
| 2007-10-17 Adam Roben <aroben@apple.com> |
| |
| Windows build fix part 2. |
| |
| Fix was by Darin, reviewed by Anders and Adam. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Add |
| FastMallocPCRE.cpp to the project, and let Visual Studio have its way |
| with the post-build step. |
| * pcre/pcre.h: Don't DLL export the entry points just because this |
| is Win32 -- this is an internal copy of PCRE and should be private. |
| * pcre/pcre_compile.c: Fix an uninitialized variable warning -- |
| there's no real problem but it's better to quiet the compiler by |
| tweaking the code slightly than turn off the warning entirely. |
| |
| 2007-10-17 Adam Roben <aroben@apple.com> |
| |
| Windows build fix. |
| |
| Reviewed by Anders. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Disable |
| some mismatched signed/unsigned comparison warnings. |
| * pcre/pcre_exec.c: |
| (match): #if-out some labels that don't seem to exist. |
| |
| 2007-10-17 Mark Rowe <mrowe@apple.com> |
| |
| Gtk build fix. |
| |
| * JavaScriptCore.pri: Add FastMallocPCRE.cpp. |
| * pcre/pcre_get. #if out two functions that depend on pcre_get_stringnumber, which |
| is currently unavailable for UTF-16. |
| |
| 2007-10-16 Darin Adler <darin@apple.com> |
| |
| Reviewed by Geoff. |
| |
| - merged PCRE changes between 6.4 and 6.5 |
| |
| * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: |
| * JavaScriptCore.xcodeproj/project.pbxproj: |
| Removed pcre_config.c, pcre_globals.c, pcre_info.c, pcre_maketables.c, |
| pcre_printint.src, pcre_refcount.c, pcre_study.c, pcre_try_flipped.c, |
| pcre_ucp_findchar.c, pcre_version.c, and ucptable.c. Added pcre_ucp_searchfuncs.c. |
| |
| * pcre/AUTHORS: |
| * pcre/LICENCE: |
| * pcre/MERGING: |
| * pcre/dftables.c: |
| * pcre/pcre-config.h: |
| * pcre/pcre.h: |
| * pcre/pcre.pri: |
| * pcre/pcre_compile.c: |
| * pcre/pcre_exec.c: |
| * pcre/pcre_fullinfo.c: |
| * pcre/pcre_get.c: |
| * pcre/pcre_internal.h: |
| * pcre/pcre_maketables.c: |
| * pcre/pcre_ord2utf8.c: |
| * pcre/pcre_tables.c: |
| * pcre/pcre_ucp_searchfuncs.c: Copied from pcre/pcre_ucp_findchar.c. |
| * pcre/pcre_xclass.c: |
| * pcre/ucp.h: |
| * pcre/ucpinternal.h: |
| * pcre/ucptable.c: |
| Updated with new versions from the PCRE 6.5 release, merged with changes. |
| |
| * pcre/pcre_config.c: Removed. |
| * pcre/pcre_globals.c: Removed. |
| * pcre/pcre_info.c: Removed. |
| * pcre/pcre_printint.src: Removed. |
| * pcre/pcre_refcount.c: Removed. |
| * pcre/pcre_study.c: Removed. |
| * pcre/pcre_try_flipped.c: Removed. |
| * pcre/pcre_ucp_findchar.c: Removed. |
| * pcre/pcre_version.c: Removed. |
| |
| 2007-10-16 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Removed KJS_VERBOSE because it was getting in the way of readability, |
| and the messages didn't seem very helpful. |
| |
| * kjs/function.cpp: |
| (KJS::FunctionImp::callAsFunction): |
| (KJS::FunctionImp::passInParameters): |
| * kjs/lookup.h: |
| (KJS::lookupPut): |
| * kjs/object.cpp: |
| (KJS::JSObject::put): |
| * kjs/value.h: |
| |
| 2007-10-16 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Removed the Parameter class because it was a redundant wrapper around |
| Identifier. |
| |
| * kjs/function.cpp: |
| (KJS::FunctionImp::passInParameters): |
| (KJS::FunctionImp::getParameterName): |
| * kjs/nodes.cpp: |
| (FunctionBodyNode::addParam): |
| * kjs/nodes.h: |
| (KJS::FunctionBodyNode::): |
| |
| 2007-10-16 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Global replace of assert with ASSERT. |
| |
| 2007-10-16 Adam Roben <aroben@apple.com> |
| |
| Make testkjs not delay-load WebKit |
| |
| Soon, delay-loading WebKit will be impossible (because we will be |
| using __declspec(thread) for thread-local storage). This change |
| prepares testkjs for the future. |
| |
| Reviewed by Sam. |
| |
| * JavaScriptCore.vcproj/JavaScriptCore.sln: Removed WebKitInitializer, |
| added FindSafari. |
| * JavaScriptCore.vcproj/testkjs/testkjs.vcproj: Don't link against |
| WebKitInitializer, don't delay-load WebKit. |
| * kjs/testkjs.cpp: Don't use WebKitInitializer. |
| |
| 2007-10-16 Adam Roben <aroben@apple.com> |
| |
| Updated testkjs for the rename of WebKit_debug.dll to WebKit.dll for the Debug configuration |
| |
| Reviewed by Kevin McCullough. |
| |
| * JavaScriptCore.vcproj/debug.vsprops: Added WebKitDLLConfigSuffix. |
| * JavaScriptCore.vcproj/debug_internal.vsprops: Ditto. |
| * JavaScriptCore.vcproj/release.vsprops: Ditto. |
| * JavaScriptCore.vcproj/testkjs/testkjs.vcproj: Use |
| WebKitDLLConfigSuffix when referring to WebKit.dll, and fixed a typo |
| in the name of icuuc36[_debug].dll. |
| |
| 2007-10-16 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Re-structured variable and function declaration code. |
| |
| Command-line JS iBench shows no regression. |
| |
| Here are the changes: |
| |
| 1. Function declarations are now processed at the same time as var |
| declarations -- namely, immediately upon entry to an execution context. |
| This does not match Firefox, which waits to process a function |
| declaration until the declaration's containing block executes, but it |
| does match IE and the ECMA spec. (10.1.3 states that var and function |
| declarations should be processed at the same time -- namely, "On |
| entering an execution context." 12.2 states that "A Block does not |
| define a new execution scope.") |
| |
| 2. Declaration processing proceeds iteratively now, rather than |
| recursively, storing the nodes is finds in stacks. This will later |
| facilitate an optimization to hold on to the gathered declaration nodes, |
| rather than re-fetching them in every function call. |
| [ http://bugs.webkit.org/show_bug.cgi?id=14868 ] |
| |
| Modified these tests because they expected the incorrect Mozilla |
| behavior described above: |
| |
| * tests/mozilla/ecma_3/Function/scope-001.js: |
| * tests/mozilla/js1_5/Scope/regress-184107.js: |
| |
| 2007-10-16 Darin Adler <darin@apple.com> |
| |
| - try to fix the GTK build |
| |
| * kjs/ustring.cpp: Include ASCIICType.h, not ASCIICtype.h. |
| |
| 2007-10-16 Darin Adler <darin@apple.com> |
| |
| - try to fix the Windows build |
| |
| * kjs/date_object.cpp: (KJS::parseDate): A couple instances of isspace were |
| in here. Not sure why it wasn't failing elsewhere. Changed to isASCIISpace. |
| |
| 2007-10-16 Darin Adler <darin@apple.com> |
| |
| - try to fix the GTK build |
| |
| * kjs/ustring.cpp: Include ASCIICType.h. |
| |
| 2007-10-16 Darin Adler <darin@apple.com> |
| |
| Reviewed by Maciej and Geoff (and looked over by Eric). |
| |
| - http://bugs.webkit.org/show_bug.cgi?id=15519 |
| eliminate use of <ctype.h> for processing ASCII |
| |
| * wtf/ASCIICType.h: Added. |
| * wtf/DisallowCType.h: Added. |
| |
| * kjs/config.h: Include DisallowCType.h. |
| |
| * kjs/date_object.cpp: |
| (KJS::skipSpacesAndComments): |
| (KJS::findMonth): |
| (KJS::parseDate): |
| * kjs/function.cpp: |
| (KJS::decode): |
| * kjs/ustring.cpp: |
| (KJS::UString::toDouble): |
| Use ASCIICType.h functions instead of ctype.h ones. |
| |
| 2007-10-14 Maciej Stachowiak <mjs@apple.com> |
| |
| Reviewed by Darin. |
| |
| - fixes for "New JavaScript benchmark" |
| http://bugs.webkit.org/show_bug.cgi?id=15515 |
| |
| * kjs/testkjs.cpp: |
| (TestFunctionImp::callAsFunction): Implement "load" for compatibility |
| with SpiderMonkey. |
| (TestFunctionImp::): ditto |
| (doIt): ditto |
| (kjsmain): Drop useless --> from output. |
| |
| 2007-10-15 Geoffrey Garen <ggaren@apple.com> |
| |
| Removed unnecessary #include. |
| |
| * API/JSObjectRef.cpp: |
| |
| 2007-10-15 Geoffrey Garen <ggaren@apple.com> |
| |
| Double-reverse build fix. My tree was out of date. |
| |
| * kjs/nodes.cpp: |
| (NumberNode::evaluate): |
| |
| 2007-10-15 Geoffrey Garen <ggaren@apple.com> |
| |
| Build fix. |
| |
| * kjs/nodes.cpp: |
| (NumberNode::evaluate): |
| |
| 2007-10-15 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Removed surprising self-named "hack" that made nested functions |
| available as named properties of their containing functions, and placed |
| containing function objects in the scope chains of nested functions. |
| |
| There were a few reasons to remove this "hack:" |
| |
| 1. It contradicted FF, IE, and the ECMA spec. |
| |
| 2. It incurred a performance penalty, since merely parsing a function |
| required parsing its body for nested functions (and so on). |
| |
| 3. SVN history contains no explanation for why it was added. It was just |
| legacy code in a large merge a long, long time ago. |
| |
| [ Patch broken off from http://bugs.webkit.org/show_bug.cgi?id=14868 ] |
| |
| * kjs/nodes.cpp: |
| (FuncDeclNode::processFuncDecl): |
| |
| 2007-10-15 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Removed the concept of AnonymousCode. It was unused, and it doesn't |
| exist in the ECMA spec. |
| |
| [ Patch broken off from http://bugs.webkit.org/show_bug.cgi?id=14868 ] |
| |
| * kjs/Context.cpp: |
| (KJS::Context::Context): |
| * kjs/function.h: |
| * kjs/nodes.cpp: |
| (ReturnNode::execute): |
| |
| 2007-10-15 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Darin Adler. |
| |
| Made function parameters DontDelete. This matches FF and the vague |
| description in ECMA 10.1.3. It's also required in order to make |
| symbol table based lookup of function parameters valid. (If the |
| parameters aren't DontDelete, you can't guarantee that you'll find |
| them later in the symbol table.) |
| |
| [ Patch broken off from http://bugs.webkit.org/show_bug.cgi?id=14868 ] |
| |
| * kjs/function.cpp: |
| (KJS::FunctionImp::passInParameters): |
| |
| 2007-10-15 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Some Vector optimizations. These are especially important when using |
| Vector as a stack for implementing recursive algorithms iteratively. |
| |
| [ Broken off from http://bugs.webkit.org/show_bug.cgi?id=14868 ] |
| |
| 1. Added shrink(), which is a version of resize() that you can call |
| to save a branch / improve code generation and inlining when you know |
| that the vector is not getting bigger. |
| |
| 2. Changed subclassing relationship in VectorBuffer to remove a call to |
| fastFree() in the destructor for the inlineCapacity != 0 template |
| specialization. This brings inline Vectors one step closer to true |
| stack-allocated arrays. |
| |
| Also changed abort() to CRASH(), since the latter works better. |
| |
| * wtf/Vector.h: |
| (WTF::VectorBufferBase::allocateBuffer): |
| (WTF::VectorBufferBase::deallocateBuffer): |
| (WTF::VectorBufferBase::VectorBufferBase): |
| (WTF::VectorBufferBase::~VectorBufferBase): |
| (WTF::): |
| (WTF::VectorBuffer::VectorBuffer): |
| (WTF::VectorBuffer::~VectorBuffer): |
| (WTF::VectorBuffer::deallocateBuffer): |
| (WTF::VectorBuffer::releaseBuffer): |
| (WTF::Vector::clear): |
| (WTF::Vector::removeLast): |
| (WTF::::operator): |
| (WTF::::fill): |
| (WTF::::shrink): |
| |
| 2007-10-12 Geoffrey Garen <ggaren@apple.com> |
| |
| Reviewed by Maciej Stachowiak. |
| |
| Fixed http://bugs.webkit.org/show_bug.cgi?id=15490 |
| Iteration statements sometimes incorrectly evaluate to the empty value |
| (KDE r670547). |
| |
| [ Broken off from http://bugs.webkit.org/show_bug.cgi?id=14868 ] |
| |
| This patch is a merge of KDE r670547, with substantial modification |
| for performance. |
| |
| It fixes do-while statements to evaluate to a value. (They used |
| to evaluate to the empty value in all cases.) |
| |
| It also fixes SourceElementsNode to maintain the value of abnormal |
| completions like "break" and "continue." |
| |
| It also re-works the main execution loop in SourceElementsNode so that |
| it (1) makes a little more sense and (2) avoids unnecessary work. This |
| is a .28% speedup on command-line JS iBench. |
| |
| * kjs/nodes.cpp: |
| (DoWhileNode::execute): |
| (SourceElementsNode::execute): |
| |
| 2007-10-15 Simon Hausmann <hausmann@kde.org> |
| |
| Reviewed by Lars. |
| |
| Fix compilation with gcc 4.3 by including 'limits' due to the use of std::numeric_limits. |
| |
| * wtf/HashTraits.h: |
| |
| 2007-10-5 Kevin Ollivier <kevino@theolliviers.com> |
| |
| Reviewed by Adam. |
| |
| Add support for MSVC7, and fix cases where PLATFORM(WIN) should |
| be PLATFORM(WIN_OS) for other ports building on Windows. |
| |
| * kjs/DateMath.cpp: |
| (KJS::getDSTOffsetSimple): |
| * kjs/JSImmediate.h: |
| * wtf/Assertions.cpp: |
| * wtf/Assertions.h: |
| * wtf/Platform.h: |
| * wtf/StringExtras.h: |
| (snprintf): |
| (vsnprintf): |
| |
| 2007-10-14 Cameron Zwarich <cwzwarich@uwaterloo.ca> |
| |
| Reviewed by Darin. |
| |
| Adds NegateNode optimization from KJS. The relevant revision in KDE |
| is 666736. |
| |
| * kjs/grammar.y: |
| * kjs/nodes.cpp: |
| (NumberNode::evaluate): |
| * kjs/nodes.h: |
| (KJS::Node::): |
| (KJS::NumberNode::): |
| * kjs/nodes2string.cpp: |
| (NumberNode::streamTo): |
| |
| 2007-10-14 Jason Foreman <jason@threeve.org> |
| |
| Reviewed by Maciej. |
| |
| Fix http://bugs.webkit.org/show_bug.cgi?id=15145 |
| |
| Ensure that if adjusting n to minimize the difference of n*intPow10(e-p+1) to x, |
| that the property n < intPow10(p) is maintained. |
| |
| * kjs/number_object.cpp: |
| (NumberProtoFunc::callAsFunction): |
| |
| == Rolled over to ChangeLog-2007-10-14 == |