| Crates.io | caseify |
| lib.rs | caseify |
| version | 0.1.3 |
| created_at | 2025-08-05 20:58:28.426606+00 |
| updated_at | 2025-11-16 08:56:01.024028+00 |
| description | A CLI tool to convert strings between different cases |
| homepage | |
| repository | https://github.com/t-webber/caseify |
| max_upload_size | |
| id | 1783090 |
| size | 41,279 |
A fast and simple Rust library and CLI tool for converting strings between different case conventions.
Add it to your Cargo.toml or run:
cargo add caseify
Then use it as such:
use caseify::Caseify;
let input = "lorem Ipsum_dolor.sit-amet";
assert_eq!(input.to_camel_case(), "loremIpsumDolorSitAmet");
assert_eq!(input.to_pascal_case(), "LoremIpsumDolorSitAmet");
assert_eq!(input.to_kebab_case(), "lorem-ipsum-dolor-sit-amet");
assert_eq!(input.to_constant_case(), "LOREM_IPSUM_DOLOR_SIT_AMET");
assert_eq!(input.to_sentence_case(), "Lorem ipsum dolor sit amet");
assert_eq!(input.to_capitalised_case(), "Lorem Ipsum Dolor Sit Amet");
assert_eq!(input.to_dot_case(), "lorem.ipsum.dolor.sit.amet");
The library intelligently handles various input formats:
use caseify::Caseify;
assert_eq!("XMLHttpRequest".to_snake_case(), "xml_http_request");
assert_eq!("linux _Kernel".to_camel_case(), "linuxKernel");
assert_eq!("some--weird___input".to_pascal_case(), "SomeWeirdInput");
You can also use the Case enum:
use caseify::Case;
assert_eq!(Case::Pascal.caseify("hello, world!"), "HelloWorld");
Install it with:
cargo install caseify
Then use it as such:
# Convert a single string
caseify --snake "SomeVariableName"
# Output: some_variable_name
# Use with pipes
echo "some text
some_snake_case
AndPascalCase" | caseify --camel
# Output:
# someText
# someSnakeCase
# andPascalCase
# Process multiple lines
cat file.txt | caseify --pascal
# Available options
caseify --help