9 releases (breaking)
new 0.7.1 | Jan 12, 2025 |
---|---|
0.6.0 | Sep 8, 2022 |
0.5.0 | Dec 27, 2021 |
0.4.0 | May 18, 2020 |
#6 in Text processing
5,003,715 downloads per month
Used in 2,864 crates
(754 directly)
100KB
1.5K
SLoC
Convert Case
Converts to and from various cases.
Rust Library convert_case
Convert case was written in Rust and is ready to be used inline with your rust code as a library.
use convert_case::{Case, Casing};
assert_eq!("ronnieJamesDio", "Ronnie_James_dio".to_case(Case::Camel));
assert_eq!("io_stream", "IOStream".to_case(Case::Snake));
assert_eq!(
"2020-04-16 My Cat Cali",
"2020-04-16_my_cat_cali".from_case(Case::Snake).to_case(Case::Title)
);
You can read the API documentation on docs.rs for a list of all features and read lots of examples.
Command Line Utility ccase
The command line utility ccase
was made to expose the tools of the convert_case
library to the command line.
$ ccase -t title super_mario_64
Super Mario 64
$ ccase -f snake -t title 2020-04-15_my_cat_cali
2020-04-16 My Cat Cali
$ ccase -t camel "convert to camel"
convertToCamel
Links
convert_case |
ccase |
|
---|---|---|
Repository | github | github |
Crate | crates.io | crates.io |
Documentation | docs.rs |
Cases
This is list of cases that convert_case supports. Some cases are simply aliases of others. The "Random" and "PseudoRandom" cases are provided in the convert_case
library with the "random" feature.
Case | Example |
---|---|
Upper | MY VARIABLE NAME |
Lower | my variable name |
Title | My Variable Name |
Toggle | mY vARIABLE nAME |
Alternating | mY vArIaBlE nAmE |
Camel | myVariableName |
Pascal UpperCamel |
MyVariableName |
Snake | my_variable_name |
Constant UpperSnake |
MY_VARIABLE_NAME |
Kebab | my-variable-name |
Cobol | MY-VARIABLE-NAME |
Train | My-Variable-Name |
Flat | myvariablename |
UpperFlat | MYVARIABLENAME |
Random | MY vaRiabLe nAME |
PseudoRandom | mY VaRiAblE nAMe |
Change Log
0.7.1
- Removed debug print statement.
0.7.0: Custom Boundaries
Boundary is no longer an enum. It now is a struct, and each enum variant cooresponds to an associated constant. For upgrading this just means changing Boundary::LowerUpper
to just Boundary::LOWER_UPPER
.
The benefit of this is that you can make your boundary conditions now, by instantiating the Boundary
struct, or using Boundary::from_delim()
. Now you can split on newlines, periods, double-colons, emojis, or a more complex case like a symbol followed by a digit. You also define which characters, if any, are removed during segmentation, and where the split happens.
Changes from this feature:
- Previous
Boundary::PascalName
enum variants now much refered to asBoundary::CONSTANT_NAME
constants. - All functions that returned groups of boundaries (such as
Boundary::defaults()
,Boundary::digit_letter()
, etc) now are const and return fixed-sized arrays[Boundary; N]
, notVec<Boundary>
. Boundary::all()
was removed, since there's no longer a sense of "all" boundaries, since you can create your own.Boundary::list_from()
has been renamed toBoundary::defaults_from()
and no longer outputsBoundary::UPPER_LOWER
, since this function now only checks default boundaries.- Create custom delimiter boundaries using
Boundary::from_delim()
.
Other breaking changes:
- Rename
Case::ScreamingSnake
toCase::Constant
. - Add
Case::Sentence
(sentence pattern and space delimiter.) Casing
trait implemented forArc<str>
andRc<str>
again.
Other changes:
- Remove most imports from doc comments.
- Remove loop over
str::chars
in favor ofgraphemes
fromunicode-segmentation
.
Other Projects
Github user Wild-W has built nodejs bindings for convert_case that are up to date with 0.6.0.
Dependencies
~315–430KB