Refactor selsnap SNAP_WORD.
Refactor the SNAP_WORD part in selsnap, and fix a bug that caused the word delimiters to be ignored if it was at the very beginning or end of a wrapped line. Signed-off-by: Roberto E. Vargas Caballero <k0ga@shike2.com>master
parent
6fd887077e
commit
5159d55c63
48
st.c
48
st.c
|
@ -703,6 +703,9 @@ selected(int x, int y) {
|
|||
|
||||
void
|
||||
selsnap(int mode, int *x, int *y, int direction) {
|
||||
int newx, newy, xt, yt;
|
||||
Glyph *gp;
|
||||
|
||||
switch(mode) {
|
||||
case SNAP_WORD:
|
||||
/*
|
||||
|
@ -710,36 +713,31 @@ selsnap(int mode, int *x, int *y, int direction) {
|
|||
* beginning of a line.
|
||||
*/
|
||||
for(;;) {
|
||||
if(direction < 0 && *x <= 0) {
|
||||
if(*y > 0 && term.line[*y - 1][term.col-1].mode
|
||||
& ATTR_WRAP) {
|
||||
*y -= 1;
|
||||
*x = term.col-1;
|
||||
} else {
|
||||
newx = *x + direction;
|
||||
newy = *y;
|
||||
if(!BETWEEN(newx, 0, term.col - 1)) {
|
||||
newy += direction;
|
||||
newx = (newx + term.col) % term.col;
|
||||
if (!BETWEEN(newy, 0, term.row - 1))
|
||||
break;
|
||||
}
|
||||
}
|
||||
if(direction > 0 && *x >= term.col-1) {
|
||||
if(*y < term.row-1 && term.line[*y][*x].mode
|
||||
& ATTR_WRAP) {
|
||||
*y += 1;
|
||||
*x = 0;
|
||||
} else {
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if(term.line[*y][*x+direction].mode & ATTR_WDUMMY) {
|
||||
*x += direction;
|
||||
continue;
|
||||
}
|
||||
|
||||
if(*x >= tlinelen(*y) || strchr(worddelimiters,
|
||||
term.line[*y][*x+direction].c[0])) {
|
||||
if(direction > 0)
|
||||
yt = *y, xt = *x;
|
||||
else
|
||||
yt = newy, xt = newx;
|
||||
if(!(term.line[yt][xt].mode & ATTR_WRAP))
|
||||
break;
|
||||
}
|
||||
|
||||
*x += direction;
|
||||
if (newx >= tlinelen(newy))
|
||||
break;
|
||||
|
||||
gp = &term.line[newy][newx];
|
||||
if (!(gp->mode & ATTR_WDUMMY) && strchr(worddelimiters, gp->c[0]))
|
||||
break;
|
||||
|
||||
*x = newx;
|
||||
*y = newy;
|
||||
}
|
||||
break;
|
||||
case SNAP_LINE:
|
||||
|
|
Reference in New Issue