This repository is a collection of utility headers with most of the code I noticed I ended up rewriting over and over. Being all header files, there's no need to include .lib files to the project.
- Most of the headers assume to be compiled with at least C++20.
- The files inside "include/utils" are mostly ready to be included and used in a C++ project. I only reccommend using the ones mentioned in this document, as some others are still not polished.
- The files inside "include/utils/beta" should not be used without extensive reading and rewriting. They're very old code I haven't yet checked.
- Some usage examples can be seen in the Tests folder.
- The angles header in particular contains errors that still need fixing; it's present in include/utils only because it's referenced in some other files.
Will add global inline constexpr variables that mirror common compilation macros, in order to use them in if-constexpr conditions.
if constexpr(utils::compilation::release) { ... }
console/io.h, console/colour.h, output/std_containers.h
The files allow for more complex interactions with the console.
In particular output/std_containers
allows to output all the standard containers. On Windows platforms the output will be coloured.
Some classes from the library will make use of these headers to define their own output stream operator (angles, math vectors, containers).
Both standard containers and library types can only be outputted after using namespace utils::output;
.
#include <utils/output/std_containers.h>
using namespace utils::output;
std::vector<int> v{1, 2, 3};
std::cout << v; // Output: [1, 2, 3]
Delegate output operations to a dedicated thread, in order to save the main thread from output operations overhead. Can support custom message types. The output is both in the console and in a .txt file in the active directory. The output file can be configured.
A "smart observer pointer" which follows resources in memory as long as they're being moved (not copied). It allows to follow objects stored in contiguous memory. The resource must follow strict criteria (either inherit from trackable, or be wrapped in a trackable_wrapper).
For instance, traditionally one could store a vector of unique pointers to some entities, so that eventual observer pointers to those entities remained valid regardless of how the vector reallocates on growth.
With the tracking pointer, it is possible to observe the entities in a vector that directly owns them, even if vector growth causes reallocation, or if the vector content is sorted.
See the tests for examples.
Useless alone. It exists as a pre-made class to inherit from any time a wrapper is needed. It exposes std::optional and std::*_pointer-like syntax for accessing the wrapped content.
algorithm/
Additional algorithms with an stl-like syntax
Generates a pool of unique identifiers which can be released and recycled for further usage.
See the tests for examples.
Some quick color conversions (rgb, hsv, hsl).
A bidimensional vector with most of the common functionalities. Comes with "custom operators" for the bravest to try.
NOTE: This header includes angle.h to keep the interface complete. However, any operation that involves angles is not guaranteed to work properly, as the angles header is not bug-free yet.
polymorphic_value.h
THIS CODE IS NOT MINE. It's in the collection only because I use it frequently.
Click here for the rightful source.