diff options
author | Lennart Poettering <lennart@poettering.net> | 2014-11-06 02:27:10 +0100 |
---|---|---|
committer | Lennart Poettering <lennart@poettering.net> | 2014-11-06 14:21:10 +0100 |
commit | cc50ef134b4104cae8783a4ca40b1a70247e3ef9 (patch) | |
tree | 30cc896be717ca682cdc23a04f58838c7a69976f /src/shared | |
parent | b80ba1da1c66f570c10a92a40f54a044fb865739 (diff) |
condition: record test state internally and beef it up to be a full enum
Diffstat (limited to 'src/shared')
-rw-r--r-- | src/shared/condition-util.c | 22 | ||||
-rw-r--r-- | src/shared/condition-util.h | 22 |
2 files changed, 30 insertions, 14 deletions
diff --git a/src/shared/condition-util.c b/src/shared/condition-util.c index 749b57712a..640a931ff5 100644 --- a/src/shared/condition-util.c +++ b/src/shared/condition-util.c @@ -429,17 +429,22 @@ int condition_test(Condition *c) { [CONDITION_FIRST_BOOT] = condition_test_first_boot, [CONDITION_NULL] = condition_test_null, }; - int r; + + int r, b; assert(c); assert(c->type >= 0); assert(c->type < _CONDITION_TYPE_MAX); r = condition_tests[c->type](c); - if (r < 0) + if (r < 0) { + c->result = CONDITION_ERROR; return r; + } - return (r > 0) == !c->negate; + b = (r > 0) == !c->negate; + c->result = b ? CONDITION_SUCCEEDED : CONDITION_FAILED; + return b; } void condition_dump(Condition *c, FILE *f, const char *prefix) { @@ -456,7 +461,7 @@ void condition_dump(Condition *c, FILE *f, const char *prefix) { c->trigger ? "|" : "", c->negate ? "!" : "", c->parameter, - CONDITION_STATE_IS_FAILED(c->state) ? "failed" : CONDITION_STATE_IS_SUCCEEDED(c->state) ? "succeeded" : "untested"); + condition_result_to_string(c->result)); } void condition_dump_list(Condition *first, FILE *f, const char *prefix) { @@ -489,3 +494,12 @@ static const char* const condition_type_table[_CONDITION_TYPE_MAX] = { }; DEFINE_STRING_TABLE_LOOKUP(condition_type, ConditionType); + +static const char* const condition_result_table[_CONDITION_RESULT_MAX] = { + [CONDITION_UNTESTED] = "untested", + [CONDITION_SUCCEEDED] = "succeeded", + [CONDITION_FAILED] = "failed", + [CONDITION_ERROR] = "error", +}; + +DEFINE_STRING_TABLE_LOOKUP(condition_result, ConditionResult); diff --git a/src/shared/condition-util.h b/src/shared/condition-util.h index 44f672b2e6..08aee94a89 100644 --- a/src/shared/condition-util.h +++ b/src/shared/condition-util.h @@ -51,15 +51,14 @@ typedef enum ConditionType { _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; @@ -68,7 +67,7 @@ typedef struct Condition { bool negate:1; char *parameter; - int state; + ConditionResult result; LIST_FIELDS(struct Condition, conditions); } Condition; @@ -84,3 +83,6 @@ void condition_dump_list(Condition *c, FILE *f, const char *prefix); const char* condition_type_to_string(ConditionType t) _const_; int condition_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_; |