X-Git-Url: http://git.roojs.org/?a=blobdiff_plain;f=RooProject.vala;h=b46ee7df5f1a1ccb505a10f4466513c1bf6ed50d;hb=9799aecc2d608dda31677ca4f704e4f2bbc7f801;hp=d869bbea0c991190f82edd3bd669a7691d30c39c;hpb=2573b2897cb15085423ed1e1cdf3fe340f187532;p=gitlive diff --git a/RooProject.vala b/RooProject.vala index d869bbea..b46ee7df 100644 --- a/RooProject.vala +++ b/RooProject.vala @@ -1,25 +1,39 @@ +/** +This a mostly a static class that manages an array of it'self... +*/ static RooProject _RooProject; public class RooProject : Object { - public static RooProject singleton() - { - - _RooProject = new RooProject(); - RooTicket.projects = new Gee.ArrayList(); - RooTicket.loadProjects(); - - } - return _RooTicket; - } public string id; // not really important that they are numbers.. public string code; public string name; public string type; + + // --- static from here on.... + + + static Gee.ArrayList _projects; + static int loadcount = 0; + const string roourl = "https://roojs.com/admin.php/Roo"; + + + static RooProject singleton() + { + if (_RooProject == null) { + _RooProject = new RooProject(); + RooProject.loadcount = 0; + RooProject.loadProjects(); + + } + return _RooProject; + } + + public static Gee.ArrayList projects() { RooProject.singleton(); @@ -27,9 +41,44 @@ public class RooProject : Object return RooProject._projects; } - static public RooProject addProject(Json.Object t) + + public static RooProject? getProjectByRepo(GitRepo repo) { + RooProject.singleton(); + // fixme -- needs to get from rep list.. + var rt = RooTicket.singleton(); + if (rt.repos.size < 1) { + rt.loadRepos(); + } + + + var pid = ""; + foreach(var roo_repo in rt.repos) { + if (roo_repo.shortname == repo.name) { + pid = roo_repo.project_id; + break; + } + } + if (pid == "") { + GLib.debug("getProjectByRepo: repo has no project"); + return null; + } + // get project by id... + foreach(var roo_project in RooProject.projects()) { + if (roo_project.id == pid) { + GLib.debug("getProjectByRepo: project_id = %s", pid); + return roo_project; + } + } + GLib.debug("getProjectByRepo: can not find project"); + return null; + + } + + + public static RooProject addProject(Json.Object t) + { RooProject.singleton(); // init... var add = new RooProject(); @@ -41,13 +90,21 @@ public class RooProject : Object GLib.debug("ADD project %s : %s : %s", add.id, add.code, add.name); return add; } - + + public static void reload() /// has to be called on singleton.. + { + RooProject.loadcount = 0; + RooProject.singleton(); + if (RooProject.loadcount == 0 ) { + RooProject.loadProjects(); + } + } static void loadProjects() // called from singleton... { - RooTicket.singleton().projects = new Gee.ArrayList(); + RooProject._projects = new Gee.ArrayList(); - + RooProject.loadcount ++; var table = new GLib.HashTable(str_hash, str_equal); table.insert("query[project_filter]","P,N,U"); @@ -86,9 +143,9 @@ public class RooProject : Object var rd = response.get_array_member ("data"); // got a valid result... - var _this = RooTicket.singleton(); + for(var i = 0; i < rd.get_length(); i++) { - _this.addProject(rd.get_object_element(i)); + RooProject.addProject(rd.get_object_element(i)); }