[prev in list] [next in list] [prev in thread] [next in thread] 

List:       jakarta-commons-dev
Subject:    [jira] [Resolved] (JEXL-405) Recursive functions corrupt evaluation frame if reassigned
From:       "Henri Biestro (Jira)" <jira () apache ! org>
Date:       2023-08-31 18:09:00
Message-ID: JIRA.13549192.1693420948000.47985.1693505340037 () Atlassian ! JIRA
[Download RAW message or body]


     [ https://issues.apache.org/jira/browse/JEXL-405?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel \
]

Henri Biestro resolved JEXL-405.
--------------------------------
    Resolution: Fixed

The fix ensures that the lambda frame is only updated during its creation/assignment \
by checking that the caller's scope is indeed the lambda's scope parent.

> Recursive functions corrupt evaluation frame if reassigned
> ----------------------------------------------------------
> 
> Key: JEXL-405
> URL: https://issues.apache.org/jira/browse/JEXL-405
> Project: Commons JEXL
> Issue Type: Bug
> Affects Versions: 3.3
> Reporter: Henri Biestro
> Assignee: Henri Biestro
> Priority: Major
> Fix For: 3.3.1
> 
> 
> This issue stems from the special handling recursive functions. A recursive \
> function is detected when a lambda is created and assigned to a variable and that \
> variable is captured by the lambda. During the assignment, the lambda frame - the \
> captured value for the lambda symbol in that frame - is updated with a reference to \
> the lambda itself. This can only occur after the lambda is created (obviously). The \
> code that handles the special case during assignment does not verify that the \
> caller is indeed its creator frame. Thus, if the lambda is assigned to a different \
> variable later on in a different scope, that same code will trash the frame with a \
> reference to the lambda...



--
This message was sent by Atlassian Jira
(v8.20.10#820010)


[prev in list] [next in list] [prev in thread] [next in thread] 

Configure | About | News | Add a list | Sponsored by KoreLogic