Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

randomexp

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

randomexp

  • 0.1.7
  • Rubygems
  • Socket score

Version published
Maintainers
1
Created
Source

Randomexp by Naresh Sekar http://github.com/nareshnavinash/randomexp

== DESCRIPTION:

andexp makes it easy to generate random string from most regular expressions.

== REQUIREMENTS:

  • none!

== INSTALL:

$ sudo gem install randomexp

== USAGE:

Randomexp adds the #generate (or #gen, for short) method to the Regexp class, which generates a 'random' string that will match your regular expression.

/abc|def/.gen # => "def"

== Valid Regexp's

Randomexp can only generate matching string from simple regular expression. Except for a few circumstances, wildcards are generally not allowed in the regular expression. is pretty domain specific, so trying to guess when to terminate a random pattern would produce unhelpful data:

/Aa{3}h*!/.gen # => RuntimeError: Sorry, "h*" is too vague, try setting a range: "h{0,3}" /Aa{3}h{3,15}!/.gen => "Aaaahhhhh!"

/(never gonna (give you up|let you down), )/.gen => RuntimeError: Sorry, "(...)" is too vague, try setting a range: "(...){0, 3}" /(never gonna (give you up|let you down), ){3,5}/.gen => "never gonna give you up, never gonna let you down, never gonna give you up, never gonna give you up, "

The exception being word characters (\w), which generate a random word from the Dictionary class.

/\w+/.gen => "groveling"

= Primitives & Complex matches

The single character matchers supported are words(\w), whitespace(\s), and digits(\d).

/\d{50}/.gen => "50315410741096763188525493528315906035878741451037"

When a multiplicity constraint is placed on a word character, a word with the valid length is generated.

/\w{10}/.gen # a word with 10 letters => "Chaucerism"

/\w{5,15}/.gen => "cabalistic"

Complex matchers use the [:...:] syntax within the regular expression.

/[:sentence:]/.gen => "Nonhearer demetricize toppiece filicic possessedness rhodizite zoomagnetism earwigginess steady"

Complex matchers can also be added by extending the Randgen class.

class Randgen def self.serial_number(options = {}) /XX\d{4}-\w-\d{5}/.gen end end

/[:serial_number:]/.gen => "XX3770-M-33114"

= Dictionary

The Dictionary loads the local users' words file, allowing randomly generated words to be chosen from thousands of entries to the words file. Words are mapped by their length to allow words to be randomly chosen based on size.

FAQs

Package last updated on 29 Sep 2021

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc