Remove libbsd support
This commit is contained in:
parent
46be9fd805
commit
6aa4b6de39
7 changed files with 87 additions and 46 deletions
2
Makefile
2
Makefile
|
@ -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
5
lcl.c
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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"
|
||||||
|
|
||||||
|
|
||||||
/***
|
/***
|
||||||
|
|
5
lfile.c
5
lfile.c
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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
88
util.c
|
@ -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
22
util.h
|
@ -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 *);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue