summary refs log tree commit diff
path: root/bin
diff options
context:
space:
mode:
Diffstat (limited to 'bin')
-rw-r--r--bin/man/psfed.17
-rw-r--r--bin/psfed.c16
2 files changed, 10 insertions, 13 deletions
diff --git a/bin/man/psfed.1 b/bin/man/psfed.1
index 59fbdbe7..88430551 100644
--- a/bin/man/psfed.1
+++ b/bin/man/psfed.1
@@ -64,10 +64,6 @@ Select glyph in previous/next row.
 .It Ic y
 Copy the selected glyph.
 .
-.It Ic p
-Paste the copied glyph
-over the selected glyph.
-.
 .It Ic e
 Edit the selected glyph in
 .Sx Edit Mode .
@@ -105,6 +101,9 @@ Flip selected bit.
 .It Ic r
 Invert glyph.
 .
+.It Ic p
+Paste the copied glyph.
+.
 .It Ic u
 Revert glyph to initial state.
 .El
diff --git a/bin/psfed.c b/bin/psfed.c
index 3cdfaec5..cb0a1475 100644
--- a/bin/psfed.c
+++ b/bin/psfed.c
@@ -248,7 +248,6 @@ static struct {
 	uint32_t scale;
 	uint32_t index;
 	bool modified;
-	uint8_t *copy;
 } normal;
 
 static struct {
@@ -257,6 +256,7 @@ static struct {
 	uint32_t x;
 	uint32_t y;
 	uint8_t *undo;
+	uint8_t *copy;
 } edit = {
 	.scale = 4,
 };
@@ -305,16 +305,11 @@ static void inputNormal(char ch) {
 		break; case 'k': normalDec(NormalCols); normalPrint("index");
 		break; case 'j': normalInc(NormalCols); normalPrint("index");
 		break; case 'y': {
-			if (!normal.copy) normal.copy = malloc(header.glyph.size);
-			if (!normal.copy) err(EX_OSERR, "malloc");
-			memcpy(normal.copy, glyph(normal.index), header.glyph.size);
+			if (!edit.copy) edit.copy = malloc(header.glyph.size);
+			if (!edit.copy) err(EX_OSERR, "malloc");
+			memcpy(edit.copy, glyph(normal.index), header.glyph.size);
 			normalPrint("copy");
 		}
-		break; case 'p': {
-			if (!normal.copy) break;
-			normal.modified = true;
-			memcpy(glyph(normal.index), normal.copy, header.glyph.size);
-		}
 		break; case 'e': {
 			normal.modified = true;
 			edit.index = normal.index;
@@ -356,6 +351,9 @@ static void inputEdit(char ch) {
 				}
 			}
 		}
+		break; case 'p': {
+			memcpy(glyph(edit.index), edit.copy, header.glyph.size);
+		}
 		break; case 'u': {
 			memcpy(glyph(edit.index), edit.undo, header.glyph.size);
 		}
1'>Exit focus and paste modes on err exitJune McEnroe 2020-02-11Add startup GPLv3 note and URLJune McEnroe I am a degenerate. 2020-02-11Make sure -D_GNU_SOURCE ends up in CFLAGS on LinuxJune McEnroe 2020-02-11Add note about setting PKG_CONFIG_PATHJune McEnroe 2020-02-11Rename query ID on nick changeJune McEnroe 2020-02-11Call completeClear when closing a windowJune McEnroe 2020-02-11Don't insert color codes for non-mentionsJune McEnroe 2020-02-11Take first two words in colorMentionsJune McEnroe This lets phrases like "hi june" get colored, but still doesn't get carried away. 2020-02-11Use time_t for save signatureJune McEnroe It's actually more likely to be 64-bit than size_t anyway, and it eliminates some helper functions. Also don't error when reading an empty save file. 2020-02-11Set self.nick to * initiallyJune McEnroe Allows removing a bunch of checks that self.nick is set, and it's what the server usually calls you before registration. Never highlight notices as mentions. 2020-02-11Define ColorCap instead of hardcoding 100June McEnroe 2020-02-11Move hash to top of chat.hJune McEnroe 2020-02-11Move base64 out of chat.hJune McEnroe 2020-02-11Move XDG_SUBDIR out of chat.hJune McEnroe 2020-02-11Fix whois idle unit calculationJune McEnroe Rookie mistake. 2020-02-11Cast towupper to wchar_tJune McEnroe For some reason it takes and returns wint_t... 2020-02-11Cast set but unused variables to voidJune McEnroe 2020-02-11Declare strlcatJune McEnroe 2020-02-11Check if VDSUSP existsJune McEnroe 2020-02-11Fix completeReplace iterationJune McEnroe 2020-02-11Use pkg(8) to configure on FreeBSDJune McEnroe 2020-02-11Remove legacy codeJune McEnroe 2020-02-11Add INSTALLING section to READMEJune McEnroe