1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-05-16 07:44:57 +00:00

Shell: Make for/match/functions put their variables only in the new scope

Otherwise, a function would, for example, overwrite its parent scope:
```sh
foo(x) { }
x=1
foo 2 # would make x=2 otherwise
```
This commit is contained in:
AnotherTest 2020-12-09 15:34:55 +03:30 committed by Andreas Kling
parent 97c5a78d27
commit 9bd81f34a5
3 changed files with 9 additions and 4 deletions

View file

@ -479,7 +479,7 @@ bool Shell::invoke_function(const AST::Command& command, int& retval)
size_t index = 0;
for (auto& arg : function.arguments) {
++index;
set_local_variable(arg, adopt(*new AST::StringValue(command.argv[index])));
set_local_variable(arg, adopt(*new AST::StringValue(command.argv[index])), true);
}
auto argv = command.argv;