virstring.h 10.1 KB
Newer Older
1
/*
2
 * Copyright (C) 2007-2014 Red Hat, Inc.
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
 *
 * This library 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.
 *
 * This library 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 this library.  If not, see
 * <http://www.gnu.org/licenses/>.
 *
 * Authors:
 *     Daniel P. Berrange <berrange@redhat.com>
 */

#ifndef __VIR_STRING_H__
# define __VIR_STRING_H__

25 26
# include <stdarg.h>

27 28
# include "internal.h"

29 30 31 32 33 34
char **virStringSplitCount(const char *string,
                           const char *delim,
                           size_t max_tokens,
                           size_t *tokcount)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);

35 36 37 38 39
char **virStringSplit(const char *string,
                      const char *delim,
                      size_t max_tokens)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);

40 41
char *virStringListJoin(const char **strings,
                        const char *delim)
42 43
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);

44 45
char **virStringListAdd(const char **strings,
                        const char *item);
46 47
void virStringListRemove(char ***strings,
                         const char *item);
48

49 50 51
void virStringListFree(char **strings);
void virStringListFreeCount(char **strings,
                            size_t count);
52

53 54 55 56
bool virStringListHasString(const char **strings,
                            const char *needle);
char *virStringListGetFirstWithPrefix(char **strings,
                                      const char *prefix)
57
    ATTRIBUTE_NONNULL(2);
58

59 60 61 62 63
char *virArgvToString(const char *const *argv);

int virStrToLong_i(char const *s,
                   char **end_ptr,
                   int base,
64 65
                   int *result)
    ATTRIBUTE_RETURN_CHECK;
66 67 68 69

int virStrToLong_ui(char const *s,
                    char **end_ptr,
                    int base,
70 71
                    unsigned int *result)
    ATTRIBUTE_RETURN_CHECK;
72 73 74
int virStrToLong_uip(char const *s,
                     char **end_ptr,
                     int base,
75 76
                     unsigned int *result)
    ATTRIBUTE_RETURN_CHECK;
77 78 79
int virStrToLong_l(char const *s,
                   char **end_ptr,
                   int base,
80 81
                   long *result)
    ATTRIBUTE_RETURN_CHECK;
82 83 84
int virStrToLong_ul(char const *s,
                    char **end_ptr,
                    int base,
85 86
                    unsigned long *result)
    ATTRIBUTE_RETURN_CHECK;
87 88 89
int virStrToLong_ulp(char const *s,
                     char **end_ptr,
                     int base,
90 91
                     unsigned long *result)
    ATTRIBUTE_RETURN_CHECK;
92 93 94
int virStrToLong_ll(char const *s,
                    char **end_ptr,
                    int base,
95 96
                    long long *result)
    ATTRIBUTE_RETURN_CHECK;
97 98 99
int virStrToLong_ull(char const *s,
                     char **end_ptr,
                     int base,
100 101
                     unsigned long long *result)
    ATTRIBUTE_RETURN_CHECK;
102 103 104
int virStrToLong_ullp(char const *s,
                      char **end_ptr,
                      int base,
105 106
                      unsigned long long *result)
    ATTRIBUTE_RETURN_CHECK;
107 108
int virStrToDouble(char const *s,
                   char **end_ptr,
109 110
                   double *result)
    ATTRIBUTE_RETURN_CHECK;
111 112 113 114 115 116 117

void virSkipSpaces(const char **str) ATTRIBUTE_NONNULL(1);
void virSkipSpacesAndBackslash(const char **str) ATTRIBUTE_NONNULL(1);
void virTrimSpaces(char *str, char **endp) ATTRIBUTE_NONNULL(1);
void virSkipSpacesBackwards(const char *str, char **endp)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);

118 119
bool virStringIsEmpty(const char *str);

120 121 122 123 124
char *virStrncpy(char *dest, const char *src, size_t n, size_t destbytes)
    ATTRIBUTE_RETURN_CHECK;
char *virStrcpy(char *dest, const char *src, size_t destbytes)
    ATTRIBUTE_RETURN_CHECK;
# define virStrcpyStatic(dest, src) virStrcpy((dest), (src), sizeof(dest))
125 126 127 128

/* Don't call these directly - use the macros below */
int virStrdup(char **dest, const char *src, bool report, int domcode,
              const char *filename, const char *funcname, size_t linenr)
129
    ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NONNULL(1);
130

131
int virStrndup(char **dest, const char *src, ssize_t n, bool report, int domcode,
132
               const char *filename, const char *funcname, size_t linenr)
133
    ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NONNULL(1);
134 135 136 137 138 139 140 141 142 143
int virAsprintfInternal(bool report, int domcode, const char *filename,
                        const char *funcname, size_t linenr, char **strp,
                        const char *fmt, ...)
    ATTRIBUTE_NONNULL(6) ATTRIBUTE_NONNULL(7) ATTRIBUTE_FMT_PRINTF(7, 8)
    ATTRIBUTE_RETURN_CHECK;
int virVasprintfInternal(bool report, int domcode, const char *filename,
                         const char *funcname, size_t linenr, char **strp,
                         const char *fmt, va_list list)
    ATTRIBUTE_NONNULL(6) ATTRIBUTE_NONNULL(7) ATTRIBUTE_FMT_PRINTF(7, 0)
    ATTRIBUTE_RETURN_CHECK;
144 145 146 147 148 149 150 151

/**
 * VIR_STRDUP:
 * @dst: variable to hold result (char*, not char**)
 * @src: string to duplicate
 *
 * Duplicate @src string and store it into @dst.
 *
152 153 154 155
 * This macro is safe to use on arguments with side effects.
 *
 * Returns -1 on failure (with OOM error reported), 0 if @src was NULL,
 * 1 if @src was copied
156 157 158 159 160 161 162 163 164 165 166
 */
# define VIR_STRDUP(dst, src) virStrdup(&(dst), src, true, VIR_FROM_THIS, \
                                        __FILE__, __FUNCTION__, __LINE__)

/**
 * VIR_STRDUP_QUIET:
 * @dst: variable to hold result (char*, not char**)
 * @src: string to duplicate
 *
 * Duplicate @src string and store it into @dst.
 *
167 168 169
 * This macro is safe to use on arguments with side effects.
 *
 * Returns -1 on failure, 0 if @src was NULL, 1 if @src was copied
170 171 172 173 174 175 176 177 178 179
 */
# define VIR_STRDUP_QUIET(dst, src) virStrdup(&(dst), src, false, 0, NULL, NULL, 0)

/**
 * VIR_STRNDUP:
 * @dst: variable to hold result (char*, not char**)
 * @src: string to duplicate
 * @n: the maximum number of bytes to copy
 *
 * Duplicate @src string and store it into @dst. If @src is longer than @n,
180 181 182
 * only @n bytes are copied and terminating null byte '\0' is added. If @n
 * is a negative number, then the whole @src string is copied. That is,
 * VIR_STRDUP(dst, src) and VIR_STRNDUP(dst, src, -1) are equal.
183
 *
184 185 186 187
 * This macro is safe to use on arguments with side effects.
 *
 * Returns -1 on failure (with OOM error reported), 0 if @src was NULL,
 * 1 if @src was copied
188 189 190 191 192 193 194 195 196 197 198 199
 */
# define VIR_STRNDUP(dst, src, n) virStrndup(&(dst), src, n, true,    \
                                             VIR_FROM_THIS, __FILE__, \
                                             __FUNCTION__, __LINE__)

/**
 * VIR_STRNDUP_QUIET:
 * @dst: variable to hold result (char*, not char**)
 * @src: string to duplicate
 * @n: the maximum number of bytes to copy
 *
 * Duplicate @src string and store it into @dst. If @src is longer than @n,
200 201 202 203
 * only @n bytes are copied and terminating null byte '\0' is added. If @n
 * is a negative number, then the whole @src string is copied. That is,
 * VIR_STRDUP_QUIET(dst, src) and VIR_STRNDUP_QUIET(dst, src, -1) are
 * equal.
204
 *
205 206 207
 * This macro is safe to use on arguments with side effects.
 *
 * Returns -1 on failure, 0 if @src was NULL, 1 if @src was copied
208 209 210
 */
# define VIR_STRNDUP_QUIET(dst, src, n) virStrndup(&(dst), src, n, false, \
                                                   0, NULL, NULL, 0)
211

212
size_t virStringListLength(const char * const *strings);
213

214 215 216 217 218 219
/**
 * virVasprintf
 *
 * Like glibc's vasprintf but makes sure *strp == NULL on failure, in which
 * case the OOM error is reported too.
 *
220 221
 * Returns -1 on failure (with OOM error reported), number of bytes printed
 * on success.
222 223 224 225 226 227 228 229 230 231
 */
# define virVasprintf(strp, fmt, list) \
    virVasprintfInternal(true, VIR_FROM_THIS, __FILE__, __FUNCTION__, \
                         __LINE__, strp, fmt, list)

/**
 * virVasprintfQuiet
 *
 * Like glibc's vasprintf but makes sure *strp == NULL on failure.
 *
232
 * Returns -1 on failure, number of bytes printed on success.
233 234 235 236 237 238 239 240 241 242 243 244
 */
# define virVasprintfQuiet(strp, fmt, list) \
    virVasprintfInternal(false, 0, NULL, NULL, 0, strp, fmt, list)

/**
 * virAsprintf:
 * @strp: variable to hold result (char **)
 * @fmt: printf format
 *
 * Like glibc's_asprintf but makes sure *strp == NULL on failure, in which case
 * the OOM error is reported too.
 *
245 246
 * Returns -1 on failure (with OOM error reported), number of bytes printed
 * on success.
247 248 249 250 251 252 253 254 255 256 257 258 259
 */

# define virAsprintf(strp, ...) \
    virAsprintfInternal(true, VIR_FROM_THIS, __FILE__, __FUNCTION__, __LINE__, \
                        strp, __VA_ARGS__)

/**
 * virAsprintfQuiet:
 * @strp: variable to hold result (char **)
 * @fmt: printf format
 *
 * Like glibc's_asprintf but makes sure *strp == NULL on failure.
 *
260
 * Returns -1 on failure, number of bytes printed on success.
261 262 263 264 265 266
 */

# define virAsprintfQuiet(strp, ...) \
    virAsprintfInternal(false, 0, NULL, NULL, 0, \
                        strp, __VA_ARGS__)

267 268
int virStringSortCompare(const void *a, const void *b);
int virStringSortRevCompare(const void *a, const void *b);
269
int virStringToUpper(char **dst, const char *src);
270

271 272 273 274 275 276
ssize_t virStringSearch(const char *str,
                        const char *regexp,
                        size_t max_results,
                        char ***matches)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(4);

277 278 279 280 281
char *virStringReplace(const char *haystack,
                       const char *oldneedle,
                       const char *newneedle)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);

J
Ján Tomko 已提交
282
void virStringStripIPv6Brackets(char *str);
283 284
bool virStringHasControlChars(const char *str);
void virStringStripControlChars(char *str);
J
Ján Tomko 已提交
285

286
bool virStringIsPrintable(const char *str);
287
bool virStringBufferIsPrintable(const uint8_t *buf, size_t buflen);
288

289 290
char *virStringEncodeBase64(const uint8_t *buf, size_t buflen);

291
void virStringTrimOptionalNewline(char *str);
292

293
#endif /* __VIR_STRING_H__ */