OpusReader: don't use strndup()
Eliminate the fallback strndup() and strnlen() implementations.
This commit is contained in:
parent
2090911363
commit
14df240f5b
@ -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])])
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -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
|
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user