string-utility 0.2.1

Provides simple substring implementation (with the RangeBound trait), keep string before or after a specified string, etc.
Documentation
  • Coverage
  • 2.44%
    1 out of 41 items documented1 out of 27 items with examples
  • Size
  • Source code size: 68.18 kB This is the summed size of all the files inside the crates.io package for this release.
  • Documentation size: 2.84 MB This is the summed size of all files generated by rustdoc for all configured targets
  • Links
  • Homepage
  • floating-floaties/string-utility
    0 0 0
  • crates.io
  • Dependencies
  • Versions
  • Owners
  • 0xBADC0FFEE0DDF00D

Simple Substring Trait

Install

Add the following line to your Cargo.toml file (under [dependencies]):

string-utility = "0.2"

Usage

Import all Traits

use string_utility::prelude::*;

Substring

use string_utility::prelude::*;

fn main() {
    let some_text = "42Hello, world!".to_string();

    // cut first two chars
    let result = some_text.substring(2..);
    let expected = "Hello, world!";
    assert_eq!(result, expected);

    // extract world string
    let result = some_text.substring(9..=13);
    let expected = "world";
    assert_eq!(result, expected);

    // keep everything up to (including) idx 13
    let result = some_text.substring(..=13);
    let expected = "42Hello, world";
    assert_eq!(result, expected);

    // keep everything up to (excluding) idx 13
    let result = some_text.substring(..13);
    let expected = "42Hello, worl";
    assert_eq!(result, expected);

    // keep everything
    let result = some_text.substring(..);
    let expected = "42Hello, world!";
    assert_eq!(result, expected);

    // get last char
    let result = some_text.substring(some_text.len()-1..);
    let expected = "!";
    assert_eq!(result, expected);

  // get last char
  let result = some_text.substring_len(1); // same as (len - 1)..usize::MAX
  let expected = "!";
  assert_eq!(result, expected);
}

Keep

All functions: trait def

use string_utility::prelude::*;

fn main() {
  let some_text = "some start value, some not-so-start value".to_string();
  
  let result = some_text
          .keep("start".to_string())  // keep(pattern)
          // from the
          .end_of_string()
          // whether to keep the pattern "start"
          .excluding_pattern() 
          // keep everything before the pattern
          .before_pattern()
          // exec
          .to_string();
    let expected = "some start value, some not-so-";
    assert_eq!(result, expected);
}