Closed Bug 475629 Opened 16 years ago Closed 14 years ago

Crash due to too much recursion with XPCConvert::JSArray2Native

Categories

(Core :: XPConnect, defect)

x86
All
defect
Not set
critical

Tracking

()

RESOLVED DUPLICATE of bug 582649

People

(Reporter: jruderman, Unassigned)

Details

(Keywords: crash, testcase)

Attachments

(1 file)

Attached file testcase
... 23 XPCConvert::JSArray2Native 24 XPCVariant::InitializeData 25 XPCVariant::newVariant 26 XPCConvert::JSData2Native 27 XPCConvert::JSArray2Native ...
Flags: wanted1.9.2?
Flags: wanted1.9.0.x?
OS: Mac OS X → All
i think that what should happen is that xpconnect should register the original variant in its map and before it converts the next variant it encounters it should see if the variant is already in the map and if it is, it should just grab it right now, it's just treating each variant it encounters as something it has to marshall from scratch i think that might mean using nsXPCWrappedJS::GetNewOrUsed instead of XPCVariant::newVariant
I think it's a little more complex than that. In a = []; a[0] = a; We haven't created the native for "a" yet, so we can't populate element 0. Ideally we need to assign element 0 after the array is built. I wonder if we unrolled the recursion that exists in JS to native conversion. Not sure if that would help or not.
Also was thinking of a way to maybe prevent this or hack something together to address it for the a = []; a[0] = a; case. But there are more tricky cases such as: var a = []; var b = []; a[0] = b; b[0] = a;
well, i think we should basically create a basic object and register it immediately such that when we start looking for objects we have a chance to find them. Rough outline: 133 XPCVariant* XPCVariant::newVariant(XPCCallContext& ccx, jsval aJSVal) 144 NS_ADDREF(variant); + TIE_JSVAL_TO_XPCONNECT(aJSVal, variant); /* register immediately */ 146 if(!variant->InitializeData(ccx)) /* the array is populated here */ 495 XPCConvert::JSData2Native(XPCCallContext& ccx, void* d, jsval s, 961 case nsXPTType::T_INTERFACE_IS: 966 if(iid->Equals(NS_GET_IID(nsIVariant))) -968 XPCVariant* variant = XPCVariant::newVariant(ccx, s); +XPCVariant* variant = nsnull; +SOMETHING* wrapper = nsnull; +nsXPCWrappedJS::GetUsedOnly(ccx, iid, s, &wrapper); /* look for objects */ +if (wrapper) { + getVariantFromWrapper(wrapper, &variant); +} +if (!variant) { + variant = XPCVariant::newVariant(ccx, s); +} Sadly, nsXPCWrappedJS::GetUsedOnly doesn't exist.
Status: NEW → RESOLVED
Closed: 14 years ago
Resolution: --- → DUPLICATE
You need to log in before you can comment on or make changes to this bug.

Attachment

General

Creator:
Created:
Updated:
Size: