OpusReader: don't use strndup()

Eliminate the fallback strndup() and strnlen() implementations.
This commit is contained in:
Max Kellermann 2013-04-09 01:03:44 +02:00
parent 2090911363
commit 14df240f5b
4 changed files with 4 additions and 67 deletions

View File

@ -136,8 +136,6 @@ AC_SEARCH_LIBS([gethostbyname], [nsl])
AC_CHECK_FUNCS(pipe2 accept4 eventfd) AC_CHECK_FUNCS(pipe2 accept4 eventfd)
AC_CHECK_FUNCS(strnlen strndup)
AC_SEARCH_LIBS([exp], [m],, AC_SEARCH_LIBS([exp], [m],,
[AC_MSG_ERROR([exp() not found])]) [AC_MSG_ERROR([exp() not found])])

View File

@ -21,7 +21,6 @@
#define MPD_OPUS_READER_HXX #define MPD_OPUS_READER_HXX
#include "check.h" #include "check.h"
#include "string_util.h"
#include <stdint.h> #include <stdint.h>
#include <string.h> #include <string.h>
@ -91,7 +90,10 @@ public:
if (src == nullptr) if (src == nullptr)
return nullptr; return nullptr;
return strndup(src, length); char *dest = new char[length + 1];
memcpy(dest, src, length);
dest[length] = 0;
return dest;
} }
}; };

View File

@ -17,11 +17,8 @@
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/ */
#include "config.h"
#include "string_util.h" #include "string_util.h"
#include <stdlib.h> /* for malloc() */
#include <string.h> /* for strnlen() */
#include <glib.h> #include <glib.h>
#include <assert.h> #include <assert.h>
@ -47,37 +44,3 @@ string_array_contains(const char *const* haystack, const char *needle)
return false; return false;
} }
#ifndef HAVE_STRNLEN
size_t
strnlen(const char *s, size_t max)
{
assert(s != NULL);
const char *t = memchr(s, 0, max);
return t != NULL
? (size_t)(t - s)
: max;
}
#endif
#if !defined(HAVE_STRNDUP)
char *
strndup(const char *str, size_t n)
{
assert(str != NULL);
size_t len = strnlen(str, n);
char* ret = (char *) malloc(len + 1);
if (ret == NULL)
return NULL;
memcpy(ret, str, len);
ret[len] = '\0';
return ret;
}
#endif

View File

@ -23,7 +23,6 @@
#include "gcc.h" #include "gcc.h"
#include <stdbool.h> #include <stdbool.h>
#include <stdlib.h> /* for size_t */
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
@ -83,31 +82,6 @@ strchug_fast(char *p)
bool bool
string_array_contains(const char *const* haystack, const char *needle); string_array_contains(const char *const* haystack, const char *needle);
#ifndef HAVE_STRNLEN
gcc_pure
size_t
strnlen(const char *s, size_t max);
#endif
#if !defined(HAVE_STRNDUP)
/**
* Duplicates the string to a newly allocated buffer
* copying at most n characters.
*
* @param str a string to duplicate
* @param n maximal number of characters to copy
* @return a pointer to the duplicated string,
* or NULL if memory allocation failed.
*/
gcc_malloc
char *
strndup(const char *str, size_t n);
#endif
#ifdef __cplusplus #ifdef __cplusplus
} /* extern "C" */ } /* extern "C" */
#endif #endif