From Code to Community: Sponsoring The Perl and Raku Conference 2025 Learn more

NAME

Rex::Apache::Build - Build your WebApp Package

DESCRIPTION

With this module you can prepare your WebApp for deployment.

SYNOPSIS

yui_path "./yuicompressor-2.4.6.jar";
get_version_from "webapp/lib/MyApp.pm", qr{\$VERSION=([^;]+);};
get_version_from "webapp/index.php", qr{\$VERSION=([^;]+);};
task "build", sub {
sprocketize;
sprocketize "app/assets/javascript/*.js",
out => "public/js/sprockets.js";
coffee;
coffee "app/assets/coffee",
out => "public/js";
sass;
sass "app/assets/stylesheets",
out => "public/stylesheets";
yui;
yui compress => "file1.js", "file2.js", "file3.css";
yui compress => glob("public/javascript/*.js"), glob("public/css/*.css");
build;
build "webapp",
source => "webapp/",
version => "1.0";
};

EXPORTED FUNCTIONS

yui_path($path_to_yui_compressor)

This function sets the path to the yui_compressor. If a relative path is given it will search from the path where the Rexfile is in.

coffee_path($path_to_coffee)

This function sets the path to the coffee compiler. If a relative path is given it will search from the path where the Rexfile is in.

sprocketize_path($path_to_sprocketize)

This function sets the path to the sprocketize compiler. If a relative path is given it will search from the path where the Rexfile is in.

sass_path($path_to_sass)

This function sets the path to the sass compiler. If a relative path is given it will search from the path where the Rexfile is in.

yui($action, @files)

Run a yui command.

task "build", sub {
# this will compress the given files
yui compress => "file1.js", "file2.js", ...;
# yui without any parameters will compress all files in public/javascripts
yui;
};
build([$name, %options])

This function builds your package. Currently only tar.gz packages are supported.

# this will a package of the current directory named after the
# directory of the Rexfile and append the version provided by
# get_version_from() function
# This function builds a tar.gz archive.
task "build", sub {
build;
};
# this will build a package of the current directory named "my-web-app" and
# append the version provided by get_version_from() function.
task "build", sub {
build "my-web-app";
};
# this function will build a package of the directory "html", name it
# "my-web-app" and append the version "1.0" to it.
task "build", sub {
build "my-web-app",
path => "html",
version => "1.0",
exclude => ["yuicompressor.jar", "foobar.html"],
type => "tgz";
};
get_version_from($file, $regexp)

Get the version out of a file.

sprocketize($path_to_js_files, %option)

This function calls the sprocketize command with the given options.

task "build", sub {
sprocketize "app/javascript/*.js",
include => [qw|app/javascripts vendor/sprockets/prototype/src|],
asset_root => "public/js",
out => "public/js/sprockets.js";
# to include more use an arrayRef
sprocketize ["app/javascript/*.js", "app/javascript/po/*.js"],
include => [qw|app/javascripts vendor/sprockets/prototype/src|],
asset_root => "public/js",
out => "public/js/sprockets.js";
# if called without parameters
sprocketize;
# it will use the following defaults:
# - javascript (sprockets) in assets/javascripts/*.js
# - include assets/javascripts
# - asset_root public
# - out public/${name_of_directory_where_Rexfile_lives}.js
};
coffee($path, %options)

Compile coffee files to javascript.

task "build", sub {
# this command will build all files in "coffeesrc" and
# write the output to "javascripts"
coffee "coffeesrc",
out => "javascripts";
# without parameters it will build all files in assets/coffee
# and write the output to public/javascripts.
coffee;
};
sass($input_dir, %option)

This command will compile all sass files in $input_dir.

task "build", sub {
# this command will compile all sass files from app/assets/stylesheets
# and put the output into public/stylesheets.
sass "app/assets/stylesheets",
out => "public/stylesheets";
# The default is to build all files in assets/sass and put the output
# into public/css.
sass;
};