mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-13 21:44:16 +00:00
Cleaned up lots of typecasts, simplified some string handling
This commit is contained in:
parent
5880cd88c8
commit
c67702a498
19 changed files with 54 additions and 116 deletions
|
@ -2218,8 +2218,7 @@ static int builtin_read( parser_t &parser, wchar_t **argv )
|
||||||
while( !finished )
|
while( !finished )
|
||||||
{
|
{
|
||||||
char b;
|
char b;
|
||||||
int read_res = read_blocked( builtin_stdin, &b, 1 );
|
if( read_blocked( builtin_stdin, &b, 1 ) <= 0 )
|
||||||
if( read_res <= 0 )
|
|
||||||
{
|
{
|
||||||
eof=1;
|
eof=1;
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -61,8 +61,7 @@ static const wchar_t *current_buffer=0;
|
||||||
What the commandline builtin considers to be the current cursor
|
What the commandline builtin considers to be the current cursor
|
||||||
position.
|
position.
|
||||||
*/
|
*/
|
||||||
static const size_t kInvalidCursorPosition = (size_t)(-1);
|
static size_t current_cursor_pos = (size_t)(-1);
|
||||||
static size_t current_cursor_pos = kInvalidCursorPosition;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Returns the current commandline buffer.
|
Returns the current commandline buffer.
|
||||||
|
|
|
@ -292,10 +292,10 @@ static int builtin_jobs( parser_t &parser, wchar_t **argv )
|
||||||
|
|
||||||
for( i=woptind; i<argc; i++ )
|
for( i=woptind; i<argc; i++ )
|
||||||
{
|
{
|
||||||
long pid;
|
int pid;
|
||||||
wchar_t *end;
|
wchar_t *end;
|
||||||
errno=0;
|
errno=0;
|
||||||
pid=wcstol( argv[i], &end, 10 );
|
pid=fish_wcstoi( argv[i], &end, 10 );
|
||||||
if( errno || *end )
|
if( errno || *end )
|
||||||
{
|
{
|
||||||
append_format(stderr_buffer,
|
append_format(stderr_buffer,
|
||||||
|
@ -305,7 +305,7 @@ static int builtin_jobs( parser_t &parser, wchar_t **argv )
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
j = job_get_from_pid( (int)pid );
|
j = job_get_from_pid( pid );
|
||||||
|
|
||||||
if( j && !job_is_completed( j ) )
|
if( j && !job_is_completed( j ) )
|
||||||
{
|
{
|
||||||
|
|
|
@ -618,7 +618,7 @@ __sentinel bool contains_internal( const wcstring &needle, ... )
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
int read_blocked(int fd, void *buf, size_t count)
|
long read_blocked(int fd, void *buf, size_t count)
|
||||||
{
|
{
|
||||||
ssize_t res;
|
ssize_t res;
|
||||||
sigset_t chldset, oldset;
|
sigset_t chldset, oldset;
|
||||||
|
@ -628,7 +628,7 @@ int read_blocked(int fd, void *buf, size_t count)
|
||||||
VOMIT_ON_FAILURE(pthread_sigmask(SIG_BLOCK, &chldset, &oldset));
|
VOMIT_ON_FAILURE(pthread_sigmask(SIG_BLOCK, &chldset, &oldset));
|
||||||
res = read( fd, buf, count );
|
res = read( fd, buf, count );
|
||||||
VOMIT_ON_FAILURE(pthread_sigmask(SIG_SETMASK, &oldset, NULL));
|
VOMIT_ON_FAILURE(pthread_sigmask(SIG_SETMASK, &oldset, NULL));
|
||||||
return (int)res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
ssize_t write_loop(int fd, const char *buff, size_t count)
|
ssize_t write_loop(int fd, const char *buff, size_t count)
|
||||||
|
|
2
common.h
2
common.h
|
@ -583,7 +583,7 @@ __sentinel bool contains_internal( const wcstring &needle, ... );
|
||||||
if you _know_ there is data available for reading, or the program
|
if you _know_ there is data available for reading, or the program
|
||||||
will hang until there is data.
|
will hang until there is data.
|
||||||
*/
|
*/
|
||||||
int read_blocked(int fd, void *buf, size_t count);
|
long read_blocked(int fd, void *buf, size_t count);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Loop a write request while failiure is non-critical. Return -1 and set errno
|
Loop a write request while failiure is non-critical. Return -1 and set errno
|
||||||
|
|
6
env.cpp
6
env.cpp
|
@ -1083,15 +1083,15 @@ env_var_t env_get_string( const wcstring &key )
|
||||||
}
|
}
|
||||||
else if( key == L"COLUMNS" )
|
else if( key == L"COLUMNS" )
|
||||||
{
|
{
|
||||||
return to_string((long)common_get_width());
|
return to_string(common_get_width());
|
||||||
}
|
}
|
||||||
else if( key == L"LINES" )
|
else if( key == L"LINES" )
|
||||||
{
|
{
|
||||||
return to_string((long)common_get_width());
|
return to_string(common_get_width());
|
||||||
}
|
}
|
||||||
else if( key == L"status" )
|
else if( key == L"status" )
|
||||||
{
|
{
|
||||||
return to_string((long)proc_get_last_status());
|
return to_string(proc_get_last_status());
|
||||||
}
|
}
|
||||||
else if( key == L"umask" )
|
else if( key == L"umask" )
|
||||||
{
|
{
|
||||||
|
|
|
@ -528,7 +528,7 @@ static void event_fire_delayed()
|
||||||
/*
|
/*
|
||||||
Send all signals in our private list
|
Send all signals in our private list
|
||||||
*/
|
*/
|
||||||
for( i=0; i<(size_t)lst->count; i++ )
|
for( int i=0; i < lst->count; i++ )
|
||||||
{
|
{
|
||||||
e.param1.signal = lst->signal[i];
|
e.param1.signal = lst->signal[i];
|
||||||
e.arguments->at(0) = sig2wcs( e.param1.signal );
|
e.arguments->at(0) = sig2wcs( e.param1.signal );
|
||||||
|
|
6
exec.cpp
6
exec.cpp
|
@ -95,6 +95,8 @@ static void exec_write_and_exit( int fd, const char *buff, size_t count, int sta
|
||||||
|
|
||||||
void exec_close( int fd )
|
void exec_close( int fd )
|
||||||
{
|
{
|
||||||
|
ASSERT_IS_MAIN_THREAD();
|
||||||
|
|
||||||
/* This may be called in a child of fork(), so don't allocate memory */
|
/* This may be called in a child of fork(), so don't allocate memory */
|
||||||
if( fd < 0 )
|
if( fd < 0 )
|
||||||
{
|
{
|
||||||
|
@ -113,7 +115,7 @@ void exec_close( int fd )
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Maybe remove this from our set of open fds */
|
/* Maybe remove this from our set of open fds */
|
||||||
if (fd < (int)open_fds.size()) {
|
if (fd < open_fds.size()) {
|
||||||
open_fds[fd] = false;
|
open_fds[fd] = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -134,7 +136,7 @@ int exec_pipe( int fd[2])
|
||||||
debug( 4, L"Created pipe using fds %d and %d", fd[0], fd[1]);
|
debug( 4, L"Created pipe using fds %d and %d", fd[0], fd[1]);
|
||||||
|
|
||||||
int max_fd = std::max(fd[0], fd[1]);
|
int max_fd = std::max(fd[0], fd[1]);
|
||||||
if ((int)open_fds.size() <= max_fd) {
|
if (open_fds.size() <= max_fd) {
|
||||||
open_fds.resize(max_fd + 1, false);
|
open_fds.resize(max_fd + 1, false);
|
||||||
}
|
}
|
||||||
open_fds.at(fd[0]) = true;
|
open_fds.at(fd[0]) = true;
|
||||||
|
|
|
@ -494,7 +494,7 @@ static void completion_print( int cols,
|
||||||
|
|
||||||
int is_last = (j==(cols-1));
|
int is_last = (j==(cols-1));
|
||||||
|
|
||||||
if( (int)lst.size() <= j*rows + i )
|
if( lst.size() <= j*rows + i )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
el = lst.at(j*rows + i );
|
el = lst.at(j*rows + i );
|
||||||
|
@ -872,11 +872,9 @@ static void mangle_descriptions( wcstring_list_t &lst )
|
||||||
*/
|
*/
|
||||||
static void join_completions( wcstring_list_t lst )
|
static void join_completions( wcstring_list_t lst )
|
||||||
{
|
{
|
||||||
long i;
|
|
||||||
|
|
||||||
std::map<wcstring, long> desc_table;
|
std::map<wcstring, long> desc_table;
|
||||||
|
|
||||||
for( i=0; i<(long)lst.size(); i++ )
|
for( size_t i=0; i<lst.size(); i++ )
|
||||||
{
|
{
|
||||||
const wchar_t *item = lst.at(i).c_str();
|
const wchar_t *item = lst.at(i).c_str();
|
||||||
const wchar_t *desc = wcschr( item, COMPLETE_SEP );
|
const wchar_t *desc = wcschr( item, COMPLETE_SEP );
|
||||||
|
|
92
fishd.cpp
92
fishd.cpp
|
@ -197,41 +197,6 @@ static void handle_term( int signal )
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
Writes a pid_t in decimal representation to str.
|
|
||||||
str must contain sufficient space.
|
|
||||||
The conservatively approximate maximum number of characters a pid_t will
|
|
||||||
represent is given by: (int)(0.31 * sizeof(pid_t) + CHAR_BIT + 1)
|
|
||||||
Returns the length of the string
|
|
||||||
*/
|
|
||||||
static int sprint_pid_t( pid_t pid, char *str )
|
|
||||||
{
|
|
||||||
int len, i = 0;
|
|
||||||
int dig;
|
|
||||||
|
|
||||||
/* Store digits in reverse order into string */
|
|
||||||
while( pid != 0 )
|
|
||||||
{
|
|
||||||
dig = pid % 10;
|
|
||||||
str[i] = '0' + dig;
|
|
||||||
pid = ( pid - dig ) / 10;
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
len = i;
|
|
||||||
/* Reverse digits */
|
|
||||||
i /= 2;
|
|
||||||
while( i )
|
|
||||||
{
|
|
||||||
i--;
|
|
||||||
dig = str[i];
|
|
||||||
str[i] = str[len - 1 - i];
|
|
||||||
str[len - 1 - i] = dig;
|
|
||||||
}
|
|
||||||
return len;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Writes a pseudo-random number (between one and maxlen) of pseudo-random
|
Writes a pseudo-random number (between one and maxlen) of pseudo-random
|
||||||
digits into str.
|
digits into str.
|
||||||
|
@ -247,7 +212,7 @@ static int sprint_pid_t( pid_t pid, char *str )
|
||||||
Excludes chars other than digits since ANSI C only guarantees that digits
|
Excludes chars other than digits since ANSI C only guarantees that digits
|
||||||
are consecutive.
|
are consecutive.
|
||||||
*/
|
*/
|
||||||
static int sprint_rand_digits( char *str, int maxlen )
|
static void sprint_rand_digits( char *str, int maxlen )
|
||||||
{
|
{
|
||||||
int i, max;
|
int i, max;
|
||||||
struct timeval tv;
|
struct timeval tv;
|
||||||
|
@ -265,7 +230,7 @@ static int sprint_rand_digits( char *str, int maxlen )
|
||||||
{
|
{
|
||||||
str[i] = '0' + 10 * (rand() / (RAND_MAX + 1.0));
|
str[i] = '0' + 10 * (rand() / (RAND_MAX + 1.0));
|
||||||
}
|
}
|
||||||
return i;
|
str[i] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -278,45 +243,22 @@ static int sprint_rand_digits( char *str, int maxlen )
|
||||||
fallback.
|
fallback.
|
||||||
The memory returned should be freed using free().
|
The memory returned should be freed using free().
|
||||||
*/
|
*/
|
||||||
static char *gen_unique_nfs_filename( const char *filename )
|
static std::string gen_unique_nfs_filename( const char *filename )
|
||||||
{
|
{
|
||||||
size_t pidlen, hnlen, orglen = strlen( filename );
|
|
||||||
char hostname[HOST_NAME_MAX + 1];
|
char hostname[HOST_NAME_MAX + 1];
|
||||||
char *newname;
|
char pid_str[256];
|
||||||
|
snprintf(pid_str, sizeof pid_str, "%ld", (long)getpid());
|
||||||
|
|
||||||
if ( gethostname( hostname, HOST_NAME_MAX + 1 ) == 0 )
|
if ( gethostname( hostname, sizeof hostname ) != 0 )
|
||||||
{
|
{
|
||||||
hnlen = strlen( hostname );
|
sprint_rand_digits( hostname, HOST_NAME_MAX );
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
hnlen = sprint_rand_digits( hostname, HOST_NAME_MAX );
|
|
||||||
hostname[hnlen] = '\0';
|
|
||||||
}
|
|
||||||
newname = (char *)malloc( orglen + 1 /* period */ + hnlen + 1 /* period */ +
|
|
||||||
/* max possible pid size: 0.31 ~= log(10)2 */
|
|
||||||
(int)(0.31 * sizeof(pid_t) * CHAR_BIT + 1)
|
|
||||||
+ 1 /* '\0' */ );
|
|
||||||
|
|
||||||
if ( newname == NULL )
|
std::string newname(filename);
|
||||||
{
|
newname.push_back('.');
|
||||||
debug( 1, L"gen_unique_nfs_filename: %s", strerror( errno ) );
|
newname.append(hostname);
|
||||||
return newname;
|
newname.push_back('.');
|
||||||
}
|
newname.append(pid_str);
|
||||||
memcpy( newname, filename, orglen );
|
|
||||||
newname[orglen] = '.';
|
|
||||||
memcpy( newname + orglen + 1, hostname, hnlen );
|
|
||||||
newname[orglen + 1 + hnlen] = '.';
|
|
||||||
pidlen = sprint_pid_t( getpid(), newname + orglen + 1 + hnlen + 1 );
|
|
||||||
newname[orglen + 1 + hnlen + 1 + pidlen] = '\0';
|
|
||||||
/* debug( 1, L"gen_unique_nfs_filename returning with: newname = \"%s\"; "
|
|
||||||
L"HOST_NAME_MAX = %d; hnlen = %d; orglen = %d; "
|
|
||||||
L"sizeof(pid_t) = %d; maxpiddigits = %d; malloc'd size: %d",
|
|
||||||
newname, (int)HOST_NAME_MAX, hnlen, orglen,
|
|
||||||
(int)sizeof(pid_t),
|
|
||||||
(int)(0.31 * sizeof(pid_t) * CHAR_BIT + 1),
|
|
||||||
(int)(orglen + 1 + hnlen + 1 +
|
|
||||||
(int)(0.31 * sizeof(pid_t) * CHAR_BIT + 1) + 1) ); */
|
|
||||||
return newname;
|
return newname;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -348,11 +290,8 @@ static int acquire_lock_file( const char *lockfile, const int timeout, int force
|
||||||
/*
|
/*
|
||||||
(Re)create a unique file and check that it has one only link.
|
(Re)create a unique file and check that it has one only link.
|
||||||
*/
|
*/
|
||||||
char *linkfile = gen_unique_nfs_filename( lockfile );
|
const std::string linkfile_str = gen_unique_nfs_filename( lockfile );
|
||||||
if( linkfile == NULL )
|
const char * const linkfile = linkfile_str.c_str();
|
||||||
{
|
|
||||||
goto done;
|
|
||||||
}
|
|
||||||
(void)unlink( linkfile );
|
(void)unlink( linkfile );
|
||||||
/* OK to not use CLO_EXEC here because fishd is single threaded */
|
/* OK to not use CLO_EXEC here because fishd is single threaded */
|
||||||
if( ( fd = open( linkfile, O_CREAT|O_RDONLY, 0600 ) ) == -1 )
|
if( ( fd = open( linkfile, O_CREAT|O_RDONLY, 0600 ) ) == -1 )
|
||||||
|
@ -439,7 +378,6 @@ static int acquire_lock_file( const char *lockfile, const int timeout, int force
|
||||||
done:
|
done:
|
||||||
/* The linkfile is not needed once the lockfile has been created */
|
/* The linkfile is not needed once the lockfile has been created */
|
||||||
(void)unlink( linkfile );
|
(void)unlink( linkfile );
|
||||||
free( linkfile );
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1313,7 +1313,7 @@ void highlight_shell( const wcstring &buff, std::vector<int> &color, size_t pos,
|
||||||
|
|
||||||
// highlight the end of the subcommand
|
// highlight the end of the subcommand
|
||||||
assert(end >= subbuff);
|
assert(end >= subbuff);
|
||||||
if ((size_t)(end - subbuff) < length) {
|
if ((end - subbuff) < length) {
|
||||||
color.at(end-subbuff)=HIGHLIGHT_OPERATOR;
|
color.at(end-subbuff)=HIGHLIGHT_OPERATOR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1418,7 +1418,7 @@ static void highlight_universal_internal( const wcstring &buffstr, std::vector<i
|
||||||
if( level == 0 )
|
if( level == 0 )
|
||||||
{
|
{
|
||||||
level++;
|
level++;
|
||||||
lst.push_back((long)(str-buff));
|
lst.push_back(str-buff);
|
||||||
prev_q = *str;
|
prev_q = *str;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -1442,7 +1442,7 @@ static void highlight_universal_internal( const wcstring &buffstr, std::vector<i
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
level++;
|
level++;
|
||||||
lst.push_back((long)(str-buff));
|
lst.push_back(str-buff);
|
||||||
prev_q = *str;
|
prev_q = *str;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
2
io.cpp
2
io.cpp
|
@ -64,7 +64,7 @@ void io_buffer_read( io_data_t *d )
|
||||||
while(1)
|
while(1)
|
||||||
{
|
{
|
||||||
char b[4096];
|
char b[4096];
|
||||||
int l;
|
long l;
|
||||||
l=read_blocked( d->param1.pipe_fd[0], b, 4096 );
|
l=read_blocked( d->param1.pipe_fd[0], b, 4096 );
|
||||||
if( l==0 )
|
if( l==0 )
|
||||||
{
|
{
|
||||||
|
|
|
@ -1033,13 +1033,13 @@ static void write_file( const char *file, int print_path )
|
||||||
\param files the list of files for which to perform the action
|
\param files the list of files for which to perform the action
|
||||||
\param fileno an internal value. Should always be set to zero.
|
\param fileno an internal value. Should always be set to zero.
|
||||||
*/
|
*/
|
||||||
static void launch( char *filter, const string_list_t &files, int fileno )
|
static void launch( char *filter, const string_list_t &files, size_t fileno )
|
||||||
{
|
{
|
||||||
char *filter_org=filter;
|
char *filter_org=filter;
|
||||||
int count=0;
|
int count=0;
|
||||||
int launch_again=0;
|
int launch_again=0;
|
||||||
|
|
||||||
if( (int)files.size() <= fileno )
|
if( files.size() <= fileno )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -161,7 +161,7 @@ static bool write_color(char *todo, unsigned char idx, bool is_fg) {
|
||||||
} else {
|
} else {
|
||||||
/* We are attempting to bypass the term here. Generate the ANSI escape sequence ourself. */
|
/* We are attempting to bypass the term here. Generate the ANSI escape sequence ourself. */
|
||||||
char stridx[128];
|
char stridx[128];
|
||||||
format_long_safe(stridx, (long)idx);
|
format_long_safe(stridx, idx);
|
||||||
char buff[128] = "\x1b[";
|
char buff[128] = "\x1b[";
|
||||||
strcat(buff, is_fg ? "38;5;" : "48;5;");
|
strcat(buff, is_fg ? "38;5;" : "48;5;");
|
||||||
strcat(buff, stridx);
|
strcat(buff, stridx);
|
||||||
|
|
|
@ -132,7 +132,7 @@ size_t parse_util_get_offset( const wcstring &str, int line, long line_offset )
|
||||||
|
|
||||||
if( off2 == (size_t)(-1) )
|
if( off2 == (size_t)(-1) )
|
||||||
{
|
{
|
||||||
off2 = (int)(wcslen( buff )+1);
|
off2 = wcslen( buff )+1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if( line_offset2 < 0 )
|
if( line_offset2 < 0 )
|
||||||
|
|
6
proc.cpp
6
proc.cpp
|
@ -377,8 +377,8 @@ static void mark_process_status( const job_t *j,
|
||||||
char mess[MESS_SIZE];
|
char mess[MESS_SIZE];
|
||||||
snprintf( mess,
|
snprintf( mess,
|
||||||
MESS_SIZE,
|
MESS_SIZE,
|
||||||
"Process %d exited abnormally\n",
|
"Process %ld exited abnormally\n",
|
||||||
(int) p->pid );
|
(long) p->pid );
|
||||||
/*
|
/*
|
||||||
If write fails, do nothing. We're in a signal handlers error
|
If write fails, do nothing. We're in a signal handlers error
|
||||||
handler. If things aren't working properly, it's safer to
|
handler. If things aren't working properly, it's safer to
|
||||||
|
@ -866,7 +866,7 @@ static void read_try( job_t *j )
|
||||||
while(1)
|
while(1)
|
||||||
{
|
{
|
||||||
char b[BUFFER_SIZE];
|
char b[BUFFER_SIZE];
|
||||||
int l;
|
long l;
|
||||||
|
|
||||||
l=read_blocked( buff->param1.pipe_fd[0],
|
l=read_blocked( buff->param1.pipe_fd[0],
|
||||||
b, BUFFER_SIZE );
|
b, BUFFER_SIZE );
|
||||||
|
|
|
@ -444,7 +444,9 @@ static void reader_repaint()
|
||||||
parser_t::principal_parser().test( data->command_line.c_str(), &data->indents[0], 0, 0 );
|
parser_t::principal_parser().test( data->command_line.c_str(), &data->indents[0], 0, 0 );
|
||||||
|
|
||||||
wcstring full_line = (data->autosuggestion.empty() ? data->command_line : data->autosuggestion);
|
wcstring full_line = (data->autosuggestion.empty() ? data->command_line : data->autosuggestion);
|
||||||
size_t len = std::max((size_t)1, full_line.size());
|
size_t len = full_line.size();
|
||||||
|
if (len < 1)
|
||||||
|
len = 1;
|
||||||
|
|
||||||
std::vector<color_t> colors = data->colors;
|
std::vector<color_t> colors = data->colors;
|
||||||
colors.resize(len, HIGHLIGHT_AUTOSUGGESTION);
|
colors.resize(len, HIGHLIGHT_AUTOSUGGESTION);
|
||||||
|
|
|
@ -60,7 +60,7 @@ void validate_pointer( const void *ptr, const wchar_t *err, int null_ok )
|
||||||
Test if the pointer data crosses a segment boundary.
|
Test if the pointer data crosses a segment boundary.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if( (0x00000003l & (long)ptr) != 0 )
|
if( (0x00000003l & (intptr_t)ptr) != 0 )
|
||||||
{
|
{
|
||||||
debug( 0, _(L"The pointer '%ls' is invalid"), err );
|
debug( 0, _(L"The pointer '%ls' is invalid"), err );
|
||||||
sanity_lose();
|
sanity_lose();
|
||||||
|
|
|
@ -384,9 +384,9 @@ int wcs2sig( const wchar_t *str )
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
errno=0;
|
errno=0;
|
||||||
long res = wcstol( str, &end, 10 );
|
int res = fish_wcstoi( str, &end, 10 );
|
||||||
if( !errno && res>=0 && res <= INT_MAX && !*end )
|
if( !errno && res>=0 && !*end )
|
||||||
return (int)res;
|
return res;
|
||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue