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