[PATCH v4 04/10] vbscript: Destroy the entire script context when the script engine is closed.

Jacek Caban jacek at codeweavers.com
Wed Nov 6 10:47:30 CST 2019


Hi Gabriel,


On 11/6/19 12:53 PM, Gabriel Ivăncescu wrote:
> When the engine is closed, even the persistent code is removed.
>
> Signed-off-by: Gabriel Ivăncescu <gabrielopcode at gmail.com>
> ---
>
> Removing the context altogether is necessary when the script context will
> be ref counted, since we can't re-use the existing one. It is also needed
> for script persistence to work properly.
>
> This is required because re-initializng a new context when the old one is
> closed can potentially fail, and decrease_state shouldn't be able to fail.
>
> So instead it is re-initialized on demand, when necessary.


I think I already mentioned it, but it doesn't look right to me. When 
releasing the context you lose safety flags that are stored in the 
context. I'd be very surprised if that's what should happen. You're also 
missing handling of AddNamedItem.

Overall, I fail to see why why we need it. It seems to me that if you go 
from closed to initialized state, you shouldn't use decrease_state at all.

Thanks,
Jacek



More information about the wine-devel mailing list