hipstr

Rust

Yet another string for Rust πŸ¦€

And bytes too!

⚑ Examples

```rust use hipstr::HipStr;

let simplegreetings = HipStr::fromstatic("Hello world"); let clone = simplegreetings.clone(); // no copy

let user = "John"; let greetings = HipStr::from(format!("Hello {}", user)); let _user = greetings.slice(6..): // no copy ```

✏️ Features

☣️ Safety of hipstr

This crate uses unsafe extensively. 🀷

It exploits a 1-bit alignment niche in pointer existing on most platform (I think all Rustc supported platform) to distinguish the inline representation from the other representations.

To make things safer, Rust is tested thoroughly on multiple platforms, normally and with Miri (MIR interpreter).

πŸ§ͺ Testing

β˜” Coverage

This crate has near full line coverage:

```bash cargo llvm-cov --all-features --html

or

cargo tarpaulin --all-features --out html --engine llvm ```

πŸ–₯️ Cross-platform testing

With cross:

bash cross test --target mips-unknown-linux-gnu # 32-bit BE cross test --target mips64-unknown-linux-gnuabi64 # 64-bit BE cross test --target i686-unknown-linux-gnu # 32-bit LE cross test --target x86_64-unknown-linux-gnu # 64-bit LE

πŸ” Miri

This crate runs successfully with Miri:

```bash MIRIFLAGS=-Zmiri-symbolic-alignment-check cargo +nightly miri test

for SEED in $(seq 0 10); do echo "Trying seed: $SEED" MIRIFLAGS="-Zmiri-seed=$SEED" cargo +nightly miri test || { echo "Failing seed: $SEED"; break; }; done ```

To check with different word size and endianness:

```bash

Big endian, 64-bit

cargo +nightly miri test --target mips64-unknown-linux-gnuabi64

Little endian, 32-bit

cargo +nightly miri test --target i686-unknown-linux-gnu ```

πŸ“¦ Similar crates

In short, HipStr, one string type to rule them all…

How standards proliferate

πŸš€ TODOs

πŸ“– Author and licenses

For now, just me PoLazarus πŸ‘» \ Help welcome! 🚨

MIT + APACHE