diff options
author | June McEnroe <june@causal.agency> | 2020-09-04 18:41:04 -0400 |
---|---|---|
committer | June McEnroe <june@causal.agency> | 2020-09-04 18:41:04 -0400 |
commit | c738cb62a069f5b9dedde8730341edb45b7a3bbb (patch) | |
tree | 65f3da7530047a2b3091b089a8ae53c4daf01d57 | |
parent | Build fbclock with -lz (diff) | |
download | src-c738cb62a069f5b9dedde8730341edb45b7a3bbb.tar.gz src-c738cb62a069f5b9dedde8730341edb45b7a3bbb.zip |
Add nudge
Diffstat (limited to '')
-rw-r--r-- | bin/.gitignore | 1 | ||||
-rw-r--r-- | bin/Makefile | 1 | ||||
-rw-r--r-- | bin/README.7 | 4 | ||||
-rw-r--r-- | bin/man1/nudge.1 | 38 | ||||
-rw-r--r-- | bin/nudge.c | 68 |
5 files changed, 111 insertions, 1 deletions
diff --git a/bin/.gitignore b/bin/.gitignore index cf808c77..6daf18fc 100644 --- a/bin/.gitignore +++ b/bin/.gitignore @@ -14,6 +14,7 @@ glitch hi hnel modem +nudge open order pbcopy diff --git a/bin/Makefile b/bin/Makefile index 61e405c0..28136ad2 100644 --- a/bin/Makefile +++ b/bin/Makefile @@ -28,6 +28,7 @@ BINS += glitch BINS += hi BINS += hnel BINS += modem +BINS += nudge BINS += order BINS += pbd BINS += pngo diff --git a/bin/README.7 b/bin/README.7 index 16d86c67..a0fcb236 100644 --- a/bin/README.7 +++ b/bin/README.7 @@ -1,4 +1,4 @@ -.Dd June 17, 2020 +.Dd September 4, 2020 .Dt BIN 7 .Os "Causal Agency" . @@ -42,6 +42,8 @@ syntax highlighter PTY input remapper .It Xr modem 1 fixed baud rate wrapper +.It Xr nudge 1 +terminal vibrator .It Xr order 1 operator precedence .It Xr pbd 1 diff --git a/bin/man1/nudge.1 b/bin/man1/nudge.1 new file mode 100644 index 00000000..143a24ba --- /dev/null +++ b/bin/man1/nudge.1 @@ -0,0 +1,38 @@ +.Dd September 4, 2020 +.Dt NUDGE 1 +.Os +. +.Sh NAME +.Nm nudge +.Nd terminal vibrator +. +.Sh SYNOPSIS +.Nm +.Op Fl n Ar count +.Op Fl s Ar shake +.Op Fl t Ar delay +. +.Sh DESCRIPTION +The +.Nm +utility +nudges the terminal. +An +.Xr xterm 1 +compatible terminal is required. +. +.Pp +The arguments are as follows: +.Bl -tag -width Ds +.It Fl n Ar count +Set the number of times +to nudge the terminal. +The default is 2. +.It Fl s Ar shake +Set the shake intensity in pixels. +The default is 10. +.It Fl t Ar delay +Set the interval between shakes +in milliseconds. +The default is 20. +.El diff --git a/bin/nudge.c b/bin/nudge.c new file mode 100644 index 00000000..438828a5 --- /dev/null +++ b/bin/nudge.c @@ -0,0 +1,68 @@ +/* Copyright (C) 2020 June McEnroe <june@causal.agency> + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + */ + +#include <err.h> +#include <stdio.h> +#include <stdlib.h> +#include <sysexits.h> +#include <termios.h> +#include <unistd.h> + +static int shake = 10; +static int delay = 20000; +static int count = 2; + +static void move(int x, int y) { + fprintf(stderr, "\33[3;%d;%dt", x, y); + usleep(delay); +} + +int main(int argc, char *argv[]) { + for (int opt; 0 < (opt = getopt(argc, argv, "n:s:t:"));) { + switch (opt) { + break; case 'n': count = atoi(optarg); + break; case 's': shake = atoi(optarg); + break; case 't': delay = atoi(optarg) * 1000; + break; default: return EX_USAGE; + } + } + + struct termios save; + int error = tcgetattr(STDIN_FILENO, &save); + if (error) err(EX_IOERR, "tcgetattr"); + + struct termios raw = save; + cfmakeraw(&raw); + error = tcsetattr(STDIN_FILENO, TCSAFLUSH, &raw); + if (error) err(EX_IOERR, "tcsetattr"); + + int x, y; + fprintf(stderr, "\33[13t"); + int n = scanf("\33[3;%d;%dt", &x, &y); + + error = tcsetattr(STDIN_FILENO, TCSANOW, &save); + if (error) err(EX_IOERR, "tcsetattr"); + if (n < 2) return EX_CONFIG; + + fprintf(stderr, "\33[5t"); + for (int i = 0; i < count; ++i) { + move(x - shake, y); + move(x, y + shake); + move(x + shake, y); + move(x, y - shake); + move(x, y); + } +} |