Skip to content

Commit

Permalink
A few more error checks during string to integer conversion in variou…
Browse files Browse the repository at this point in the history
…s places

darcs-hash:20070109134117-ac50b-8816e238b0b6aa3fe83c0a4695d719a60b0d17d4.gz
  • Loading branch information
liljencrantz committed Jan 9, 2007
1 parent b70092e commit 6e71b5a
Show file tree
Hide file tree
Showing 3 changed files with 116 additions and 84 deletions.
8 changes: 6 additions & 2 deletions main.c
Original file line number Diff line number Diff line change
Expand Up @@ -195,8 +195,12 @@ static int fish_parse_opt( int argc, char **argv, char **cmd_ptr )
case 'd':
{
char *end;
int tmp = strtol(optarg, &end, 10);
if( tmp >= 0 && tmp <=10 && !*end )
int tmp;

errno = 0;
tmp = strtol(optarg, &end, 10);

if( tmp >= 0 && tmp <=10 && !*end && !errno )
{
debug_level=tmp;
}
Expand Down
187 changes: 107 additions & 80 deletions parser.c
Original file line number Diff line number Diff line change
Expand Up @@ -112,6 +112,11 @@ The fish parser. Contains functions for parsing and evaluating code.
*/
#define ILLEGAL_CMD_ERR_MSG _( L"Illegal command name '%ls'")

/**
Error message when encountering an illegal file descriptor
*/
#define ILLEGAL_FD_ERR_MSG _( L"Illegal file descriptor '%ls'")

/**
Error message for wildcards with no matches
*/
Expand Down Expand Up @@ -1366,21 +1371,31 @@ static void parse_job_argument_list( process_t *p,
{
case TOK_PIPE:
{
wchar_t *end;

if( (p->type == INTERNAL_EXEC) )
{
error( SYNTAX_ERROR,
tok_get_pos( tok ),
EXEC_ERR_MSG );
return;
}
p->pipe_write_fd = wcstol( tok_last( tok ), 0, 10 );

errno = 0;
p->pipe_write_fd = wcstol( tok_last( tok ), &end, 10 );
if( p->pipe_write_fd < 0 || errno || *end )
{
error( SYNTAX_ERROR,
tok_get_pos( tok ),
ILLEGAL_FD_ERR_MSG,
tok_last( tok ) );
return;
}

if( !p->argv )
halloc_register( j, p->argv = list_to_char_arr( args ) );
p->next = halloc( j, sizeof( process_t ) );
if( p->next == 0 )
{
DIE_MEM();
}

tok_next( tok );

/*
Expand Down Expand Up @@ -1505,7 +1520,8 @@ static void parse_job_argument_list( process_t *p,
int type = tok_last_type( tok );
io_data_t *new_io;
wchar_t *target = 0;

wchar_t *end;

/*
Don't check redirections in skipped part
Expand All @@ -1530,93 +1546,104 @@ static void parse_job_argument_list( process_t *p,
if( !new_io )
DIE_MEM();

errno = 0;
new_io->fd = wcstol( tok_last( tok ),
0,
&end,
10 );
tok_next( tok );

switch( tok_last_type( tok ) )
if( new_io->fd < 0 || errno || *end )
{
case TOK_STRING:
{
target = (wchar_t *)expand_one( j, wcsdup( tok_last( tok ) ), 0);
error( SYNTAX_ERROR,
tok_get_pos( tok ),
ILLEGAL_FD_ERR_MSG,
tok_last( tok ) );
}
else
{

tok_next( tok );

if( target == 0 && error_code == 0 )
switch( tok_last_type( tok ) )
{
case TOK_STRING:
{
target = (wchar_t *)expand_one( j, wcsdup( tok_last( tok ) ), 0);

if( target == 0 && error_code == 0 )
{
error( SYNTAX_ERROR,
tok_get_pos( tok ),
REDIRECT_TOKEN_ERR_MSG,
tok_last( tok ) );

}
break;
}

default:
error( SYNTAX_ERROR,
tok_get_pos( tok ),
REDIRECT_TOKEN_ERR_MSG,
tok_last( tok ) );

}
break;
tok_get_desc( tok_last_type(tok)) );
}

default:
error( SYNTAX_ERROR,
tok_get_pos( tok ),
REDIRECT_TOKEN_ERR_MSG,
tok_get_desc( tok_last_type(tok)) );
}

if( target == 0 || wcslen( target )==0 )
{
if( error_code == 0 )
error( SYNTAX_ERROR,
tok_get_pos( tok ),
_(L"Invalid IO redirection") );
tok_next(tok);
}
else
{


switch( type )
if( target == 0 || wcslen( target )==0 )
{
if( error_code == 0 )
error( SYNTAX_ERROR,
tok_get_pos( tok ),
_(L"Invalid IO redirection") );
tok_next(tok);
}
else
{
case TOK_REDIRECT_APPEND:
new_io->io_mode = IO_FILE;
new_io->param2.flags = O_CREAT | O_APPEND | O_WRONLY;
new_io->param1.filename = target;
break;

case TOK_REDIRECT_OUT:
new_io->io_mode = IO_FILE;
new_io->param2.flags = O_CREAT | O_WRONLY | O_TRUNC;
new_io->param1.filename = target;
break;
switch( type )
{
case TOK_REDIRECT_APPEND:
new_io->io_mode = IO_FILE;
new_io->param2.flags = O_CREAT | O_APPEND | O_WRONLY;
new_io->param1.filename = target;
break;

case TOK_REDIRECT_IN:
new_io->io_mode = IO_FILE;
new_io->param2.flags = O_RDONLY;
new_io->param1.filename = target;
break;
case TOK_REDIRECT_OUT:
new_io->io_mode = IO_FILE;
new_io->param2.flags = O_CREAT | O_WRONLY | O_TRUNC;
new_io->param1.filename = target;
break;

case TOK_REDIRECT_FD:
{
if( wcscmp( target, L"-" ) == 0 )
{
new_io->io_mode = IO_CLOSE;
}
else
case TOK_REDIRECT_IN:
new_io->io_mode = IO_FILE;
new_io->param2.flags = O_RDONLY;
new_io->param1.filename = target;
break;

case TOK_REDIRECT_FD:
{
new_io->io_mode = IO_FD;
new_io->param1.old_fd = wcstol( target,
0,
10 );
if( ( new_io->param1.old_fd < 0 ) ||
( new_io->param1.old_fd > 10 ) )
if( wcscmp( target, L"-" ) == 0 )
{
error( SYNTAX_ERROR,
tok_get_pos( tok ),
_(L"Requested redirection to something that is not a file descriptor %ls"),
target );
new_io->io_mode = IO_CLOSE;
}
else
{
new_io->io_mode = IO_FD;
new_io->param1.old_fd = wcstol( target,
0,
10 );
if( ( new_io->param1.old_fd < 0 ) ||
( new_io->param1.old_fd > 10 ) )
{
error( SYNTAX_ERROR,
tok_get_pos( tok ),
_(L"Requested redirection to something that is not a file descriptor %ls"),
target );

tok_next(tok);
tok_next(tok);
}
}
break;
}
break;
}

}
}

Expand Down Expand Up @@ -1677,14 +1704,14 @@ static void parse_job_argument_list( process_t *p,
}

/*
static void print_block_stack( block_t *b )
{
if( !b )
return;
print_block_stack( b->outer );
static void print_block_stack( block_t *b )
{
if( !b )
return;
print_block_stack( b->outer );
debug( 0, L"Block type %ls, skip: %d", parser_get_block_desc( b->type ), b->skip );
}
debug( 0, L"Block type %ls, skip: %d", parser_get_block_desc( b->type ), b->skip );
}
*/

/**
Expand Down
5 changes: 3 additions & 2 deletions set_color.c
Original file line number Diff line number Diff line change
Expand Up @@ -102,10 +102,11 @@ int translate_color( char *str )

if( !str )
return -1;


errno = 0;
color = strtol( str, &endptr, 10 );
if(endptr<=str)

if( *endptr || color<0 || errno )
{
int i;
color = -1;
Expand Down

0 comments on commit 6e71b5a

Please sign in to comment.