No description
Find a file
Evan Burkey 2d5675d157
All checks were successful
test / test (push) Successful in 11s
clean
2026-04-22 19:00:37 -07:00
.forgejo/workflows ci and docs 2026-04-10 05:31:14 -07:00
include bitops 2026-04-14 07:20:51 -07:00
src state machine 2026-04-13 19:45:39 -07:00
tests bitops 2026-04-14 07:20:51 -07:00
.gitignore clean 2026-04-22 19:00:37 -07:00
clanggen.sh Implement Server (#1) 2024-07-09 21:03:23 +00:00
CMakeLists.txt bitops 2026-04-14 07:20:51 -07:00
LICENSE init 2021-02-01 14:06:37 -08:00
Makefile fix compiler warnings 2024-08-13 12:57:36 -07:00
README.md ci and docs 2026-04-10 05:31:14 -07:00

libflint

My personal library of common C data structures and algorithms. Supports Linux, macOS, OpenBSD, and FreeBSD.

Documentation

Extensive documentation can be found here. You can also check out the per-module test files in tests/ for example usage.

Building

libflint requires Cmake to be built. It can then be built using either cmake or make with the provided build files. The Makefile is a wrapper around Cmake for Makefile compatibility.

Cmake

If libflint is in ./lib/libflint

add_subdirectory(lib/libflint)

when building target...

target_include_directories(${TARGET} PRIVATE lib/libflint/include) target_link_libraries(${TARGET} PRIVATE flint )

Testing

cmake -B build && cmake --build build
ctest --test-dir build                # run all tests
ctest --test-dir build --parallel     # run in parallel
ctest --test-dir build --label-exclude slow  # skip slow tests (network, macos)

Requirements

Building on Linux requires libbsd. Building on macOS, OpenBSD, or FreeBSD requires no extra dependencies.

Libraries

libflint includes uthash for a hash table implementation. uthash is a single header file included in the source code of libflint. See the top of include/uthash.h for license information