mirror of
https://gitea.wildfiregames.com/0ad/0ad.git
synced 2026-06-22 03:25:48 +00:00
SpiderMonkey 31 upgrade
This upgrade also introduces exact stack rooting (see to the wiki: JSRootingGuide) and fixes problems with moving GC. This allows us to enable generational garbage collection (GGC). Measurements a few months ago have shown a performance improvement of a non-visual replay of around 13.5%. This probably varies quite a bit, but it should be somewhere between 5-20%. Memory usage has also been improved. Check the forum thread for details. Thanks to everyone from the team who helped with this directly or indirectly (review, finding and fixing issues, the required C++11 upgrade, the new autobuilder etc.)! Also thanks to the SpiderMonkey developers who helped on the #jsapi channel or elsewhere! Fixes #2462, #2415, #2428, #2684, #1374 Refs #2973, #2669 This was SVN commit r16214.
This commit is contained in:
@@ -95,7 +95,7 @@ JSTrapStatus CheckForBreakRequestHandler_(JSContext* cx, JSScript* script, jsbyt
|
||||
}
|
||||
|
||||
CMutex CallHookMutex;
|
||||
static void* CallHook_(JSContext* cx, JSStackFrame* fp, JSBool before, JSBool* UNUSED(ok), void* closure)
|
||||
static void* CallHook_(JSContext* cx, JSStackFrame* fp, bool before, bool* UNUSED(ok), void* closure)
|
||||
{
|
||||
CScopeLock lock(CallHookMutex);
|
||||
CThreadDebugger* pThreadDebugger = (CThreadDebugger*) closure;
|
||||
@@ -673,7 +673,7 @@ void CThreadDebugger::SaveCallstack()
|
||||
functionID = JS_NewStringCopyZ(m->m_pScriptInterface->GetContext(), "anonymous");
|
||||
}
|
||||
|
||||
JSBool ret = JS_DefineElement(m->m_pScriptInterface->GetContext(), jsArray, counter, STRING_TO_JSVAL(functionID), NULL, NULL, 0);
|
||||
bool ret = JS_DefineElement(m->m_pScriptInterface->GetContext(), jsArray, counter, STRING_TO_JSVAL(functionID), NULL, NULL, 0);
|
||||
ENSURE(ret);
|
||||
fp = JS_FrameIterator(m->m_pScriptInterface->GetContext(), &iter);
|
||||
counter++;
|
||||
@@ -785,20 +785,20 @@ namespace CyclicRefWorkaround
|
||||
|
||||
struct Stringifier
|
||||
{
|
||||
static JSBool callback(const jschar* buf, uint32 len, void* data)
|
||||
static bool callback(const jschar* buf, uint32 len, void* data)
|
||||
{
|
||||
utf16string str(buf, buf+len);
|
||||
std::wstring strw(str.begin(), str.end());
|
||||
|
||||
Status err; // ignore Unicode errors
|
||||
static_cast<Stringifier*>(data)->stream << utf8_from_wstring(strw, &err);
|
||||
return JS_TRUE;
|
||||
return true;
|
||||
}
|
||||
|
||||
std::stringstream stream;
|
||||
};
|
||||
|
||||
JSBool replacer(JSContext* cx, uintN UNUSED(argc), jsval* vp)
|
||||
bool replacer(JSContext* cx, uintN UNUSED(argc), jsval* vp)
|
||||
{
|
||||
jsval value = JS_ARGV(cx, vp)[1];
|
||||
jsval key = JS_ARGV(cx, vp)[0];
|
||||
@@ -824,14 +824,14 @@ namespace CyclicRefWorkaround
|
||||
JS_SET_RVAL(cx, vp, ret);
|
||||
g_LastKey = key;
|
||||
g_LastValue = value;
|
||||
return JS_TRUE;
|
||||
return true;
|
||||
}
|
||||
}
|
||||
g_LastKey = key;
|
||||
g_LastValue = value;
|
||||
g_RecursionDetectedInPrevReplacer = false;
|
||||
JS_SET_RVAL(cx, vp, JS_ARGV(cx, vp)[1]);
|
||||
return JS_TRUE;
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user