5 releases (3 breaking)
0.4.0 | Aug 5, 2024 |
---|---|
0.3.0 | Dec 20, 2023 |
0.2.1 | Jun 2, 2023 |
0.2.0 | Apr 23, 2023 |
0.1.0 | Apr 11, 2023 |
#512 in Visualization
28 downloads per month
1MB
17K
SLoC
(static_table
) Cook tables at compiler time
The library provides a macros to build a pretty tables at compile time.
There's 2 types of tables you can build.
- Standard adjusted tables (
static_table::static_table
). - Not adjusted, floating tables (
static_table::pool_table
).
To find a more features and settings which you can use with the macros please check out the documentation (docs.rs).
Get started
Add the library to your Cargo.toml
.
# Cargo.toml
[dependencies]
static_table = "0.2"
An example of static_table
usage.
Example | Result |
---|---|
|
|
An example of pool_table
usage.
Example | Result |
---|---|
|
|
You can even use the macros in the documentation
/// Add joins 2 integers together to get a sum.
///
/// ```
#[doc = static_table::static_table!([
["a", "b", "result"],
["1", '2', '3'],
["2", '2', '4']
])]
/// ```
pub fn add(left: usize, right: usize) -> usize {
left + right
}
Binary size concern
It's something you shall be aware of.
Using static_table
MIGHT increase a binary size, because the table will be stored as actual symbols in a static section of a binary file (ELF, PE etc.).
I have run a few tests in this regard.
And a binary which used static_table
has SUBSTATIANALY smaller size than
a binary with a build table at runtime using lazy_static
/once_cell
.
I am not sure though why it is a case.
debug mode release mode
static_table 13497232 4501576
runtime table 12031120 4156024
Dependencies
~3.5MB
~71K SLoC