sites

public wiki contents of suckless.org
git clone git://git.suckless.org/sites
Log | Files | Refs

commit 835d132571c264cbd85a21150ba32c98b12b47e8
parent 4c3c113f05cc81c09fb4b8828dc6d23502812ba5
Author: Quentin Rameau <quinq@fifth.space>
Date:   Tue, 11 Sep 2018 19:10:46 +0200

[st] iso14755: rename patch to reflect the master commit

Diffstat:
st.suckless.org/patches/iso14755/index.md | 2+-
st.suckless.org/patches/iso14755/st-iso14755-20180911-5b850e0.diff | 88-------------------------------------------------------------------------------
st.suckless.org/patches/iso14755/st-iso14755-20180911-67d0cb6.diff | 88+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
3 files changed, 89 insertions(+), 89 deletions(-)

diff --git a/st.suckless.org/patches/iso14755/index.md b/st.suckless.org/patches/iso14755/index.md @@ -11,7 +11,7 @@ and then pushed to st. Download -------- -* [st-iso14755-20180911-5b850e0.diff](st-iso14755-20180911-5b850e0.diff) +* [st-iso14755-20180911-67d0cb6.diff](st-iso14755-20180911-67d0cb6.diff) Authors ------- diff --git a/st.suckless.org/patches/iso14755/st-iso14755-20180911-5b850e0.diff b/st.suckless.org/patches/iso14755/st-iso14755-20180911-5b850e0.diff @@ -1,88 +0,0 @@ -diff --git a/config.def.h b/config.def.h -index 823e79f..82b1b09 100644 ---- a/config.def.h -+++ b/config.def.h -@@ -177,6 +177,7 @@ static Shortcut shortcuts[] = { - { TERMMOD, XK_V, clippaste, {.i = 0} }, - { TERMMOD, XK_Y, selpaste, {.i = 0} }, - { TERMMOD, XK_Num_Lock, numlock, {.i = 0} }, -+ { TERMMOD, XK_I, iso14755, {.i = 0} }, - }; - - /* -diff --git a/st.1 b/st.1 -index e8d6059..81bceff 100644 ---- a/st.1 -+++ b/st.1 -@@ -159,6 +159,10 @@ Copy the selected text to the clipboard selection. - .TP - .B Ctrl-Shift-v - Paste from the clipboard selection. -+.TP -+.B Ctrl-Shift-i -+Launch dmenu to enter a unicode codepoint and send the corresponding glyph -+to st. - .SH CUSTOMIZATION - .B st - can be customized by creating a custom config.h and (re)compiling the source -diff --git a/st.c b/st.c -index 574dbee..76bb3ea 100644 ---- a/st.c -+++ b/st.c -@@ -38,11 +38,15 @@ - - /* macros */ - #define IS_SET(flag) ((term.mode & (flag)) != 0) -+#define NUMMAXLEN(x) ((int)(sizeof(x) * 2.56 + 0.5) + 1) - #define ISCONTROLC0(c) (BETWEEN(c, 0, 0x1f) || (c) == '\177') - #define ISCONTROLC1(c) (BETWEEN(c, 0x80, 0x9f)) - #define ISCONTROL(c) (ISCONTROLC0(c) || ISCONTROLC1(c)) - #define ISDELIM(u) (utf8strchr(worddelimiters, u) != NULL) - -+/* constants */ -+#define ISO14755CMD "dmenu -w \"$WINDOWID\" -p codepoint: </dev/null" -+ - enum term_mode { - MODE_WRAP = 1 << 0, - MODE_INSERT = 1 << 1, -@@ -1977,6 +1981,28 @@ tprinter(char *s, size_t len) - } - } - -+void -+iso14755(const Arg *arg) -+{ -+ FILE *p; -+ char *us, *e, codepoint[9], uc[UTF_SIZ]; -+ unsigned long utf32; -+ -+ if (!(p = popen(ISO14755CMD, "r"))) -+ return; -+ -+ us = fgets(codepoint, sizeof(codepoint), p); -+ pclose(p); -+ -+ if (!us || *us == '\0' || *us == '-' || strlen(us) > 7) -+ return; -+ if ((utf32 = strtoul(us, &e, 16)) == ULONG_MAX || -+ (*e != '\n' && *e != '\0')) -+ return; -+ -+ ttywrite(uc, utf8encode(utf32, uc), 1); -+} -+ - void - toggleprinter(const Arg *arg) - { -diff --git a/st.h b/st.h -index 38c61c4..dac64d8 100644 ---- a/st.h -+++ b/st.h -@@ -80,6 +80,7 @@ void die(const char *, ...); - void redraw(void); - void draw(void); - -+void iso14755(const Arg *); - void printscreen(const Arg *); - void printsel(const Arg *); - void sendbreak(const Arg *); diff --git a/st.suckless.org/patches/iso14755/st-iso14755-20180911-67d0cb6.diff b/st.suckless.org/patches/iso14755/st-iso14755-20180911-67d0cb6.diff @@ -0,0 +1,88 @@ +diff --git a/config.def.h b/config.def.h +index 823e79f..82b1b09 100644 +--- a/config.def.h ++++ b/config.def.h +@@ -177,6 +177,7 @@ static Shortcut shortcuts[] = { + { TERMMOD, XK_V, clippaste, {.i = 0} }, + { TERMMOD, XK_Y, selpaste, {.i = 0} }, + { TERMMOD, XK_Num_Lock, numlock, {.i = 0} }, ++ { TERMMOD, XK_I, iso14755, {.i = 0} }, + }; + + /* +diff --git a/st.1 b/st.1 +index e8d6059..81bceff 100644 +--- a/st.1 ++++ b/st.1 +@@ -159,6 +159,10 @@ Copy the selected text to the clipboard selection. + .TP + .B Ctrl-Shift-v + Paste from the clipboard selection. ++.TP ++.B Ctrl-Shift-i ++Launch dmenu to enter a unicode codepoint and send the corresponding glyph ++to st. + .SH CUSTOMIZATION + .B st + can be customized by creating a custom config.h and (re)compiling the source +diff --git a/st.c b/st.c +index 574dbee..76bb3ea 100644 +--- a/st.c ++++ b/st.c +@@ -38,11 +38,15 @@ + + /* macros */ + #define IS_SET(flag) ((term.mode & (flag)) != 0) ++#define NUMMAXLEN(x) ((int)(sizeof(x) * 2.56 + 0.5) + 1) + #define ISCONTROLC0(c) (BETWEEN(c, 0, 0x1f) || (c) == '\177') + #define ISCONTROLC1(c) (BETWEEN(c, 0x80, 0x9f)) + #define ISCONTROL(c) (ISCONTROLC0(c) || ISCONTROLC1(c)) + #define ISDELIM(u) (utf8strchr(worddelimiters, u) != NULL) + ++/* constants */ ++#define ISO14755CMD "dmenu -w \"$WINDOWID\" -p codepoint: </dev/null" ++ + enum term_mode { + MODE_WRAP = 1 << 0, + MODE_INSERT = 1 << 1, +@@ -1977,6 +1981,28 @@ tprinter(char *s, size_t len) + } + } + ++void ++iso14755(const Arg *arg) ++{ ++ FILE *p; ++ char *us, *e, codepoint[9], uc[UTF_SIZ]; ++ unsigned long utf32; ++ ++ if (!(p = popen(ISO14755CMD, "r"))) ++ return; ++ ++ us = fgets(codepoint, sizeof(codepoint), p); ++ pclose(p); ++ ++ if (!us || *us == '\0' || *us == '-' || strlen(us) > 7) ++ return; ++ if ((utf32 = strtoul(us, &e, 16)) == ULONG_MAX || ++ (*e != '\n' && *e != '\0')) ++ return; ++ ++ ttywrite(uc, utf8encode(utf32, uc), 1); ++} ++ + void + toggleprinter(const Arg *arg) + { +diff --git a/st.h b/st.h +index 38c61c4..dac64d8 100644 +--- a/st.h ++++ b/st.h +@@ -80,6 +80,7 @@ void die(const char *, ...); + void redraw(void); + void draw(void); + ++void iso14755(const Arg *); + void printscreen(const Arg *); + void printsel(const Arg *); + void sendbreak(const Arg *);