XBPS Library API 20240111
The X Binary Package System
vasprintf.c
1/* $NetBSD: asprintf.c,v 1.2 2007/07/20 00:10:06 tnn Exp $ */
2
3/*-
4 * Copyright (c) 2007 Joerg Sonnenberger <joerg@NetBSD.org>.
5 * All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 *
11 * 1. Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in
15 * the documentation and/or other materials provided with the
16 * distribution.
17 *
18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
21 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
22 * COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
23 * INCIDENTAL, SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING,
24 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
25 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
26 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
27 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
28 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29 * SUCH DAMAGE.
30 */
31
32#include <stdio.h>
33#include <stdlib.h>
34#include <stdarg.h>
35#include "compat.h"
36
37int HIDDEN
38vasprintf(char **ret, const char *fmt, va_list ap)
39{
40 char *buf, *new_buf;
41 size_t len;
42 int retval;
43
44 len = 128;
45 buf = malloc(len);
46 if (buf == NULL) {
47 *ret = NULL;
48 return -1;
49 }
50
51 retval = vsnprintf(buf, len, fmt, ap);
52 if (retval < 0) {
53 free(buf);
54 *ret = NULL;
55 return -1;
56 }
57
58 if (retval < (int)len) {
59 new_buf = realloc(buf, retval + 1);
60 if (new_buf == NULL)
61 *ret = buf;
62 else
63 *ret = new_buf;
64 return retval;
65 }
66
67 len = (size_t)retval + 1;
68 free(buf);
69 buf = malloc(len);
70 if (buf == NULL) {
71 *ret = NULL;
72 return -1;
73 }
74 retval = vsnprintf(buf, len, fmt, ap);
75 if (retval != (int)len - 1) {
76 free(buf);
77 *ret = NULL;
78 return -1;
79 }
80 *ret = buf;
81 return retval;
82}