summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 52e3a2e)
raw | patch | inline | side by side (parent: 52e3a2e)
| author | Jonas Fonseca <fonseca@diku.dk> | |
| Sat, 17 Jan 2009 09:08:41 +0000 (10:08 +0100) | ||
| committer | Jonas Fonseca <fonseca@diku.dk> | |
| Wed, 21 Jan 2009 22:21:06 +0000 (23:21 +0100) | 
| NEWS | patch | blob | history | |
| tig.c | patch | blob | history | 
index 2dda5202420c40a32e36c2e85be304a60e8d9caa..9eb36d552066ef25ea18fd8719f6118f43109df7 100644 (file)
--- a/NEWS
+++ b/NEWS
 Improvements:
  - Tree view: avoid flickering when updating.
+ - Tree & blob view: open any blob in an editor.
 Bug fixes:
index 74f78df589921a65ae038903944c2f4c0be5029e..70845310300e9890d9d1ded8947fcc1ac281c234 100644 (file)
--- a/tig.c
+++ b/tig.c
        IO_FG,                  /* Execute command with same std{in,out,err}. */
        IO_RD,                  /* Read only fork+exec IO. */
        IO_WR,                  /* Write only fork+exec IO. */
+       IO_AP,                  /* Append fork+exec output to file. */
 };
 struct io {
        if ((io->type == IO_RD || io->type == IO_WR) &&
            pipe(pipefds) < 0)
                return FALSE;
+       else if (io->type == IO_AP)
+               pipefds[1] = io->pipe;
        if ((io->pid = fork())) {
                if (pipefds[!(io->type == IO_WR)] != -1)
                if (io->type != IO_FG) {
                        int devnull = open("/dev/null", O_RDWR);
                        int readfd  = io->type == IO_WR ? pipefds[0] : devnull;
-                       int writefd = io->type == IO_RD ? pipefds[1] : devnull;
+                       int writefd = (io->type == IO_RD || io->type == IO_AP)
+                                                       ? pipefds[1] : devnull;
                        dup2(readfd,  STDIN_FILENO);
                        dup2(writefd, STDOUT_FILENO);
        return run_io_do(&io);
 }
+static bool
+run_io_append(const char **argv, enum format_flags flags, int fd)
+{
+       struct io io = {};
+
+       init_io(&io, NULL, IO_AP);
+       io.pipe = fd;
+       if (format_argv(io.argv, argv, flags))
+               return run_io_do(&io);
+       close(fd);
+       return FALSE;
+}
+
 static bool
 run_io_rd(struct io *io, const char **argv, enum format_flags flags)
 {
        return TRUE;
 }
+static void
+open_blob_editor()
+{
+       char file[SIZEOF_STR] = "/tmp/tigblob.XXXXXX";
+       int fd = mkstemp(file);
+
+       if (fd == -1)
+               report("Failed to create temporary file");
+       else if (!run_io_append(blob_ops.argv, FORMAT_ALL, fd))
+               report("Failed to save blob data to file");
+       else
+               open_editor(FALSE, file);
+       if (fd != -1)
+               unlink(file);
+}
+
 static enum request
 tree_request(struct view *view, enum request request, struct line *line)
 {
                if (line->type != LINE_TREE_FILE) {
                        report("Edit only supported for files");
                } else if (!is_head_commit(view->vid)) {
-                       report("Edit only supported for files in the current work tree");
+                       open_blob_editor();
                } else {
                        open_editor(TRUE, opt_file);
                }
        return add_line_text(view, line, LINE_DEFAULT) != NULL;
 }
+static enum request
+blob_request(struct view *view, enum request request, struct line *line)
+{
+       switch (request) {
+       case REQ_EDIT:
+               open_blob_editor();
+               return REQ_NONE;
+       default:
+               return pager_request(view, request, line);
+       }
+}
+
 static const char *blob_argv[SIZEOF_ARG] = {
        "git", "cat-file", "blob", "%(blob)", NULL
 };
        NULL,
        blob_read,
        pager_draw,
-       pager_request,
+       blob_request,
        pager_grep,
        pager_select,
 };
![[tokkee]](http://tokkee.org/images/avatar.png)
