Commit graph

82 commits

Author SHA1 Message Date
82b5200857 Add meson build scripts 2022-06-07 16:43:26 +02:00
9919f1aeb2 Use std::to_string when doing ascii conversions
It's fast, it works, it's correct. No need for
any of the fancy stuff when all we want is int
to ascii string.

Currently on my system the implementation of
std::to_string is *very* similar to mine, but
it doesn't have the overhead of calculating
ASCII offsets because their lookup already
contains ASCII values.
2021-06-07 23:10:35 +02:00
e1599820b4 Revert "Trying with a smaller lookup, still slower than std::to_string"
This reverts commit 18cdd4d9b5.
2021-06-07 22:13:50 +02:00
18cdd4d9b5 Trying with a smaller lookup, still slower than std::to_string 2021-06-07 22:12:58 +02:00
180f79fae9 Replace std::array with C array 2021-06-07 21:54:46 +02:00
c9b2d36491 Pull lookup out.
This makes the function run faster
2021-06-07 21:52:33 +02:00
a171faa95d Revert lookup removal, but keep the speed test cpp
This reverts commit 4f1c0f8d6df21d7c3b404d41512bba0b60ba7689.
2021-06-07 20:21:44 +02:00
a68815b3cd Same conversion but without any lookup 2021-06-07 20:21:32 +02:00
e3140a3add Trying with a smaller lookup, still slower than std::to_string 2021-06-07 20:20:35 +02:00
9dbabcb5c4 Working on optimisation but I'm still losing to std::to_string() 2021-05-29 22:52:30 +02:00
420257f578 Use parameter instead of assuming 10 numeric digits 2021-05-29 17:07:55 +02:00
199db7640e Add support for int_conv<std::array>() 2021-05-29 16:47:48 +02:00
938c8fa9a4 Make code a bit more readable
Changed so that int_conv<string_view>() called on a
non-constexpr doesn't compiler anymore (because code
would try to go through a consteval method). It
wouldn't work anyways as the returned value would be
always garbage. If you want a string_view then you
must either give a constexpr input value or you must
call int_conv_raw and call to_string_view() yourself.
This is better than throwing a runtime exception (which
was working ok btw).

All the SafeRetVal stuff is not needed anymore.

Also no need for all that confusing sfinae, I can just
use a bool FromInt and specialise on that.
2021-05-29 16:44:06 +02:00
a675624cab Add case sensitivity support to sse conversion 2021-05-29 12:01:01 +02:00
094f7fc679 Rename HashType to TigerHash 2021-05-29 00:57:24 +02:00
e8467cebe0 Remove custom lengthof()
duckhandy has an implementation already
2021-05-29 00:56:39 +02:00
d068e68e75 Replace with consteval
It doesn't makes any sense to use this implementation
at runtime.
2021-05-29 00:52:13 +02:00
327d93a6a4 Fix namespaces, copyright and magic numbers 2021-05-29 00:52:13 +02:00
d3731253e4 Import build time tiger hasd from doorkeeper 2021-05-29 00:34:39 +02:00
1ec0e143fd Replace string with basic_string<T> 2021-05-28 02:48:49 +02:00
d0e7ca0bee Merge functions 2021-05-28 02:48:07 +02:00
9539b5430f Some small code improvements 2021-05-28 02:41:41 +02:00
562eba5f68 Delete sequence_bt.hpp
This stuff has been in the standard lib
for a long time now.
2021-05-28 02:40:19 +02:00
422b475ce3 Add support for constexpr string_view creation 2021-05-28 02:06:28 +02:00
e62da38cf9 Cleaning up and simplifying code a bit 2021-05-28 02:03:52 +02:00
eedad0d82c Move Version to bt namespace 2021-04-22 14:10:28 +02:00
5db217c978 Update copyright to 2021 2021-04-22 14:07:53 +02:00
710cdf9f04 Allow string_view conv when it's safe
You can still force a string_view conv even when it's
not safe to do so if you only intend to use the
return value during its lifetime validity. Call
int_conv_temporary() in that case.
2021-04-22 13:59:51 +02:00
b52343014b int_conv can be constexpr sometimes 2021-04-22 13:57:57 +02:00
1f44e74465 Test if conversion is using the sse when possible 2021-04-22 13:44:49 +02:00
13bd166827 Rename Count to lowercase, make const 2021-04-22 13:37:02 +02:00
3124548314 Implement Version class 2021-04-22 13:34:05 +02:00
93d2ad6bd0 Make ary_to_int() constexpr 2021-04-22 13:02:51 +02:00
3343b51a39 Simplify code 2021-04-22 03:09:31 +02:00
40bae9c49d Build fix for clang 2021-04-22 02:59:51 +02:00
1c6de14cd4 Add test for upper case conversions and fix as necessary 2020-08-14 00:30:22 +01:00
f1d6ac789e Indentation 2020-08-14 00:04:05 +01:00
79ca881bc1 Warning fix
This fixes ary_to_int() for negative values
2020-08-13 23:54:06 +01:00
a5705c5be0 Update copyright to 2020 2020-08-13 21:27:38 +01:00
e6cef7e3ee Get rid of lexical_cast.
This stuff is quite old and I don't think I ever
felt confident enough to use it in real code.
2020-08-13 20:47:42 +01:00
7fb56e65ff Remove submodule, use the system Sprout 2020-05-05 01:59:04 +02:00
9f1d24e832 Add licence header 2018-11-27 09:57:17 +00:00
891303a578 Add a very simple ResourcePool implementation. 2018-11-26 22:28:28 +00:00
fb774671ad Fixes and more tests 2018-11-20 09:26:17 +00:00
a7d0cefbb9 Add BitfieldPack implementation. 2018-11-20 08:56:43 +00:00
4eb4209409 Add unit test and fix for non-char types. 2018-10-13 00:44:38 +01:00
9ad3cc317c Support string+ary and ary.to<T>() 2018-10-13 00:18:04 +01:00
7e88e9ee8e Range pointers should be const. 2018-10-13 00:17:10 +01:00
af7538c5fa Fix include path. 2018-10-13 00:16:50 +01:00
7ceaf01a37 Add new int_conv.hpp that provides a semantic_cast-like int_conv. 2018-10-12 20:55:14 +01:00