NAME

transerialize - transerialize files from a format to a different one

VERSION

version 1.5.0

SYNOPSIS

# simple
$ transerialize foo.yaml bar.json

# with options
$ transerialize pretty=1 foo.yaml bar.json

# reading from STDIN
$ cat foo.yaml | transerialize -.yaml bar.json

# printing to STDOUT
$ transerialize foo.yaml -.json

DESCRIPTION

transerialize is a command-line interface to the File::Serialize function of the same name.

The command behaves pretty much like its underlying function, except for the details below.

Default options

All leading arguments containing an '=' will be considered default options. In other words,

$ transerialize pretty=1 format=json foo bar

is equivalent to the script

use File::Serialize { pretty => 1, format => 'json' };

transerialize_file 'foo' => 'bar';

Code arguments

Any argument that begin with a '{', '[' or 'sub {' will be eval'ed (as opposed as being considered filenames).

Intermediary steps

Any intermediary step that doesn't look like code (as specified in the previous section) is doing to be interpreted as a Perl script returning a transformation function.

For example, you could grab the title of a blog entry and put it in the frontmatter via:

$ transerialize ./README.md ./set_front_title.pl -.json

with ./set_front_title.pl looking like:

sub {
    return $_ if $_->{title};

    $_->{title} = $1 if $_->{_content} =~ /^# (.*)/m;

    return $_;
}

Loading intermediary steps from file

Any of the argument passed to transerialize that has a leading @ is considered a serialized file containing a list of files and will be expanded. Useful if you do have a lot of intermediary steps and the command line is getting ungainly long.

For example, you could have

# file ./process_blog.yml
- set_front_title.pl
- gather_tags.pl

$ transerialize README.md @./process_blog.pl -.json

STDIN and STDOUT

An input filename which main part is a dash will be taken to be STDIN. For example

$ transerialize_file -.yaml foo.json

will read STDIN, consider it to be YAML, and then convert it to JSON.

Likewise, an output file which main part is a dash will be printed on STDOUT. For example

$ transerialize_file foo.yaml -.json

will print out the data of foo.yaml as JSON.

Accessing source and destination files

The original source and destination files are available to transformation scripts via the global variables $File::Serialize::SOURCE and $File::Serialize::DESTINATION.

AUTHOR

Yanick Champoux <yanick@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2021, 2019, 2017, 2016, 2015 by Yanick Champoux.

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