2 represent a git branch..
5 Does repo require branching? - flag in config?
6 ** list of repo's ?? with ability to turn on/off
8 Start editing without branch?
9 -> show prompt to start branch
10 -> flag a ticket? optional ??
12 Once editing branch...
13 -> merge with squash / ticket...
14 ** show list of repo's with 'working' branches?
15 ** select some/all to merge with a issue fix..
17 ?? closing ticket in system ??
20 need to push all? / fetch all?
28 public class GitBranch : Object
32 public bool active = false;
33 public string lastrev = "";
34 public string name = "";
35 public string remote = "";
36 public string remoterev = "";
38 public GitBranch(GitRepo repo)
43 public static void loadBranches(GitRepo repo)
45 repo.branches = new Gee.HashMap<string,GitBranch>();
47 var branches = new Gee.HashMap<string,GitBranch>();
49 string[] cmd = { "branch", "--no-color", "--verbose", "--no-abbrev" , "-a" };
50 var res = repo.git( cmd );
51 var lines = res.split("\n");
52 for (var i = 0; i < lines.length ; i++) {
53 var br = new GitBranch(repo);
54 if (!br.parseBranchListItem(lines[i])) {
57 GLib.debug("add branch %s", br.realName());
59 branches.set(br.realName(), br);
61 repo.currentBranch = br;
67 "--format", "%(refname:short):remotes/%(upstream:short)",
72 repo.branches = branches;
79 public bool parseBranchListItem(string str)
84 this.active = str[0] == '*';
86 var parts = Regex.split_simple ("[ \t]+", str.substring(2).strip());
87 if (parts[1] == "->") { // it's an alias.. eg. remotes/origin/HEAD -> origin/master..
91 this.lastrev = parts[1];
92 if (parts[0].has_prefix("remotes/")) {
93 this.remote = parts[0];
99 public string realName()
101 return this.name == "" ? this.remote : this.name;