NAME

Regexp::Melody - Melody is a language that compiles to regular expressions, while aiming to be more readable and maintainable

VERSION

version 0.001000

SYNOPSIS

use Test2::V0;
use Regexp::Melody;

my $re = Regexp::Melody->new( <<'MELODY' );
16 of "na";

2 of match {
  <space>;
  "batman";
}
MELODY

like( "nananananananananananananananana batman", $re );

done_testing;

DESCRIPTION

Melody is a more verbose way of writing regular expressions.

Melody syntax is described at https://yoav-lavi.github.io/melody/book/.

This module is a wrapper around the Rust implementation of Melody, and provides a functional interface identical to the Rust library, as well as an object-oriented interface which may be more convenient for use in Perl.

FUNCTIONAL INTERFACE

No functions are exported by default, but they may be requested:

use Regexp::Melody qw( compiler );

Functions

compiler( $melody )

Compiles the string of Melody into a PCRE-like string.

OBJECT-ORIENTED INTERFACE

Constructor

new( $melody )

Compiles a string of Melody into a regular expression.

The returned object is a blessed Perl object, but may be used on the right hand side of the `=~` operator like a regexp.

(It's actually a blessed regexp ref, but that detail may change in future versions of this module.)

Methods

to_melody()

Turns the regexp back into a string of Melody.

BUGS

Please report any bugs to https://github.com/tobyink/p5-regexp-melody/issues.

SEE ALSO

https://crates.io/crates/melody_compiler.

https://yoav-lavi.github.io/melody/book/.

AUTHOR

Author: Toby Inkster

Contributors:

Yoav Lavi (Rust library)

COPYRIGHT AND LICENSE

This software is copyright (c) 2023 by Toby Inkster.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.