--- libelwix/src/elwix.c 2013/05/30 09:07:33 1.2 +++ libelwix/src/elwix.c 2022/09/26 18:55:21 1.9.56.1 @@ -3,7 +3,7 @@ * by Michael Pounov * * $Author: misho $ -* $Id: elwix.c,v 1.2 2013/05/30 09:07:33 misho Exp $ +* $Id: elwix.c,v 1.9.56.1 2022/09/26 18:55:21 misho Exp $ * ************************************************************************** The ELWIX and AITNET software is distributed under the following @@ -12,7 +12,7 @@ terms: All of the documentation and software included in the ELWIX and AITNET Releases is copyrighted by ELWIX - Sofia/Bulgaria -Copyright 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013 +Copyright 2004 - 2016 by Michael Pounov . All rights reserved. Redistribution and use in source and binary forms, with or without @@ -119,15 +119,16 @@ elwix_mm_inuse() } +#pragma GCC visibility push(hidden) // init libelwix routine -__attribute__((constructor)) void +__attribute__((constructor)) static void _elwix_init() { - elwixInit(ELWIX_MPOOL, 0); + elwixInit(MEMMGR, 0); } // fini libelwix routine -__attribute__((destructor)) void +__attribute__((destructor)) static void _elwix_fini() { elwixFini(); @@ -173,7 +174,7 @@ elwixInit(int mm, u_long maxmem) } /* - * elwixFini() - Finish libaitio library memory management + * elwixFini() - Finish libelwix library memory management * * return: none */ @@ -193,3 +194,85 @@ elwixFini() break; } } +#pragma GCC visibility pop + +/* + * elwix_byteOrder() - Detect platform byte order + * + * return: 1 = little endian or 0 big endian + */ +int +elwix_byteOrder() +{ + int x = 1; + + return *(char*) &x; +} + +#ifndef HAVE_STRLCPY +/* + * Copy src to string dst of size siz. At most siz-1 characters + * will be copied. Always NUL terminates (unless siz == 0). + * Returns strlen(src); if retval >= siz, truncation occurred. + */ +size_t +strlcpy(char *dst, const char *src, size_t siz) +{ + char *d = dst; + const char *s = src; + register size_t n = siz; + + /* Copy as many bytes as will fit */ + if (n) + while (--n) + if ((*d++ = *s++) == '\0') + break; + + /* Not enough room in dst, add NUL and traverse rest of src */ + if (!n) { + if (siz) + *d = '\0'; /* NUL-terminate dst */ + while (*s++); + } + + return (s - src - 1); /* count does not include NUL */ +} +#endif + +#ifndef strlcat +/* + * Appends src to string dst of size siz (unlike strncat, siz is the + * full size of dst, not space left). At most siz-1 characters + * will be copied. Always NUL terminates (unless siz <= strlen(dst)). + * Returns strlen(src) + MIN(siz, strlen(initial dst)). + * If retval >= siz, truncation occurred. + */ +size_t +strlcat(char *dst, const char *src, size_t siz) +{ + char *d = dst; + const char *s = src; + register size_t n = siz; + size_t dlen; + + /* Find the end of dst and adjust bytes left but don't go past end */ + while (n-- && *d != '\0') + d++; + + dlen = d - dst; + n = siz - dlen; + if (!n) + return (dlen + strlen(s)); + + while (*s != '\0') { + if (n != 1) { + *d++ = *s; + n--; + } + s++; + } + *d = '\0'; + + return (dlen + (s - src)); /* count does not include NUL */ +} +#endif