virstring.h 9.8 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 40 41 42 43 44
char **virStringSplit(const char *string,
                      const char *delim,
                      size_t max_tokens)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);

char *virStringJoin(const char **strings,
                    const char *delim)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);

void virStringFreeList(char **strings);
45
void virStringFreeListCount(char **strings, size_t count);
46

47
bool virStringArrayHasString(char **strings, const char *needle);
48 49
char *virStringGetFirstWithPrefix(char **strings, const char *prefix)
    ATTRIBUTE_NONNULL(2);
50

51 52 53 54 55
char *virArgvToString(const char *const *argv);

int virStrToLong_i(char const *s,
                   char **end_ptr,
                   int base,
56 57
                   int *result)
    ATTRIBUTE_RETURN_CHECK;
58 59 60 61

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

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);

110 111
bool virStringIsEmpty(const char *str);

112 113 114 115 116
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))
117 118 119 120

/* 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)
121
    ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NONNULL(1);
122

123
int virStrndup(char **dest, const char *src, ssize_t n, bool report, int domcode,
124
               const char *filename, const char *funcname, size_t linenr)
125
    ATTRIBUTE_RETURN_CHECK ATTRIBUTE_NONNULL(1);
126 127 128 129 130 131 132 133 134 135
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;
136 137 138 139 140 141 142 143

/**
 * VIR_STRDUP:
 * @dst: variable to hold result (char*, not char**)
 * @src: string to duplicate
 *
 * Duplicate @src string and store it into @dst.
 *
144 145 146 147
 * 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
148 149 150 151 152 153 154 155 156 157 158
 */
# 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.
 *
159 160 161
 * 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
162 163 164 165 166 167 168 169 170 171
 */
# 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,
172 173 174
 * 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.
175
 *
176 177 178 179
 * 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
180 181 182 183 184 185 186 187 188 189 190 191
 */
# 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,
192 193 194 195
 * 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.
196
 *
197 198 199
 * 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
200 201 202
 */
# define VIR_STRNDUP_QUIET(dst, src, n) virStrndup(&(dst), src, n, false, \
                                                   0, NULL, NULL, 0)
203

204
size_t virStringListLength(const char * const *strings);
205

206 207 208 209 210 211
/**
 * virVasprintf
 *
 * Like glibc's vasprintf but makes sure *strp == NULL on failure, in which
 * case the OOM error is reported too.
 *
212 213
 * Returns -1 on failure (with OOM error reported), number of bytes printed
 * on success.
214 215 216 217 218 219 220 221 222 223
 */
# 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.
 *
224
 * Returns -1 on failure, number of bytes printed on success.
225 226 227 228 229 230 231 232 233 234 235 236
 */
# 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.
 *
237 238
 * Returns -1 on failure (with OOM error reported), number of bytes printed
 * on success.
239 240 241 242 243 244 245 246 247 248 249 250 251
 */

# 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.
 *
252
 * Returns -1 on failure, number of bytes printed on success.
253 254 255 256 257 258
 */

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

259 260
int virStringSortCompare(const void *a, const void *b);
int virStringSortRevCompare(const void *a, const void *b);
261
int virStringToUpper(char **dst, const char *src);
262

263 264 265 266 267 268
ssize_t virStringSearch(const char *str,
                        const char *regexp,
                        size_t max_results,
                        char ***matches)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(4);

269 270 271 272 273
char *virStringReplace(const char *haystack,
                       const char *oldneedle,
                       const char *newneedle)
    ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3);

J
Ján Tomko 已提交
274
void virStringStripIPv6Brackets(char *str);
275 276
bool virStringHasControlChars(const char *str);
void virStringStripControlChars(char *str);
J
Ján Tomko 已提交
277

278
bool virStringIsPrintable(const char *str);
279
bool virStringBufferIsPrintable(const uint8_t *buf, size_t buflen);
280

281 282
char *virStringEncodeBase64(const uint8_t *buf, size_t buflen);

283
#endif /* __VIR_STRING_H__ */