Fixing the selection in a single line again.

Thanks p37sitdu@lavabit.com!
master
Christoph Lohmann 2013-05-26 16:10:22 +02:00
parent 8f1bef0502
commit b5144100a5
1 changed files with 8 additions and 3 deletions

11
st.c
View File

@ -667,16 +667,21 @@ y2row(int y) {
static void static void
selsort(void) { selsort(void) {
sel.nb.x = sel.ob.y < sel.oe.y ? sel.ob.x : sel.oe.x; if(sel.ob.y == sel.oe.y) {
sel.nb.x = MIN(sel.ob.x, sel.oe.x);
sel.ne.x = MAX(sel.ob.x, sel.oe.x);
} else {
sel.nb.x = sel.ob.y < sel.oe.y ? sel.ob.x : sel.oe.x;
sel.ne.x = sel.ob.y < sel.oe.y ? sel.oe.x : sel.ob.x;
}
sel.nb.y = MIN(sel.ob.y, sel.oe.y); sel.nb.y = MIN(sel.ob.y, sel.oe.y);
sel.ne.x = sel.ob.y < sel.oe.y ? sel.oe.x : sel.ob.x;
sel.ne.y = MAX(sel.ob.y, sel.oe.y); sel.ne.y = MAX(sel.ob.y, sel.oe.y);
} }
static inline bool static inline bool
selected(int x, int y) { selected(int x, int y) {
if(sel.ne.y == y && sel.nb.y == y) if(sel.ne.y == y && sel.nb.y == y)
return BETWEEN(x, sel.nb.x, sel.ne.y); return BETWEEN(x, sel.nb.x, sel.ne.x);
if(sel.type == SEL_RECTANGULAR) { if(sel.type == SEL_RECTANGULAR) {
return ((sel.nb.y <= y && y <= sel.ne.y) return ((sel.nb.y <= y && y <= sel.ne.y)