Merge branch 'jc/merge'
[git/gitweb-caching.git] / pager.c
blob4587fbbdb51e50c1e3e6e4c3476cdccd4ac59cee
1 #include "cache.h"
3 /*
4 * This is split up from the rest of git so that we might do
5 * something different on Windows, for example.
6 */
8 static void run_pager(const char *pager)
10 execlp(pager, pager, NULL);
11 execl("/bin/sh", "sh", "-c", pager, NULL);
14 void setup_pager(void)
16 pid_t pid;
17 int fd[2];
18 const char *pager = getenv("GIT_PAGER");
20 if (!isatty(1))
21 return;
22 if (!pager)
23 pager = getenv("PAGER");
24 if (!pager)
25 pager = "less";
26 else if (!*pager || !strcmp(pager, "cat"))
27 return;
29 pager_in_use = 1; /* means we are emitting to terminal */
31 if (pipe(fd) < 0)
32 return;
33 pid = fork();
34 if (pid < 0) {
35 close(fd[0]);
36 close(fd[1]);
37 return;
40 /* return in the child */
41 if (!pid) {
42 dup2(fd[1], 1);
43 close(fd[0]);
44 close(fd[1]);
45 return;
48 /* The original process turns into the PAGER */
49 dup2(fd[0], 0);
50 close(fd[0]);
51 close(fd[1]);
53 setenv("LESS", "FRSX", 0);
54 run_pager(pager);
55 die("unable to execute pager '%s'", pager);
56 exit(255);