Panotools::Makefile.3pm

Langue: en

Version: 2009-11-11 (fedora - 01/12/10)

Section: 3 (Bibliothèques de fonctions)

NAME

Panotools::Makefile - Makefile creation

SYNOPSIS

Simple object interface for generating Makefiles

DESCRIPTION

Writing Makefiles directly from perl scripts with print and ``\t'' etc... is prone to error, this library provides a simple perl interface for assembling Makefiles.

USAGE

   use Panotools::Makefile;
 
 

Create a new Makefile object:

   my $makefile = new Panotools::Makefile;
 
 

Start adding items to the Makefile:

Rule() returns a new Panotools::Makefile::Rule object, Variable() returns a new Panotools::Makefile::Variable object and Comment() returns a new Panotools::Makefike::Variable object:

   my $var_user = $makefile->Variable ('USER');
   $var_user->Values ("Dr. Largio d'Apalansius (MB)");
 
   my $rule_all = $makefile->Rule ('all');
   $rule_all->Command ('echo', '$(USER_SHELL)', '>', 'My File.txt');
 
   $makefile->Comment ('.PHONY target isn't strictly necessary in this case');
   my $rule_phony = $makefile->Rule;
   $rule_phony->Targets ('.PHONY');
   $rule_phony->Prerequisites ('all');
 
 

Write the Makefile:

   $makefile->Write ('/path/to/Makefile');
 
 

..or let the module execute rules with 'make' directly:

   $makefile->DoIt ('all') || warn "Didn't work :-(";
 
 

The following command will be executed, something that isn't possible with perl system() or exec(), and would otherwise require careful assembly with backticks:

   echo Dr.\ Largio\ d\'Apalansius\ \(MB\) > My\ File.txt
 
 

On the Windows platform you get appropriate quoting:

   echo "Dr. Largio d'Apalansius (MB)" > "My File.txt"