X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fshared%2Fcondition-util.h;h=28d1d94ff477420b2af94be627db92d5eef5d136;hb=651c33185eeb449385b471fffa8882a163c496f0;hp=deeb6b4257b3bde1e168ccbe46db9d6c4361e6a1;hpb=d1bddcec98551ea748f39a742a4cbcf9ea9254ef;p=elogind.git diff --git a/src/shared/condition-util.h b/src/shared/condition-util.h index deeb6b425..28d1d94ff 100644 --- a/src/shared/condition-util.h +++ b/src/shared/condition-util.h @@ -28,6 +28,17 @@ #include "macro.h" typedef enum ConditionType { + CONDITION_ARCHITECTURE, + CONDITION_VIRTUALIZATION, + CONDITION_HOST, + CONDITION_KERNEL_COMMAND_LINE, + CONDITION_SECURITY, + CONDITION_CAPABILITY, + CONDITION_AC_POWER, + + CONDITION_NEEDS_UPDATE, + CONDITION_FIRST_BOOT, + CONDITION_PATH_EXISTS, CONDITION_PATH_EXISTS_GLOB, CONDITION_PATH_IS_DIRECTORY, @@ -37,38 +48,31 @@ typedef enum ConditionType { CONDITION_DIRECTORY_NOT_EMPTY, CONDITION_FILE_NOT_EMPTY, CONDITION_FILE_IS_EXECUTABLE, - CONDITION_KERNEL_COMMAND_LINE, - CONDITION_VIRTUALIZATION, - CONDITION_SECURITY, - CONDITION_CAPABILITY, - CONDITION_HOST, - CONDITION_AC_POWER, - CONDITION_ARCHITECTURE, - CONDITION_NEEDS_UPDATE, - CONDITION_FIRST_BOOT, + CONDITION_NULL, + _CONDITION_TYPE_MAX, _CONDITION_TYPE_INVALID = -1 } ConditionType; -#define CONDITION_STATE_IS_SUCCEEDED(state) ((state) > 0) -#define CONDITION_STATE_IS_UNKNOWN(state) ((state) == 0) -#define CONDITION_STATE_IS_FAILED(state) ((state) < 0) - -enum { - CONDITION_STATE_SUCCEEDED = -1, - CONDITION_STATE_UNKNOWN = 0, - CONDITION_STATE_FAILED = 1 -}; +typedef enum ConditionResult { + CONDITION_UNTESTED, + CONDITION_SUCCEEDED, + CONDITION_FAILED, + CONDITION_ERROR, + _CONDITION_RESULT_MAX, + _CONDITION_RESULT_INVALID = -1 +} ConditionResult; typedef struct Condition { - ConditionType type; + ConditionType type:8; bool trigger:1; bool negate:1; + ConditionResult result:6; + char *parameter; - int state; LIST_FIELDS(struct Condition, conditions); } Condition; @@ -77,16 +81,16 @@ Condition* condition_new(ConditionType type, const char *parameter, bool trigger void condition_free(Condition *c); void condition_free_list(Condition *c); -int condition_test_kernel_command_line(Condition *c); -int condition_test_virtualization(Condition *c); -int condition_test_architecture(Condition *c); -int condition_test_host(Condition *c); -int condition_test_ac_power(Condition *c); - int condition_test(Condition *c); -void condition_dump(Condition *c, FILE *f, const char *prefix); -void condition_dump_list(Condition *c, FILE *f, const char *prefix); +void condition_dump(Condition *c, FILE *f, const char *prefix, const char *(*to_string)(ConditionType t)); +void condition_dump_list(Condition *c, FILE *f, const char *prefix, const char *(*to_string)(ConditionType t)); const char* condition_type_to_string(ConditionType t) _const_; -int condition_type_from_string(const char *s) _pure_; +ConditionType condition_type_from_string(const char *s) _pure_; + +const char* assert_type_to_string(ConditionType t) _const_; +ConditionType assert_type_from_string(const char *s) _pure_; + +const char* condition_result_to_string(ConditionResult r) _const_; +ConditionResult condition_result_from_string(const char *s) _pure_;