mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-27 20:25:12 +00:00
Cleanup and improve the exit status numbers and the messages generated on error as well as make sure that keyboard shortcuts don't change the status
darcs-hash:20080108193145-75c98-56c8aa2dd081af643d206820aa36bf3b6e49e0f2.gz
This commit is contained in:
parent
da4a4bcc18
commit
71c2cde390
7 changed files with 51 additions and 16 deletions
|
@ -955,8 +955,9 @@ If fish encounters a problem while executing a command, the status
|
||||||
variable may also be set to a specific value:
|
variable may also be set to a specific value:
|
||||||
|
|
||||||
- 1 is the generally the exit status from fish builtins if they where supplied with invalid arguments
|
- 1 is the generally the exit status from fish builtins if they where supplied with invalid arguments
|
||||||
- 125 means an unknown error occured while trying to execute the command
|
- 124 means that the command was not executed because none of the wildcards in the command produced any matches
|
||||||
- 126 means that the command was not executed because none of the wildcards in the command produced any matches
|
- 125 means that while an executable with the specified name was located, the operating system could not actually execute the command
|
||||||
|
- 126 means that while a file with the specified name was located, it was not executable
|
||||||
- 127 means that no function, builtin or command with the given name could be located
|
- 127 means that no function, builtin or command with the given name could be located
|
||||||
|
|
||||||
\subsection variables-color Variables for changing highlighting colors
|
\subsection variables-color Variables for changing highlighting colors
|
||||||
|
|
7
exec.c
7
exec.c
|
@ -509,7 +509,6 @@ static void launch_process( process_t *p )
|
||||||
}
|
}
|
||||||
|
|
||||||
errno = err;
|
errno = err;
|
||||||
|
|
||||||
debug( 0,
|
debug( 0,
|
||||||
_( L"Failed to execute process '%ls'. Reason:" ),
|
_( L"Failed to execute process '%ls'. Reason:" ),
|
||||||
p->actual_cmd );
|
p->actual_cmd );
|
||||||
|
@ -566,15 +565,15 @@ static void launch_process( process_t *p )
|
||||||
sb_destroy( &sz1 );
|
sb_destroy( &sz1 );
|
||||||
sb_destroy( &sz2 );
|
sb_destroy( &sz2 );
|
||||||
|
|
||||||
exit(1);
|
exit(STATUS_EXEC_FAIL);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
default:
|
default:
|
||||||
{
|
{
|
||||||
wperror( L"execve" );
|
debug(0, L"The file '%ls' is marked as an executable but could not be run by the operating system.", p->actual_cmd);
|
||||||
FATAL_EXIT();
|
exit(STATUS_EXEC_FAIL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
3
input.c
3
input.c
|
@ -408,9 +408,12 @@ static wint_t input_exec_binding( input_mapping_t *m, const wchar_t *seq )
|
||||||
This key sequence is bound to a command, which
|
This key sequence is bound to a command, which
|
||||||
is sent to the parser for evaluation.
|
is sent to the parser for evaluation.
|
||||||
*/
|
*/
|
||||||
|
int last_status = proc_get_last_status();
|
||||||
|
|
||||||
eval( m->command, 0, TOP );
|
eval( m->command, 0, TOP );
|
||||||
|
|
||||||
|
proc_set_last_status( last_status );
|
||||||
|
|
||||||
/*
|
/*
|
||||||
We still need to return something to the caller, R_NULL
|
We still need to return something to the caller, R_NULL
|
||||||
tells the reader that no key press needs to be handled,
|
tells the reader that no key press needs to be handled,
|
||||||
|
|
12
parser.c
12
parser.c
|
@ -1970,7 +1970,10 @@ static int parse_job( process_t *p,
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
int err;
|
||||||
|
|
||||||
p->actual_cmd = path_get_path( j, (wchar_t *)al_get( args, 0 ) );
|
p->actual_cmd = path_get_path( j, (wchar_t *)al_get( args, 0 ) );
|
||||||
|
err = errno;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Check if the specified command exists
|
Check if the specified command exists
|
||||||
|
@ -2062,12 +2065,17 @@ static int parse_job( process_t *p,
|
||||||
cmd,
|
cmd,
|
||||||
cmd );
|
cmd );
|
||||||
}
|
}
|
||||||
|
else if( err!=ENOENT )
|
||||||
|
{
|
||||||
|
debug( 0,
|
||||||
|
_(L"The file '%ls' is not executable by this user"),
|
||||||
|
cmd?cmd:L"UNKNOWN" );
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
debug( 0,
|
debug( 0,
|
||||||
_(L"Unknown command '%ls'"),
|
_(L"Unknown command '%ls'"),
|
||||||
cmd?cmd:L"UNKNOWN" );
|
cmd?cmd:L"UNKNOWN" );
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
tmp = current_tokenizer_pos;
|
tmp = current_tokenizer_pos;
|
||||||
|
@ -2078,7 +2086,7 @@ static int parse_job( process_t *p,
|
||||||
current_tokenizer_pos=tmp;
|
current_tokenizer_pos=tmp;
|
||||||
|
|
||||||
job_set_flag( j, JOB_SKIP, 1 );
|
job_set_flag( j, JOB_SKIP, 1 );
|
||||||
proc_set_last_status( STATUS_UNKNOWN_COMMAND );
|
proc_set_last_status( err==ENOENT?STATUS_UNKNOWN_COMMAND:STATUS_NOT_EXECUTABLE );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
22
path.c
22
path.c
|
@ -31,6 +31,8 @@ wchar_t *path_get_path( void *context, const wchar_t *cmd )
|
||||||
{
|
{
|
||||||
wchar_t *path;
|
wchar_t *path;
|
||||||
|
|
||||||
|
int err = ENOENT;
|
||||||
|
|
||||||
CHECK( cmd, 0 );
|
CHECK( cmd, 0 );
|
||||||
|
|
||||||
debug( 3, L"path_get_path( '%ls' )", cmd );
|
debug( 3, L"path_get_path( '%ls' )", cmd );
|
||||||
|
@ -40,14 +42,28 @@ wchar_t *path_get_path( void *context, const wchar_t *cmd )
|
||||||
if( waccess( cmd, X_OK )==0 )
|
if( waccess( cmd, X_OK )==0 )
|
||||||
{
|
{
|
||||||
struct stat buff;
|
struct stat buff;
|
||||||
wstat( cmd, &buff );
|
if(wstat( cmd, &buff ))
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
if( S_ISREG(buff.st_mode) )
|
if( S_ISREG(buff.st_mode) )
|
||||||
return halloc_wcsdup( context, cmd );
|
return halloc_wcsdup( context, cmd );
|
||||||
else
|
else
|
||||||
|
{
|
||||||
|
errno = EACCES;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
{
|
||||||
|
struct stat buff;
|
||||||
|
wstat( cmd, &buff );
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
path = env_get(L"PATH");
|
path = env_get(L"PATH");
|
||||||
if( path == 0 )
|
if( path == 0 )
|
||||||
|
@ -107,6 +123,8 @@ wchar_t *path_get_path( void *context, const wchar_t *cmd )
|
||||||
free( path_cpy );
|
free( path_cpy );
|
||||||
return new_cmd;
|
return new_cmd;
|
||||||
}
|
}
|
||||||
|
err = EACCES;
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -130,6 +148,8 @@ wchar_t *path_get_path( void *context, const wchar_t *cmd )
|
||||||
free( path_cpy );
|
free( path_cpy );
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
errno = err;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
1
proc.c
1
proc.c
|
@ -190,7 +190,6 @@ void proc_destroy()
|
||||||
void proc_set_last_status( int s )
|
void proc_set_last_status( int s )
|
||||||
{
|
{
|
||||||
last_status = s;
|
last_status = s;
|
||||||
// debug( 0, L"Set last status to %d\n", s );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int proc_get_last_status()
|
int proc_get_last_status()
|
||||||
|
|
9
proc.h
9
proc.h
|
@ -25,15 +25,20 @@
|
||||||
#define STATUS_UNKNOWN_COMMAND 127
|
#define STATUS_UNKNOWN_COMMAND 127
|
||||||
|
|
||||||
/**
|
/**
|
||||||
The status code use when a wildcard had no matches
|
The status code use when an unknown error occured during execution of a command
|
||||||
*/
|
*/
|
||||||
#define STATUS_UNMATCHED_WILDCARD 126
|
#define STATUS_NOT_EXECUTABLE 126
|
||||||
|
|
||||||
/**
|
/**
|
||||||
The status code use when an unknown error occured during execution of a command
|
The status code use when an unknown error occured during execution of a command
|
||||||
*/
|
*/
|
||||||
#define STATUS_EXEC_FAIL 125
|
#define STATUS_EXEC_FAIL 125
|
||||||
|
|
||||||
|
/**
|
||||||
|
The status code use when a wildcard had no matches
|
||||||
|
*/
|
||||||
|
#define STATUS_UNMATCHED_WILDCARD 124
|
||||||
|
|
||||||
/**
|
/**
|
||||||
The status code used for normal exit in a builtin
|
The status code used for normal exit in a builtin
|
||||||
*/
|
*/
|
||||||
|
|
Loading…
Reference in a new issue