NAME
Catmandu::Fix::Inlineable - Role for all Catmandu fixes that can be inlined
SYNOPSIS
package Catmandu::Fix::my_fix1;
use Catmandu::Sane;
use Moo;
with 'Catmandu::Fix::Inlineable';
sub fix {
my ($self, $data) = @_;
....FIXER GENERATING CODE....
$data
}
package Catmandu::Fix::my_fix2;
use Catmandu::Sane;
use Moo;
# Catmandu::Fix::Base automatically is Inlineable
with 'Catmandu::Fix::Base';
sub emit {
my ($self, $fixer) = @_;
....FIXER GENERATING CODE....
}
package main;
use Catmandu::Fix::my_fix1 as => 'my_fix1';
# disabling caching may be desirable with fixes that have side effects like
# writing to a file, the downside is that a new instance of the fix will be
# created with each invocation
use Catmandu::Fix::my_fix2 as => 'my_fix2', cache => 0;
my $data = {};
$data = my_fix1($data);
$data = my_fix2($data);
SEE ALSO
For more information how to create fixes read the following two blog posts:
http://librecat.org/catmandu/2014/03/14/create-a-fixer.html http://librecat.org/catmandu/2014/03/26/creating-a-fixer-2.html