Remove libbsd support

This commit is contained in:
Jeremy Baxter 2023-06-27 12:33:51 +12:00
parent 46be9fd805
commit 6aa4b6de39
7 changed files with 87 additions and 46 deletions

View file

@ -3,7 +3,7 @@ PREFIX = /usr/local
CC = cc CC = cc
CFLAGS = -std=c99 -pedantic -fpic -O2 -Wall -Wextra -Wno-override-init -I. -Ilua-5.4 CFLAGS = -std=c99 -pedantic -fpic -O2 -Wall -Wextra -Wno-override-init -I. -Ilua-5.4
CPPFLAGS = -D_DEFAULT_SOURCE -DLUA_USE_READLINE CPPFLAGS = -D_DEFAULT_SOURCE -DLUA_USE_READLINE
LDFLAGS = -Wl,--gc-sections -lbsd -ldl -lm -lreadline LDFLAGS = -lm -lreadline
OBJS = csto.o lcallisto.o lcl.o lenvironment.o lfile.o \ OBJS = csto.o lcallisto.o lcl.o lenvironment.o lfile.o \
ljson.o lmath.o los.o lprocess.o lsocket.o util.o ljson.o lmath.o los.o lprocess.o lsocket.o util.o

5
lcl.c
View file

@ -9,10 +9,7 @@
#include <unistd.h> #include <unistd.h>
#include <libgen.h> #include <libgen.h>
#include <errno.h> #include <errno.h>
#ifdef __linux__ #ifdef BSD
# include <bsd/string.h>
#else
/* assume BSD */
# include <string.h> # include <string.h>
#endif #endif

View file

@ -6,10 +6,7 @@
#include <stdlib.h> #include <stdlib.h>
#include <errno.h> #include <errno.h>
#ifdef __linux__ #ifdef BSD
# include <bsd/string.h>
#else
/* assume BSD */
# include <string.h> # include <string.h>
#endif #endif
@ -18,6 +15,7 @@
#include "lenvironment.h" #include "lenvironment.h"
#include "lcallisto.h" #include "lcallisto.h"
#include "util.h"
/*** /***

View file

@ -9,10 +9,7 @@
#include <unistd.h> #include <unistd.h>
#include <libgen.h> #include <libgen.h>
#include <errno.h> #include <errno.h>
#ifdef __linux__ #ifdef BSD
# include <bsd/string.h>
#else
/* assume BSD */
# include <string.h> # include <string.h>
#endif #endif

View file

@ -9,10 +9,7 @@
#include <signal.h> #include <signal.h>
#include <string.h> #include <string.h>
#include <errno.h> #include <errno.h>
#ifdef __linux__ #ifdef BSD
# include <bsd/string.h>
#else
/* assume BSD */
# include <string.h> # include <string.h>
#endif #endif

88
util.c
View file

@ -6,32 +6,94 @@
* of these functions. * of these functions.
*/ */
#include <util.h>
#include <string.h> #include <string.h>
#include <lua.h> #include <lua.h>
#include <lauxlib.h> #include <lauxlib.h>
int lfail(lua_State *L, const char* mesg) #include "util.h"
int
lfail(lua_State *L, const char* mesg)
{ {
luaL_pushfail(L); luaL_pushfail(L);
lua_pushstring(L, mesg); lua_pushstring(L, mesg);
return LFAIL_RET; return LFAIL_RET;
} }
void strprepend(char *s, const char *t) #ifndef BSD
/*
* Appends src to string dst of size dsize (unlike strncat, dsize is the
* full size of dst, not space left). At most dsize-1 characters
* will be copied. Always NUL terminates (unless dsize <= strlen(dst)).
* Returns strlen(src) + MIN(dsize, strlen(initial dst)).
* If retval >= dsize, truncation occurred.
*/
size_t
strlcat(char *dst, const char *src, size_t dsize)
{
const char *odst = dst;
const char *osrc = src;
size_t n = dsize;
size_t dlen;
/* Find the end of dst and adjust bytes left but don't go past end. */
while (n-- != 0 && *dst != '\0')
dst++;
dlen = dst - odst;
n = dsize - dlen;
if (n-- == 0)
return(dlen + strlen(src));
while (*src != '\0') {
if (n != 0) {
*dst++ = *src;
n--;
}
src++;
}
*dst = '\0';
return(dlen + (src - osrc)); /* count does not include NUL */
}
/*
* Copy string src to buffer dst of size dsize. At most dsize-1
* chars will be copied. Always NUL terminates (unless dsize == 0).
* Returns strlen(src); if retval >= dsize, truncation occurred.
*/
size_t
strlcpy(char *dst, const char *src, size_t dsize)
{
const char *osrc = src;
size_t nleft = dsize;
/* Copy as many bytes as will fit. */
if (nleft != 0) {
while (--nleft != 0) {
if ((*dst++ = *src++) == '\0')
break;
}
}
/* Not enough room in dst, add NUL and traverse rest of src. */
if (nleft == 0) {
if (dsize != 0)
*dst = '\0'; /* NUL-terminate dst */
while (*src++)
;
}
return(src - osrc - 1); /* count does not include NUL */
}
#endif
/*
* Prepends t to s.
*/
void
strprepend(char *s, const char *t)
{ {
size_t len = strlen(t); size_t len = strlen(t);
memmove(s + len, s, strlen(s) + 1); memmove(s + len, s, strlen(s) + 1);
memcpy(s, t, len); memcpy(s, t, len);
} }
void strslice(const char *s, char *buf, size_t start, size_t end)
{
size_t j = 0;
for (size_t i = start; i <= end; ++i) {
buf[j++] = s[i];
}
buf[j] = 0;
}

22
util.h
View file

@ -9,20 +9,10 @@
lua_setfield(L, -2, lib[i].name); \ lua_setfield(L, -2, lib[i].name); \
} }
/* int lfail(lua_State *, const char *);
* Pushes the fail value and the string mesg
* onto the stack, then returns 2.
*/
int lfail(lua_State *L, const char* mesg);
/*
* Prepends t onto s.
* Assumes s has enough space allocated
* for the combined string.
*/
void strprepend(char* s, const char* t);
/* #ifndef BSD
* Slices the string s into buf. size_t strlcat(char *, const char *, size_t);
* The sliced string has the range [start .. end]. size_t strlcpy(char *, const char *, size_t);
*/ #endif
void strslice(const char *s, char *buf, size_t start, size_t end); void strprepend(char *, const char *);