worktree.c: add find_worktree()
authorNguyễn Thái Ngọc Duy <pclouds@gmail.com>
Fri, 3 Jun 2016 12:19:39 +0000 (19:19 +0700)
committerJunio C Hamano <gitster@pobox.com>
Sat, 4 Jun 2016 04:58:18 +0000 (21:58 -0700)
So far we haven't needed to identify an existing worktree from command
line. Future commands such as lock or move will need it. The current
implementation identifies worktrees by path (*). In future, the function
could learn to identify by $(basename $path) or tags...

(*) We could probably go cheaper with comparing inode number (and
probably more reliable than paths when unicode enters the game). But not
all systems have good inode that so let's stick to something simple for
now.

Helped-by: Eric Sunshine <sunshine@sunshineco.com>
Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
worktree.c
worktree.h
index f4a4f3809298023250e51b780687c0305e67cef6..0782e00983d5a0dbcbeefa222d21352aa54dc7cc 100644 (file)
@@ -214,6 +214,21 @@ const char *get_worktree_git_dir(const struct worktree *wt)
                return git_common_path("worktrees/%s", wt->id);
 }
 
+struct worktree *find_worktree(struct worktree **list,
+                              const char *prefix,
+                              const char *arg)
+{
+       char *path;
+
+       arg = prefix_filename(prefix, strlen(prefix), arg);
+       path = xstrdup(real_path(arg));
+       for (; *list; list++)
+               if (!fspathcmp(path, real_path((*list)->path)))
+                       break;
+       free(path);
+       return *list;
+}
+
 int is_worktree_being_rebased(const struct worktree *wt,
                              const char *target)
 {
index 13949093cc1610fcafbefb22d1f8b9441fbd4ade..7ad15da0dcbab77d3baa110cd95a6d23c2ee334a 100644 (file)
@@ -29,6 +29,14 @@ extern struct worktree **get_worktrees(void);
  */
 extern const char *get_worktree_git_dir(const struct worktree *wt);
 
+/*
+ * Search a worktree that can be unambiguously identified by
+ * "arg". "prefix" must not be NULL.
+ */
+extern struct worktree *find_worktree(struct worktree **list,
+                                     const char *prefix,
+                                     const char *arg);
+
 /*
  * Free up the memory for worktree(s)
  */