Xinqi Bao's Git
projects
/
st.git
/ blobdiff
summary
|
log
|
commit
|
diff
|
tree
raw
|
inline
| side by side
Move remaining selection mode logic into selextend
[st.git]
/
st.c
diff --git
a/st.c
b/st.c
index
21cba9e
..
b7e215e
100644
(file)
--- a/
st.c
+++ b/
st.c
@@
-167,11
+167,11
@@
static ssize_t xwrite(int, const char *, size_t);
/* Globals */
Term term;
/* Globals */
Term term;
-Selection sel;
int cmdfd;
pid_t pid;
int oldbutton = 3; /* button event on startup: 3 = release */
int cmdfd;
pid_t pid;
int oldbutton = 3; /* button event on startup: 3 = release */
+static Selection sel;
static CSIEscape csiescseq;
static STREscape strescseq;
static int iofd = 1;
static CSIEscape csiescseq;
static STREscape strescseq;
static int iofd = 1;
@@
-402,9
+402,17
@@
selstart(int col, int row, int snap)
}
void
}
void
-selextend(int col, int row, int type)
+selextend(int col, int row, int type
, int done
)
{
int oldey, oldex, oldsby, oldsey, oldtype;
{
int oldey, oldex, oldsby, oldsey, oldtype;
+
+ if (!sel.mode)
+ return;
+ if (done && sel.mode == SEL_EMPTY) {
+ selclear();
+ return;
+ }
+
oldey = sel.oe.y;
oldex = sel.oe.x;
oldsby = sel.nb.y;
oldey = sel.oe.y;
oldex = sel.oe.x;
oldsby = sel.nb.y;
@@
-419,6
+427,8
@@
selextend(int col, int row, int type)
if (oldey != sel.oe.y || oldex != sel.oe.x || oldtype != sel.type)
tsetdirt(MIN(sel.nb.y, oldsby), MAX(sel.ne.y, oldsey));
if (oldey != sel.oe.y || oldex != sel.oe.x || oldtype != sel.type)
tsetdirt(MIN(sel.nb.y, oldsby), MAX(sel.ne.y, oldsey));
+
+ sel.mode = done ? SEL_IDLE : SEL_READY;
}
void
}
void