/* c++ -Izap/include -Lzap -otest test.cc -lzap */ #include #include #include #include #include #include #include #include extern "C" auto zap_test_foreachfn(void * const _ptr) -> void { /* This function is passed to foreach, which requires C-linkage function pointers. I tried to overload the function to also accept C++-linkage function pointers, but that only made GCC moan. */ auto const ptr {static_cast(_ptr)}; auto val {*ptr}; if (val == 0x45) {throw ::std::domain_error {"Damn!"};} val %= 0x2; *ptr = val; } int main(void) { ::std::fprintf(stderr,"zap test\n"); ::std::fprintf(stderr,"arch: %s\n",sus_archstr); ::std::fprintf(stderr,"fast: %s\n",::zap_fastimpl ? "yes" : "no"); ::std::fprintf(stderr,"\n"); { { auto val {::zap_abs_c(-0x5D)}; ::std::fprintf(stderr,"val: %hhi\n",val); assert(val == 0x5D); } { auto val {::zap_abs_i(-0xEF4)}; ::std::fprintf(stderr,"val: %i\n",val); assert(val == 0xEF4); } { auto val {::zap_abs_l(-0x6666E67B)}; ::std::fprintf(stderr,"val: %li\n",val); assert(val == 0x6666E67B); } { auto val {::zap_abs_ll(-0x7C91A4B244F0DC99)}; ::std::fprintf(stderr,"val: %lli\n",val); assert(val == 0x7C91A4B244F0DC99); } { auto val {::zap_abs_s(-0xDC9)}; ::std::fprintf(stderr,"val: %i\n",val); assert(val == 0xDC9); } } ::std::fprintf(stderr,"\n"); { { /* Largest number for each signed parameter: (floor(cbrt(2^(x-1)-1))) */ auto val {::zap_fma_c(0x5,0x2,0x2)}; ::std::fprintf(stderr,"val: %hhi\n",val); assert(val == 0x9); } { auto val {::zap_fma_i(0x29,0x4AD,0x453)}; ::std::fprintf(stderr,"val: %i\n",val); assert(val == 0x143840); } { auto val {::zap_fma_l(0x1BAA11,0x361DA,0x17462F)}; ::std::fprintf(stderr,"val: %li\n",val); assert(val == 0x4EB8123D17); } { auto val {::zap_fma_ll(0x45,0x60,0x1A4)}; ::std::fprintf(stderr,"val: %lli\n",val); assert(val == 0x9DC5); } { auto val {::zap_fma_s(0x7,0xE,0x1D)}; ::std::fprintf(stderr,"val: %i\n",val); assert(val == 0x19D); } { /* Largest number for each unsigned parameter: (floor(cbrt(2^x-1))) */ auto val {::zap_fma_uc(0x6u,0x6u,0x3u)}; ::std::fprintf(stderr,"val: %hhu\n",val); assert(val == 0x18u); } { auto val {::zap_fma_ui(0x14u,0x17u,0x3u)}; ::std::fprintf(stderr,"val: %u\n",val); assert(val == 0x59); } { auto val {::zap_fma_ul(0x5AAu,0x412u,0x16Du)}; ::std::fprintf(stderr,"val: %lu\n",val); assert(val == 0x5D354u); } { auto val {::zap_fma_ull(0x10EFC7u,0x19FB63u,0x1133259u)}; ::std::fprintf(stderr,"val: %llu\n",val); assert(val == 0x1BEE278BAB32u); } { auto val {::zap_fma_us(0x23u,0x19u,0x1Cu)}; ::std::fprintf(stderr,"val: %u\n",val); assert(val == 0x2DF); } } ::std::fprintf(stderr,"\n"); { constexpr ::std::size_t arrsz {0x8u}; ::std::uint_least64_t arr0[arrsz] {0x0u}; ::zap_memfill(arr0,arrsz * sizeof (::std::uint_least64_t),0x0u); ::std::fprintf(stderr,"arr0[0]: %" PRIXLEAST64 "\n",arr0[0x0u]); ::std::fprintf(stderr,"arr0[1]: %" PRIXLEAST64 "\n",arr0[0x1u]); ::std::fprintf(stderr,"arr0[2]: %" PRIXLEAST64 "\n",arr0[0x2u]); ::std::fprintf(stderr,"arr0[3]: %" PRIXLEAST64 "\n",arr0[0x3u]); ::std::fprintf(stderr,"arr0[4]: %" PRIXLEAST64 "\n",arr0[0x4u]); ::std::fprintf(stderr,"arr0[5]: %" PRIXLEAST64 "\n",arr0[0x5u]); ::std::fprintf(stderr,"arr0[6]: %" PRIXLEAST64 "\n",arr0[0x6u]); assert(arr0[0x0u] == 0x0u); assert(arr0[0x1u] == 0x0u); assert(arr0[0x2u] == 0x0u); assert(arr0[0x3u] == 0x0u); assert(arr0[0x4u] == 0x0u); assert(arr0[0x5u] == 0x0u); assert(arr0[0x6u] == 0x0u); ::zap_memfill(arr0,arrsz * sizeof (::std::uint_least64_t),0x7Fu); ::std::fprintf(stderr,"arr0[0]: %" PRIXLEAST64 "\n",arr0[0x0u]); ::std::fprintf(stderr,"arr0[1]: %" PRIXLEAST64 "\n",arr0[0x1u]); ::std::fprintf(stderr,"arr0[2]: %" PRIXLEAST64 "\n",arr0[0x2u]); ::std::fprintf(stderr,"arr0[3]: %" PRIXLEAST64 "\n",arr0[0x3u]); ::std::fprintf(stderr,"arr0[4]: %" PRIXLEAST64 "\n",arr0[0x4u]); ::std::fprintf(stderr,"arr0[5]: %" PRIXLEAST64 "\n",arr0[0x5u]); ::std::fprintf(stderr,"arr0[6]: %" PRIXLEAST64 "\n",arr0[0x6u]); assert(arr0[0x0u] == 0x7F7F7F7F7F7F7F7Fu); assert(arr0[0x1u] == 0x7F7F7F7F7F7F7F7Fu); assert(arr0[0x2u] == 0x7F7F7F7F7F7F7F7Fu); assert(arr0[0x3u] == 0x7F7F7F7F7F7F7F7Fu); assert(arr0[0x4u] == 0x7F7F7F7F7F7F7F7Fu); assert(arr0[0x5u] == 0x7F7F7F7F7F7F7F7Fu); assert(arr0[0x6u] == 0x7F7F7F7F7F7F7F7Fu); ::std::uint_least64_t arr1[arrsz] {0x0u}; ::zap_memcpy(arr0,arrsz * sizeof (::std::uint_least64_t),arr1); ::std::fprintf(stderr,"arr1[0]: %" PRIXLEAST64 "\n",arr1[0x0u]); ::std::fprintf(stderr,"arr1[1]: %" PRIXLEAST64 "\n",arr1[0x1u]); ::std::fprintf(stderr,"arr1[2]: %" PRIXLEAST64 "\n",arr1[0x2u]); ::std::fprintf(stderr,"arr1[3]: %" PRIXLEAST64 "\n",arr1[0x3u]); ::std::fprintf(stderr,"arr1[4]: %" PRIXLEAST64 "\n",arr1[0x4u]); ::std::fprintf(stderr,"arr1[5]: %" PRIXLEAST64 "\n",arr1[0x5u]); ::std::fprintf(stderr,"arr1[6]: %" PRIXLEAST64 "\n",arr1[0x6u]); assert(arr1[0x0u] == arr0[0x0u]); assert(arr1[0x1u] == arr0[0x1u]); assert(arr1[0x2u] == arr0[0x2u]); assert(arr1[0x3u] == arr0[0x3u]); assert(arr1[0x4u] == arr0[0x4u]); assert(arr1[0x5u] == arr0[0x5u]); assert(arr1[0x6u] == arr0[0x6u]); auto const eq {::zap_memeq(arr1,arrsz,arr0)}; ::std::fprintf(stderr,"eq: %u\n",eq); assert(eq); } ::std::fprintf(stderr,"\n"); { auto const str {"Hello there! General Kenobi?"}; ::std::fprintf(stderr,"str: \"%s\"\n",str); auto const strsz {::zap_strlen(str)}; ::std::fprintf(stderr,"strsz: %zX\n",strsz); assert(strsz == 0x1Cu); } ::std::fprintf(stderr,"\n"); { auto str {"Oh my science!"}; ::std::fprintf(stderr,"str: \"%s\"\n",str); auto len {::zap_strlen(str)}; ::std::fprintf(stderr,"len: %zX\n",len); ::std::size_t pos0 = ::zap_fndchr(str,' '); ::std::size_t pos1 = ::zap_fndbyte(str,len,(unsigned char)' '); ::std::fprintf(stderr,"pos0: %zX\n",pos0); ::std::fprintf(stderr,"pos1: %zX\n",pos1); assert(pos0 == 0x2u); assert(pos1 == pos0); str += pos0 + 0x1u; len = ::zap_strlen(str); pos0 = ::zap_fndchr(str,' '); pos1 = ::zap_fndbyte(str,len,(unsigned char)' '); ::std::fprintf(stderr,"pos0: %zX\n",pos0); ::std::fprintf(stderr,"pos1: %zX\n",pos1); assert(pos0 == 0x2u); assert(pos1 == pos0); str += pos0 + 0x1u; len = ::zap_strlen(str); pos0 = ::zap_fndchr(str,' '); pos1 = ::zap_fndbyte(str,len,(unsigned char)' '); ::std::fprintf(stderr,"pos0: %zX\n",pos0); ::std::fprintf(stderr,"pos1: %zX\n",pos1); assert(pos0 == SIZE_MAX); assert(pos1 == pos0); } ::std::fprintf(stderr,"\n"); { char const str0[] = "What's up, my guy?"; ::std::fprintf(stderr,"str0: \"%s\"\n",str0); char const str1[] = "What's up, my guy?"; ::std::fprintf(stderr,"str1: \"%s\"\n",str1); char const str2[] = "I don't know you!"; ::std::fprintf(stderr,"str2: \"%s\"\n",str2); bool const cmp0 = ::zap_streq(str0,str1); bool const cmp1 = ::zap_streq(str0,str2); bool const cmp2 = ::zap_streq(str1,str2); ::std::fprintf(stderr,"cmp0: %u\n",cmp0); ::std::fprintf(stderr,"cmp1: %u\n",cmp1); ::std::fprintf(stderr,"cmp2: %u\n",cmp2); assert(cmp0); assert(!cmp1); assert(!cmp2); } ::std::fprintf(stderr,"\n"); { char const str0[] = "What in the world are you doing?"; ::std::fprintf(stderr,"str0: \"%s\"\n",str0); char str1[sizeof (str0)]; assert(::zap_strcpy(str0,str1) == 0x20u); ::std::fprintf(stderr,"str1: \"%s\"\n",str1); assert(::zap_streq(str0,str1)); } ::std::fprintf(stderr,"\n"); { char const str0[] {"Oej Moej Goejd"}; char const str1[] {"Er jeg egentlig okay med AWP?"}; ::std::fprintf(stderr,"str0: \"%s\"\n",str0); ::std::fprintf(stderr,"str1: \"%s\"\n",str1); auto const cmp0 {::zap_strcmp(str0,str1)}; auto const cmp1 {::zap_strcmp(str0,str0)}; auto const cmp2 {::zap_strcmp(str1,str0)}; auto const leastsz {sizeof (str0) < sizeof (str1) ? sizeof (str0) : sizeof (str1)}; auto const cmp3 {::zap_memcmp(str0,leastsz,str1)}; auto const cmp4 {::zap_memcmp(str0,leastsz,str0)}; auto const cmp5 {::zap_memcmp(str1,leastsz,str0)}; ::std::fprintf(stderr,"cmp0: %i\n",cmp0); ::std::fprintf(stderr,"cmp1: %i\n",cmp1); ::std::fprintf(stderr,"cmp2: %i\n",cmp2); ::std::fprintf(stderr,"cmp3: %i\n",cmp3); ::std::fprintf(stderr,"cmp4: %i\n",cmp4); ::std::fprintf(stderr,"cmp5: %i\n",cmp5); assert(cmp0 > 0x0); assert(cmp1 == 0x0); assert(cmp2 < 0x0); assert(cmp3 > 0x0); assert(cmp4 == 0x0); assert(cmp5 < 0x0); } ::std::fprintf(stderr,"\n"); { int arr[] { 0x0, 0x1, 0x2, 0x3, }; void * rem {nullptr}; ::zap_foreach(arr,sizeof (int),sizeof (arr) / sizeof (int),::zap_test_foreachfn); ::std::fprintf(stderr,"arr[0]: %i\n",arr[0x0u]); ::std::fprintf(stderr,"arr[1]: %i\n",arr[0x1u]); ::std::fprintf(stderr,"arr[2]: %i\n",arr[0x2u]); ::std::fprintf(stderr,"arr[3]: %i\n",arr[0x3u]); assert(arr[0x0u] == 0x0); assert(arr[0x1u] == 0x1); assert(arr[0x2u] == 0x0); assert(arr[0x3u] == 0x1); } ::std::fprintf(stderr,"\n"); ::std::fprintf(stderr,"All tests have passed!\n"); }