2008-08-10 Jan Michael Alonzo 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 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 Reviewed by Maciej. Fix some style issues in the sampling tool. * VM/SamplingTool.cpp: (KJS::sleepForMicroseconds): (KJS::SamplingTool::dump): 2008-08-09 Cameron Zwarich 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 Reviewed by Oliver. Bug 20330: JSCore crash loading any filehurricane media page 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 Not reviewed, build fix. * JavaScriptCore.exp: 2008-08-08 Oliver Hunt 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 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ø Revert change 35595. * wtf/RetainPtr.h: 2008-08-06 Ariya Hidayat Fix non-Mac build. * wtf/RetainPtr.h: CoreFoundation only for PLATFORM(MAC) 2008-08-06 Ariya Hidayat Fix non-Mac build. * wtf/RetainPtr.h: CoreFoundation only for PLATFORM(MAC) 2008-08-06 Csaba Osztrogonac Reviewed by Darin. Landed by Cameron. Bug 20272: typo in JavaScriptCore Correct the documentation for op_not. (typo) Fix #undef. (typo) * VM/Machine.cpp: (KJS::Machine::privateExecute): 2008-08-06 Cameron Zwarich Reviewed by Maciej. Bug 20286: Load constants all at once instead of using op_load 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 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 Reviewed by Darin. Bug 20293: Crash in JavaScript codegen for eval("const a;") Correctly handle constant declarations in eval code with no initializer. * kjs/nodes.cpp: (KJS::ConstDeclNode::emitCodeSingle): 2008-08-05 Cameron Zwarich Reviewed by Oliver. Roll out r35555 because of correctness issues. * VM/Machine.cpp: (KJS::Machine::privateExecute): 2008-08-05 Maciej Stachowiak 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 Reviewed by Cameron Zwarich. Bug 19359: JavaScriptCore behaves differently from FF2/3 and IE when handling context in catch statement 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 Reviewed by Eric Seidel. Added JavaScriptCore/API/WebKitAvailability to list of files in javascriptcore_h_api. * GNUmakefile.am: 2008-08-01 Alexey Proskuryakov 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 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 Reviewed by Adam. Fix Windows build. * kjs/collector.h: * wtf/FastMalloc.cpp: 2008-07-31 Csaba Osztrogonac Reviewed by Simon. Bug 20170: [Qt] missing namespace defines in JavaScriptCore.pro * JavaScriptCore.pro: Added missing define. 2008-07-31 Alexey Proskuryakov 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 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 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 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 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 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 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 Reviewed by Alexey Proskuryakov. Fix compilation without multi-threading support. * kjs/collector.cpp: (KJS::Heap::Heap): 2008-07-30 Anders Carlsson Add WebKitAvailability.h forwarding header. * ForwardingHeaders/JavaScriptCore/WebKitAvailability.h: Added. 2008-07-30 Anders Carlsson Fix the else. * API/WebKitAvailability.h: 2008-07-30 Anders Carlsson * 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 One step closer towards fixing the Windows build. * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCoreGenerated.make: Make sure to copy WebKitAvailability.h 2008-07-29 Gavin Barraclough Reviewed by Geoff Garen. Bug 20209: Atomize constant strings 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 Reviewed by Alexey Proskuryakov. 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 Reviewed by Geoff Garen. Don't call JSGarbageCollect() on a released context. * API/testapi.c: (main): 2008-07-29 Alexey Proskuryakov 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 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 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 Attempt to fix the Qt build. * wtf/ThreadingQt.cpp: Add the extra argument to createThread. 2008-07-29 Adam Roben 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 Windows build fix * wtf/ThreadingWin.cpp: (WTF::setThreadName): Move a misplaced assertion to here... (WTF::createThread): ...from here. 2008-07-29 Adam Roben 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 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 Reviewed by Sam Weinig. Renamed "ConstructTypeNative" => "ConstructTypeHost". 2008-07-26 Mark Rowe Speculative fix for the wx build. * JavaScriptCoreSources.bkl: Add JSStaticScopeObject.cpp to the list of source files. 2008-07-25 Oliver Hunt RS=Cameron Zwarich. Whoops, forgot to save style correction. * kjs/JSStaticScopeObject.h: 2008-07-25 Oliver Hunt Reviewed by Cameron Zwarich. Bug 19718: Named anonymous functions are slow accessing global variables 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 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 Windows build fix * JavaScriptCore.vcproj/testapi/testapi.vcproj: Add API/ to the include path. 2008-07-25 Simon Hausmann 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 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 Prospective WX build fix, add JavaScriptCore/API to the include search path. * jscore.bkl: 2008-07-25 Simon Hausmann 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 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 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 Reviewed by Alexey Proskuryakov. Bug 20142: REGRESSION(r35245): /=/ weirdness 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 Build fix after r35293: Add API/ to the include path. * GNUmakefile.am: 2008-07-23 Adam Roben 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 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 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 Bug 20097: [Qt] 20% Sunspider slow-down Reviewed by Simon Hausmann. * kjs/jsc.pro: Added missing NDEBUG define for release builds. 2008-07-23 Alexey Proskuryakov 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 Build fix. * kjs/ArgList.h: (KJS::ArgList::operator new): removed an extraneous "ArgList::" inside the class definition. 2008-07-22 Geoffrey Garen 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 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 Reviewed by Sam Weinig. 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 Add Vector::find This is a convenience wrapper around std::find. Reviewed by Anders Carlsson. * wtf/Vector.h: 2008-07-19 Oliver Hunt Reviewed by Cameron Zwarich. Bug 20104: Exception in tables/mozilla_expected_failures/bugs/bug92868_1.html includes the equals operator in the quoted expression 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 Windows build fix. * kjs/JSGlobalObjectFunctions.cpp: (KJS::isStrWhiteSpace): 2008-07-18 Steve Falkenburg Windows build fix. * kjs/nodes.h: (KJS::ThrowableExpressionData::ThrowableExpressionData): 2008-07-18 Oliver Hunt Reviewed by Cameron Zwarich. Bug 18774: SQUIRRELFISH: print meaningful error messages 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 Reviewed by Cameron Zwarich. Three renames: "CallTypeNative" => "CallTypeHost" "code" => "byteCode" "generatedCode" => "generatedByteCode" 2008-07-18 Geoffrey Garen 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 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 Bug 19975: [OpenBSD] Patches to enable build of WebKit Reviewed by David Kilzer. Support for OpenBSD, mostly threading and libm tweaks. * kjs/collector.cpp: #include (KJS::currentThreadStackBase): use pthread_stackseg_np() to get stack base * kjs/config.h: OpenBSD also provides * wtf/MathExtras.h: #include and (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 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 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 Build fix. * kjs/InternalFunction.cpp: 2008-07-17 Sam Weinig Roll out r35199 as it is causing failures on the PPC build. 2008-07-17 Geoffrey Garen 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 Reviewed by Oliver Hunt. Fixed 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 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 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 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 Reviewed by Simon. Fix MinGW build (broken in r35198) and simplify getLocalTime(). * kjs/DateMath.cpp: (KJS::getLocalTime): 2008-07-17 Gavin Barraclough 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 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 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 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 Fixed build. * kjs/JSGlobalObject.cpp: 2008-07-16 Kevin McCullough Reviewed by Sam and Geoff. 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 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 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 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 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 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 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 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 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 Buidl fix. Make sure the second insertBefore method returns a value. * wtf/ListHashSet.h: (WTF::::insertBefore): 2008-07-14 Adam Roben Windows build fix * JavaScriptCore.vcproj/jsc/jsc.vcproj: Added include/pthreads to the include path. 2008-07-14 Alexey Proskuryakov 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 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 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 Windows build fix: Add wtf/RefCountedLeakCounter to the project. * JavaScriptCore.vcproj/WTF/WTF.vcproj: 2008-07-12 Jan Michael Alonzo Gtk, Qt and Wx build fix: Add wtf/RefCountedLeakCounter in the build scripts * GNUmakefile.am: * JavaScriptCore.pri: * JavaScriptCoreSources.bkl: 2008-07-11 Stephanie Lewis 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 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 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 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 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 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 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 Reviewed by Darin. 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 Gtk build fix. * GNUmakefile.am: Add HeavyProfile.cpp 2008-07-09 Mark Rowe Reviewed by Geoff Garen. Don't warn about deprecated functions in production builds. * Configurations/Base.xcconfig: * Configurations/DebugRelease.xcconfig: 2008-07-09 Darin Adler * JavaScriptCore.pri: Fix Qt build by adding HeavyProfile.cpp. 2008-07-09 Kevin Ollivier wx biuld fix. Add HeavyProfile.cpp to build files. * JavaScriptCoreSources.bkl: 2008-07-09 Kevin McCullough - Windows build fix. * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: 2008-07-09 Kevin McCullough - Build fix. * profiler/HeavyProfile.cpp: (KJS::HeavyProfile::mergeProfiles): 2008-07-09 Kevin McCullough Reviewed by Geoff and Adam. 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 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 Prospective Gtk/Wx build fixes, add ProfileGenerator.cpp to the build. * GNUmakefile.am: * JavaScriptCoreSources.bkl: 2008-07-08 Simon Hausmann Fix the Qt build, add ProfileGenerator.cpp to the build. * JavaScriptCore.pri: 2008-07-07 David Kilzer 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 Reviewed by Geoff. Bug 19926: URL causes crash within a minute 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 Rubber stamped by Adele. * VM/Machine.cpp: (KJS::Machine::privateExecute): Fix a typo in a comment. 2008-07-07 Steve Falkenburg Build fixes. * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: * JavaScriptCore.vcproj/testapi/testapi.vcproj: 2008-07-07 Kevin McCullough 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 Reviewed by Cameron Zwarich. Third step in broad cleanup effort. [ File list elided ] 2008-07-06 Sam Weinig Reviewed by Cameron Zwarich. Second step in broad cleanup effort. [ File list elided ] 2008-07-05 Sam Weinig Reviewed by Cameron Zwarich. First step in broad cleanup effort. [ File list elided ] 2008-07-05 Sam Weinig 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 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 Fix build on case-sensitive build systems. * kjs/IndexToNameMap.cpp: 2008-07-05 Sam Weinig 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 Fix non-AllInOne build. * kjs/JSGlobalObject.cpp: 2008-07-05 Sam Weinig 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 Really fix the mac build. * JavaScriptCore.xcodeproj/project.pbxproj: 2008-07-04 Sam Weinig Fix mac build. * JavaScriptCore.xcodeproj/project.pbxproj: 2008-07-04 Sam Weinig Fix non-AllInOne builds. * kjs/Error.cpp: * kjs/GetterSetter.cpp: * kjs/JSImmediate.cpp: * kjs/operations.cpp: 2008-07-04 Sam Weinig 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 Fix the Wx build, added TreeProfile.cpp to the build. * JavaScriptCoreSources.bkl: 2008-07-03 Mark Rowe 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 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 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 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 - Windows build fix * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Added TreeProfile.{h,cpp}. 2008-07-03 Dan Bernstein Reviewed by Anders Carlsson. - Windows build fix * VM/Machine.cpp: (KJS::Machine::Machine): 2008-07-03 Simon Hausmann Reviewed by Alexey Proskuryakov. Fix the non-threaded build. * kjs/JSGlobalData.cpp: (KJS::JSGlobalData::threadInstanceInternal): 2008-07-03 Simon Hausmann Fix the Qt build, added TreeProfile to the build. * JavaScriptCore.pri: 2008-07-02 Alexey Proskuryakov 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 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 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 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 Build fix for r34960. Add TreeProfile.cpp to build. * GNUmakefile.am: 2008-07-02 Geoffrey Garen 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 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 Reviewed by Darin. Bug 19776: Number.toExponential() is incorrect for numbers between 0.1 and 1 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 Reviewed by Darin. 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 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 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 Another non-AllInOne build fix. * kjs/JSGlobalObject.cpp: Include JSLock.h here, too. 2008-07-02 Alexey Proskuryakov Non-AllInOne build fix. * kjs/interpreter.cpp: Include JSLock.h. 2008-06-30 Alexey Proskuryakov 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 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 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 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 Reviewed by Darin. Bug 19844: JavaScript Switch statement modifies "this" 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 Gtk+ build fix. * kjs/list.cpp: Include "JSCell.h" 2008-07-01 Kevin McCullough Build fix. * JavaScriptCore.xcodeproj/project.pbxproj: 2008-07-01 Dan Bernstein Reviewed by Anders Carlsson. - Mac release build fix * JavaScriptCore.exp: 2008-07-01 Sam Weinig Try and fix mac builds. * JavaScriptCore.exp: 2008-07-01 Sam Weinig Fix non-AllInOne builds. * kjs/DateMath.cpp: 2008-07-01 Sam Weinig 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 Build fixes. * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: * kjs/JSGlobalObject.h: (KJS::JSGlobalObject::addStaticGlobals): 2008-07-01 Simon Hausmann Build fix, include OwnPtr.h. * kjs/RegExpConstructor.h: 2008-06-30 Geoffrey Garen 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 Reviewed by Oliver Hunt. Removed the "registerBase" abstraction. Since the register file never reallocates, we can keep direct pointers into it, instead of tuples. SunSpider says 0.8% faster. 2008-06-30 Oliver Hunt 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 Reviewed by Oliver. Bug 19830: REGRESSION (r34883): Google Reader doesn't show up feed list on sidebar 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 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 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 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 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 Fix 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 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 Rubber-stamped by Oliver. Correct the documentation for op_put_by_index. * VM/Machine.cpp: (KJS::Machine::privateExecute): 2008-06-29 Cameron Zwarich Reviewed by Oliver. Bug 19821: Merge the instruction pair (less, jfalse) 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 Fix non-AllInOne builds. * kjs/JSObject.cpp: * kjs/JSValue.cpp: 2008-06-29 Sam Weinig Build fix for Qt. * kjs/DateMath.cpp: * kjs/DatePrototype.cpp: 2008-06-29 Sam Weinig 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 Fix non-AllInOne build. * kjs/DateConstructor.cpp: * kjs/DateMath.cpp: * kjs/JSObject.cpp: 2008-06-29 Sam Weinig 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 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 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 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 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 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 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 Fix non-AllInOne builds. * kjs/StringConstructor.cpp: 2008-06-28 Sam Weinig 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 Gtk build fix: JSVariableObject is now part of AllInOne * GNUmakefile.am: 2008-06-28 Darin Adler 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 Try and fix the Windows build again. * kjs/RegExpObject.cpp: * kjs/date_object.cpp: * kjs/error_object.cpp: 2008-06-28 Sam Weinig Rubber-stamped by Darin Adler. Remove unused StringConstructorFunction class. * kjs/string_object.h: 2008-06-28 Sam Weinig 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 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 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 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 Reviewed by Oliver. * kjs/nodes.h: Remove obsolete PlacementNewAdopt constructors. We no longer mutate the AST in place. 2008-06-28 Jan Michael Alonzo Reviewed by Oliver Hunt. Build fix * VM/Machine.cpp: include stdio.h for printf 2008-06-27 Sam Weinig 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 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 Reviewed by Sam. Bug 18626: SQUIRRELFISH: support the "slow script" dialog 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 Gtk and Qt build fix: Remove RegisterFileStack from the build scripts. * GNUmakefile.am: * JavaScriptCore.pri: 2008-06-27 Adele Peterson 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 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 Speculative fix for the Windows build. * kjs/JSImmediate.cpp: 2008-06-26 Mark Rowe 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 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 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 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 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 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 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 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 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 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 Reviewed by Tim. JSProfiler: Profiler goes into an infinite loop sometimes. 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 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 Build fix. * kjs/nodes.cpp: 2008-06-24 Joerg Bornemann 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 Fix the Qt build, added missing include. * kjs/PropertySlot.cpp: 2008-06-24 Alexey Proskuryakov 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 Reviewed by Oliver. Bug 19730: REGRESSION (r34497): Text in alerts in "Leisure suit Larry" is not wrapped 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 Reviewed by Adam Roben. Fix compile with MinGW. * kjs/Shell.cpp: * wtf/Threading.h: (WTF::atomicIncrement): (WTF::atomicDecrement): 2008-06-23 Mark Rowe 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 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 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 Reviewed by Oliver. Bug 19716: REGRESSION (SquirrelFish): Reproducible crash after entering a username at mint.com 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 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 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 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 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 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 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 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 Reviewed by Oliver. Remove unused destructors. * kjs/nodes.cpp: * kjs/nodes.h: 2008-06-20 Timothy Hatcher 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 !USE(MULTIPLE_THREADS) on Darwin build fix * kjs/InitializeThreading.cpp: (KJS::initializeThreading): * kjs/collector.h: 2008-06-20 Kevin McCullough -Leopard Build Fix. * profiler/Profile.cpp: (KJS::Profile::removeProfileStart): (KJS::Profile::removeProfileEnd): 2008-06-20 Kevin McCullough Just giving credit. * ChangeLog: 2008-06-20 Kevin McCullough Reviewed by Tim and Dan. 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 Reviewed by Tim. 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 Reviewed by Simon. Surpress compiler warning (int vs unsigned comparison). * wtf/unicode/qt4/UnicodeQt4.h: (WTF::Unicode::toLower): 2008-06-19 Ariya Hidayat Reviewed by Timothy Hatcher. Introduce compiler define for MinGW, to have COMPILER(MINGW). * wtf/Platform.h: 2008-06-19 Alexey Proskuryakov 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 GTK+/autotools build fix. JSGlobalObject.cpp in now in AllInOneFile.cpp and shouldn't be built separately. * GNUmakefile.am: 2008-06-19 Alexey Proskuryakov 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 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 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 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 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 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 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 Reviewed by Geoff. 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 Rubber stamped by Adam Roben. Include JSGlobalObject.h to fix the build. * kjs/ScopeChain.cpp: 2008-06-17 Cameron Zwarich Reviewed by Oliver. Reduce code duplication in emitReadModifyAssignment(). * kjs/nodes.cpp: (KJS::emitReadModifyAssignment): 2008-06-17 Cameron Zwarich Reviewed by Oliver. Sort includes alphabetically. * kjs/nodes.cpp: 2008-06-16 Cameron Zwarich Reviewed by Maciej. Bug 19596: LEAK: Gmail leaks SegmentedVector 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 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 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 Trying to fix Windows build. * kjs/PropertyNameArray.h: * kjs/identifier.cpp: Include ExecState.h 2008-06-16 Geoffrey Garen 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 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 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 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 Reviewed by John. 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 Reviewed by Sam Weinig. JSProfiler: Remove the recursion limit in the profiler. * profiler/Profile.cpp: (KJS::Profile::willExecute): 2008-06-16 Kevin McCullough Reviewed by Sam. 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 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 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 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 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 Gtk build fix * GNUmakefile.am: 2008-06-15 Darin Adler - 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 - 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 - 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 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 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 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 Rubber-stamped by Maciej. Install 'jsc' application by default. * GNUmakefile.am: 2008-06-15 Maciej Stachowiak 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 Reviewed by Maciej. Mac build fix. * JavaScriptCore.xcodeproj/project.pbxproj: * kjs/nodes.h: 2008-06-15 Cameron Zwarich 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 Reviewed by Maciej. Remove unused preprocessor macros related to exceptions in the old interpreter. * kjs/nodes.cpp: 2008-06-15 Cameron Zwarich Reviewed by Maciej. Bug 19484: More instructions needs to use temporary registers 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 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 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 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 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 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 Reviewed by Oliver. Remove helper functions in the parser that are no longer needed. * kjs/grammar.y: 2008-06-14 Cameron Zwarich Reviewed by Oliver. Bug 19484: More instructions needs to use temporary registers 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 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 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 * 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 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 Reviewed by Geoff. 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 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 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 Reviewed by Maciej. Bug 19510: CodeBlock::needsFullScopeChain not always set for global code 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 Reviewed by Maciej. Bug 19498: REGRESSION (r34497): crash while loading GMail * 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 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 Reviewed by Darin. Bug 19457: Create fused opcodes for tests and conditional jumps 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 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 wx build fix. Link against libedit on Mac since HAVE(READLINE) is defined there. * jscore.bkl: 2008-06-10 Alexey Proskuryakov 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 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 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 Reviewed by Darin. Bug 17531: Add interactive mode to testkjs 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 Reviewed by Darin. Bug 19346: REGRESSION: Mootools 1.2 Class inheritance broken in post-SquirrelFish merge 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 Reviewed by Dan Bernstein. Bug 17928: testkjs shouldn't require "-f" * kjs/testkjs.cpp: (printUsageStatement): (parseArguments): 2008-06-07 Cameron Zwarich Reviewed by Eric. Bug 17548: JavaScriptCore print(a, b) differs from Spidermonkey Behavior * kjs/testkjs.cpp: (functionPrint): 2008-06-07 Cameron Zwarich Reviewed by Sam. Bug 17547: JavaScriptCore print() differs from Spidermonkey Behavior * kjs/testkjs.cpp: (functionPrint): 2008-06-07 Alexey Proskuryakov 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 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 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 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 Reviewed by Oliver. Bug 19424: Add support for logging opcode pair counts * 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 Reviewed by Adam. 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 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 Reviewed by Alp Toker. Fix whitespaces. * kjs/collector.cpp: (KJS::getPlatformThreadRegisters): 2008-06-05 Antti Koivisto Reviewed by Darin. Support compiling JavaScriptCore for ARM. * kjs/collector.cpp: (KJS::getPlatformThreadRegisters): (KJS::otherThreadStackPointer): 2008-06-05 Kevin McCullough 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 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 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 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 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 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 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 Reviewed by Maciej. Bug 19400: subscript operator does not protect base when necessary 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 Reviewed by Maciej Stachowiak. Big cleanup of formatting and whitespace. 2008-06-04 Cameron Zwarich 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 Reviewed by Geoff. 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 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 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 Rubber-stamped by Darin. Fix spacing in collector.{h,cpp}. * kjs/collector.cpp: * kjs/collector.h: 2008-06-03 Cameron Zwarich Reviewed by Maciej. Build fix. The cleanup in r34355 missed a method. * kjs/nodes.cpp: * kjs/nodes.h: 2008-06-03 Darin Adler 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 Reviewed by Tim. Bug 12983: Web Inspector break on the debugger keyword 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 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 Reviewed by Oliver. * VM/Machine.cpp: (KJS::Machine::privateExecute): Document throw and catch opcodes. 2008-06-02 Geoffrey Garen Reviewed by Alexey Proskuryakov. Removed JSObject::call, since it just called JSObject::callAsFunction. SunSpider reports no change. 2008-06-02 Geoffrey Garen 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 Build fix for non-AllInOne builds * kjs/array_object.cpp: Added a missing #include. 2008-06-02 Kevin McCullough Took out accidental confilct lines I checked in. * ChangeLog: 2008-06-02 Kevin McCullough Reviewed by Darin. 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 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 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 Reviewed by Alice Liu. Refactored some hand-rolled code to call ScopeChain::globalObject instead. 2008-06-02 Geoffrey Garen 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 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 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 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 Reviewed by Oliver. - fixed 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 Build fix. * kjs/array_instance.cpp: 2008-05-29 Alexey Proskuryakov Reviewed by Darin. https://bugs.webkit.org/show_bug.cgi?id=19294 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 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 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 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 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 Reviewed by Oliver. "const f" crashes in JavaScriptCore Make sure to null check the initializer. * kjs/nodes.cpp: (KJS::ConstDeclNode::emitCodeSingle): 2008-05-28 Adam Roben 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 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 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 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 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 Roll out r34163 A better fix is on the way. * DerivedSources.make: * JavaScriptCore.vcproj/JavaScriptCore/build-generated-files.sh: 2008-05-27 Adam Roben 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 Reviewed by Geoff and Maciej. 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 wx build fixes to catch up with SquirrelFish, etc. * JavaScriptCoreSources.bkl: * jscore.bkl: * wtf/Platform.h: 2008-05-27 Darin Adler 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 Windows build fix. * kjs/testkjs.cpp: 2008-05-26 Maciej Stachowiak Reviewed by Anders. - make addStaticGlobals protected instead of private so subclasses can use it * JavaScriptCore.exp: * kjs/JSGlobalObject.h: 2008-05-26 Geoffrey Garen Reviewed by Darin Adler. Fixed 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ø 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 Fixing a typo in the previous commit made as a last minute change. * kjs/regexp_object.cpp: 2008-05-24 Alexey Proskuryakov 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 Win32/gcc build fix. Remove MSVC assumption. * wtf/TCSpinLock.h: (TCMalloc_SlowLock): 2008-05-24 Oleg Finkelshteyn 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 Reviewed by Geoff. 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 Reviewed by Sam. 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 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 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 Reviewed by Oliver Hunt. - fixed 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 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 Rolled out r34073 because it caused lots of layout test crashes. 2008-05-23 Geoffrey Garen Rolled out r34085 because it measured as a 7.6% performance regression. 2008-05-23 Adam Roben Windows build fix * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Add the profiler directory to the include path. 2008-05-23 Oliver Hunt 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 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 Build fix for gcc 3. Default constructor required in ExecState, used by OldInterpreterExecState. * kjs/ExecState.h: (KJS::ExecState::ExecState): 2008-05-23 Mark Rowe Reviewed by Oliver Hunt. Fix 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 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 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 Fix the Qt build by adding profiler/ to the include search path. * JavaScriptCore.pri: 2008-05-22 Kevin McCullough 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 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 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 GTK+ build fix. Add JavaScriptCore/profiler to include path. * GNUmakefile.am: 2008-05-22 Adam Roben 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 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 Reviewed by Darin. 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 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 Build fix. * VM/Machine.cpp: (KJS::callEval): 2008-05-22 Kevin McCullough Reviewed by Sam. 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 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 Reviewed by Darin. Bug 19116: SquirrelFish shouldn't regress on variable lookups 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 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 RS=Maciej. Roll out r34020 as it causes recursion tests to fail. * kjs/object.cpp: (KJS::JSObject::call): 2008-05-22 Oliver Hunt Reviewed by Mark. Don't leak the SymbolTable when compiling eval code. * kjs/nodes.cpp: (KJS::EvalNode::generateCode): 2008-05-22 Simon Hausmann 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 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 Reviewed by Oliver. - fixed crash on celtic kane JS benchmark * kjs/nodes.cpp: (KJS::WithNode::emitCode): (KJS::TryNode::emitCode): 2008-05-21 Kevin McCullough Reviewed by Maciej and Geoff. 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 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 Reviewed by Oliver and Sam. - fixed 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 Sadness :( * kjs/config.h: 2008-05-21 Kevin McCullough Reviewed by Maciej. 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 GTK+/UNIX testkjs build fix. Include signal.h. * kjs/testkjs.cpp: 2008-05-21 Oliver Hunt Yet more windows build fixes * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: 2008-05-21 Oliver Hunt Yet more windows build fixes * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: 2008-05-21 Alp Toker GTK+ build fix. Add DebuggerCallFrame.cpp and take AllInOneFile.cpp changes into account. * GNUmakefile.am: 2008-05-21 Oliver Hunt Add DebuggerCallFrame.{h,cpp} to the project file * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: 2008-05-21 Alp Toker GTK+ port build fixes following squirrelfish merge r33979. * GNUmakefile.am: 2008-05-21 Maciej Stachowiak 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 Rubber-stamped by Maciej. Replace non-standard #pragma marks with comments to avoid compiler warnings. * profiler/ProfileNode.cpp: 2008-05-21 Geoffrey Garen 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 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 Reviewed by Maciej. Bug 19116: SquirrelFish shouldn't regress on variable lookups 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 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 Reviewed by Maciej. Bug 19116: SquirrelFish shouldn't regress on variable lookups 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 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 Reviewed by Maciej. Bug 19116: SquirrelFish shouldn't regress on variable lookups 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 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 Reviewed by Geoff. Bug 19110: SquirrelFish: Google Maps - no maps 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 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 Reviewed by Maciej. Bug 18752: SQUIRRELFISH: exceptions are not always handled by the vm 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 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 Reviewed by Oliver. Bug 18991: SquirrelFish: Major codegen issue in a.b=expr, a[b]=expr Fix the last remaining blocking cases of this bug. * kjs/grammar.y: * kjs/nodes.cpp: (KJS::ReadModifyResolveNode::emitCode): 2008-05-17 Cameron Zwarich Reviewed by Oliver. Partial fix for: Bug 18991: SquirrelFish: Major codegen issue in a.b=expr, a[b]=expr 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 Reviewed by Maciej. Bug 19106: SquirrelFish: Activation is not marked correctly 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 Reviewed by Geoff. Bug 19076: SquirrelFish: RegisterFile can be corrupted if implictly reenter global scope with no declared vars 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 Reviewed by Oliver Hunt. Bug 19098: SquirrelFish: Ref'd temporaries can be clobbered 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 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 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 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 Reviewed by Maciej. Bug 19024: SQUIRRELFISH: ASSERTION FAILED: activation->isActivationObject() in Machine::unwindCallFrame 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 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 Reviewed by Geoff. Bug 19025: SQUIRRELFISH: malformed syntax in onload handler causes crash Simple fix -- move the use of functionBodyNode to after the null check. * kjs/function_object.cpp: (KJS::FunctionObjectImp::construct): 2008-05-13 Geoffrey Garen 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 Reviewed by Geoff. Bug 19027: SquirrelFish: Incorrect codegen for pre-increment 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 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 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 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 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 Reviewed by Darin. Bug 18752: SQUIRRELFISH: exceptions are not always handled by the vm 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 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 Reviewed by Geoff. Bug 18752: SQUIRRELFISH: exceptions are not always handled by the vm 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 Reviewed by Geoff. Bug 18934: SQUIRRELFISH: ASSERT @ nytimes.com due to RegisterFile being clobbered 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 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 Reviewed by Oliver. Bug 18961: SQUIRRELFISH: Gmail doesn't load 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 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 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 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 Debug build fix * kjs/JSGlobalObject.cpp: (KJS::JSGlobalObject::restoreLocalStorage): 2008-05-09 Oliver Hunt 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 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 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 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 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 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 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 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 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 Reviewed by Geoff. Fix call frame set up for native -> JS function calls. * VM/Machine.cpp: (KJS::Machine::execute): 2008-05-05 Geoffrey Garen 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 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 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 Reviewed by Oliver. Bug 18749: SQUIRRELFISH: const support is broken 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 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 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 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 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 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 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 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 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 Reviewed by Sam. - fix accidental breakage from last patch * VM/Machine.cpp: (KJS::Machine::privateExecute): 2008-05-03 Maciej Stachowiak 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 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 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 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 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 Reviewed by Maciej. Bug 18864: SquirrelFish: Support getter and setter definition in object literals 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 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 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 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 Reviewed by Geoff and Maciej. Bug 18827: SquirrelFish: Prevent getters and setters from destroying the current RegisterFile 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 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 Reviewed by Maciej. Bug 18827: SquirrelFish: Prevent getters and setters from destroying the current RegisterFile 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 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 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 Fixed tyop. * kjs/ExecState.h: 2008-04-30 Geoffrey Garen Debug build fix: export a missing symbol. * JavaScriptCore.exp: 2008-04-30 Geoffrey Garen 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 WebCore build fix: forward-declare ScopeChain. * kjs/interpreter.h: 2008-04-30 Geoffrey Garen Build fix for JavaScriptGlue: export a missing symbol. * JavaScriptCore.exp: 2008-04-30 Geoffrey Garen 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 Reviewed by Maciej. Bug 18643: SQUIRRELFISH: need to support implicit function calls (valueOf, toString, getters/setters) 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 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 Reviewed by Geoff. Restore base pointer when popping a global RegisterFile * VM/RegisterFileStack.cpp: (KJS::RegisterFileStack::popGlobalRegisterFile): 2008-04-28 Oliver Hunt Reviewed by Geoff. Bug 18643: SQUIRRELFISH: need to support implicit function calls (valueOf, toString, getters/setters) 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 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 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 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 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 Reviewed by Maciej. Bug 18746: SQUIRRELFISH: indirect eval used when direct eval should be used 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 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 Reviewed by Maciej. Bug 18628: SQUIRRELFISH: need to support recursion limit 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 Reviewed by Geoff. Bug 18628: SQUIRRELFISH: need to support recursion limit 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 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 Reviewed by Maciej. Bug 18736: SQUIRRELFISH: switch statements with no default have incorrect codegen 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 Reviewed by Maciej. Bug 18628: SQUIRRELFISH: need to support recursion limit More bounds checking. * VM/Machine.cpp: (KJS::Machine::execute): * VM/RegisterFile.cpp: (KJS::RegisterFile::growBuffer): * VM/RegisterFile.h: 2008-04-25 Maciej Stachowiak 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 Reviewed by Maciej. Bug 18732: SQUIRRELFISH: exceptions thrown by native constructors are ignored Fixes another regression test. * VM/Machine.cpp: (KJS::Machine::privateExecute): 2008-04-25 Cameron Zwarich Reviewed by Maciej. Bug 18728: SQUIRRELFISH: invalid regular expression constants should throw exceptions Fixes another regression test. * kjs/nodes.cpp: (KJS::RegExpNode::emitCode): 2008-04-24 Cameron Zwarich Reviewed by Geoffrey Garen. Bug 18735: SQUIRRELFISH: closures are sometimes given an incorrect 'this' value when called 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 Reviewed by Oliver Hunt. Added support for arguments.callee. 2008-04-24 Oliver Hunt Reviewed by Maciej. Bug 18628: SQUIRRELFISH: need to support recursion limit 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 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 Reviewed by Oliver. Bug 18717: SQUIRRELFISH: eval returns the wrong value for a variable declaration statement 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 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 Reviewed by Geoffrey Garen. Bug 18716: SQUIRRELFISH: typeof should return undefined for an undefined variable reference This fixes 2 more regression tests. * kjs/nodes.cpp: (KJS::TypeOfResolveNode::emitCode): 2008-04-24 Geoffrey Garen 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 Reviewed by Maciej. Bug 18707: SQUIRRELFISH: eval always performs toString() on its argument This fixes 4 more regression tests. * VM/Machine.cpp: (KJS::eval): 2008-04-23 Maciej Stachowiak 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 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 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 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 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 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 Reviewed by Geoff. Bug 18672: SQUIRRELFISH: codegen fails with a large number of temporaries Add a SegmentedVector type, which provides a Vector 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 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 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 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 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 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 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 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 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 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 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 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 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 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 Reviewed by Geoff. Bug 18649: SQUIRRELFISH: correctly handle exceptions in eval code 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 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 Reviewed by Maciej. Bug 18671: SquirrelFish: continue inside switch fails * VM/CodeGenerator.cpp: (KJS::CodeGenerator::jumpContextForLabel): * VM/CodeGenerator.h: * kjs/nodes.cpp: (KJS::ContinueNode::emitCode): 2008-04-21 Geoffrey Garen 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 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 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 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 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 Fix debug build * kjs/nodes.cpp: (KJS::ConstDeclNode::evaluateSingle): 2008-04-21 Cameron Zwarich Reviewed by Oliver. Bug 18664: SQUIRRELFISH: correctly throw a SyntaxError when parsing of eval code fails Correctly throw a SyntaxError when parsing of eval code fails. * VM/Machine.cpp: (KJS::eval): 2008-04-21 Oliver Hunt 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 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 Reviewed by Maciej Stachowiak. Removed support for empty ScopeChains. SunSpider reports no change. 2008-04-21 Geoffrey Garen Reviewed by Maciej Stachowiak. Removed some completely unused ScopeChain member functions. SunSpider reports no change. 2008-04-21 Geoffrey Garen Reviewed by Maciej Stachowiak. Avoid creating unnecessary ScopeChain objects, to reduce refcount churn. SunSpider reports no change. 2008-04-21 Maciej Stachowiak Rubber stamped by Alexey. Add some braces.x * kjs/testkjs.cpp: (runWithScripts): 2008-04-21 Maciej Stachowiak 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 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 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 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 Reviewed by Maciej. Bug 18642: Iterator context may get placed into the return register, leading to much badness 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 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 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 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 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 Reviewed by Maciej. Bug 18619: Support continue, break, and return in try .. finally blocks 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 Rubber-stamped by Oliver Hunt. Remove unnecessary files from testkjs, testapi and minidom targets. * JavaScriptCore.xcodeproj/project.pbxproj: 2008-04-17 Geoffrey Garen 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 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 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 and Cameron Zwarich 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 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 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 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 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 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 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 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 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 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 Reviewed by Maciej. Bug 18526: Throw exceptions when resolve fails for op_resolve_base_and_func. 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 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 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 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 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 Reviewed by Maciej. Bug 18436: Need to throw exception on read/modify/write or similar resolve for nonexistent property 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 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 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 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 Reviewed and slightly tweaked by Geoffrey Garen. Bug 18489: Squirrelfish doesn't build on linux * 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 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 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 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 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 Reviewed by Maciej. Bug 18231: Improve support for function call nodes in SquirrelFish 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 This time for sure. * kjs/interpreter.cpp: (KJS::Interpreter::evaluate): 2008-04-10 Geoffrey Garen 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 Reviewed by Geoff. Bug 18338: Support exceptions in SquirrelFish 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 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 Reviewed by Oliver Hunt. Implement codegen for ReadModifyDotNode. * kjs/nodes.cpp: (KJS::ReadModifyDotNode::emitCode): * kjs/nodes.h: 2008-04-06 Sam Weinig 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 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 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 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 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 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 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 Reviewed by Sam. - fix crash in codegen from new nodes * VM/CodeGenerator.cpp: (KJS::CodeGenerator::emitConstruct): * kjs/nodes.h: 2008-04-03 Maciej Stachowiak Reviewed by Geoff. * kjs/nodes.cpp: (KJS::ReadModifyResolveNode::emitCode): (KJS::ReadModifyBracketNode::emitCode): * kjs/nodes.h: 2008-04-02 Maciej Stachowiak 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 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 Rubber stamped by Geoff - fix Release build * kjs/nodes.cpp: (KJS::getNonLocalSymbol): 2008-04-02 Geoffrey Garen 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 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 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 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 Reviewed by Oliver. Bug 18274: ResolveNode::emitCode() doesn't make a new temporary when dst is 0, leading to incorrect codegen * kjs/nodes.cpp: (KJS::FunctionCallBracketNode::emitCode): (KJS::FunctionCallDotNode::emitCode): 2008-04-01 Maciej Stachowiak 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 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 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 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 Reviewed by Oliver. - generate call for PostIncDotNode * kjs/nodes.cpp: (KJS::PostIncDotNode::emitCode): * kjs/nodes.h: 2008-04-01 Maciej Stachowiak Build fix. - fix build (not sure how this ever worked?) * kjs/nodes.cpp: (KJS::FunctionCallBracketNode::emitCode): 2008-04-01 Maciej Stachowiak Reviewed by Geoff. - generate code for FunctionCallBracketNode * kjs/nodes.cpp: (KJS::FunctionCallBracketNode::emitCode): * kjs/nodes.h: 2008-04-01 Maciej Stachowiak 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 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 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 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 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 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 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 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 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 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 Reviewed by Maciej Stachowiak. Added op_post_dec. 2008-03-31 Cameron Zwarich Reviewed by Geoffrey Garen. Add support for FunctionCallDotNode. * kjs/nodes.cpp: (KJS::FunctionCallDotNode::emitCode): * kjs/nodes.h: 2008-03-31 Geoffrey Garen 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 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 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 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 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 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 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 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 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 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 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 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 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 Reviewed by Maciej. Add support for FunctionCallValueNode. * kjs/nodes.cpp: (KJS::FunctionCallValueNode::emitCode): * kjs/nodes.h: 2008-03-31 Maciej Stachowiak 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 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 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 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 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 Reviewed by Sam. Implement CommaNode. * kjs/nodes.cpp: (KJS::CommaNode::emitCode): * kjs/nodes.h: 2008-03-30 Cameron Zwarich 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 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 Reviewed by Maciej. Bug 18204: SquirrelFish: continue/break do not correctly handle scope popping 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 Reviewed by Geoffrey Garen. Add emitCode support for ConditionalNode. * kjs/nodes.cpp: (KJS::ConditionalNode::emitCode): * kjs/nodes.h: 2008-03-28 Geoffrey Garen 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 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 Reviewed by Geoff. Bug 18192: Squirrelfish needs support for break and continue 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 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 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 Clean up code and debug output. * VM/CodeBlock.cpp: (KJS::CodeBlock::dump): * VM/Machine.cpp: (KJS::Machine::privateExecute): 2008-03-27 Geoffrey Garen Moved an ASSERT to a more logical place. * VM/Machine.cpp: (KJS::Machine::privateExecute): 2008-03-27 Sam Weinig 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 Reviewed by Maciej. Bug 18142: squirrelfish needs to support dynamic scoping/with 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 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 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 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 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 Reviewed by Oliver Hunt. Moved a few files around in the XCode project. * JavaScriptCore.xcodeproj/project.pbxproj: 2008-03-26 Geoffrey Garen 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 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 Reviewed by Geoff Garen. Bug 18059: squirrelfish needs to compile on platforms without computed goto "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 Moved my notes from nodes.h to the wiki. * kjs/nodes.h: 2008-03-24 Geoffrey Garen 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 - 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 Reviewed by Anders. - fix 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 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. 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 Reviewed by Darin. 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 Reviewed by Tim. 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 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 Reviewed by Darin. 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 Reviewed by Adam. 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 Reviewed by Tim. 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 Accidentally turned on the profiler. * kjs/config.h: 2008-05-20 Kevin McCullough Reviewed by Tim. 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 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 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 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 Reviewed by Tim. 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 Reviewed by Adam. 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 Rubberstamped by Geoff. Turn off the profiler because it is a performance regression. * kjs/config.h: 2008-05-19 Alp Toker 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 Reviewed by Tim. 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 Reviewed by Tim. 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 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 - Build fix. * JavaScriptCore.exp: 2008-05-15 Kevin McCullough Reviewed by Tim. 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 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 Reviewed by Tim. JavaScript profiler (10928) - Turn on the profiler. * kjs/config.h: 2008-05-14 Kevin McCullough Reviewed by Tim. JavaScript profiler (10928) - Expose the new profiler functions to the WebInspector. * JavaScriptCore.exp: 2008-05-14 Kevin McCullough Giving credit where credit is due. * ChangeLog: 2008-05-14 Kevin McCullough Reviewed by Geoff and Sam. 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 Reviewed by Sam. 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 Reviewed by John. 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 Reviewed by Darin. REGRESSION: A script fails because of a straw BOM character in it. 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 Not reviewed, build fix. * kjs/date_object.cpp: (KJS::DateObjectFuncImp::callAsFunction): 2008-05-13 Anders Carlsson Reviewed by Sam. 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 Giving credit where credit is due. * ChangeLog: 2008-05-13 Kevin McCullough Reviewed by Adam and Geoff. 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 Reviewed by Sam. 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 Reviewed by Geoffrey Garen. 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 Reviewed by Tim Hatcher. 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 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 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 Qt & wx build fix. * JavaScriptCore.pri: Add profiler/Profile.cpp. * JavaScriptCoreSources.bkl: Ditto. 2008-05-10 Jan Michael Alonzo Reviewed by Maciej. Gtk+ build fix * GNUmakefile.am: Add Profile.cpp in _sources 2008-05-09 Brady Eidson 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 Reviewed by Tim. - 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 Reviewed by Mark. Enable NPAPI plug-ins on 64-bit. * wtf/Platform.h: 2008-05-07 Julien Chaffraix 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 Reviewed by Simon. Support for isMainThread in the Qt port. * wtf/ThreadingQt.cpp: (WTF::initializeThreading): Adjusted. (WTF::isMainThread): Added. 2008-05-05 Darin Adler 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 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 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 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 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 Reviewed by Maciej Stachowiak. - Mac build fix * wtf/StrHash.h: Added header guards and removed #include "config.h". 2008-05-01 Ada Chan #include in identifier.cpp. Reviewed by Maciej. * kjs/identifier.cpp: 2008-05-01 Steve Falkenburg Build fix. * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: 2008-05-01 Sam Weinig Fix build. * JavaScriptCore.xcodeproj/project.pbxproj: 2008-05-01 Kevin McCullough Reviewed by Darin. 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 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 Reviewed by Darin. Wrapped Dashboard code with ENABLE(DASHBOARD_SUPPORT) * wtf/Platform.h: 2008-04-29 Kevin McCullough Reviewed by Geoff. - 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 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 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 Reviewed by Darin. Fix run-webkit-tests --threading and provisionally fix 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 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 into PtrHash>. * 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 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 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 Reviewed by Maciej. - fix 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::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 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 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 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 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 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 Reviewed by Adam and Sam. - 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 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 Reviewed by Anders. - simplify use of HashTraits to prepare for some upcoming hash table changes * kjs/SymbolTable.h: Made SymbolTableIndexHashTraits derive from HashTraits and specialize only the empty value. 2008-04-23 Holger Hans Peter Freyther 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 Reviewed by Adam. 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 Reviewed by Darin. Move collector main thread initialization from WebKit/win to KJS::initializeThreading. * kjs/InitializeThreading.cpp: (KJS::initializeThreading): 2008-04-21 Adam Roben 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 Reviewed by Lars. Made convertValueToQVariant accessible from within WebKit/qt/Api * bindings/qt/qt_runtime.h: 2008-04-21 Holger Hans Peter Freyther 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 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 Reviewed by Alp Toker. Don't build testkjs with rpath. * GNUmakefile.am: 2008-04-18 Kevin Ollivier 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 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 * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Windows build fix. 2008-04-11 Mark Rowe 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 Reviewed by Sam. - 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 Reviewed by Sam and Adam. - 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 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 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 Build fix for gcc 4.3. Include stdio.h for printf. * profiler/FunctionCallProfile.cpp: * profiler/Profiler.cpp: 2008-04-17 Jon Honeycutt Reviewed by mrowe. * wtf/Platform.h: Add HAVE_ACCESSIBILITY to Platform.h. 2008-04-17 Alexey Proskuryakov 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 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 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 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 Reviewed by Sam and Geoff. - 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 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 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 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 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 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 Unreviewed build fix for gcc. ::msToGregorianDateTime is not known to it. * kjs/date_object.cpp: (KJS::DateInstance::msToGregorianDateTime): 2008-04-16 Alexey Proskuryakov 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 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 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 Reviewed by Adam. Add ENABLE_OFFLINE_WEB_APPLICATIONS to FEATURE_DEFINES. * Configurations/JavaScriptCore.xcconfig: 2008-04-15 Andre Poenitz 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 Reviewed by Adam. Don't leak the prototype class. * API/JSClassRef.cpp: (OpaqueJSClass::create): 2008-04-14 Steve Falkenburg Fix build. * wtf/ThreadingWin.cpp: 2008-04-14 Alexey Proskuryakov 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 Touched a file to make JavaScriptCore.vcproj rebuild. * wtf/MathExtras.h: 2008-04-14 Adam Roben 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 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 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 Windows build fix. * kjs/grammar.y: 2008-04-11 Alexey Proskuryakov 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 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 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 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 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 VC++ Express build fix * JavaScriptCore.vcproj/testkjs/testkjs.vcproj: Link against user32.lib. 2008-04-09 Adam Roben Build fix * JavaScriptCore.exp: Export isMainThread. 2008-04-09 Adam Roben Build fix * wtf/AlwaysInline.h: Make sure to #include Platform.h before using the macros it defines. 2008-04-08 Mark Rowe Export WTF::initializeThreading() from JavaScriptCore. * JavaScriptCore.exp: 2008-04-04 Sam Weinig 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 Encourage Windows to rebuild - AGAIN... * kjs/DateMath.cpp: 2008-04-08 Adam Roben Mac build fix * JavaScriptCore.exp: Add callOnMainThread, and sorted the list. 2008-04-08 Brady Eidson 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 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 Add "ENABLE_DOM_STORAGE" to keep in sync with the rest of the project * Configurations/JavaScriptCore.xcconfig: 2008-04-07 Adam Roben Windows build fix * wtf/ThreadingWin.cpp: Back out some changes I didn't mean to land. 2008-04-07 Adam Roben 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 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 Reviewed by Oliver Hunt. Ensure that debug symbols are generated for x86_64 and ppc64 builds. * Configurations/Base.xcconfig: 2008-04-01 Christian Dywan Build fix for GCC 4.3. * wtf/unicode/icu/CollatorICU.cpp: include string.h 2008-04-01 Alexey Proskuryakov 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 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 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 Reviewed by Oliver Hunt. 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 Reviewed by Geoff. Bug 17924: Crash in KJS::ConstDeclNode::evaluate with |with| and |const| 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 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 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 Reviewed by Mark Rowe. 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 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 Fix Bug 18060: Assertion failure (JSLock not held) beneath JSCallbackObject::toString Reviewed by Geoff Garen. Bug fix: * API/JSCallbackObjectFunctions.h: (KJS::JSCallbackObject::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 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 Force JSC headers to be copied by touching a file * kjs/array_instance.cpp: (KJS::ArrayInstance::getPropertyNames): 2008-03-26 Adam Roben 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 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 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 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 Fix Bug 18077: Integrate testapi.c into the Windows build Reviewed by Steve Falkenburg. * JavaScriptCore.vcproj/testapi/testapi.vcproj: Added. 2008-03-25 Adam Roben 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 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 Windows build fix. * kjs/dtoa.cpp: Include stdint.h. 2008-03-25 Alexey Proskuryakov 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 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 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 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 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 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 Webkit does not build on linux powerpc Reviewed by David Kilzer. * wtf/TCSpinLock.h: (TCMalloc_SpinLock::Unlock): 2008-03-21 Rodney Dawes 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 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 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 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 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 - fix build * JavaScriptCore.xcodeproj/project.pbxproj: install Activation.h as private 2008-03-20 Maciej Stachowiak 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 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 Reviewed by Sam Weinig. Fix release build. * kjs/JSGlobalObject.cpp: Add missing #include. 2008-03-19 Sam Weinig Reviewed by Anders Carlsson. Fix for 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 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 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 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 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 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 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 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 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 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 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 Don't define PLATFORM(MIDDLE_ENDIAN) on little endian ARM. Reviewed by Darin. See . * wtf/Platform.h: Added check for !defined(__ARMEL__) when defining PLATFORM(MIDDLE_ENDIAN). 2008-03-17 Oliver Hunt 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 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 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 PGO build fixes. * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: 2008-03-14 Oliver Hunt 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 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 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 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 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 Reviewed by eseidel. Landed by eseidel. * wtf/FastMalloc.cpp: #include outside of any namespaces. 2008-03-13 Mark Mentovai Reviewed by eseidel. Landed by eseidel. * pcre/pcre_exec.cpp: Fix misnamed variable, allowing -DDEBUG build to succeed. * wtf/ThreadingPthreads.cpp: #include for gettimeofday in non-pch build. 2008-03-13 Steve Falkenburg 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 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 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 Build fix. * JavaScriptCore.vcproj/WTF/WTF.vcproj: 2008-03-12 Alp Toker Another autotools testkjs build fix attempt. * GNUmakefile.am: 2008-03-12 Alp Toker Attempt to fix the autotools testkjs build on systems with non-standard include paths. * GNUmakefile.am: 2008-03-11 Alexey Proskuryakov Reviewed by Darin. 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 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 - Windows build fix * kjs/function.cpp: (KJS::decode): Initialize variable. 2008-03-10 Brent Fulgham 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 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 No review, build fix only. Attempt to fix the windows build? * kjs/ustring.h: change unsigned short to UChar 2008-03-10 Eric Seidel 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 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 Reviewed by Alp Toker. Conditionalise ICU for Unicode in the GTK+ port. * wtf/Platform.h: 2008-03-07 David D. Kilzer 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 Reviewed by Darin Adler. Fixed 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 Build fix. * JavaScriptCore.vcproj/testkjs/testkjs.vcproj: 2008-03-06 Steve Falkenburg Build fix. * JavaScriptCore.vcproj/WTF/WTF.vcproj: 2008-03-06 Alp Toker Fix the build fix in r30845 to support out-of-tree builds. * GNUmakefile.am: 2008-03-06 Steve Falkenburg Build fix. * wtf/ThreadingWin.cpp: (WTF::ThreadCondition::timedWait): 2008-03-06 Darin Adler - another small step towards fixing the Qt build * JavaScriptCore.pri: Remove more references to the now-obsolete bindings directory. 2008-03-06 Darin Adler - 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 Gtk Build fix * wtf/ThreadingGtk.cpp: (WTF::ThreadCondition::timedWait): 2008-03-06 Alexey Proskuryakov 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 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 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 - try to fix the Qt build * JavaScriptCore.pri: Add the wtf/unicode directory. 2008-03-06 Darin Adler - try to fix the GTK build * GNUmakefile.am: Add a -I for the wtf/unicode directory. 2008-03-06 Darin Adler - 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 Reviewed by Darin. 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 Fix the wx build after the bindings move. * JavaScriptCoreSources.bkl: * jscore.bkl: 2008-03-05 Alp Toker GTK+ build fix for breakage introduced in r30800. Track moved bridge sources from JavaScriptCore to WebCore. * GNUmakefile.am: 2008-03-05 Brent Fulgham 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 Reviewed by Alexey and Mark Rowe Fix for - 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 Remove unused header includes from interpreter.cpp. Reviewed by Darin. * kjs/interpreter.cpp: Remove unused header includes. 2008-03-05 Anders Carlsson Reviewed by Sam. Remove bindings/. * bindings: Removed. 2008-03-05 Anders Carlsson Don't build bindings/ anymore. * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: 2008-03-05 Anders Carlsson 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 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 Mac build fix. * JavaScriptCore.exp: Add new symbol to exports file. 2008-03-03 Oliver Hunt Reviewed by Anders. Make ForInNode check for the timeout interrupt * kjs/nodes.cpp: (KJS::ForInNode::execute): 2008-03-02 Brent Fulgham 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 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 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 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 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 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 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 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 Reviewed by Adam. * JavaScriptCore.exp: Sort the contents of this file. 2008-02-25 Adam Roben MSVC build fix * kjs/testkjs.cpp: (functionQuit): Don't add a return statement after exit(0) for MSVC. 2008-02-24 Sam Weinig 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 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 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 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 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 * GNUmakefile.am: Add GLOBALDEPS for testkjs and minidom. 2008-02-23 Darin Adler 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 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::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 Not reviewed, Gtk build fix. * kjs/testkjs.pro: 2008-02-23 Alexey Proskuryakov 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 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 Qt/Wx build fix - this file was still in a wrong namespace, too. * wtf/ThreadingNone.cpp: 2008-02-23 Alexey Proskuryakov More build fixing - fix mismatched braces. * JavaScriptCore.pri: 2008-02-23 Alexey Proskuryakov 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 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 Reviewed by Sam Weinig. Partial fix for 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 Reviewed by Alexey P. 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 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 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 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 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 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 Reviewed by Sam. * wtf/ASCIICType.h: (WTF::toASCIIHexValue): Added. 2008-02-17 Darin Adler * wtf/ListHashSet.h: (WTF::swap): Removed stray return statement. 2008-02-15 Adam Roben Make JavaScriptCore's FEATURE_DEFINES match WebCore's Reviewed by Mark. * Configurations/JavaScriptCore.xcconfig: 2008-02-14 Stephanie Lewis Reviewed by Geoff. Update order files. * JavaScriptCore.order: 2008-02-14 Geoffrey Garen Reviewed by Sam Weinig. Fixed 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 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 , since that's where getpid() comes from. 2008-02-13 Oliver Hunt Reviewed by Alexey P. 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 Reviewed by Brady Eidson. 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 Reviewed by Anders Carlsson. Fixes for: Match Firefox's cross-domain model more accurately by return the built-in version of functions even if they have been overridden 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 Rubber stamped by Eric. * kjs/ExecState.h: (KJS::ExecState::takeException): Added. 2008-02-10 Darin Adler 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 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 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 Reviewed by Maciej. 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 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 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 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 Reviewed by Darin Adler. PLT speedup related to 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 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 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 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 Reviewed by Oliver Hunt. Update versioning to support the mysterious future. * Configurations/Version.xcconfig: Add SYSTEM_VERSION_PREFIX_1060. 2008-02-04 Cameron Zwarich 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/ 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 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 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 Rubber-stamped by Mark Rowe. Remove all trailing whitespace in the GTK+ port and related components. * GNUmakefile.am: 2008-02-02 Darin Adler Reviewed by Geoff Garen. PLT speedup related to 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 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 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 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 Reviewed by Oliver. - fix 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 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 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 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 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 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 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 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 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 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 Build fix. * JavaScriptCore.vcproj/JavaScriptCore.sln: 2008-01-24 Steve Falkenburg Build fix. * JavaScriptCore.vcproj/JavaScriptCoreSubmit.sln: 2008-01-24 Michael Goddard 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 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 Reviewed by Simon. Code style cleanups. Add spaces before/after braces in inline function. * bindings/qt/qt_instance.h: 2008-01-24 Michael Goddard 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 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 Rubber-stamped by Mark Rowe. Remove whitespace after -I in automake include lists. * GNUmakefile.am: 2008-01-23 Michael Goddard Reviewed by Lars Knoll . 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 Reviewed by Darin and Adam. 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 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 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 - Build fix. * kjs/ustring.h: 2008-01-18 Kevin McCullough - Build fix. * kjs/ustring.cpp: * kjs/ustring.h: (KJS::UString::cost): 2008-01-18 Kevin McCullough 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 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 Reviewed by Simon Hausmann . Fix compilation on Win64(2): Implemented currentThreadStackBase on X86-64 on Windows * kjs/collector.cpp: (KJS::Collector::heapAllocate): 2008-01-18 Prasanth Ullattil Reviewed by Simon Hausmann . Fix compilation on Win64(1): Define WTF_PLATFORM_X86_64 correctly on Win64. * wtf/Platform.h: 2008-01-17 Antti Koivisto Fix Windows build. * kjs/regexp_object.cpp: (KJS::regExpProtoFuncToString): 2008-01-16 Sam Weinig 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 Reviewed by Maciej & Darin. Fixes Bug 16868: Gmail crash and Bug 16871: Crash when loading apple.com/startpage 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 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 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 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 Reviewed by Geoffrey Garen. Fix 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 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 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 Reviewed by Beth Dakin. Remove unneeded variable. * kjs/string_object.cpp: (KJS::StringProtoFuncSubstr::callAsFunction): 2008-01-14 Steve Falkenburg 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 * 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 Fix Bug 16871: Crash when loading apple.com/startpage 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 Reviewed by Oliver. - 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 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 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 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 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 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 Reviewed by Mark Rowe. Hide non-public symbols in GTK+/autotools release builds. * GNUmakefile.am: 2008-01-12 Cameron Zwarich 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 - try to fix Qt Windows build * pcre/dftables: Remove reliance on the list form of Perl pipes. 2008-01-12 Darin Adler - 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 Another Windows build fix. * kjs/Activation.h: 2008-01-12 Mark Rowe Attempted Windows build fix. Use struct consistently when forward-declaring ActivationStackNode and StackActivation. * kjs/Activation.h: * kjs/JSGlobalObject.h: 2008-01-12 Cameron Zwarich 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 Reviewed by Oliver Hunt. Fixed 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 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 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 Reviewed by John Sullivan. Fixed some world leak reports: * PLT complains about world leak of 1 JavaScript Interpreter after running cvs-base suite * 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 Silence qmake warning about ctgen lacking input. Rubber-stamped by Alp Toker. * pcre/pcre.pri: 2008-01-10 David Kilzer dftables should be rewritten as a script 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 Reviewed by Darin Adler. - fix http://bugs.webkit.org/show_bug.cgi?id=16782 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 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 Reviewed by Mark. Enable SVG_FONTS by default. * Configurations/JavaScriptCore.xcconfig: 2008-01-07 Darin Adler 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 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::quiet_nan() and std::numeric_limits::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 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 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 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 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 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 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 * API/JSRetainPtr.h: One more file that needed the change below. 2008-01-05 Darin Adler * wtf/OwnPtr.h: OwnPtr needs the same fix as RefPtr below. 2008-01-05 Adam Roben Build fix. Reviewed by Maciej. * wtf/RetainPtr.h: Use PtrType instead of T* because of the RemovePointer magic. 2008-01-05 Darin Adler 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 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 Reviewed by Maciej Stachowiak. Have the two malloc zones print useful diagnostics if their free method are unexpectedly invoked. Due to 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 GTK+ autotools build fix. Terminate empty rules. * GNUmakefile.am: 2008-01-03 Simon Hausmann 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 * 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 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 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 Reviewed and landed by Darin. * kjs/nodes.cpp: (KJS::DoWhileNode::execute): Added a missing return. 2008-01-02 Darin Adler - try to fix Qt build * wtf/unicode/qt4/UnicodeQt4.h: (WTF::Unicode::foldCase): Add some missing const. 2008-01-02 Alice Liu 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 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 Rubber-stamped by Alp Toker. * GNUmakefile.am: Add missing dependency on grammar.y. 2008-01-01 Darin Adler 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 - rolled scope chain optimization out; it was breaking the world 2008-01-01 Darin Adler 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 Reviewed by Geoff. - fix http://bugs.webkit.org/show_bug.cgi?id=16648 REGRESSION (r28165): Yuku.com navigation prints "jsRegExpExecute failed with result -2" 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 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 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 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 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 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 Reviewed by Sam. Remove maxInt/minInt, replacing with std:max/min() * kjs/array_object.cpp: (KJS::ArrayProtoFuncSplice::callAsFunction): * kjs/operations.cpp: * kjs/operations.h: 2007-12-30 Eric Seidel 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 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 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 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 Reviewed by Sam. More small cleanups to toPrecision * kjs/number_object.cpp: (KJS::numberToPrecision): 2007-12-28 Eric Seidel 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 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 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 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 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 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 Fix builds that don't use AllInOneFile.cpp following breakage introduced in r28973. * kjs/grammar.y: 2007-12-24 Maciej Stachowiak 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 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 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 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 - 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 Windows build fix * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Copy npruntime_internal.h to WebKitBuild. 2007-12-20 Eric Seidel 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 Reviewed by Sam. * wtf/OwnPtr.h: (WTF::operator==): Added. (WTF::operator!=): Added. 2007-12-20 Geoffrey Garen 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 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 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 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 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 - 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 - roll out that last change -- it was causing test failures; I'll check it back in after fixing them 2007-12-20 Darin Adler 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 Added Radar number. * kjs/nodes.cpp: (KJS::ProgramNode::processDeclarations): 2007-12-20 Geoffrey Garen Linux build fix: config.h has to come first. * kjs/error_object.cpp: 2007-12-19 Geoffrey Garen 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 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 Make appendToVarDeclarationList static RS=Weinig. * kjs/grammar.y: 2007-12-18 Oliver Hunt 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 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 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 2007-12-18 Mark Rowe Rubber-stamped by Maciej Stachowiak. Remove outdated and non-functioning project files for the Apollo port. * JavaScriptCore.apolloproj: Removed. 2007-12-18 Darin Adler - 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 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 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 - speculative build fix for non-gcc platforms * pcre/pcre_exec.cpp: (match): Remove unused cases from return switch. 2007-12-16 Mark Rowe Speculative build fix for non-Mac platforms. * pcre/pcre_compile.cpp: Include string.h for memset, memmove, etc. 2007-12-16 Darin Adler 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 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 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 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 Reviewed by Darin Adler and Maciej Stachowiak. More refactoring to support global variable optimization. Changed SymbolTable to use RefPtr 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 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 Reviewed by Mark Rowe. Enable the AllInOneFile.cpp optimization for the GTK+ port. * JavaScriptCore.pri: 2007-12-14 Mark Rowe Unreviewed. Remove commented out fprintf's that were for debugging purposes only. * wtf/FastMalloc.cpp: (WTF::TCMalloc_PageHeap::IncrementalScavenge): 2007-12-14 Mark Rowe 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 Build fix for GTK+/Qt and ports that don't use AllInOneFile.cpp. Include UnusedParam.h. * wtf/TCSystemAlloc.cpp: 2007-12-14 Oliver Hunt Reviewed by Stephanie. Fix build on windows * wtf/FastMalloc.cpp: (WTF::TCMalloc_PageHeap::IncrementalScavenge): 2007-12-14 Dan Bernstein - try again to fix the Windows build * wtf/TCSystemAlloc.cpp: (TCMalloc_SystemRelease): 2007-12-14 Dan Bernstein - try to fix the Windows build * wtf/TCSystemAlloc.cpp: (TCMalloc_SystemRelease): 2007-12-14 Mark Rowe 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 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 Reviewed by Darin and Geoff. 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 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 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 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 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 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 * wtf/unicode/qt4/UnicodeQt4.h: Try to fix Qt build by adding U16_IS_SINGLE. 2007-12-10 Darin Adler 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 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 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 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 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 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 Reviewed by Mark Rowe 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 Tiger build fix. * kjs/grammar.y: Use @1 and @0 in place of @$ where Tiger's bison chokes. 2007-12-10 Darin Adler 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 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 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 Reviewed by Sam W. Split the ENABLE_SVG_EXPERIMENTAL_FEATURES flag into separate flags. Fixes Must disable SVG animation Disable SVG filters on Mac to match Windows behavior Minor config changes. * Configurations/JavaScriptCore.xcconfig: * JavaScriptCore.xcodeproj/project.pbxproj: 2007-12-07 Sam Weinig 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 Reviewed by Sam Weinig. Refactored variable access optimization: Removed the assumption that the FunctionBodyNode holds the symbol table. 2007-12-07 Geoffrey Garen Build fix: added #include. * kjs/nodes.cpp: 2007-12-07 Geoffrey Garen Build fix: added #include. * kjs/interpreter.cpp: 2007-12-07 Geoffrey Garen Build fix: added #include. * kjs/grammar.y: 2007-12-07 Geoffrey Garen Build fix: added #include. * kjs/function_object.cpp: 2007-12-07 Geoffrey Garen 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 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 Build fix: added JSVariableObject.cpp to the .pri file. * JavaScriptCore.pri: 2007-12-07 Geoffrey Garen Build fix: added #include. * kjs/function.cpp: 2007-12-07 Steve Falkenburg 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 Build fix: removed stray name qualification. * kjs/function.h: (KJS::ActivationImp::ActivationImp): 2007-12-07 Geoffrey Garen 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 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 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 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 Reviewed by Eric Seidel. - fix http://bugs.webkit.org/show_bug.cgi?id=16321 new RegExp("[\u0097]{4,6}", "gmy") crashes in DEBUG builds 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 Qt Windows build fix. Include the time-related headers in the correct place. * kjs/JSGlobalObject.cpp: * kjs/interpreter.cpp: 2007-12-05 Darin Adler Not reviewed; just undoing a previous commit. - remove earlier incorrect fix for http://bugs.webkit.org/show_bug.cgi?id=16220 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 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 Build fix: added some #includes. * kjs/JSImmediate.cpp: 2007-12-05 Geoffrey Garen Build fix: added some #includes. * kjs/JSGlobalObject.cpp: * kjs/JSImmediate.cpp: 2007-12-05 Geoffrey Garen Build fix: Fixed #include spelling. * kjs/debugger.cpp: 2007-12-05 Geoffrey Garen Build fix: added #include. * kjs/debugger.cpp: 2007-12-05 Geoffrey Garen Build fix: added a forward declaration. * kjs/debugger.h: 2007-12-05 Geoffrey Garen Build fix: added an #include. * kjs/error_object.cpp: 2007-12-05 Geoffrey Garen Build fix: added an #include. * kjs/bool_object.cpp: 2007-12-05 Geoffrey Garen 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 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 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 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 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 Fix gtk build. * wtf/TCSystemAlloc.cpp: 2007-12-03 Oliver Hunt 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 Reviewed by Sam. Make isSafeScript const. * kjs/JSGlobalObject.h: (KJS::JSGlobalObject::isSafeScript): 2007-12-04 Darin Adler Reviewed by Geoff. - fix first part of http://bugs.webkit.org/show_bug.cgi?id=16220 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 Reviewed by Geoff. - fix http://bugs.webkit.org/show_bug.cgi?id=15618 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 - fix a copy-and-paste-o * bindings/npruntime.cpp: (_NPN_GetIntIdentifier): 2007-12-03 Dan Bernstein 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 Reviewed by Mitz. - fix http://bugs.webkit.org/show_bug.cgi?id=15848 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 Build fix: added an #include. * kjs/collector.cpp: 2007-12-02 Geoffrey Garen 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 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 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 Reviewed by Eric. * ChangeLog: * pcre/pcre_compile.cpp: (compile_branch): 2007-11-30 Eric Seidel 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 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 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 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 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 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 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 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 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 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 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 Reviewed by Sam. Comment cleanup * pcre/pcre_exec.cpp: (match): 2007-11-26 Eric Seidel Reviewed by Sam. Further cleanups to calculateCompiledPatternLengthAndFlags * pcre/pcre_compile.cpp: (calculateCompiledPatternLengthAndFlags): * pcre/pcre_internal.h: 2007-11-26 Eric Seidel 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 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 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 Reviewed by Oliver. Deprecate jsRegExpExecute's offset-vector fallback code * pcre/pcre_exec.cpp: (jsRegExpExecute): 2007-11-26 Eric Seidel 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 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 Reviewed by Mitz. Remove branch from return * pcre/pcre_compile.cpp: (compile_branch): * pcre/pcre_exec.cpp: (match): 2007-11-26 Eric Seidel Reviewed by Maciej. Add repeatInformationFromInstructionOffset inline * pcre/pcre_exec.cpp: (repeatInformationFromInstructionOffset): (match): 2007-11-26 Eric Seidel 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 Reviewed by Sam. Make i locally scoped for better code clarity * pcre/pcre_exec.cpp: (match): 2007-11-26 Eric Seidel 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 Reviewed by Sam. Small speedup (0.7%) by simplifying canUseStackBufferForNextFrame() check * pcre/pcre_exec.cpp: (MatchStack::MatchStack): (MatchStack::popCurrentFrame): 2007-11-25 Eric Seidel 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 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 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 Reviewed by Sam. Section off MatchData arguments into args struct * pcre/pcre_exec.cpp: (MatchStack::pushNewFrame): (match): 2007-11-24 Eric Seidel Reviewed by Sam. Remove redundant eptrblock struct * pcre/pcre_exec.cpp: (MatchStack::pushNewFrame): (match): 2007-11-24 Eric Seidel 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 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 Reviewed by Sam. Further cleanup GET/PUT inlines * pcre/pcre_internal.h: (putOpcodeValueAtOffset): (getOpcodeValueAtOffset): (putOpcodeValueAtOffsetAndAdvance): (put2ByteOpcodeValueAtOffset): (get2ByteOpcodeValueAtOffset): (put2ByteOpcodeValueAtOffsetAndAdvance): 2007-11-24 Eric Seidel 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 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 Reviewed by Sam. cleanup _pcre_ucp_othercase * pcre/pcre_ucp_searchfuncs.cpp: (_pcre_ucp_othercase): 2007-11-24 Eric Seidel 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 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 Reviewed by Sam. clean up is_counted_repeat * pcre/pcre_compile.cpp: (is_counted_repeat): 2007-11-24 Eric Seidel Reviewed by Sam. clean up check_escape * pcre/pcre_compile.cpp: (check_escape): 2007-11-24 Eric Seidel Reviewed by Sam. Reformat find_fixedlength * pcre/pcre_compile.cpp: (find_fixedlength): 2007-11-24 Eric Seidel Reviewed by Sam. reformat is_anchored * pcre/pcre_compile.cpp: (is_anchored): 2007-11-24 Eric Seidel 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 Reviewed by Sam. Pass around MatchData objects by reference * pcre/pcre_exec.cpp: (pchars): (match_ref): (match): (jsRegExpExecute): 2007-11-24 Eric Seidel 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 Reviewed by Sam. Clean up find_firstassertedchar * pcre/pcre_compile.cpp: (get_othercase_range): (find_firstassertedchar): (calculateCompiledPatternLengthAndFlags): 2007-11-24 Eric Seidel Reviewed by Tim Hatcher. Pass around CompileData& instead of CompileData* * pcre/pcre_compile.cpp: (compile_branch): (jsRegExpCompile): 2007-11-24 Eric Seidel 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 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 Reviewed by Maciej. clean up formating in compile_branch * pcre/pcre_compile.cpp: (compile_branch): 2007-11-24 Eric Seidel Reviewed by Sam. Fix spacing for read_repeat_counts * pcre/pcre_compile.cpp: (read_repeat_counts): 2007-11-24 Eric Seidel 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 Reviewed by Sam. reformat get_othercase_range * pcre/pcre_compile.cpp: (get_othercase_range): 2007-11-24 Eric Seidel 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 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 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 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 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 Prospective MSVC build fix. Roll back dllexport/dllimport support for now. * API/JSBase.h: 2007-11-27 Alp Toker 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 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 Reviewed by Darin. Add a ValueType typedef. * wtf/Vector.h: 2007-11-26 Darin Adler 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 Reviewed by Kevin McCullough. Fixed 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 GTK+/Qt/Wx build fix for breakage introduced in r28039. * ForwardingHeaders/JavaScriptCore/JSRetainPtr.h: Added. 2007-11-24 Laszlo Gombos 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 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 MSVC7 build fix. (rand_s doesn't exist there) Reviewed by Adam Roben. * kjs/config.h: * wtf/MathExtras.h: 2007-11-23 Kevin Ollivier 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 Reviewed by George Staikos . 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 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 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 Reviewed by Tim Hatcher. 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 (). * 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 wx port build fix (wx headers include ctype functions). * kjs/config.h: 2007-11-19 Kevin Ollivier Remove outdated and unused Windows port files. Reviewed by Adam Roben. * Makefile.vc: Removed. * README-Win32.txt: Removed. 2007-11-18 Eric Seidel Reviewed by Oliver. * tests/mozilla/jsDriver.pl: exit non-0 when user aborts test run 2007-11-17 Mark Rowe Reviewed by Darin Adler. Fix: REGRESSION: testapi exits with assertion failure in debug build 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 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 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 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 Windows build fix. * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: 2007-11-16 Mark Rowe Windows build fix. * kjs/lexer.cpp: (KJS::Lexer::record8): 2007-11-16 Mark Rowe 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&. * kjs/ustring.h: 2007-11-16 Adam Roben 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 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 Gtk build fix. * kjs/Parser.cpp: 2007-11-15 Mark Rowe 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 Qt build fix. * kjs/Parser.h: 2007-11-15 Geoffrey Garen 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 Reviewed by Darin. 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 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 Reviewed by Sam. Remove RETURN_ERROR, add MatchStack * pcre/pcre_exec.cpp: (MatchStack::MatchStack): (MatchStack::unrollAnyHeapAllocatedFrames): (matchError): (match): 2007-11-15 Eric Seidel 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 Windows build fix. * JavaScriptCore.vcproj/JavaScriptCore.make: 2007-11-14 Alexey Proskuryakov 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 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 Reviewed by Oliver. More PCRE style cleanup. * pcre/pcre_compile.cpp: (compile_regex): 2007-11-14 Adam Roben Clean up the bison conflict checking script Reviewed by Geoff. * DerivedSources.make: 2007-11-14 Eric Seidel 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 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 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 Add RefCounted.h (And remove Shared.h) * JavaScriptCore.vcproj/WTF/WTF.vcproj: 2007-11-13 Geoffrey Garen Build fix. * kjs/regexp.h: 2007-11-13 Geoffrey Garen 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 Build fix Reviewed by Geoff. * kjs/regexp.h: Added a missing #include. 2007-11-13 Geoffrey Garen 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 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 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 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 * 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 Build fix for breakage to non-Mac builds introduced in r27746. * kjs/ustring.cpp: 2007-11-13 Eric Seidel 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 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 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 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 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 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 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 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 Build fix * wtf/FastMalloc.h: Add missing using statement. 2007-11-11 Oliver Hunt 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 Fix 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 Build fix. Use the correct filename case. * kjs/nodes.h: 2007-11-11 Geoffrey Garen 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 Reviewed by Eric. Partial fix for 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 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 - 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 * pcre/dftables.pro: Try fixing Qt builds (I looked at qt-win) by adding another include path. 2007-11-11 Darin Adler * JavaScriptCore.xcodeproj/project.pbxproj: Try fixing Mac Tiger builds by adding another include path. 2007-11-11 Darin Adler 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 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 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 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 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 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 Windows build fix Reviewed by Darin. * kjs/value.h: (KJS::jsNumber): Add some explicit casts. 2007-11-08 Darin Adler - fix build * kjs/grammar.y: * kjs/nodes.h: * kjs/property_map.cpp: 2007-11-08 Darin Adler - 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 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 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 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 Bakefiles for building JavaScriptCore, needed by wx port. Reviewed by Mark Rowe. * JavaScriptCoreSources.bkl: Added. * jscore.bkl: Added. 2007-11-08 Oliver Hunt 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 - fix build * kjs/nodes.h: Add missing parameter name. 2007-11-08 Eric Seidel 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 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 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 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 Gtk build fix. * kjs/lookup.h: Add missing include. 2007-11-08 Sam Weinig 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 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 Fix a precedence warning on Windows * kjs/JSImmediate.h: (KJS::JSImmediate::toBoolean): 2007-11-08 Mark Rowe Build fix for JavaScriptGlue. * wtf/MathExtras.h: Include stdlib.h for srand and RAND_MAX. 2007-11-08 Darin Adler - Windows build fix * kjs/JSImmediate.h: Include MathExtras.h rather than math.h since this file uses "signbit". 2007-11-08 Oliver Hunt 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 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 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 Gtk build fix. * kjs/regexp_object.cpp: 2007-11-07 Geoffrey Garen 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 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 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 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 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 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 Reviewed by Maciej. Avoid unnecessarily boxing the result from post inc/decrement for 0.3% gain in sunspider We now convert the common 'for (...; ...; ++) ...' to the semantically identical 'for (...; ...; ++) ...'. * 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 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 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 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 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 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 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 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 Mac build fix. * kjs/array_object.cpp: (KJS::ArrayProtoFunc::callAsFunction): 2007-11-05 Adam Roben Windows build fix * kjs/list.h: 2007-11-05 Mark Rowe Build fix. Add missing #include. * kjs/operations.cpp: 2007-11-05 Eric Seidel 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 * kjs/operations.cpp: (KJS::equal): correct broken change. 2007-11-05 Eric Seidel 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 Gtk build fix. * pcre/pcre.pri: 2007-11-05 Mark Rowe Gtk build fix. * kjs/list.cpp: 2007-11-05 Geoffrey Garen Touched a file to test my new HTTP access. * kjs/scope_chain.cpp: 2007-11-05 Alp Toker 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 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 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 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 * pcre/pcre_exec.c: (match): Try to fix the Windows build by removing unreachable code. 2007-11-03 Darin Adler - 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 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 , 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 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 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 - 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 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 * pcre/pcre_compile.c: (check_escape): Windows build fix. Get rid of C-incompatible declaration. 2007-11-03 Mark Rowe Gtk build fix. * kjs/nodes.cpp: Add missing include. 2007-11-03 Darin Adler Reviewed by Maciej. - fix http://bugs.webkit.org/show_bug.cgi?id=15814 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 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 Sort files(...); sections of Xcode project files. Rubber-stamped by Darin. * JavaScriptCore.xcodeproj/project.pbxproj: 2007-11-03 Maciej Stachowiak 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 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 Reviewed by Oliver. - add SourceElements as a typedef for Vector >. * 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 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 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 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 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 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 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 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 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 Windows build fix * kjs/ExecState.h: 2007-10-31 Maciej Stachowiak 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 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 Reviewed by Sam. - Corrected spelling. * wtf/HashTraits.h: 2007-10-31 Mark Rowe Further Gtk build fixage. * kjs/regexp_object.cpp: 2007-10-31 Mark Rowe Gtk build fix. * kjs/regexp.h: 2007-10-31 Darin Adler 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 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 * kjs/nodes.h: include OwnPtr.h 2007-10-31 Oliver Hunt 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 * 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 * kjs/property_map.cpp: Include HashTable.h the right way to fix the build for non-Mac ports. 2007-10-31 Alexey Proskuryakov 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 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 * 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 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 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 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 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: 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 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 Reviewed by Adam Roben, Sam Weinig. Made conflicts in grammar.y a persistent build failure. * DerivedSources.make: 2007-10-30 Kevin McCullough 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 Reviewed by Darin Adler. Fixed 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 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 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 Not reviewed, build fix. - Include Vector.h in a way that actually works. * kjs/LocalStorage.h: 2007-10-29 Maciej Stachowiak Not reviewed, build fix. - Install LocalStorage.h as a private header. * JavaScriptCore.xcodeproj/project.pbxproj: 2007-10-29 Maciej Stachowiak 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 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 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 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 Build fix only, no review. * JavaScriptCore.exp: Export symbol for new StringInstance::getOwnPropertySlot 2007-10-29 Mark Rowe Gtk build fix. Move struct declarations into nodes.h. * kjs/grammar.y: * kjs/nodes.h: 2007-10-29 Eric Seidel 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 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 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 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 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 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 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 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 - 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 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 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 - 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 Gtk build fix. Add include of MathExtras.h. * kjs/string_object.cpp: 2007-10-28 Mark Rowe 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 Build fix: use the new-fangled missingSymbolMarker(). * kjs/nodes.cpp: (KJS::ResolveNode::optimizeVariableAccess): * kjs/nodes.h: (KJS::LocalVarAccessNode::LocalVarAccessNode): 2007-10-28 Geoffrey Garen 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 Reviewed by Maciej. Fix "AllInOneFile.o has a global initializer in it". Some versions of gcc generate a global initializer for std::numeric_limits::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 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 - fix GTK build * kjs/nodes2string.cpp: (KJS::isParserRoundTripNumber): Use isNaN and isInf instead of isnan and isinf. 2007-10-28 Darin Adler 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 Define wx port and set wx port USE options. Reviewed by Adam Roben. * wtf/Platform.h: 2007-10-28 Mark Rowe 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 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 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 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 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 - BuildFix - Forgot to change the build step when I changed the filename. * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: 2007-10-27 Geoffrey Garen 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 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 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 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 Silence a warning. * kjs/SymbolTable.h: 2007-10-27 Mark Rowe Gtk build fix. * kjs/function.h: 2007-10-26 Kevin McCullough 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 Reviewed by Adam. - Made JSStringCreateWithBSTR capable of handling null BSTRs. * API/JSStringRefCOM.cpp: (JSStringCreateWithBSTR): 2007-10-26 Sam Weinig Windows build fix. * kjs/SymbolTable.h: Add header gaurd. * kjs/nodes.h: #include "SymbolTable.h" 2007-10-26 Geoffrey Garen Suggested by Anders Carlsson. Fixed tyop. * kjs/function.cpp: (KJS::ActivationImp::getOwnPropertySlot): 2007-10-26 Geoffrey Garen 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 Build fix: svn add SymbolTable.h * kjs/SymbolTable.h: Added. (KJS::SymbolTable::set): (KJS::SymbolTable::get): 2007-10-26 Geoffrey Garen Build fix: export SymbolTable.h to WebCore. * JavaScriptCore.xcodeproj/project.pbxproj: 2007-10-26 Geoffrey Garen Comment tweak suggested by Maciej. * kjs/function.cpp: (KJS::ActivationImp::getOwnPropertySlot): 2007-10-26 Geoffrey Garen 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 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 - Corrected function name mistake in this changelog. 2007-10-26 Kevin McCullough 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 Windows build fix. * kjs/collector.cpp: (KJS::Collector::collect): 2007-10-26 Oliver Hunt 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 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 Gtk build fix. * kjs/ExecState.h: 2007-10-26 Maciej Stachowiak 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 Windows build fix. * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: 2007-10-26 Mark Rowe Gtk build fix. * JavaScriptCore.pri: * kjs/ExecState.cpp: 2007-10-26 Maciej Stachowiak 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 Windows build fix. * kjs/string_object.cpp: (KJS::StringObjectFuncImp::callAsFunction): 2007-10-25 Darin Adler 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 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 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 Reviewed by Adam Roben. Remove JSStringRefCFHack from windows as it is no longer needed. * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: 2007-10-25 Geoffrey Garen 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 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 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 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 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 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 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 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 Reviewed by Geoff. * JavaScriptCore.xcodeproj/project.pbxproj: re-mark JSGlobalObject.h as private 2007-10-25 Geoffrey Garen 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 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 Build fix for Gtk, no review. * kjs/collector.cpp: #include "context.h" 2007-10-24 Eric Seidel 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 Gtk build fix. * kjs/identifier.h: Remove extra qualification. 2007-10-24 Geoffrey Garen Reviewed by Sam Weinig. Disable ALWAYS_INLINE in debug builds, since it drives the debugger crazy. * wtf/AlwaysInline.h: 2007-10-24 Geoffrey Garen 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 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 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 Reviewed by darin. * kjs/nodes.h: (KJS::ImmediateNumberNode::): Fix ASSERT correctness (and debug build!) 2007-10-24 Darin Adler 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 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 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 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 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 Reviewed by Maciej. * kjs/JSImmediate.h: (KJS::JSImmediate::getUInt32): Changed an && to an & for a 1% gain in SunSpider. 2007-10-23 Oliver Hunt 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 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 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 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 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 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 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 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 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 Windows build fix * JavaScriptCore.vcproj/JavaScriptCore/JavaScriptCore.vcproj: Turn off warning about implicit conversion to bool. 2007-10-22 Mark Rowe Gtk build fix. * kjs/array_instance.cpp: 2007-10-22 Darin Adler 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 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 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 Reviewed by Simon Hausmann . * 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 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 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 - 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 * kjs/array_object.cpp: (KJS::ArrayInstance::put): Add missing assignment that was causing regression test crash. 2007-10-21 Darin Adler 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 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 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 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 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 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 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 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 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 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 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 PLT on Windows got 2.5% slower between r25406 and r25422 - fixed at least some of Reviewed by Mark Rowe. - fix http://bugs.webkit.org/show_bug.cgi?id=15543 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 Reviewed by Oliver. * wtf/Platform.h: #define USE_PTHREADS on Mac. 2007-10-17 Geoffrey Garen 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 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 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 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 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 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 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 Reviewed by Darin Adler. Global replace of assert with ASSERT. 2007-10-16 Adam Roben 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 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 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 - try to fix the GTK build * kjs/ustring.cpp: Include ASCIICType.h, not ASCIICtype.h. 2007-10-16 Darin Adler - 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 - try to fix the GTK build * kjs/ustring.cpp: Include ASCIICType.h. 2007-10-16 Darin Adler Reviewed by Maciej and Geoff (and looked over by Eric). - http://bugs.webkit.org/show_bug.cgi?id=15519 eliminate use of 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 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 Removed unnecessary #include. * API/JSObjectRef.cpp: 2007-10-15 Geoffrey Garen Double-reverse build fix. My tree was out of date. * kjs/nodes.cpp: (NumberNode::evaluate): 2007-10-15 Geoffrey Garen Build fix. * kjs/nodes.cpp: (NumberNode::evaluate): 2007-10-15 Geoffrey Garen 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 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 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 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 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 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 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 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 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 ==