mirror of
https://git.notmuchmail.org/git/notmuch
synced 2025-01-25 12:44:25 +01:00
8b445212e4
Since we need to do this for portability, (some systems don't have a strndup function), we might as well do it unconditionally. There's almost no disadvantage to doing so, and this has the advantages of not requiring a configure-time check nor having two different implementations, one of which would often be less tested.
134 lines
2.5 KiB
C
134 lines
2.5 KiB
C
/* xutil.c - Various wrapper functions to abort on error.
|
|
*
|
|
* Copyright © 2009 Carl Worth
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program 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 General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see http://www.gnu.org/licenses/ .
|
|
*
|
|
* Author: Carl Worth <cworth@cworth.org>
|
|
*/
|
|
|
|
#include "notmuch-private.h"
|
|
|
|
#include <stdio.h>
|
|
|
|
void *
|
|
xcalloc (size_t nmemb, size_t size)
|
|
{
|
|
void *ret;
|
|
|
|
ret = calloc (nmemb, size);
|
|
if (ret == NULL) {
|
|
fprintf (stderr, "Out of memory.\n");
|
|
exit (1);
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
void *
|
|
xmalloc (size_t size)
|
|
{
|
|
void *ret;
|
|
|
|
ret = malloc (size);
|
|
if (ret == NULL) {
|
|
fprintf (stderr, "Out of memory.\n");
|
|
exit (1);
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
void *
|
|
xrealloc (void *ptr, size_t size)
|
|
{
|
|
void *ret;
|
|
|
|
ret = realloc (ptr, size);
|
|
if (ret == NULL) {
|
|
fprintf (stderr, "Out of memory.\n");
|
|
exit (1);
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
char *
|
|
xstrdup (const char *s)
|
|
{
|
|
char *ret;
|
|
|
|
ret = strdup (s);
|
|
if (ret == NULL) {
|
|
fprintf (stderr, "Out of memory.\n");
|
|
exit (1);
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
char *
|
|
xstrndup (const char *s, size_t n)
|
|
{
|
|
char *ret;
|
|
|
|
if (strlen (s) <= n)
|
|
n = strlen (s);
|
|
|
|
ret = malloc (n + 1);
|
|
if (ret == NULL) {
|
|
fprintf (stderr, "Out of memory.\n");
|
|
exit (1);
|
|
}
|
|
memcpy (ret, s, n);
|
|
ret[n] = '\0';
|
|
|
|
return ret;
|
|
}
|
|
|
|
void
|
|
xregcomp (regex_t *preg, const char *regex, int cflags)
|
|
{
|
|
int rerr;
|
|
|
|
rerr = regcomp (preg, regex, cflags);
|
|
if (rerr) {
|
|
size_t error_size = regerror (rerr, preg, NULL, 0);
|
|
char *error = xmalloc (error_size);
|
|
|
|
regerror (rerr, preg, error, error_size);
|
|
INTERNAL_ERROR ("compiling regex %s: %s\n",
|
|
regex, error);
|
|
}
|
|
}
|
|
|
|
int
|
|
xregexec (const regex_t *preg, const char *string,
|
|
size_t nmatch, regmatch_t pmatch[], int eflags)
|
|
{
|
|
unsigned int i;
|
|
int rerr;
|
|
|
|
rerr = regexec (preg, string, nmatch, pmatch, eflags);
|
|
if (rerr)
|
|
return rerr;
|
|
|
|
for (i = 0; i < nmatch; i++) {
|
|
if (pmatch[i].rm_so == -1)
|
|
INTERNAL_ERROR ("matching regex against %s: Sub-match %d not found\n",
|
|
string, i);
|
|
}
|
|
|
|
return 0;
|
|
}
|