|
|
@ -922,60 +922,59 @@ getsel(void) { |
|
|
|
int x, y, bufsize, size, i, ex; |
|
|
|
int x, y, bufsize, size, i, ex; |
|
|
|
Glyph *gp, *last; |
|
|
|
Glyph *gp, *last; |
|
|
|
|
|
|
|
|
|
|
|
if(sel.ob.x == -1) { |
|
|
|
if(sel.ob.x == -1) |
|
|
|
str = NULL; |
|
|
|
return NULL; |
|
|
|
} else { |
|
|
|
|
|
|
|
bufsize = (term.col+1) * (sel.ne.y-sel.nb.y+1) * UTF_SIZ; |
|
|
|
|
|
|
|
ptr = str = xmalloc(bufsize); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* append every set & selected glyph to the selection */ |
|
|
|
bufsize = (term.col+1) * (sel.ne.y-sel.nb.y+1) * UTF_SIZ; |
|
|
|
for(y = sel.nb.y; y < sel.ne.y + 1; y++) { |
|
|
|
ptr = str = xmalloc(bufsize); |
|
|
|
gp = &term.line[y][0]; |
|
|
|
|
|
|
|
last = &gp[term.col-1]; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
while(last >= gp && !(selected(last - gp, y) && |
|
|
|
/* append every set & selected glyph to the selection */ |
|
|
|
strcmp(last->c, " ") != 0)) { |
|
|
|
for(y = sel.nb.y; y < sel.ne.y + 1; y++) { |
|
|
|
--last; |
|
|
|
gp = &term.line[y][0]; |
|
|
|
} |
|
|
|
last = &gp[term.col-1]; |
|
|
|
|
|
|
|
|
|
|
|
for(x = 0; gp <= last; x++, ++gp) { |
|
|
|
while(last >= gp && !(selected(last - gp, y) && |
|
|
|
if(!selected(x, y) || (gp->mode & ATTR_WDUMMY)) |
|
|
|
strcmp(last->c, " ") != 0)) { |
|
|
|
continue; |
|
|
|
--last; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
size = utf8len(gp->c); |
|
|
|
for(x = 0; gp <= last; x++, ++gp) { |
|
|
|
memcpy(ptr, gp->c, size); |
|
|
|
if(!selected(x, y) || (gp->mode & ATTR_WDUMMY)) |
|
|
|
ptr += size; |
|
|
|
continue; |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
size = utf8len(gp->c); |
|
|
|
* Copy and pasting of line endings is inconsistent |
|
|
|
memcpy(ptr, gp->c, size); |
|
|
|
* in the inconsistent terminal and GUI world. |
|
|
|
ptr += size; |
|
|
|
* The best solution seems like to produce '\n' when |
|
|
|
} |
|
|
|
* something is copied from st and convert '\n' to |
|
|
|
|
|
|
|
* '\r', when something to be pasted is received by |
|
|
|
|
|
|
|
* st. |
|
|
|
|
|
|
|
* FIXME: Fix the computer world. |
|
|
|
|
|
|
|
*/ |
|
|
|
|
|
|
|
if(y < sel.ne.y && x > 0 && !((gp-1)->mode & ATTR_WRAP)) |
|
|
|
|
|
|
|
*ptr++ = '\n'; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
/*
|
|
|
|
* If the last selected line expands in the selection |
|
|
|
* Copy and pasting of line endings is inconsistent |
|
|
|
* after the visible text '\n' is appended. |
|
|
|
* in the inconsistent terminal and GUI world. |
|
|
|
*/ |
|
|
|
* The best solution seems like to produce '\n' when |
|
|
|
if(y == sel.ne.y) { |
|
|
|
* something is copied from st and convert '\n' to |
|
|
|
i = term.col; |
|
|
|
* '\r', when something to be pasted is received by |
|
|
|
while(--i > 0 && term.line[y][i].c[0] == ' ') |
|
|
|
* st. |
|
|
|
/* nothing */; |
|
|
|
* FIXME: Fix the computer world. |
|
|
|
ex = sel.ne.x; |
|
|
|
*/ |
|
|
|
if(sel.nb.y == sel.ne.y && sel.ne.x < sel.nb.x) |
|
|
|
if(y < sel.ne.y && x > 0 && !((gp-1)->mode & ATTR_WRAP)) |
|
|
|
ex = sel.nb.x; |
|
|
|
*ptr++ = '\n'; |
|
|
|
if(i < ex) |
|
|
|
|
|
|
|
*ptr++ = '\n'; |
|
|
|
/*
|
|
|
|
} |
|
|
|
* If the last selected line expands in the selection |
|
|
|
|
|
|
|
* after the visible text '\n' is appended. |
|
|
|
|
|
|
|
*/ |
|
|
|
|
|
|
|
if(y == sel.ne.y) { |
|
|
|
|
|
|
|
i = term.col; |
|
|
|
|
|
|
|
while(--i > 0 && term.line[y][i].c[0] == ' ') |
|
|
|
|
|
|
|
/* nothing */; |
|
|
|
|
|
|
|
ex = sel.ne.x; |
|
|
|
|
|
|
|
if(sel.nb.y == sel.ne.y && sel.ne.x < sel.nb.x) |
|
|
|
|
|
|
|
ex = sel.nb.x; |
|
|
|
|
|
|
|
if(i < ex) |
|
|
|
|
|
|
|
*ptr++ = '\n'; |
|
|
|
} |
|
|
|
} |
|
|
|
*ptr = 0; |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
*ptr = 0; |
|
|
|
return str; |
|
|
|
return str; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|