NAME Data::Section::Writer - Write __DATA__ section files for Data::Section, Data::Section::Simple or Mojo::Loader::data_section VERSION version 0.03 SYNOPSIS This code: use strict; use warnings; use Data::Section::Writer; use Path::Tiny qw( path ); Data::Section::Writer ->new( perl_filename => "foo.pl" ) ->add_file( "hello.txt", "hello world" ) ->add_file( "a.out", path("a.out")->slurp_raw, 'base64' ) ->update_file; Will add this to the bottom of foo.pl __DATA__ @@ a.out (base64) f0VMRgIBAQAAAAAAAAAAAAMAPgABAAAAQBAAAAAAAABAAAAAAAAAAGA2AAAAAAAAAAAAAEAAOAAN AEAAHQAcAAYAAAAEAAAAQAAAAAAAAABAAAAAAAAAAEAAAAAAAAAA2AIAAAAAAADYAgAAAAAAAAgA AAAAAAAAAwAAAAQAAAAYAwAAAAAAABgDAAAAAAAAGAMAAAAAAAAcAAAAAAAAABwAAAAAAAAAAQAA ... @@ hello.txt hello world (binary file truncated for readability) DESCRIPTION This class is an interface for updating the __DATA__ section of your Perl module or script programmatically for it to work with one of the many modules that allows for multiple files in a __DATA__ section, such as Data::Section, Data::Section::Simple, Data::Section::Pluggable or Mojo::Loader. Data::Section uses a different header format by default, but you can still use this module with it if you set header_re to qr/^@@ (.*)$/. ATTRIBUTES perl_filename The name of the Perl source file. If not provided then the source for the caller will be used. METHODS add_file $writer->add_file($text_filename, $content); $writer->add_file($binary_filename, $content, 'base64'); Add a file. Binary files can be encoded using base64. Such binaries files are only supported by Mojo::Loader at the moment. render_section my $perl = $writer->render_section; Returns the __DATA__ section. update_file $writer->update_file; Update the existing Perl source file, OR create a new Perl source file with just the __DATA__ section. [version 0.02] Starting with version 0.02, this method will not write to the file if the content won't change. unchanged [version 0.02] my $bool = $writer->unchanged; Returns: `undef` If </update_file> hasn't been called yet. `0` If the last call to </update_file> modified the file. `1` If the last call to </update_file> did not modify the file. add_format $writer->add_format( $ext, sub ($writer, $content) { return ... } ); Adds a content formatter to the given filename extension. The extension should be a filename extension without the ., for example txt or json. The callback takes the Data::Section::Writable instance as its first argument and the content to be processed as the second. This callback should return the format content as a scalar. You can chain multiple content formatters to the same filename extension, and they will be called in the order that they were added. add_plugin $writer->add_plugin( $name, %args ); Applies the plugin with $name. If the plugin supports instance mode (that is: it has a constructor named new), then %args will be passed to the constructor. For included plugins see "CORE PLUGINS". To write your own see "PLUGIN ROLES". CORE PLUGINS This module will work with some core Data::Section::Pluggable plugins listed here. json Automatically encode json into Perl data structures. See Data::Section::Pluggable::Plugin::Json. PLUGIN ROLES FormatContentPlugin Used for adding content formatting for specific formats. This is essentially a way to wrap the add_format method as a module. See Data::Section::Pluggable::Role::FormatContentPlugin. CAVEATS Added text files will get an added trailing new line if they do not already have them. This is a requirement of the format used by the data section modules. For binary files (base64 encoded) the content returned by Mojo::Loader should be identical. Not tested, and probably not working for Windows formatted text files, though patches for this are welcome. SEE ALSO Data::Section::Pluggable AUTHOR Graham Ollis <plicease@cpan.org> COPYRIGHT AND LICENSE This software is copyright (c) 2024 by Graham Ollis. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.