summary refs log tree commit diff
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--edit.c49
1 files changed, 43 insertions, 6 deletions
diff --git a/edit.c b/edit.c
index 6b044cb..dde3396 100644
--- a/edit.c
+++ b/edit.c
@@ -58,9 +58,6 @@ static void home(void) {
 static void end(void) {
 	line.ptr = line.end;
 }
-static void kill(void) {
-	line.end = line.ptr;
-}
 
 static void backspace(void) {
 	if (line.ptr == line.buf) return;
@@ -96,6 +93,38 @@ static void enter(void) {
 	line.end = line.buf;
 }
 
+static void backWord(void) {
+	left();
+	editHead();
+	wchar_t *word = wcsrchr(line.buf, ' ');
+	editTail();
+	line.ptr = (word ? &word[1] : line.buf);
+}
+static void foreWord(void) {
+	right();
+	editHead();
+	editTail();
+	wchar_t *word = wcschr(line.ptr, ' ');
+	line.ptr = (word ? word : line.end);
+}
+
+static void killBackWord(void) {
+	wchar_t *from = line.ptr;
+	backWord();
+	wmemmove(line.ptr, from, line.end - from);
+	line.end -= from - line.ptr;
+}
+static void killForeWord(void) {
+	wchar_t *from = line.ptr;
+	foreWord();
+	wmemmove(from, line.ptr, line.end - line.ptr);
+	line.end -= line.ptr - from;
+	line.ptr = from;
+}
+static void killLine(void) {
+	line.end = line.ptr;
+}
+
 static char *prefix;
 static void complete(void) {
 	if (!line.tab) {
@@ -151,8 +180,15 @@ static void reject(void) {
 }
 
 static bool editMeta(wchar_t ch) {
-	(void)ch;
-	return false;
+	switch (ch) {
+		break; case L'b':  reject(); backWord();
+		break; case L'f':  reject(); foreWord();
+		break; case L'\b': reject(); killBackWord();
+		break; case L'd':  reject(); killForeWord();
+
+		break; default: return false;
+	}
+	return true;
 }
 
 static bool editCtrl(wchar_t ch) {
@@ -162,7 +198,8 @@ static bool editCtrl(wchar_t ch) {
 		break; case L'A': reject(); home();
 		break; case L'E': reject(); end();
 		break; case L'D': reject(); delete();
-		break; case L'K': reject(); kill();
+		break; case L'W': reject(); killBackWord();
+		break; case L'K': reject(); killLine();
 
 		break; case L'C': accept(); insert(IRC_COLOR);
 		break; case L'N': accept(); insert(IRC_RESET);
ond on a big PNG screenshot. Almost all the remaining time is spent in deflate. 2021-09-21Rewrite pngo, add explicit optionsJune McEnroe Interesting to see how my code habits have changed. 2021-09-16Fix /* **/ comment matchingJune McEnroe 2021-09-15Remove typer, add downgrade to READMEJune McEnroe 2021-09-15Set bot mode on downgradeJune McEnroe 2021-09-15Enter capsicum in downgradeJune McEnroe 2021-09-15Factor out common parts of downgrade messagesJune McEnroe Also bump the message cap to 1024 because that is ostensibly useful for replying to older messages. 2021-09-14Add downgrade IRC botJune McEnroe 2021-09-14Sort by title if authors matchJune McEnroe There are probably better things to sort by but title definitely always exists. 2021-09-13Swap-remove tags as they're foundJune McEnroe This makes it even faster. From ~1s on a sqlite3.c amalgamation to ~0.85s. 2021-09-12Replace htagml regex with strncmpJune McEnroe Since ctags only ever produces regular expressions of the form /^re$/ or /^re/ with no other special characters, instead unescape the pattern and simply use strncmp. Running on a sqlite3.c amalgamation, the regex version takes ~37s while the strncmp version takes ~1s, producing identical output. Big win! 2021-09-11Also defer printing comment for lone close-parensJune McEnroe 2021-09-10Publish "git-comment"June McEnroe 2021-09-10Add git comment --pretty optionJune McEnroe 2021-09-08Defer printing comment if line is blank or closing braceJune McEnroe This fixes badly indented comments. 2021-09-08Up default min-repeat to 30 linesJune McEnroe 2021-09-08Handle dirty lines in git-commentJune McEnroe 2021-09-08Document and install git-commentJune McEnroe 2021-09-08Add repeat and all options to git-commentJune McEnroe 2021-09-08Add group threshold to git-commentJune McEnroe