NAME
Config::AutoConf - A module to implement some of AutoConf macros in pure perl.
ABSTRACT
With this module I pretend to simulate some of the tasks AutoConf macros do. To detect a command, to detect a library, etc.
SYNOPSIS
use Config::AutoConf;
Config::AutoConf->check_prog("agrep");
my $grep = Config::AutoConf->check_progs("agrep", "egrep", "grep");
Config::AutoConf->check_header("ncurses.h");
my $curses = Config::AutoConf->check_headers("ncurses.h","curses.h");
Config::AutoConf->check_prog_awk;
Config::AutoConf->check_prog_egrep;
Config::AutoConf->check_cc();
Config::AutoConf->check_lib("ncurses", "tgoto");
Config::AutoConf->check_file("/etc/passwd"); # -f && -r
FUNCTIONS
check_file
This function checks if a file exists in the system and is readable by the user. Returns a boolean. You can use '-f $file && -r $file' so you don't need to use a function call.
check_files
This function checks if a set of files exist in the system and are readable by the user. Returns a boolean.
check_prog
This function checks for a program with the supplied name. In success returns the full path for the executable;
check_progs
This function takes a list of program names. Returns the full path for the first found on the system. Returns undef if none was found.
check_prog_yacc
From the autoconf documentation,
If `bison' is found, set [...] `bison -y'.
Otherwise, if `byacc' is found, set [...] `byacc'.
Otherwise set [...] `yacc'.
Returns the full path, if found.
check_prog_awk
From the autoconf documentation,
Check for `gawk', `mawk', `nawk', and `awk', in that order, and
set output [...] to the first one that is found. It tries
`gawk' first because that is reported to be the best
implementation.
Note that it returns the full path, if found.
check_prog_egrep
From the autoconf documentation,
Check for `grep -E' and `egrep', in that order, and [...] output
[...] the first one that is found.
Note that it returns the full path, if found.
check_cc
This function checks if you have a running C compiler.
check_headers
This function uses check_header to check if a set of include files exist in the system and can be included and compiled by the available compiler. Returns the name of the first header file found.
check_header
This function is used to check if a specific header file is present in the system: if we detect it and if we can compile anything with that header included. Note that normally you want to check for a header first, and then check for the corresponding library (not all at once).
The standard usage for this module is:
Config::AutoConf->check_header("ncurses.h");
This function will return a true value (1) on success, and a false value if the header is not present or not available for common usage.
check_lib
This function is used to check if a specific library includes some function. Call it with the library name (without the lib portion), and the name of the function you want to test:
Config::AutoConf->check_lib("z", "gzopen");
It returns 1 if the function exist, 0 otherwise.
AUTHOR
Alberto Simões, <ambs@cpan.org>
NEXT STEPS
Although a lot of work needs to be done, this is the next steps I intent to take.
- detect flex/lex
- detect yacc/bison/byacc
- detect ranlib (not sure about its importance)
These are the ones I think not too much important, and will be addressed later, or by request.
- detect an 'install' command
- detect a 'ln -s' command -- there should be a module doing
this kind of task.
BUGS
A lot. Portability is a pain. <Patches welcome!>.
Please report any bugs or feature requests to bug-extutils-autoconf@rt.cpan.org
, or through the web interface at http://rt.cpan.org. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
ACKNOWLEDGEMENTS
Michael Schwern for kind MacOS X help.
Ken Williams for ExtUtils::CBuilder
COPYRIGHT & LICENSE
Copyright 2004-2005 Alberto Simões, All Rights Reserved.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
SEE ALSO
ExtUtils::CBuilder(3)
1 POD Error
The following errors were encountered while parsing the POD:
- Around line 378:
Non-ASCII character seen before =encoding in 'Simões,'. Assuming CP1252