Config::ApacheFormat 1.1 ======================== CHANGES 1.1 Tue Nov 26 12:00:00 2002 - Added new options 'valid_directives' and 'valid_blocks' to allow the parser to produce syntax errors on invalid data. Thanks to Rudy Lippan for the suggestion. - Fixed bug where blocks with multi-part names couldn't be accessed with block(). - Fixed spelling error in API. The wrong spelling of "inheritance" as "inheritence" is now deprecated. - Modified get() to avoid recursion when inheritance_support is on for a small speedup. - Optimized parsing for a 50% speedup on large files. - Lowered memory usage. INSTALLATION To install this module type the following: perl Makefile.PL make make test make install DEPENDENCIES This module requires these other modules and libraries: Carp Scalar::Util 1.07 Class::MethodMaker 1.08 Text::Balanced 1.89 File::Spec 0.82 DESCRIPTION This module is designed to parse a configuration file in the same syntax used by the Apache web server (see http://httpd.apache.org for details). This allows you to build applications which can be easily managed by experienced Apache admins. Also, by using this module, you'll benefit from the support for nested blocks with built-in parameter inheritance. This can greatly reduce the amount or repeated information in your configuration files. A good reference to the Apache configuration file format can be found here: http://httpd.apache.org/docs-2.0/configuring.html To quote from that document, concerning directive syntax: Apache configuration files contain one directive per line. The back-slash "\" may be used as the last character on a line to indicate that the directive continues onto the next line. There must be no other characters or white space between the back-slash and the end of the line. Directives in the configuration files are case-insensitive, but arguments to directives are often case sensitive. Lines that begin with the hash character "#" are considered comments, and are ignored. Comments may not be included on a line after a configuration directive. Blank lines and white space occurring before a directive are ignored, so you may indent directives for clarity. And block notation: Directives placed in the main configuration files apply to the entire server. If you wish to change the configuration for only a part of the server, you can scope your directives by placing them in <Directory>, <DirectoryMatch>, <Files>, <FilesMatch>, <Location>, and <LocationMatch> sections. These sections limit the application of the directives which they enclose to particular filesystem locations or URLs. They can also be nested, allowing for very fine grained configuration. RATIONALE There are at least two other modules on CPAN that perform a similar function to this one, Apache::ConfigFile and Apache::ConfigParser. Although both are close to what I need, neither is totally satisfactory. Apache::ConfigFile suffers from a complete lack of tests and a rather clumsy API. Also, it doesn't support quoted strings correctly. Apache::ConfigParser comes closer to my needs, but contains code specific to parsing actual Apache configuration files. As such it is unsuitable to parsing an application configuration file in Apache format. Unlike Apache::ConfigFile, Apache::ConfigParser lacks support for Include. Additionally, neither module supports directive inheritance within blocks. As this is the main benefit of Apache's block syntax I decided I couldn't live without it. In general, I see no problem with reinventing the wheel as long as you're sure your version will really be better. I believe this is, at least for my purposes. COPYRIGHT AND LICENSE Copyright (C) 2002 Sam Tregar This program is free software; you can redistribute it and/or modify it under the same terms as Perl 5 itself.