misc.c revision 1.14 1 1.14 wiz /* $NetBSD: misc.c,v 1.14 2014/06/06 21:56:39 wiz Exp $ */
2 1.5 tls
3 1.1 alm /*-
4 1.12 christos * Copyright (c) 1992 Diomidis Spinellis.
5 1.3 cgd * Copyright (c) 1992, 1993
6 1.3 cgd * The Regents of the University of California. All rights reserved.
7 1.1 alm *
8 1.1 alm * This code is derived from software contributed to Berkeley by
9 1.1 alm * Diomidis Spinellis of Imperial College, University of London.
10 1.1 alm *
11 1.1 alm * Redistribution and use in source and binary forms, with or without
12 1.1 alm * modification, are permitted provided that the following conditions
13 1.1 alm * are met:
14 1.1 alm * 1. Redistributions of source code must retain the above copyright
15 1.1 alm * notice, this list of conditions and the following disclaimer.
16 1.1 alm * 2. Redistributions in binary form must reproduce the above copyright
17 1.1 alm * notice, this list of conditions and the following disclaimer in the
18 1.1 alm * documentation and/or other materials provided with the distribution.
19 1.14 wiz * 3. Neither the name of the University nor the names of its contributors
20 1.1 alm * may be used to endorse or promote products derived from this software
21 1.1 alm * without specific prior written permission.
22 1.1 alm *
23 1.1 alm * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
24 1.1 alm * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25 1.1 alm * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26 1.1 alm * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
27 1.1 alm * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28 1.1 alm * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29 1.1 alm * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30 1.1 alm * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31 1.1 alm * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32 1.1 alm * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33 1.1 alm * SUCH DAMAGE.
34 1.1 alm */
35 1.1 alm
36 1.9 gdamore #if HAVE_NBTOOL_CONFIG_H
37 1.9 gdamore #include "nbtool_config.h"
38 1.9 gdamore #endif
39 1.9 gdamore
40 1.6 lukem #include <sys/cdefs.h>
41 1.14 wiz __RCSID("$NetBSD: misc.c,v 1.14 2014/06/06 21:56:39 wiz Exp $");
42 1.12 christos #ifdef __FBSDID
43 1.12 christos __FBSDID("$FreeBSD: head/usr.bin/sed/misc.c 200462 2009-12-13 03:14:06Z delphij $");
44 1.12 christos #endif
45 1.12 christos
46 1.1 alm #include <sys/types.h>
47 1.1 alm
48 1.12 christos #include <err.h>
49 1.12 christos #include <limits.h>
50 1.1 alm #include <regex.h>
51 1.1 alm #include <stdio.h>
52 1.1 alm #include <stdlib.h>
53 1.1 alm #include <string.h>
54 1.1 alm
55 1.1 alm #include "defs.h"
56 1.1 alm #include "extern.h"
57 1.1 alm
58 1.1 alm /*
59 1.1 alm * malloc with result test
60 1.1 alm */
61 1.1 alm void *
62 1.11 tnn xmalloc(size_t size)
63 1.1 alm {
64 1.1 alm void *p;
65 1.1 alm
66 1.1 alm if ((p = malloc(size)) == NULL)
67 1.12 christos err(1, "malloc(%zu)", size);
68 1.12 christos return p;
69 1.1 alm }
70 1.1 alm
71 1.1 alm /*
72 1.1 alm * realloc with result test
73 1.1 alm */
74 1.1 alm void *
75 1.11 tnn xrealloc(void *p, size_t size)
76 1.1 alm {
77 1.1 alm if (p == NULL) /* Compatibility hack. */
78 1.1 alm return (xmalloc(size));
79 1.1 alm
80 1.1 alm if ((p = realloc(p, size)) == NULL)
81 1.12 christos err(1, "realloc(%zu)", size);
82 1.12 christos return p;
83 1.1 alm }
84 1.1 alm
85 1.1 alm /*
86 1.12 christos * realloc with result test
87 1.12 christos */
88 1.12 christos void *
89 1.12 christos xcalloc(size_t c, size_t n)
90 1.12 christos {
91 1.12 christos void *p;
92 1.12 christos
93 1.12 christos if ((p = calloc(c, n)) == NULL)
94 1.12 christos err(1, "calloc(%zu, %zu)", c, n);
95 1.12 christos return p;
96 1.12 christos }
97 1.12 christos /*
98 1.12 christos * Return a string for a regular expression error passed. This is overkill,
99 1.1 alm * because of the silly semantics of regerror (we can never know the size of
100 1.1 alm * the buffer).
101 1.1 alm */
102 1.1 alm char *
103 1.7 wiz strregerror(int errcode, regex_t *preg)
104 1.1 alm {
105 1.10 lukem char buf[1];
106 1.1 alm static char *oe;
107 1.1 alm size_t s;
108 1.1 alm
109 1.1 alm if (oe != NULL)
110 1.1 alm free(oe);
111 1.10 lukem s = regerror(errcode, preg, buf, 0);
112 1.1 alm oe = xmalloc(s);
113 1.1 alm (void)regerror(errcode, preg, oe, s);
114 1.1 alm return (oe);
115 1.1 alm }
116