X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fmachine%2Fmachine.h;h=7b27aa27e0ec53e2e880be2f4146eef56349642b;hb=4cee5eede280b7fd48c18a1942616c4ac896a554;hp=7501fa372e32eba00a73c7197dfeb6463b734a54;hpb=1ee306e1248866617c96ed9f4263f375588ad838;p=elogind.git diff --git a/src/machine/machine.h b/src/machine/machine.h index 7501fa372..7b27aa27e 100644 --- a/src/machine/machine.h +++ b/src/machine/machine.h @@ -22,10 +22,10 @@ ***/ typedef struct Machine Machine; +typedef struct MachineOperation MachineOperation; typedef enum KillWho KillWho; #include "list.h" -#include "util.h" #include "machined.h" typedef enum MachineState { @@ -50,6 +50,17 @@ enum KillWho { _KILL_WHO_INVALID = -1 }; +#define MACHINE_OPERATIONS_MAX 64 + +struct MachineOperation { + Machine *machine; + pid_t pid; + sd_bus_message *message; + int errno_fd; + sd_event_source *event_source; + LIST_FIELDS(MachineOperation, operations); +}; + struct Machine { Manager *manager; @@ -63,7 +74,7 @@ struct Machine { char *service; char *root_directory; - char *scope; + char *unit; char *scope_job; pid_t leader; @@ -73,31 +84,30 @@ struct Machine { bool in_gc_queue:1; bool started:1; - DBusMessage *create_message; + sd_bus_message *create_message; + + int *netif; + unsigned n_netif; LIST_FIELDS(Machine, gc_queue); + + MachineOperation *operations; + unsigned n_operations; }; Machine* machine_new(Manager *manager, const char *name); void machine_free(Machine *m); -int machine_check_gc(Machine *m, bool drop_not_started); +bool machine_check_gc(Machine *m, bool drop_not_started); void machine_add_to_gc_queue(Machine *m); -int machine_start(Machine *m); +int machine_start(Machine *m, sd_bus_message *properties, sd_bus_error *error); int machine_stop(Machine *m); int machine_save(Machine *m); int machine_load(Machine *m); int machine_kill(Machine *m, KillWho who, int signo); -char *machine_bus_path(Machine *s); - MachineState machine_get_state(Machine *u); -extern const DBusObjectPathVTable bus_machine_vtable; - -int machine_send_signal(Machine *m, bool new_machine); -int machine_send_changed(Machine *m, const char *properties); - -int machine_send_create_reply(Machine *m, DBusError *error); +MachineOperation *machine_operation_unref(MachineOperation *o); const char* machine_class_to_string(MachineClass t) _const_; MachineClass machine_class_from_string(const char *s) _pure_;