aboutsummaryrefslogtreecommitdiffstats
path: root/search.c
diff options
context:
space:
mode:
authorFumitoshi UKAI <ukai@debian.or.jp>2003-01-22 16:10:27 +0000
committerFumitoshi UKAI <ukai@debian.or.jp>2003-01-22 16:10:27 +0000
commitb8b4edb15b7c1eca41c6272a197b37574d5c8238 (patch)
tree6b5680ba64aacb350b972e377e883c37e32909cf /search.c
parent[w3m-dev 03675] x-face (diff)
downloadw3m-b8b4edb15b7c1eca41c6272a197b37574d5c8238.tar.gz
w3m-b8b4edb15b7c1eca41c6272a197b37574d5c8238.zip
[w3m-dev 03676] cleanup for pipe
* etc.c (open_pipe_rw): added * file.c (uncompress_stream): rewrite using open_pipe_rw * image.c (openImgdisplay): rewrite using open_pipe_rw * local.c (localcgi_popen_rw): deleted (localcgi_post): rewrite using open_pipe_rw * proto.h (open_pipe_rw): added * search.c (migemor): initialized to NULL (migemow): initialized to NULL (migemo_pid): initialized to 0 (open_migemo): rewrite using open_pipe_rw From: Hironori SAKAMOTO <hsaka@mth.biglobe.ne.jp>
Diffstat (limited to 'search.c')
-rw-r--r--search.c35
1 files changed, 6 insertions, 29 deletions
diff --git a/search.c b/search.c
index e818597..e671f85 100644
--- a/search.c
+++ b/search.c
@@ -1,4 +1,4 @@
-/* $Id: search.c,v 1.24 2003/01/17 16:57:20 ukai Exp $ */
+/* $Id: search.c,v 1.25 2003/01/22 16:10:29 ukai Exp $ */
#include "fm.h"
#include "regex.h"
#include <signal.h>
@@ -14,9 +14,9 @@ set_mark(Line *l, int pos, int epos)
#ifdef USE_MIGEMO
/* Migemo: romaji --> kana+kanji in regexp */
-static FILE *migemor, *migemow;
+static FILE *migemor = NULL, *migemow = NULL;
static int migemo_running;
-static int migemo_pid;
+static int migemo_pid = 0;
void
init_migemo()
@@ -35,41 +35,18 @@ init_migemo()
static int
open_migemo(char *migemo_command)
{
- int fdr[2];
- int fdw[2];
-
- if (pipe(fdr) < 0)
- goto err0;
- if (pipe(fdw) < 0)
- goto err1;
-
- flush_tty();
- /* migemow:fdw[1] -|-> fdw[0]=0 {migemo} fdr[1]=1 -|-> fdr[0]:migemor */
- migemo_pid = fork();
+ migemo_pid = open_pipe_rw(&migemor, &migemow);
if (migemo_pid < 0)
- goto err2;
+ goto err0;
if (migemo_pid == 0) {
/* child */
- close(fdr[0]);
- close(fdw[1]);
- dup2(fdw[0], 0);
- dup2(fdr[1], 1);
setup_child(FALSE, 2, -1);
myExec(migemo_command);
/* XXX: ifdef __EMX__, use start /f ? */
}
- close(fdr[1]);
- close(fdw[0]);
- migemor = fdopen(fdr[0], "r");
- migemow = fdopen(fdw[1], "w");
return 1;
- err2:
- close(fdw[0]);
- close(fdw[1]);
- err1:
- close(fdr[0]);
- close(fdr[1]);
err0:
+ migemo_pid = 0;
migemo_active = migemo_running = 0;
return 0;
}