summaryrefslogtreecommitdiffstats
path: root/pager.c
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@osdl.org>2006-02-28 20:26:21 +0100
committerJunio C Hamano <junkio@cox.net>2006-02-28 23:49:32 +0100
commitf67b45f862d17b54037b9b59eefc385624d1fa83 (patch)
tree072f8159ea1d9c39899e7644f251d250de5c976f /pager.c
parentgit-rev-list libification: rev-list walking (diff)
downloadgit-f67b45f862d17b54037b9b59eefc385624d1fa83.tar.xz
git-f67b45f862d17b54037b9b59eefc385624d1fa83.zip
Introduce trivial new pager.c helper infrastructure
This introduces the new function void setup_pager(void); to set up output to be written through a pager applocation. All in preparation for doing the simple scripts in C. Signed-off-by: Linus Torvalds <torvalds@osdl.org> Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'pager.c')
-rw-r--r--pager.c48
1 files changed, 48 insertions, 0 deletions
diff --git a/pager.c b/pager.c
new file mode 100644
index 0000000000..1364e15d23
--- /dev/null
+++ b/pager.c
@@ -0,0 +1,48 @@
+#include "cache.h"
+
+/*
+ * This is split up from the rest of git so that we might do
+ * something different on Windows, for example.
+ */
+
+static void run_pager(void)
+{
+ const char *prog = getenv("PAGER");
+ if (!prog)
+ prog = "less";
+ setenv("LESS", "-S", 0);
+ execlp(prog, prog, NULL);
+}
+
+void setup_pager(void)
+{
+ pid_t pid;
+ int fd[2];
+
+ if (!isatty(1))
+ return;
+ if (pipe(fd) < 0)
+ return;
+ pid = fork();
+ if (pid < 0) {
+ close(fd[0]);
+ close(fd[1]);
+ return;
+ }
+
+ /* return in the child */
+ if (!pid) {
+ dup2(fd[1], 1);
+ close(fd[0]);
+ close(fd[1]);
+ return;
+ }
+
+ /* The original process turns into the PAGER */
+ dup2(fd[0], 0);
+ close(fd[0]);
+ close(fd[1]);
+
+ run_pager();
+ exit(255);
+}