X-Git-Url: http://git.roojs.org/?a=blobdiff_plain;f=GitRepo.vala;h=3c258357f9ba886c4d03ce6bec6a5f510ebdb87b;hb=c8bc028311655fb453141768779b772a063f4b2c;hp=e18872b2c73216a3f2b11c1e73a4e93d1c3459ef;hpb=9adf374263e53c2dd89f2b3d583374c7b99fe68a;p=gitlive diff --git a/GitRepo.vala b/GitRepo.vala index e18872b2..3c258357 100644 --- a/GitRepo.vala +++ b/GitRepo.vala @@ -25,7 +25,9 @@ public class GitRepo : Object public string ahead_or_behind = ""; public Gee.HashMap ignore_files; - public GitBranch currentBranch; + + public GitBranch currentBranch; + public Gee.HashMap branches; // accessed in GitBranch.. public RooTicket? activeTicket; public Gee.HashMap cache; @@ -48,7 +50,7 @@ public class GitRepo : Object */ public static int indexOf( Array repos, string gitpath) { // make a fake object to compare against.. - var test_repo = GitRepo.get(gitpath); + var test_repo = GitRepo.get_sync(gitpath); for(var i =0; i < repos.length; i++) { if (repos.index(i).gitdir == test_repo.gitdir) { @@ -128,7 +130,7 @@ public class GitRepo : Object continue; } - var rep = GitRepo.get( sp ); + var rep = GitRepo.get_sync( sp ); list_cache.append_val(rep); } @@ -137,13 +139,39 @@ public class GitRepo : Object } - public static GitRepo get(string path) + public static GitRepo get_sync(string path) { + GitRepo ret; var cache = GitRepo.singleton().cache; if (cache.has_key(path)) { - return cache.get(path); + ret = cache.get(path); + } else { + ret = new GitRepo(path); } - return new GitRepo(path); + return ret; + } + + public static async GitRepo? get(string path) + { + + SourceFunc callback = GitRepo.get.callback; + GitRepo ret = null; + ThreadFunc run = () => { + + var cache = GitRepo.singleton().cache; + if (cache.has_key(path)) { + ret = cache.get(path); + } else { + ret = new GitRepo(path); + } + Idle.add((owned) callback); + return true; + + }; + new Thread("thread-new-gitrepo", run); + yield; + return ret; + } private GitRepo.single() { @@ -927,7 +955,43 @@ public class GitRepo : Object } - + + public void doUpdate() + { + // update the branches.. + + + } + + + public static void updateAllAsync(string after) + { + var done = 0; + + var tr = GitRepo.singleton().cache; + + var update_all_total = tr.size; + foreach(var repo in tr.values) { + repo.doUpdate.begin((obj, res) => { + GitRepo.updateRepo.end(res); + done++; + if (update_all_total != done) { + return; + } + switch (after) { + case "show_clones": + Clones.singleton().show(); + break; + default: + GLib.debug("Unkown call after load = %s", update_all_after); + break; + } + } + } + + + } + @@ -958,6 +1022,9 @@ public class GitRepo : Object } GLib.debug("calls total = %d", (int) update_all_total); } + + + public static void updateAllCallback(GitRepo repo, int err, string res) { repo.loadBranches();