chiark / gitweb /
fix memleak
[elogind.git] / manager.h
index 53cacdf..287e532 100644 (file)
--- a/manager.h
+++ b/manager.h
@@ -5,6 +5,7 @@
 
 #include <stdbool.h>
 #include <inttypes.h>
+#include <stdio.h>
 
 typedef struct Manager Manager;
 
@@ -17,6 +18,10 @@ typedef struct Manager Manager;
 struct Manager {
         uint32_t current_job_id;
 
+        /* Note that the set of names we know of is allowed to be
+         * incosistent. However the subset of it that is loaded may
+         * not, and the list of jobs may neither. */
+
         /* Active jobs and names */
         Hashmap *names;  /* name string => Name object n:1 */
         Hashmap *jobs;   /* job id => Job object 1:1 */
@@ -24,9 +29,11 @@ struct Manager {
         /* Names that need to be loaded */
         LIST_HEAD(Meta, load_queue); /* this is actually more a stack than a queue, but uh. */
 
-        /* Jobs to be added resp. removed. */
-        Hashmap *jobs_to_add;  /* Name object => Job object 1:1 */
-        Set *jobs_to_remove;
+        /* Jobs to be added */
+        Hashmap *transaction_jobs;      /* Name object => Job object list 1:1 */
+        JobDependency *transaction_anchor;
+
+        bool dispatching_load_queue:1;
 };
 
 Manager* manager_new(void);
@@ -36,6 +43,13 @@ Job *manager_get_job(Manager *m, uint32_t id);
 Name *manager_get_name(Manager *m, const char *name);
 
 int manager_load_name(Manager *m, const char *name, Name **_ret);
-int manager_add_job(Manager *m, JobType job, Name *name, JobMode mode, Job **_ret);
+int manager_add_job(Manager *m, JobType type, Name *name, JobMode mode, bool force, Job **_ret);
+
+void manager_dump_names(Manager *s, FILE *f, const char *prefix);
+void manager_dump_jobs(Manager *s, FILE *f, const char *prefix);
+
+void manager_transaction_unlink_job(Manager *m, Job *j);
+
+void manager_clear_jobs(Manager *m);
 
 #endif