aboutsummaryrefslogtreecommitdiffstats
path: root/terms.c
diff options
context:
space:
mode:
authorbptato <nincsnevem662@gmail.com>2021-02-19 22:46:07 +0000
committerbptato <nincsnevem662@gmail.com>2021-02-19 22:48:52 +0000
commit081f42e35c793bc79e95628e15dbe9147637c45e (patch)
treea427842ca43f94ad82816a1876fabb517d1ea45f /terms.c
parentFix potential segfault (diff)
downloadw3m-081f42e35c793bc79e95628e15dbe9147637c45e.tar.gz
w3m-081f42e35c793bc79e95628e15dbe9147637c45e.zip
Convert images to PNG for kitty with ImageMagick
Diffstat (limited to '')
-rw-r--r--terms.c81
1 files changed, 65 insertions, 16 deletions
diff --git a/terms.c b/terms.c
index 04a1bcb..37d23bb 100644
--- a/terms.c
+++ b/terms.c
@@ -546,15 +546,75 @@ put_image_iterm2(char *url, int x, int y, int w, int h)
MOVE(Currentbuf->cursorY,Currentbuf->cursorX);
}
+void ttymode_set(int mode, int imode);
+void ttymode_reset(int mode, int imode);
+
void
put_image_kitty(char *url, int x, int y, int w, int h, int sx, int sy, int sw,
int sh, int cols, int rows)
{
Str buf;
- char *base64, *cbuf, *type;
+ char *base64, *cbuf, *type, *tmpf;
+ char *argv[4];
FILE *fp;
int c, i, j, k, t;
struct stat st;
+ pid_t pid;
+ MySignalHandler(*volatile previntr) (SIGNAL_ARG);
+ MySignalHandler(*volatile prevquit) (SIGNAL_ARG);
+ MySignalHandler(*volatile prevstop) (SIGNAL_ARG);
+
+ if (!url)
+ return;
+
+ type = guessContentType(url);
+ t = 100; /* always convert to png for now. */
+
+ if(!(type && !strcasecmp(type, "image/png"))) {
+ buf = Strnew();
+ tmpf = Sprintf("%s/%s.png", tmp_dir, mybasename(url))->ptr;
+
+ /* convert only if png doesn't exist yet. */
+
+ if (stat(tmpf, &st)) {
+ if (stat(url, &st))
+ return;
+
+ flush_tty();
+
+ previntr = mySignal(SIGINT, SIG_IGN);
+ prevquit = mySignal(SIGQUIT, SIG_IGN);
+ prevstop = mySignal(SIGTSTP, SIG_IGN);
+
+ if ((pid = fork()) == 0) {
+ i = 0;
+
+ close(STDERR_FILENO); /* Don't output error message. */
+ ttymode_set(ISIG, 0);
+
+ if ((cbuf = getenv("W3M_KITTY_TO_PNG")))
+ argv[i++] = cbuf;
+ else
+ argv[i++] = "convert";
+
+ argv[i++] = url;
+ argv[i++] = tmpf;
+ argv[i++] = NULL;
+ execvp(argv[0],argv);
+ exit(0);
+ }
+ else if (pid > 0) {
+ waitpid(pid, &i, 0);
+ ttymode_reset(ISIG, 0);
+ mySignal(SIGINT, previntr);
+ mySignal(SIGQUIT, prevquit);
+ mySignal(SIGTSTP, prevstop);
+ }
+
+ pushText(fileToDelete, tmpf);
+ }
+ url = tmpf;
+ }
if (stat(url, &st))
return;
@@ -563,18 +623,10 @@ put_image_kitty(char *url, int x, int y, int w, int h, int sx, int sy, int sw,
if (!fp)
return;
- type = guessContentType(url);
- if(type && !strcasecmp(type, "image/png")) {
- t = 100;
- } else {
- /* TODO: kitty +kitten icat or link imlib/gdkpixbuf? */
- return;
- }
-
MOVE(y, x);
- buf = Sprintf("\x1b_Gf=100,s=%d,v=%d,a=T,m=1,X=%d,Y=%d,x=%d,y=%d,"
+ buf = Sprintf("\x1b_Gf=100,s=%d,v=%d,a=T,m=1,x=%d,y=%d,"
"w=%d,h=%d,c=%d,r=%d;",
- w, h, x, y, sx, sy, sw, sh, cols, rows);
+ w, h, sx, sy, sw, sh, cols, rows);
cbuf = GC_MALLOC_ATOMIC(3072);
@@ -591,9 +643,9 @@ put_image_kitty(char *url, int x, int y, int w, int h, int sx, int sy, int sw,
return;
if (c == EOF)
- buf = Sprintf("\x1b_Gf=100,s=%d,v=%d,a=T,m=0,X=%d,Y=%d,x=%d,y=%d,"
+ buf = Sprintf("\x1b_Gf=100,s=%d,v=%d,a=T,m=0,x=%d,y=%d,"
"w=%d,h=%d,c=%d,r=%d;",
- w, h, x, y, sx, sy, sw, sh, cols, rows);
+ w, h, sx, sy, sw, sh, cols, rows);
writestr(buf->ptr);
buf = Sprintf("%s\x1b\\", base64);
@@ -722,9 +774,6 @@ save_first_animation_frame(const char *path)
return NULL;
}
-void ttymode_set(int mode, int imode);
-void ttymode_reset(int mode, int imode);
-
void
put_image_sixel(char *url, int x, int y, int w, int h, int sx, int sy, int sw, int sh, int n_terminal_image)
{