mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-13 05:28:49 +00:00
Yet another tweak to the move_word function
darcs-hash:20061012161317-ac50b-3b374e2b6c4c22f82c1cf018bf83298c8216fcb1.gz
This commit is contained in:
parent
a620a1e5ed
commit
92446bda80
1 changed files with 35 additions and 7 deletions
42
reader.c
42
reader.c
|
@ -1531,6 +1531,19 @@ static void move_word( int dir, int erase )
|
|||
int end_buff_pos=data->buff_pos;
|
||||
int step = dir?1:-1;
|
||||
|
||||
/*
|
||||
Return if we are already at the edge
|
||||
*/
|
||||
if( !dir && data->buff_pos == 0 )
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
if( dir && data->buff_pos == data->buff_len )
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
/*
|
||||
If we are beyond the last character and moving left, start by
|
||||
moving one step, since otehrwise we'll start on the \0, which
|
||||
|
@ -1543,6 +1556,14 @@ static void move_word( int dir, int erase )
|
|||
|
||||
end_buff_pos--;
|
||||
}
|
||||
|
||||
/*
|
||||
When moving left, ignore the character under the cursor
|
||||
*/
|
||||
if( !dir )
|
||||
{
|
||||
end_buff_pos+=2*step;
|
||||
}
|
||||
|
||||
/*
|
||||
Remove all whitespace characters before finding a word
|
||||
|
@ -1578,7 +1599,6 @@ static void move_word( int dir, int erase )
|
|||
|
||||
end_buff_pos+=step;
|
||||
|
||||
|
||||
}
|
||||
|
||||
/*
|
||||
|
@ -1598,23 +1618,31 @@ static void move_word( int dir, int erase )
|
|||
if( end_buff_pos == data->buff_len )
|
||||
break;
|
||||
}
|
||||
|
||||
|
||||
c = data->buff[end_buff_pos];
|
||||
|
||||
|
||||
if( !iswalnum( c ) )
|
||||
{
|
||||
/*
|
||||
Don't gobble the boundary character if it was a
|
||||
whitespace, but do for all other non-alphabetic
|
||||
characters
|
||||
Don't gobble the boundary character when moving to the
|
||||
right
|
||||
*/
|
||||
if( iswspace( c ) /* && ( abs( end_buff_pos-data->buff_pos ) > 1 ) */ && (step < 0))
|
||||
if( !dir )
|
||||
end_buff_pos -= step;
|
||||
break;
|
||||
}
|
||||
end_buff_pos+=step;
|
||||
}
|
||||
|
||||
/*
|
||||
Make sure we move at least one character
|
||||
*/
|
||||
if( end_buff_pos==data->buff_pos )
|
||||
{
|
||||
end_buff_pos+=step;
|
||||
}
|
||||
|
||||
|
||||
if( erase )
|
||||
{
|
||||
int remove_count = abs(data->buff_pos - end_buff_pos);
|
||||
|
|
Loading…
Reference in a new issue