[PATCH 5/5] jscript: Clear the CODEONLY flag for persistent items when the script is reinitialized.

Gabriel Ivăncescu gabrielopcode at gmail.com
Tue Mar 24 08:59:04 CDT 2020


On 24/03/2020 02:34, Jacek Caban wrote:
> Hi Gabriel,
> 
> On 23.03.2020 14:53, Gabriel Ivăncescu wrote:
>> diff --git a/dlls/jscript/jscript.c b/dlls/jscript/jscript.c
>> index 3fcaab0..eb328d2 100644
>> --- a/dlls/jscript/jscript.c
>> +++ b/dlls/jscript/jscript.c
>> @@ -757,6 +757,9 @@ static HRESULT WINAPI 
>> JScript_SetScriptSite(IActiveScript *iface,
>>               hres = retrieve_named_item_disp(pass, item);
>>               if(FAILED(hres)) return hres;
>>           }
>> +
>> +        /* For some reason, Windows clears the CODEONLY flag */
>> +        item->flags &= ~SCRIPTITEM_CODEONLY;
> 
> 
> This clearly shows that we're still not interpreting those flags 
> correctly and this patch just tries to hide the problem. I think we 
> simply shouldn't depend on the flag but rather on item->disp being set. 
> See the attached patch (on top of your patches). It solves some of test 
> failures that you observed. The remaining problem is that we still store 
> IDispatch for visible items. The attached test shows that we probably 
> shouldn't.
> 
> 

I'm not sure if that's going to work. We have tests covering a lot of 
stuff already; if we change some of it, then some of the tests will 
fail. If we don't store disp for visible items, so we can pass the new 
test, then the test at line 1360 will fail.

There's also the test at line 1383. Which is same as line 1360, except 
that it also has the CODEONLY flag (its "disp" was still retrieved 
earlier, though). In that case, the disp is not used.

Both of them have the VISIBLE flag -- and yet only the former one 
accesses its disp. I don't know how to solve this situation without 
checking the flags.



More information about the wine-devel mailing list