mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-13 21:44:16 +00:00
Make sure that a command is never executed as the subcommand of the 'builtin' builtin
darcs-hash:20061214000152-ac50b-f1593dfeb4cecdbe48599ffe8d76a956989c7d24.gz
This commit is contained in:
parent
774c050f92
commit
9a8e5e64ed
1 changed files with 27 additions and 4 deletions
29
parser.c
29
parser.c
|
@ -56,6 +56,11 @@ The fish parser. Contains functions for parsing and evaluating code.
|
|||
*/
|
||||
#define MAX_RECURSION_DEPTH 128
|
||||
|
||||
/**
|
||||
Error message for unknown builtin
|
||||
*/
|
||||
#define UNKNOWN_BUILTIN_ERR_MSG _(L"Unknown builtin '%ls'")
|
||||
|
||||
/**
|
||||
Error message for improper use of the exec builtin
|
||||
*/
|
||||
|
@ -1711,6 +1716,7 @@ static int parse_job( process_t *p,
|
|||
array_list_t *args = al_halloc( j ); // The list that will become the argc array for the program
|
||||
int use_function = 1; // May functions be considered when checking what action this command represents
|
||||
int use_builtin = 1; // May builtins be considered when checking what action this command represents
|
||||
int use_command = 1; // May commands be considered when checking what action this command represents
|
||||
int is_new_block=0; // Does this command create a new block?
|
||||
|
||||
block_t *prev_block = current_block;
|
||||
|
@ -1834,7 +1840,15 @@ static int parse_job( process_t *p,
|
|||
{
|
||||
use_function = 0;
|
||||
if( wcscmp( L"command", nxt )==0 )
|
||||
use_builtin=0;
|
||||
{
|
||||
use_builtin = 0;
|
||||
use_command = 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
use_builtin = 1;
|
||||
use_command = 0;
|
||||
}
|
||||
}
|
||||
else if( wcscmp( L"not", nxt )==0 )
|
||||
{
|
||||
|
@ -1973,7 +1987,7 @@ static int parse_job( process_t *p,
|
|||
}
|
||||
}
|
||||
|
||||
if( !p->type || (p->type == INTERNAL_EXEC) )
|
||||
if( (!p->type || (p->type == INTERNAL_EXEC) ) )
|
||||
{
|
||||
/*
|
||||
If we are not executing the current block, allow
|
||||
|
@ -2012,7 +2026,7 @@ static int parse_job( process_t *p,
|
|||
If we have defined a wrapper around cd, use it,
|
||||
otherwise use the cd builtin
|
||||
*/
|
||||
if( function_exists( L"cd" ) )
|
||||
if( use_function && function_exists( L"cd" ) )
|
||||
p->type = INTERNAL_FUNCTION;
|
||||
else
|
||||
p->type = INTERNAL_BUILTIN;
|
||||
|
@ -2097,8 +2111,17 @@ static int parse_job( process_t *p,
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
if( (p->type == EXTERNAL) && !use_command )
|
||||
{
|
||||
error( SYNTAX_ERROR,
|
||||
tok_get_pos( tok ),
|
||||
UNKNOWN_BUILTIN_ERR_MSG,
|
||||
al_get( args, al_get_count( args ) -1 ) );
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
if( is_new_block )
|
||||
{
|
||||
|
||||
|
|
Loading…
Reference in a new issue