chiark / gitweb /
nspawn: make -U a tiny bit smarter
[elogind.git] / src / basic / parse-util.h
1 #pragma once
2
3 /***
4   This file is part of systemd.
5
6   Copyright 2010 Lennart Poettering
7
8   systemd is free software; you can redistribute it and/or modify it
9   under the terms of the GNU Lesser General Public License as published by
10   the Free Software Foundation; either version 2.1 of the License, or
11   (at your option) any later version.
12
13   systemd is distributed in the hope that it will be useful, but
14   WITHOUT ANY WARRANTY; without even the implied warranty of
15   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16   Lesser General Public License for more details.
17
18   You should have received a copy of the GNU Lesser General Public License
19   along with systemd; If not, see <http://www.gnu.org/licenses/>.
20 ***/
21
22 #include <inttypes.h>
23 #include <limits.h>
24 #include <stddef.h>
25 #include <stdint.h>
26 #include <sys/types.h>
27
28 #include "macro.h"
29
30 #define MODE_INVALID ((mode_t) -1)
31
32 int parse_boolean(const char *v) _pure_;
33 int parse_pid(const char *s, pid_t* ret_pid);
34 int parse_mode(const char *s, mode_t *ret);
35 int parse_ifindex(const char *s, int *ret);
36
37 int parse_size(const char *t, uint64_t base, uint64_t *size);
38
39 #if 0 /// UNNEEDED by elogind
40 int parse_range(const char *t, unsigned *lower, unsigned *upper);
41
42 #define FORMAT_BYTES_MAX 8
43 char *format_bytes(char *buf, size_t l, uint64_t t);
44 #endif // 0
45
46 int safe_atou(const char *s, unsigned *ret_u);
47 int safe_atoi(const char *s, int *ret_i);
48 int safe_atollu(const char *s, unsigned long long *ret_u);
49 int safe_atolli(const char *s, long long int *ret_i);
50
51 int safe_atou8(const char *s, uint8_t *ret);
52
53 int safe_atou16(const char *s, uint16_t *ret);
54 int safe_atoi16(const char *s, int16_t *ret);
55
56 static inline int safe_atou32(const char *s, uint32_t *ret_u) {
57         assert_cc(sizeof(uint32_t) == sizeof(unsigned));
58         return safe_atou(s, (unsigned*) ret_u);
59 }
60
61 static inline int safe_atoi32(const char *s, int32_t *ret_i) {
62         assert_cc(sizeof(int32_t) == sizeof(int));
63         return safe_atoi(s, (int*) ret_i);
64 }
65
66 static inline int safe_atou64(const char *s, uint64_t *ret_u) {
67         assert_cc(sizeof(uint64_t) == sizeof(unsigned long long));
68         return safe_atollu(s, (unsigned long long*) ret_u);
69 }
70
71 static inline int safe_atoi64(const char *s, int64_t *ret_i) {
72         assert_cc(sizeof(int64_t) == sizeof(long long int));
73         return safe_atolli(s, (long long int*) ret_i);
74 }
75
76 #if LONG_MAX == INT_MAX
77 static inline int safe_atolu(const char *s, unsigned long *ret_u) {
78         assert_cc(sizeof(unsigned long) == sizeof(unsigned));
79         return safe_atou(s, (unsigned*) ret_u);
80 }
81 static inline int safe_atoli(const char *s, long int *ret_u) {
82         assert_cc(sizeof(long int) == sizeof(int));
83         return safe_atoi(s, (int*) ret_u);
84 }
85 #else
86 static inline int safe_atolu(const char *s, unsigned long *ret_u) {
87         assert_cc(sizeof(unsigned long) == sizeof(unsigned long long));
88         return safe_atollu(s, (unsigned long long*) ret_u);
89 }
90 static inline int safe_atoli(const char *s, long int *ret_u) {
91         assert_cc(sizeof(long int) == sizeof(long long int));
92         return safe_atolli(s, (long long int*) ret_u);
93 }
94 #endif
95
96 #if SIZE_MAX == UINT_MAX
97 static inline int safe_atozu(const char *s, size_t *ret_u) {
98         assert_cc(sizeof(size_t) == sizeof(unsigned));
99         return safe_atou(s, ret_u);
100 }
101 #else
102 static inline int safe_atozu(const char *s, size_t *ret_u) {
103         assert_cc(sizeof(size_t) == sizeof(long unsigned));
104         return safe_atolu(s, ret_u);
105 }
106 #endif
107
108 int safe_atod(const char *s, double *ret_d);
109
110 int parse_fractional_part_u(const char **s, size_t digits, unsigned *res);