Skip to content

Use regular expressions to generate text.

License

Apache-2.0, MIT licenses found

Licenses found

Apache-2.0
LICENSE-APACHE
MIT
LICENSE-MIT
Notifications You must be signed in to change notification settings

CryptArchy/regex_generate

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

25 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

regex_generate

Use regular expressions to generate text. This crate is very new and raw. It's a work-in-progress, but feel free to add issues or PRs or use it for your own ideas, if you find it interesting. No guarantees or warranties are implied, use this code at your own risk.

Thanks to the amazing folks who work on rust-lang/regex which is the heart of this crate. Using regex_syntax made this crate 1000x easier to produce.

Documentation

Magically generated and graciously hosted by Docs.rs.

The documentation is not good right now.

Usage

Add this to your Cargo.toml:

[dependencies]
regex_generate = "0.2"

and this to your crate root:

extern crate regex_generate;

This example generates a date in YYYY-MM-DD format and prints it. Adapted from the example for rust-lang/regex.

extern crate regex_generate;
extern crate rand;

use regex_generate::{DEFAULT_MAX_REPEAT, Generator};

fn main() {
    let mut gen = Generator::new(r"(?x)
(?P<year>[0-9]{4})  # the year
-
(?P<month>[0-9]{2}) # the month
-
(?P<day>[0-9]{2})   # the day
", rand::thread_rng(), DEFAULT_MAX_REPEAT).unwrap();
    let mut buffer = vec![];
    gen.generate(&mut buffer).unwrap();
    let output = String::from_utf8(buffer).unwrap();

    println!("Random Date: {}", output);
}

Tests

Run tests with cargo test -- --nocapture

Benches

Run benchmarks with rustup run nightly cargo bench

Tips

  • Be explicit in your character classes or you will get unexpected results.
  • . really means any, as in any valid unicode character.
  • Likewise, \d means any number, not just [0-9].
  • The default maximum for repetitions (like .*) is 100, but you can set it yourself with generate_with_max_repeat.

TODO

  • Add convenience method for directly generating complete strings
  • Implement Iter for making lots of strings?
  • Add tests for regex bytes feature
  • Account for case insensitivity in Literal
  • Do something with group numbers or names? (No back referencing in the syntax, so maybe nothing can be done.)

License

regex_generate is primarily distributed under the terms of both the MIT license and the Apache License (Version 2.0), with portions covered by various BSD-like licenses.

See LICENSE-APACHE and LICENSE-MIT for details.

About

Use regular expressions to generate text.

Resources

License

Apache-2.0, MIT licenses found

Licenses found

Apache-2.0
LICENSE-APACHE
MIT
LICENSE-MIT

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages