mirror of
https://github.com/systemd/systemd.git
synced 2025-03-19 22:50:17 +03:00
core: fix property changes in transient units
This commit is contained in:
parent
e954c9cfa6
commit
6d2357247b
Notes:
Lennart Poettering
2014-02-17 15:50:25 +01:00
Backport: bugfix
@ -910,9 +910,6 @@ int bus_unit_set_properties(
|
||||
assert(u);
|
||||
assert(message);
|
||||
|
||||
if (u->transient)
|
||||
mode &= UNIT_RUNTIME;
|
||||
|
||||
/* We iterate through the array twice. First run we just check
|
||||
* if all passed data is valid, second run actually applies
|
||||
* it. This is to implement transaction-like behaviour without
|
||||
|
@ -2860,7 +2860,6 @@ static int drop_in_file(Unit *u, UnitSetPropertiesMode mode, const char *name, c
|
||||
assert(name);
|
||||
assert(_p);
|
||||
assert(_q);
|
||||
assert(mode & (UNIT_PERSISTENT|UNIT_RUNTIME));
|
||||
|
||||
b = xescape(name, "/.");
|
||||
if (!b)
|
||||
@ -2879,7 +2878,7 @@ static int drop_in_file(Unit *u, UnitSetPropertiesMode mode, const char *name, c
|
||||
return -ENOENT;
|
||||
|
||||
p = strjoin(c, "/", u->id, ".d", NULL);
|
||||
} else if (mode & UNIT_PERSISTENT)
|
||||
} else if (mode == UNIT_PERSISTENT && !u->transient)
|
||||
p = strjoin("/etc/systemd/system/", u->id, ".d", NULL);
|
||||
else
|
||||
p = strjoin("/run/systemd/system/", u->id, ".d", NULL);
|
||||
@ -2905,7 +2904,7 @@ int unit_write_drop_in(Unit *u, UnitSetPropertiesMode mode, const char *name, co
|
||||
assert(name);
|
||||
assert(data);
|
||||
|
||||
if (!(mode & (UNIT_PERSISTENT|UNIT_RUNTIME)))
|
||||
if (!IN_SET(mode, UNIT_PERSISTENT, UNIT_RUNTIME))
|
||||
return 0;
|
||||
|
||||
r = drop_in_file(u, mode, name, &p, &q);
|
||||
@ -2925,7 +2924,7 @@ int unit_write_drop_in_format(Unit *u, UnitSetPropertiesMode mode, const char *n
|
||||
assert(name);
|
||||
assert(format);
|
||||
|
||||
if (!(mode & (UNIT_PERSISTENT|UNIT_RUNTIME)))
|
||||
if (!IN_SET(mode, UNIT_PERSISTENT, UNIT_RUNTIME))
|
||||
return 0;
|
||||
|
||||
va_start(ap, format);
|
||||
@ -2948,7 +2947,7 @@ int unit_write_drop_in_private(Unit *u, UnitSetPropertiesMode mode, const char *
|
||||
if (!UNIT_VTABLE(u)->private_section)
|
||||
return -EINVAL;
|
||||
|
||||
if (!(mode & (UNIT_PERSISTENT|UNIT_RUNTIME)))
|
||||
if (!IN_SET(mode, UNIT_PERSISTENT, UNIT_RUNTIME))
|
||||
return 0;
|
||||
|
||||
ndata = strjoin("[", UNIT_VTABLE(u)->private_section, "]\n", data, NULL);
|
||||
@ -2967,7 +2966,7 @@ int unit_write_drop_in_private_format(Unit *u, UnitSetPropertiesMode mode, const
|
||||
assert(name);
|
||||
assert(format);
|
||||
|
||||
if (!(mode & (UNIT_PERSISTENT|UNIT_RUNTIME)))
|
||||
if (!IN_SET(mode, UNIT_PERSISTENT, UNIT_RUNTIME))
|
||||
return 0;
|
||||
|
||||
va_start(ap, format);
|
||||
@ -2986,7 +2985,7 @@ int unit_remove_drop_in(Unit *u, UnitSetPropertiesMode mode, const char *name) {
|
||||
|
||||
assert(u);
|
||||
|
||||
if (!(mode & (UNIT_PERSISTENT|UNIT_RUNTIME)))
|
||||
if (!IN_SET(mode, UNIT_PERSISTENT, UNIT_RUNTIME))
|
||||
return 0;
|
||||
|
||||
r = drop_in_file(u, mode, name, &p, &q);
|
||||
|
Loading…
x
Reference in New Issue
Block a user