mirror of
https://github.com/morgan9e/systemd
synced 2026-04-14 16:37:19 +09:00
core: simply timer expression parsing by using ".ltype" field of conf-parser logic
No change of behaviour. Let's just not parse the lvalue all the time with timer_base_from_string() if we can already pass it in parsed.
This commit is contained in:
@@ -427,12 +427,12 @@ EXEC_CONTEXT_CONFIG_ITEMS(Swap)m4_dnl
|
||||
CGROUP_CONTEXT_CONFIG_ITEMS(Swap)m4_dnl
|
||||
KILL_CONTEXT_CONFIG_ITEMS(Swap)m4_dnl
|
||||
m4_dnl
|
||||
Timer.OnCalendar, config_parse_timer, 0, 0
|
||||
Timer.OnActiveSec, config_parse_timer, 0, 0
|
||||
Timer.OnBootSec, config_parse_timer, 0, 0
|
||||
Timer.OnStartupSec, config_parse_timer, 0, 0
|
||||
Timer.OnUnitActiveSec, config_parse_timer, 0, 0
|
||||
Timer.OnUnitInactiveSec, config_parse_timer, 0, 0
|
||||
Timer.OnCalendar, config_parse_timer, TIMER_CALENDAR, 0
|
||||
Timer.OnActiveSec, config_parse_timer, TIMER_ACTIVE, 0
|
||||
Timer.OnBootSec, config_parse_timer, TIMER_BOOT, 0
|
||||
Timer.OnStartupSec, config_parse_timer, TIMER_STARTUP, 0
|
||||
Timer.OnUnitActiveSec, config_parse_timer, TIMER_UNIT_ACTIVE, 0
|
||||
Timer.OnUnitInactiveSec, config_parse_timer, TIMER_UNIT_INACTIVE, 0
|
||||
Timer.Persistent, config_parse_bool, 0, offsetof(Timer, persistent)
|
||||
Timer.WakeSystem, config_parse_bool, 0, offsetof(Timer, wake_system)
|
||||
Timer.RemainAfterElapse, config_parse_bool, 0, offsetof(Timer, remain_after_elapse)
|
||||
|
||||
@@ -1498,24 +1498,24 @@ int config_parse_exec_smack_process_label(
|
||||
return 0;
|
||||
}
|
||||
|
||||
int config_parse_timer(const char *unit,
|
||||
const char *filename,
|
||||
unsigned line,
|
||||
const char *section,
|
||||
unsigned section_line,
|
||||
const char *lvalue,
|
||||
int ltype,
|
||||
const char *rvalue,
|
||||
void *data,
|
||||
void *userdata) {
|
||||
int config_parse_timer(
|
||||
const char *unit,
|
||||
const char *filename,
|
||||
unsigned line,
|
||||
const char *section,
|
||||
unsigned section_line,
|
||||
const char *lvalue,
|
||||
int ltype,
|
||||
const char *rvalue,
|
||||
void *data,
|
||||
void *userdata) {
|
||||
|
||||
_cleanup_(calendar_spec_freep) CalendarSpec *c = NULL;
|
||||
_cleanup_free_ char *k = NULL;
|
||||
Unit *u = userdata;
|
||||
Timer *t = data;
|
||||
usec_t usec = 0;
|
||||
TimerValue *v;
|
||||
TimerBase b;
|
||||
_cleanup_(calendar_spec_freep) CalendarSpec *c = NULL;
|
||||
Unit *u = userdata;
|
||||
_cleanup_free_ char *k = NULL;
|
||||
int r;
|
||||
|
||||
assert(filename);
|
||||
@@ -1529,19 +1529,13 @@ int config_parse_timer(const char *unit,
|
||||
return 0;
|
||||
}
|
||||
|
||||
b = timer_base_from_string(lvalue);
|
||||
if (b < 0) {
|
||||
log_syntax(unit, LOG_ERR, filename, line, 0, "Failed to parse timer base, ignoring: %s", lvalue);
|
||||
return 0;
|
||||
}
|
||||
|
||||
r = unit_full_printf(u, rvalue, &k);
|
||||
if (r < 0) {
|
||||
log_syntax(unit, LOG_ERR, filename, line, r, "Failed to resolve unit specifiers in '%s', ignoring: %m", rvalue);
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (b == TIMER_CALENDAR) {
|
||||
if (ltype == TIMER_CALENDAR) {
|
||||
if (calendar_spec_from_string(k, &c) < 0) {
|
||||
log_syntax(unit, LOG_ERR, filename, line, 0, "Failed to parse calendar specification, ignoring: %s", k);
|
||||
return 0;
|
||||
@@ -1552,13 +1546,15 @@ int config_parse_timer(const char *unit,
|
||||
return 0;
|
||||
}
|
||||
|
||||
v = new0(TimerValue, 1);
|
||||
v = new(TimerValue, 1);
|
||||
if (!v)
|
||||
return log_oom();
|
||||
|
||||
v->base = b;
|
||||
v->value = usec;
|
||||
v->calendar_spec = TAKE_PTR(c);
|
||||
*v = (TimerValue) {
|
||||
.base = ltype,
|
||||
.value = usec,
|
||||
.calendar_spec = TAKE_PTR(c),
|
||||
};
|
||||
|
||||
LIST_PREPEND(value, t->values, v);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user