mirror of
https://github.com/zeek/zeek.git
synced 2025-10-07 09:08:20 +00:00
Fix reference counting issues related to lambdas/closures
For example, circular references between a lambda function the frame it's stored within and/or its closure could cause memory leaks. This also fixes other various reference-count ownership issues that could lead to memory errors. There may still be some potential/undiscovered issues because the "outer ID" finding logic doesn't look quite right as the AST traversal descends within nested lambdas and considers their locals as "outer", but possibly the other logic for locating values in closures or cloning closures just works around that behavior.
This commit is contained in:
parent
0fe2a14d98
commit
44d922c4b5
11 changed files with 283 additions and 78 deletions
|
@ -120,7 +120,12 @@ Val* Val::DoClone(CloneState* state)
|
|||
// Derived classes are responsible for this. Exception:
|
||||
// Functions and files. There aren't any derived classes.
|
||||
if ( type->Tag() == TYPE_FUNC )
|
||||
return new Val(AsFunc()->DoClone());
|
||||
{
|
||||
auto c = AsFunc()->DoClone();
|
||||
auto rval = new Val(c);
|
||||
Unref(c);
|
||||
return rval;
|
||||
}
|
||||
|
||||
if ( type->Tag() == TYPE_FILE )
|
||||
{
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue