diff options
-rw-r--r-- | Changes | 1 | ||||
-rw-r--r-- | bench.c | 4 | ||||
-rw-r--r-- | lzfP.h | 27 | ||||
-rw-r--r-- | lzf_d.c | 2 |
4 files changed, 16 insertions, 18 deletions
@@ -4,6 +4,7 @@ greatly speeding up decompression in most cases. - finally disable rep movsb - it's a big loss on modern intel cpus, and only a small win on amd cpus. + - improve c++ compatibility of the code. 3.5 Fri May 1 02:28:42 CEST 2009 - lzf_compress did sometimes write one octet past the given output @@ -1,4 +1,5 @@ #include <stdio.h> +#include <unistd.h> #include <assert.h> #include <string.h> #include <time.h> @@ -41,8 +42,6 @@ static void sigu (int signum) { } -int eventfd(unsigned int,int); - #define DSIZE 2821120 unsigned char data[DSIZE], data2[DSIZE*2], data3[DSIZE*2]; @@ -56,7 +55,6 @@ int main(void) int lp; char buf[8192]; int p[2]; - int evfd = eventfd (0, 0); long ctr = 1; struct stat sbuf; @@ -94,7 +94,7 @@ /* * Avoid assigning values to errno variable? for some embedding purposes * (linux kernel for example), this is necessary. NOTE: this breaks - * the documentation in lzf.h. + * the documentation in lzf.h. Avoiding errno has no speed impact. */ #ifndef AVOID_ERRNO # define AVOID_ERRNO 0 @@ -124,13 +124,24 @@ /*****************************************************************************/ /* nothing should be changed below */ +#ifdef __cplusplus +# include <cstring> +using namespace std; +#else +# include <string.h> +#endif + typedef unsigned char u8; typedef const u8 *LZF_STATE[1 << (HLOG)]; #if !STRICT_ALIGN /* for unaligned accesses we need a 16 bit datatype. */ -# include <limits.h> +# ifdef __cplusplus +# include <climits> +# else +# include <limits.h> +# endif # if USHRT_MAX == 65535 typedef unsigned short u16; # elif UINT_MAX == 65535 @@ -142,17 +153,7 @@ typedef const u8 *LZF_STATE[1 << (HLOG)]; #endif #if ULTRA_FAST -# if defined(VERY_FAST) -# undef VERY_FAST -# endif -#endif - -#if INIT_HTAB -# ifdef __cplusplus -# include <cstring> -# else -# include <string.h> -# endif +# undef VERY_FAST #endif #endif @@ -36,8 +36,6 @@ #include "lzfP.h" -#include <string.h> /* for memcpy/memset */ - #if AVOID_ERRNO # define SET_ERRNO(n) #else |