Why not adopt me?
NAME
Macro::Micro - really simple templating for really simple templates
VERSION
version 0.051
$Id: Micro.pm 28159 2007-02-24 15:20:40Z rjbs $
SYNOPSIS
use Macro::Micro;
my $expander = Macro::Micro->new;
$expander->register_macros(
ALIGNMENT => "Lawful Good",
HEIGHT => sub {
my ($macro, $object, $stash) = @_;
$stash->{race}->avg_height;
},
);
$expander->expand_macros_in($character, { race => $human_obj });
# character is now a Lawful Good, 5' 6" human
DESCRIPTION
This module performs very basic expansion of macros in text, with a very basic concept of context and lazy evaluation.
METHODS
new
my $expander = Macro::Micro->new(%arg);
This method creates a new macro expander.
There is only one valid argument:
macro_format - this is the format for macros; see the macro_format method
Because of memory leaks in perl 5.6, this method will return a Macro::Micro::perl56 object instead of a Macro::Micro object under versions prior to 5.8.
macro_format
$expander->macro_format( qr/.../ );
This method returns the macro format regexp for the expander. It must be a reference to a regular expression, and should have two capture groups. The first should return the entire string to be replaced in the text, and the second the name of the macro found.
The default macro format is: qr/([\[<] (\w+) [>\]])/x
In other words: a probably-valid-identiifer inside angled or square backets.
register_macros
$expander->register_macros($name => $value, ... );
This method register one or more macros for later expansion. The macro names must be either strings or a references to regular expression. The values may be either strings or references to code.
These macros may later be used for expansion by "expand_macros"
.
clear_macros
$expander->clear_macros;
This method clears all registered macros.
get_macro
my $macro = $expander->get_macro($macro_name);
This returns the currently-registered value for the named macro. If the given macro name is not registered exactly, the name is checked against any regular expression macros that are registered. The first of these to match is returned.
At present, the regular expression macros are checked in an arbitrary order.
expand_macros
my $rewritten = $expander->expand_macros($text, \%stash);
This method returns the result of rewriting the macros found the text. The stash is a set of data that may be used to expand the macros.
The text is scanned for content matching the expander's "macro_format". If found, the macro name in the found content is looked up with "get_macro"
. If a macro is found, it is used to replace the found content in the text.
A macros whose value is text is expanded into that text. A macros whose value is code is expanded by calling the code as follows:
$replacement = $macro_value->($macro_name, $text, \%stash);
Macros are not expanded recursively.
expand_macros_in
$expander->expand_macros_in($object, \%stash);
This rewrites the content of $object
in place, using the expander's macros and the provided stash of data.
At present, only scalar references can be rewritten in place. In the future, there will be a system to define how various classes of objects should be rewritten in place, such as email messages.
fast_expander
my $fast_expander = $expander->fast_expander($stash);
my $rewritten_text = $fast_expander->($original_text);
This method returns a closure which will expand the macros in text passed to it using the expander's macros and the passed-in stash.
study
my $template = $expander->study($text);
Given a string, this returns an object which can be used as an argument to expand_macros
. Macro::Micro will find and mark the locations of macros in the text so that calls to expand the macros will not need to search the text.
AUTHOR
Ricardo SIGNES, <rjbs@cpan.org>
BUGS
Please report any bugs or feature requests to bug-macro-micro@rt.cpan.org
, or through the web interface at http://rt.cpan.org. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
COPYRIGHT
Copyright 2005-2006 Ricardo SIGNES, All Rights Reserved.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.