]> git.ipfire.org Git - people/ms/systemd.git/blame - manager.h
implement hashmap_copy() and hashmap_merge()
[people/ms/systemd.git] / manager.h
CommitLineData
60918275
LP
1/*-*- Mode: C; c-basic-offset: 8 -*-*/
2
3#ifndef foomanagerhfoo
4#define foomanagerhfoo
5
6#include <stdbool.h>
7#include <inttypes.h>
8
9typedef struct Manager Manager;
10
11#include "name.h"
12#include "job.h"
13#include "hashmap.h"
14#include "list.h"
15#include "set.h"
16
17struct Manager {
18 uint32_t current_job_id;
19
20 /* Active jobs and names */
21 Hashmap *names; /* name string => Name object n:1 */
22 Hashmap *jobs; /* job id => Job object 1:1 */
23
24 /* Names that need to be loaded */
25 LIST_HEAD(Meta, load_queue); /* this is actually more a stack than a queue, but uh. */
26
27 /* Jobs to be added resp. removed. */
28 Hashmap *jobs_to_add; /* Name object => Job object 1:1 */
29 Set *jobs_to_remove;
223dabab
LP
30
31 bool dispatching_load_queue:1;
60918275
LP
32};
33
34Manager* manager_new(void);
35void manager_free(Manager *m);
36
37Job *manager_get_job(Manager *m, uint32_t id);
38Name *manager_get_name(Manager *m, const char *name);
39
40int manager_load_name(Manager *m, const char *name, Name **_ret);
41int manager_add_job(Manager *m, JobType job, Name *name, JobMode mode, Job **_ret);
42
43#endif