https://github.com/karnkaul/ktl
  
  
    Collection of ktl header libraries - small C++20 wrapper utilities 
    https://github.com/karnkaul/ktl
  
async-queue bitflags cpp cpp20 cpp20-library future header-only library n-tree not-null result stl thread threading
        Last synced: 7 months ago 
        JSON representation
    
Collection of ktl header libraries - small C++20 wrapper utilities
- Host: GitHub
- URL: https://github.com/karnkaul/ktl
- Owner: karnkaul
- License: gpl-3.0
- Created: 2021-07-29T05:32:52.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2022-08-15T03:30:19.000Z (about 3 years ago)
- Last Synced: 2025-03-25T16:55:35.178Z (7 months ago)
- Topics: async-queue, bitflags, cpp, cpp20, cpp20-library, future, header-only, library, n-tree, not-null, result, stl, thread, threading
- Language: C++
- Homepage:
- Size: 96.7 KB
- Stars: 11
- Watchers: 2
- Forks: 0
- Open Issues: 0
- 
            Metadata Files:
            - Readme: README.md
- License: LICENSE
 
Awesome Lists containing this project
README
          ## KTL
A lightweight set of utility headers written in C++20.
### Usage
**Requirements**
- CMake
- C++20 compiler (and stdlib)
**Steps**
1. Clone repo to appropriate subdirectory, say `ktl`
1. Add library to project via: `add_subdirectory(ktl)` and `target_link_libraries(foo ktl::ktl)`
1. Use desired headers via `#include `
### Headers
#### `async/async_queue.hpp`
FIFO queue with thread safe "sleepy" API.
Features:
- Policy customization
- Multiple queues
- Thread-safe push-and-notify (to any desired queue)
- Thread-safe wait-and-pop (from first of any desired queues)
- Clear all queues and return residue
- Deactivate all queues (as secondary wait condition)
#### `async/kfuture.hpp`
Async operation / shared state wrappers, with `.then()` support.
#### `async/kfunction.hpp`
Callable wrapper that cannot be copied, only moved. Used in `kpackaged_task` and `kfuture`.
#### `async/kthread.hpp`
`std::thread` wrapper that joins on destruction / move, and supports `stop_t` tokens.
#### `async/kmutex.hpp`
Basic and strict wrappers for a `T` and its (mutable) mutex, stdlib RAII lock types.
#### `async/shared_kmutex.hpp`
Aliases of `tmutex` with `std::shared_mutex`.
#### `enum_flags/enum_flags.hpp`
Wrapper around an integral type used as bit flags.
#### `enum_flags/bitflags.hpp`
Free functions for working with integral bit flags.
#### `byte_array.hpp`
Lightweight, resizeable wrapper over `std::unique_ptr`.
#### `debug_trap.hpp`
x86/x64 debugger trap/break.
#### `delegate.hpp`
Tagged observer store with RAII signals.
#### `either.hpp`
RAII union of two types.
#### `enumerate.hpp`
Wrapper for indexed iteration over ranges represented by pairs of iterators.
#### `expected.hpp`
Union of expected and unexpected types; uses `either.hpp`.
#### `fifo_map.hpp`
First-In First-Out map.
#### `fixed_any.hpp`
Fixed-size type erased storage.
#### `fixed_vector.hpp`
Fixed-size vector-like container using bytearray as storage.
#### `hash_table.hpp`
Lightweight hash-table with open addressing and reduced iterator stability.
#### `kformat.hpp`
Lightweight fmt-like `std::string` interpolation with basic formatting support.
#### `kunique_ptr.hpp`
Lightweight unique pointer to heap-allocated Type*.
#### `kversion.hpp`
Semantic version.
#### `monotonic_map.hpp`
Wrapper over an (un)ordered map that associates each T with a unique RAII handle which can be used to unregister the instance.
#### `n_tree.hpp`
Models a "forward" N-tree (no parent link) via `std::forward_list`.
#### `not_null.hpp`
Wrapper for raw / smart pointers that is restricted from being null.
#### `ring_buffer.hpp`
Rotating ring-buffer using contiguous storage (`std::vector` by default). Overwrites on overflow.
#### `ring_counter.hpp`
Fixed-size rotating integral counter. Supports increment/decrement.
### Contributing
Pull/merge requests are welcome.
**[Original Repository](https://github.com/karnkaul/ktl)**