mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
Bug 694867 - Part b: Pass a JSScript to nsXULPrototypeScript::Set; r=volkmar
This commit is contained in:
parent
6bc6ac23b6
commit
e566d3ad18
@ -3039,7 +3039,8 @@ nsXULPrototypeScript::DeserializeOutOfLine(nsIObjectInputStream* aInput,
|
|||||||
|
|
||||||
if (useXULCache) {
|
if (useXULCache) {
|
||||||
PRUint32 newLangID = nsIProgrammingLanguage::UNKNOWN;
|
PRUint32 newLangID = nsIProgrammingLanguage::UNKNOWN;
|
||||||
void *newScriptObject = cache->GetScript(mSrcURI, &newLangID);
|
JSScript* newScriptObject =
|
||||||
|
static_cast<JSScript*>(cache->GetScript(mSrcURI, &newLangID));
|
||||||
if (newScriptObject) {
|
if (newScriptObject) {
|
||||||
// Things may blow here if we simply change the script
|
// Things may blow here if we simply change the script
|
||||||
// language - other code may already have pre-fetched the
|
// language - other code may already have pre-fetched the
|
||||||
@ -3170,7 +3171,7 @@ nsXULPrototypeScript::UnlinkJSObjects()
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
nsXULPrototypeScript::Set(void *aObject)
|
nsXULPrototypeScript::Set(JSScript* aObject)
|
||||||
{
|
{
|
||||||
NS_ASSERTION(!mScriptObject.mObject, "Leaking script object.");
|
NS_ASSERTION(!mScriptObject.mObject, "Leaking script object.");
|
||||||
if (!aObject) {
|
if (!aObject) {
|
||||||
@ -3184,7 +3185,7 @@ nsXULPrototypeScript::Set(void *aObject)
|
|||||||
&NS_CYCLE_COLLECTION_NAME(nsXULPrototypeNode),
|
&NS_CYCLE_COLLECTION_NAME(nsXULPrototypeNode),
|
||||||
aObject, false);
|
aObject, false);
|
||||||
if (NS_SUCCEEDED(rv)) {
|
if (NS_SUCCEEDED(rv)) {
|
||||||
mScriptObject.mObject = static_cast<JSScript*>(aObject);
|
mScriptObject.mObject = aObject;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -342,9 +342,9 @@ public:
|
|||||||
"Wrong language, this will leak the previous object.");
|
"Wrong language, this will leak the previous object.");
|
||||||
|
|
||||||
mScriptObject.mLangID = aHolder.getScriptTypeID();
|
mScriptObject.mLangID = aHolder.getScriptTypeID();
|
||||||
Set((void*)aHolder);
|
Set(aHolder.getScript());
|
||||||
}
|
}
|
||||||
void Set(void *aObject);
|
void Set(JSScript* aObject);
|
||||||
|
|
||||||
struct ScriptObjectHolder
|
struct ScriptObjectHolder
|
||||||
{
|
{
|
||||||
|
@ -3383,10 +3383,11 @@ nsXULDocument::LoadScript(nsXULPrototypeScript* aScriptProto, bool* aBlock)
|
|||||||
|
|
||||||
if (isChromeDoc && useXULCache) {
|
if (isChromeDoc && useXULCache) {
|
||||||
PRUint32 fetchedLang = nsIProgrammingLanguage::UNKNOWN;
|
PRUint32 fetchedLang = nsIProgrammingLanguage::UNKNOWN;
|
||||||
void *newScriptObject =
|
JSScript* newScriptObject =
|
||||||
nsXULPrototypeCache::GetInstance()->GetScript(
|
static_cast<JSScript*>(
|
||||||
|
nsXULPrototypeCache::GetInstance()->GetScript(
|
||||||
aScriptProto->mSrcURI,
|
aScriptProto->mSrcURI,
|
||||||
&fetchedLang);
|
&fetchedLang));
|
||||||
if (newScriptObject) {
|
if (newScriptObject) {
|
||||||
// The script language for a proto must remain constant - we
|
// The script language for a proto must remain constant - we
|
||||||
// can't just change it for this unexpected language.
|
// can't just change it for this unexpected language.
|
||||||
|
@ -42,6 +42,8 @@
|
|||||||
#include "nsIScriptContext.h"
|
#include "nsIScriptContext.h"
|
||||||
#include "nsIDOMScriptObjectFactory.h"
|
#include "nsIDOMScriptObjectFactory.h"
|
||||||
|
|
||||||
|
#include "jspubtd.h"
|
||||||
|
|
||||||
// A thin class used to help with script object memory management. No virtual
|
// A thin class used to help with script object memory management. No virtual
|
||||||
// functions and a fully inline implementation should keep the cost down.
|
// functions and a fully inline implementation should keep the cost down.
|
||||||
// [Note that a fully inline implementation is necessary for use by other
|
// [Note that a fully inline implementation is necessary for use by other
|
||||||
@ -81,6 +83,9 @@ public:
|
|||||||
operator void *() const {
|
operator void *() const {
|
||||||
return mObject;
|
return mObject;
|
||||||
}
|
}
|
||||||
|
JSScript* getScript() const {
|
||||||
|
return static_cast<JSScript*>(mObject);
|
||||||
|
}
|
||||||
|
|
||||||
// Drop the script object - but *not* the nsIScriptContext.
|
// Drop the script object - but *not* the nsIScriptContext.
|
||||||
nsresult drop() {
|
nsresult drop() {
|
||||||
|
Loading…
Reference in New Issue
Block a user