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

Download history 1488686/week @ 2024-09-27 1609245/week @ 2024-10-04 1543771/week @ 2024-10-11 1633140/week @ 2024-10-18 1612808/week @ 2024-10-25 1540942/week @ 2024-11-01 1562648/week @ 2024-11-08 1588166/week @ 2024-11-15 1366251/week @ 2024-11-22 1400381/week @ 2024-11-29 1651550/week @ 2024-12-06 1588456/week @ 2024-12-13 754831/week @ 2024-12-20 731818/week @ 2024-12-27 1449634/week @ 2025-01-03 1775118/week @ 2025-01-10

5,003,715 downloads per month
Used in 2,864 crates (754 directly)

MIT license

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
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 as Boundary::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], not Vec<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 to Boundary::defaults_from() and no longer outputs Boundary::UPPER_LOWER, since this function now only checks default boundaries.
  • Create custom delimiter boundaries using Boundary::from_delim().

Other breaking changes:

  • Rename Case::ScreamingSnake to Case::Constant.
  • Add Case::Sentence (sentence pattern and space delimiter.)
  • Casing trait implemented for Arc<str> and Rc<str> again.

Other changes:

  • Remove most imports from doc comments.
  • Remove loop over str::chars in favor of graphemes from unicode-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