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:
axel 2006-12-14 10:01:52 +10:00
parent 774c050f92
commit 9a8e5e64ed

View file

@ -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 )
{