Coverage Report

Created: 2026-04-12 06:58

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/tmux/xmalloc.c
Line
Count
Source
1
/* $OpenBSD$ */
2
3
/*
4
 * Author: Tatu Ylonen <ylo@cs.hut.fi>
5
 * Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
6
 *                    All rights reserved
7
 * Versions of malloc and friends that check their results, and never return
8
 * failure (they call fatalx if they encounter an error).
9
 *
10
 * As far as I am concerned, the code I have written for this software
11
 * can be used freely for any purpose.  Any derived versions of this
12
 * software must be clearly marked as such, and if the derived work is
13
 * incompatible with the protocol description in the RFC file, it must be
14
 * called by a name other than "ssh" or "Secure Shell".
15
 */
16
17
#include <errno.h>
18
#include <limits.h>
19
#include <stdint.h>
20
#include <stdio.h>
21
#include <stdlib.h>
22
#include <string.h>
23
24
#include "tmux.h"
25
26
void *
27
xmalloc(size_t size)
28
2
{
29
2
  void *ptr;
30
31
2
  if (size == 0)
32
0
    fatalx("xmalloc: zero size");
33
2
  ptr = malloc(size);
34
2
  if (ptr == NULL)
35
0
    fatalx("xmalloc: allocating %zu bytes: %s",
36
0
        size, strerror(errno));
37
2
  return ptr;
38
2
}
39
40
void *
41
xcalloc(size_t nmemb, size_t size)
42
252
{
43
252
  void *ptr;
44
45
252
  if (size == 0 || nmemb == 0)
46
0
    fatalx("xcalloc: zero size");
47
252
  ptr = calloc(nmemb, size);
48
252
  if (ptr == NULL)
49
0
    fatalx("xcalloc: allocating %zu * %zu bytes: %s",
50
0
        nmemb, size, strerror(errno));
51
252
  return ptr;
52
252
}
53
54
void *
55
xrealloc(void *ptr, size_t size)
56
12
{
57
12
  return xreallocarray(ptr, 1, size);
58
12
}
59
60
void *
61
xreallocarray(void *ptr, size_t nmemb, size_t size)
62
12
{
63
12
  void *new_ptr;
64
65
12
  if (nmemb == 0 || size == 0)
66
0
    fatalx("xreallocarray: zero size");
67
12
  new_ptr = reallocarray(ptr, nmemb, size);
68
12
  if (new_ptr == NULL)
69
0
    fatalx("xreallocarray: allocating %zu * %zu bytes: %s",
70
0
        nmemb, size, strerror(errno));
71
12
  return new_ptr;
72
12
}
73
74
void *
75
xrecallocarray(void *ptr, size_t oldnmemb, size_t nmemb, size_t size)
76
1
{
77
1
  void *new_ptr;
78
79
1
  if (nmemb == 0 || size == 0)
80
0
    fatalx("xrecallocarray: zero size");
81
1
  new_ptr = recallocarray(ptr, oldnmemb, nmemb, size);
82
1
  if (new_ptr == NULL)
83
0
    fatalx("xrecallocarray: allocating %zu * %zu bytes: %s",
84
0
        nmemb, size, strerror(errno));
85
1
  return new_ptr;
86
1
}
87
88
char *
89
xstrdup(const char *str)
90
299
{
91
299
  char *cp;
92
93
299
  if ((cp = strdup(str)) == NULL)
94
0
    fatalx("xstrdup: %s", strerror(errno));
95
299
  return cp;
96
299
}
97
98
char *
99
xstrndup(const char *str, size_t maxlen)
100
0
{
101
0
  char *cp;
102
103
0
  if ((cp = strndup(str, maxlen)) == NULL)
104
0
    fatalx("xstrndup: %s", strerror(errno));
105
0
  return cp;
106
0
}
107
108
int
109
xasprintf(char **ret, const char *fmt, ...)
110
0
{
111
0
  va_list ap;
112
0
  int i;
113
114
0
  va_start(ap, fmt);
115
0
  i = xvasprintf(ret, fmt, ap);
116
0
  va_end(ap);
117
118
0
  return i;
119
0
}
120
121
int
122
xvasprintf(char **ret, const char *fmt, va_list ap)
123
0
{
124
0
  int i;
125
126
0
  i = vasprintf(ret, fmt, ap);
127
128
0
  if (i == -1)
129
0
    fatalx("xasprintf: %s", strerror(errno));
130
131
0
  return i;
132
0
}
133
134
int
135
xsnprintf(char *str, size_t len, const char *fmt, ...)
136
0
{
137
0
  va_list ap;
138
0
  int i;
139
140
0
  va_start(ap, fmt);
141
0
  i = xvsnprintf(str, len, fmt, ap);
142
0
  va_end(ap);
143
144
0
  return i;
145
0
}
146
147
int
148
xvsnprintf(char *str, size_t len, const char *fmt, va_list ap)
149
0
{
150
0
  int i;
151
152
0
  if (len > INT_MAX)
153
0
    fatalx("xsnprintf: len > INT_MAX");
154
155
0
  i = vsnprintf(str, len, fmt, ap);
156
157
0
  if (i < 0 || i >= (int)len)
158
0
    fatalx("xsnprintf: overflow");
159
160
0
  return i;
161
0
}