diff options
| author | Lennart Poettering <lennart@poettering.net> | 2016-12-08 00:28:05 +0100 | 
|---|---|---|
| committer | Lennart Poettering <lennart@poettering.net> | 2016-12-20 20:00:08 +0100 | 
| commit | a4c35b6b4d8457e15caa3fe18ce8050918932d00 (patch) | |
| tree | 317c67da81641d44a2a2b3b627833f2be07853c3 /src | |
| parent | 72d17ce680a22b958b4c074f62d9fa44bc1f54e0 (diff) | |
nspawn: split out VolatileMode definitions
This moves the VolatileMode enum and its helper functions to src/shared/. This
is useful to then reuse them to implement systemd.volatile= in a later commit.
Diffstat (limited to 'src')
| -rw-r--r-- | src/nspawn/nspawn-mount.c | 18 | ||||
| -rw-r--r-- | src/nspawn/nspawn-mount.h | 11 | ||||
| -rw-r--r-- | src/shared/volatile-util.c | 41 | ||||
| -rw-r--r-- | src/shared/volatile-util.h | 30 | 
4 files changed, 72 insertions, 28 deletions
| diff --git a/src/nspawn/nspawn-mount.c b/src/nspawn/nspawn-mount.c index aaa64a7ba8..72c007f204 100644 --- a/src/nspawn/nspawn-mount.c +++ b/src/nspawn/nspawn-mount.c @@ -1349,21 +1349,3 @@ fail:          (void) rmdir(template);          return r;  } - -VolatileMode volatile_mode_from_string(const char *s) { -        int b; - -        if (isempty(s)) -                return _VOLATILE_MODE_INVALID; - -        b = parse_boolean(s); -        if (b > 0) -                return VOLATILE_YES; -        if (b == 0) -                return VOLATILE_NO; - -        if (streq(s, "state")) -                return VOLATILE_STATE; - -        return _VOLATILE_MODE_INVALID; -} diff --git a/src/nspawn/nspawn-mount.h b/src/nspawn/nspawn-mount.h index 467082a737..6b33fbff57 100644 --- a/src/nspawn/nspawn-mount.h +++ b/src/nspawn/nspawn-mount.h @@ -22,6 +22,7 @@  #include <stdbool.h>  #include "cgroup-util.h" +#include "volatile-util.h"  typedef enum MountSettingsMask {          MOUNT_FATAL              = 1 << 0, /* if set, a mount error is considered fatal */ @@ -32,14 +33,6 @@ typedef enum MountSettingsMask {                                                Works only if MOUNT_APPLY_APIVFS_RO is also set. */  } MountSettingsMask; -typedef enum VolatileMode { -        VOLATILE_NO, -        VOLATILE_YES, -        VOLATILE_STATE, -        _VOLATILE_MODE_MAX, -        _VOLATILE_MODE_INVALID = -1 -} VolatileMode; -  typedef enum CustomMountType {          CUSTOM_MOUNT_BIND,          CUSTOM_MOUNT_TMPFS, @@ -77,5 +70,3 @@ int mount_custom(const char *dest, CustomMount *mounts, unsigned n, bool userns,  int setup_volatile(const char *directory, VolatileMode mode, bool userns, uid_t uid_shift, uid_t uid_range, const char *selinux_apifs_context);  int setup_volatile_state(const char *directory, VolatileMode mode, bool userns, uid_t uid_shift, uid_t uid_range, const char *selinux_apifs_context); - -VolatileMode volatile_mode_from_string(const char *s); diff --git a/src/shared/volatile-util.c b/src/shared/volatile-util.c new file mode 100644 index 0000000000..1329b51f4e --- /dev/null +++ b/src/shared/volatile-util.c @@ -0,0 +1,41 @@ +/*** +  This file is part of systemd. + +  Copyright 2015 Lennart Poettering + +  systemd is free software; you can redistribute it and/or modify it +  under the terms of the GNU Lesser General Public License as published by +  the Free Software Foundation; either version 2.1 of the License, or +  (at your option) any later version. + +  systemd is distributed in the hope that it will be useful, but +  WITHOUT ANY WARRANTY; without even the implied warranty of +  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +  Lesser General Public License for more details. + +  You should have received a copy of the GNU Lesser General Public License +  along with systemd; If not, see <http://www.gnu.org/licenses/>. +***/ + +#include "macro.h" +#include "parse-util.h" +#include "string-util.h" +#include "volatile-util.h" + +VolatileMode volatile_mode_from_string(const char *s) { +        int b; + +        if (isempty(s)) +                return _VOLATILE_MODE_INVALID; + +        b = parse_boolean(s); +        if (b > 0) +                return VOLATILE_YES; +        if (b == 0) +                return VOLATILE_NO; + +        if (streq(s, "state")) +                return VOLATILE_STATE; + +        return _VOLATILE_MODE_INVALID; +} diff --git a/src/shared/volatile-util.h b/src/shared/volatile-util.h new file mode 100644 index 0000000000..d012940c76 --- /dev/null +++ b/src/shared/volatile-util.h @@ -0,0 +1,30 @@ +#pragma once + +/*** +  This file is part of systemd. + +  Copyright 2016 Lennart Poettering + +  systemd is free software; you can redistribute it and/or modify it +  under the terms of the GNU Lesser General Public License as published by +  the Free Software Foundation; either version 2.1 of the License, or +  (at your option) any later version. + +  systemd is distributed in the hope that it will be useful, but +  WITHOUT ANY WARRANTY; without even the implied warranty of +  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +  Lesser General Public License for more details. + +  You should have received a copy of the GNU Lesser General Public License +  along with systemd; If not, see <http://www.gnu.org/licenses/>. +***/ + +typedef enum VolatileMode { +        VOLATILE_NO, +        VOLATILE_YES, +        VOLATILE_STATE, +        _VOLATILE_MODE_MAX, +        _VOLATILE_MODE_INVALID = -1 +} VolatileMode; + +VolatileMode volatile_mode_from_string(const char *s); | 
