NAME
Stenciller.pm - Convert textfiles to different output
VERSION
Version 0.1000, released 2015-01-15.
SYNOPSIS
use Stenciller;
my $stenciller = Stenciller->new(filepath => 't/corpus/test-1.stencil');
my $content = $stenciller->render('ToUnparsedText');
DESCRIPTION
Stenciller reads a special fileformat and provides a way to convert the content into different types of output. For example, it can be used to create documentation and tests from the same source file.
File format
== stencil {} ==
--input--
--end input--
--output--
--end output--
This is the basic layout. A stencil ends when a new stencil block is discovered (there is no set limit to the number of stencils in a file). The (optional) hash is for settings. Each stencil has five parts: before_input
, input
, between
, output
and after_output
. In addition to this there is a header before the first stencil.
ATTRIBUTES
filepath
File | required | read-only |
The textfile to parse.
header_lines
ArrayRef[ Str ] | optional, default is a coderef
|
read/write |
After parsing, this contains all lines in the header.
is_utf8
Bool | optional, default: 1
|
read-only |
Determines how the stencil file is read.
skip_if_input_empty
Bool | optional, default: 1
|
read-only |
If a stencil has no input content, skip entire stencil.
skip_if_output_empty
Bool | optional, default: 1
|
read-only |
If a stencil has no output content, skip entire stencil.
stencils
ArrayRef[ Stencil ] | optional, default is a coderef
|
read/write |
After parsing, this contains all parsed stencils.
METHODS
render
Positional parameters | ||||
$plugin_name
|
Str | required | Plugin to render contents with. |
|
@constructor_args
|
required | slurpy | Constructor arguments for the plugin. |
|
Returns | ||||
Str | Returns the rendered contents. |
PLUGINS
The actual rendering is done by plugins. There are two plugins bundled in this distribution:
Custom plugins should be in the Stenciller::Plugin namespace and consume the Stenciller::Renderer role.
SOURCE
https://github.com/Csson/p5-Stenciller
HOMEPAGE
https://metacpan.org/release/Stenciller
AUTHOR
Erik Carlsson <info@code301.com>
COPYRIGHT AND LICENSE
This software is copyright (c) 2015 by Erik Carlsson <info@code301.com>.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.