You are viewing a plain text version of this content. The canonical link for it is here.
Posted to cvs@httpd.apache.org by bu...@apache.org on 2012/05/06 16:18:10 UTC

svn commit: r816029 [9/23] - in /websites/staging/httpd/trunk/content: ./ apreq/ apreq/docs/ apreq/docs/libapreq2/ contributors/ css/ dev/ dev/images/ dev/whiteboard/ docs-project/ docs/ images/ info/ info/css-security/ library/ mod_fcgid/ mod_ftp/ mod...

Added: websites/staging/httpd/trunk/content/apreq/docs/libapreq2/apreq_changes.html
==============================================================================
--- websites/staging/httpd/trunk/content/apreq/docs/libapreq2/apreq_changes.html (added)
+++ websites/staging/httpd/trunk/content/apreq/docs/libapreq2/apreq_changes.html Sun May  6 14:18:02 2012
@@ -0,0 +1,517 @@
+<html>
+<head>
+  <link rel="stylesheet" type="text/css" href="dox.css" />
+  <title>libapreq2-2.13: libapreq2: CHANGES</title> 
+</head>
+<body>
+<div id="page-header">
+<p class="menu">
+   <a href="http://www.apache.org/">Apache Software Foundation</a> &gt; <a href="http://httpd.apache.org">HTTP Server Project</a> &gt;
+<a href="http://httpd.apache.org/apreq/">Request Library Subproject</a></p>
+<p class="apache">Apache HTTP Server Request Library</p>
+<img alt="" src="feather.gif" /></div>
+<!-- Generated by Doxygen 1.5.6 -->
+<div class="navigation" id="top">
+  <div class="tabs">
+    <ul>
+      <li><a href="index.html"><span>Main&nbsp;Page</span></a></li>
+      <li><a href="pages.html"><span>Related&nbsp;Pages</span></a></li>
+      <li><a href="modules.html"><span>Modules</span></a></li>
+      <li><a href="annotated.html"><span>Data&nbsp;Structures</span></a></li>
+      <li><a href="files.html"><span>Files</span></a></li>
+      <li><a href="examples.html"><span>Examples</span></a></li>
+    </ul>
+  </div>
+</div>
+<div class="contents">
+<h1><a class="anchor" name="apreq_changes">CHANGES </a></h1>! brief List of major changes.<h2><a class="anchor" name="v2_13">
+Changes with libapreq2-2.13 (released December 3, 2010)</a></h2>
+<ul>
+<li>HTTP Only Cookie [Robert Stone &amp; Adam Prime] The C and Perl Cookie APIs now support an HttpOnly flag to tell user agents to deny client-side script access to the cookie</li></ul>
+<h2><a class="anchor" name="v2_12">
+Changes with libapreq2-2.12 (released March 13, 2009)</a></h2>
+<ul>
+<li>C API [joes] Make the cookie parser a little more flexible.</li></ul>
+<h2><a class="anchor" name="v2_11">
+Changes with libapreq2-2.11 (not released)</a></h2>
+<ul>
+<li>Interactive CGI module [issac] Allow cgi module to interactively prompt for parameters and cookies when running a script from the command line and not from a CGI interface</li></ul>
+<h2><a class="anchor" name="v2_10">
+Changes with libapreq2-2.10 (not released)</a></h2>
+<ul>
+<li>Perl Glue [joes] Fix the linking of the perl modules to libapreq2 and libapr on Solaris.</li></ul>
+<p>
+<ul>
+<li>Perl Glue [joes] Fix install-time linking issue of the .so modules. Previously they would remain linked against the src library path, not the install path.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Add optional interface for <a class="el" href="group__mod__apreq2.html#g68f508b2e1d9909328d7b1277ce4aa80">apreq_handle_apache2()</a>.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Clean up buggy apreq_hook_find_param().</li></ul>
+<p>
+<ul>
+<li>Perl Glue Build [Philip M. Gollucci] config.status format changed format yet again in autoconf 2.62+.</li></ul>
+<p>
+<ul>
+<li>License [Mladen Turk] Add libapreq.rc and generate libapreq.res</li></ul>
+<p>
+<ul>
+<li>Build [Mladen Turk] Add APREQ_DECLARE_EXPORT/APREQ_DECLARE_STATIC in the same way as APR declares so that dllexport/dllimport get correctly handled.</li></ul>
+<p>
+<ul>
+<li>Build [Randy Kobes] Add appropriate manifest command to embed manifest files on Win32 when using VC8</li></ul>
+<p>
+<ul>
+<li>C API [Andy Grundman, joes] Add missing bytes_read initializer to <a class="el" href="apreq__module_8h.html#beaaad6c03b54ca963f9f14a3031e912">apreq_handle_custom()</a>.</li></ul>
+<p>
+<ul>
+<li>C API [suggested by Vinay Y S, tested by Steve Hay and Peter Walsham] For Win32, remove the flag |= APR_FILE_NOCLEANUP | APR_SHARELOCK; in apreq_file_cleanup, to avoid problems with file uploads.</li></ul>
+<h2><a class="anchor" name="v2_09">
+Changes with libapreq2-2.09 ( not released)</a></h2>
+<ul>
+<li>C API [joes] Fix leak associated to calling <a class="el" href="apreq__util_8h.html#3bbe5ee2d1537c6a9f30d0fed9f5f1e1">apreq_brigade_fwrite()</a> on an upload brigade.</li></ul>
+<p>
+<ul>
+<li>Build [Philip M. Gollucci] SunOS (Solaris) Users must use gmake not make for building.</li></ul>
+<p>
+<ul>
+<li>Build [Philip M. Gollucci] SunOS (Solaris) Code around bug in libtool (at least in 1.5.18, 1.5.20, 1.5.22) causing mod_apreq2 to be built instead of mod_apreq2.so</li></ul>
+<p>
+<ul>
+<li>C API [Philip M. Gollucci] Fix comparison signed vs unsigned comparison in apreq_fwritev() on SunOS/gcc where iovec.iov_len is a long.</li></ul>
+<p>
+<ul>
+<li>Build [Philip M. Gollucci] SunOS (Solaris) fix duplicate link error to libexpat.so -- by using the one from httpd exclusively now.</li></ul>
+<p>
+<ul>
+<li>Build [Philip M. Gollucci] code around |_!!_#| autoconf 2.60 bug.</li></ul>
+<h2><a class="anchor" name="v2_08">
+Changes with libapreq2-2.08 (released August 8, 2006)</a></h2>
+<ul>
+<li>Perl API [Randy Kobes] add APR_FILE_NOCLEANUP | APR_SHARELOCK to flags passed to <a class="el" href="apreq__util_8h.html#b266a81c528de92654eb37f9890c4a7d">apreq_file_mktemp()</a> on Win32 in library/util.c, in order to clean up occasional stray temp files left behind in the Perl upload test (reported by Steve Hay)</li></ul>
+<p>
+<ul>
+<li>Build [Philip M. Gollucci, Bojan Smojver, joes] make input brigade volatile in order to give hints to GCC <a href="https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=193740">https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=193740</a> This fixes an infinite look split_on_bdry() of library/parser_multipart.c particularly on linux/gcc 4.x platforms.</li></ul>
+<p>
+<ul>
+<li>Perl Glue Fix "value computed not used" gcc 4.1.x compile errors</li></ul>
+<p>
+<ul>
+<li>Build [Randy Kobes] Fix the location of apxs and the names of the apr and aprutil libraries on Win32 to enable building against Apache/2.2.</li></ul>
+<p>
+<ul>
+<li>Perl Glue docs [Philip M. Gollucci] Fix the 'docs_install' make target to actually install the docs for the perl glue.</li></ul>
+<p>
+<ul>
+<li>Perl Glue Build [Philip M. Gollucci] Regenerate glue/perl/xsbuilder/ppport.h to fix perl 5.8.8+ on some plaforms.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Add code for <a class="el" href="apreq__module_8h.html#7435376b1f543c604d8326de3157e075">apreq_cookies()</a>.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Expose the constants in <a class="el" href="apreq__error_8h.html" title="Error status codes.Define the APREQ_ error codes.">apreq_error.h</a> via the APR::Request::Error package.</li></ul>
+<h2><a class="anchor" name="v2_07">
+Changes with libapreq2-2.07 (released February 12, 2006)</a></h2>
+<ul>
+<li>C API [joes] SECURITY: CVE-2006-0042 (cve.mitre.org) Eliminate potential quadratic behavior in apreq_parse_headers() and apreq_parse_urlencoded().</li></ul>
+<p>
+<ul>
+<li>Perl API [Philip M. Gollucci] Fix Apache2::Cookie-&gt;cookies() to comply with its documentation</li></ul>
+<p>
+<ul>
+<li>C API [Philip M. Gollucci] Use the APREQ_DEFAULT_READ_LIMIT constant for the read_limit</li></ul>
+<p>
+<ul>
+<li>C API [Ville Skyttä, Dirk Nehring] Add explicit cast in <a class="el" href="apreq__util_8h.html#785be2ceae273b0a7b2ffda223b2ebae">apreq_escape()</a>/apreq_util.h to keep C++ compilers happy.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Protect against arbitrary recursion depth in apreq_parse_multipart() by adding a reasonable compile-time MAX_LEVEL limit.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Clean up end-of-file parsing for apreq_parse_multipart(), conforming to rfc-2046 § 5.1.1.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Move APR::Request::Param::Table and APR::Request::Cookie::Table packages to APR::Request module.</li></ul>
+<p>
+<ul>
+<li>Perl XS [Steve Hay] Fix compile problems on Win32 without PERL_IMPLICIT_SYS related to link being an unresolved symbol.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] APR::Request::Cookie::thaw() isn't a class method.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Fix off-by-one bug in the continuation-lines portion of the header parser.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Move APR::Request::upload to APR::Request, where it belongs.</li></ul>
+<p>
+<ul>
+<li>Perl XS [Nikolay Ananiev] Use MP_STATIC declarations to allow Cygwin builds.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] encode()/decode() were busted with zero-length args. This caused Apache2::Cookie::new() to segfault on cookie value of "".</li></ul>
+<p>
+<ul>
+<li>C API [joes] Add <a class="el" href="apreq__util_8h.html#e11e0b3e2304a2e8c30aaa464ea78037">apreq_charset_divine()</a> and eliminate charset offset from return value of apreq_decode(v).</li></ul>
+<p>
+<ul>
+<li>C API [joes] Improve the cp1252-charset heuristics for apreq_decode(v).</li></ul>
+<p>
+<ul>
+<li>C API [Ralph Mattes] Add explicit casts for apreq_param_charset_* to keep c++ compilers happy.</li></ul>
+<h2><a class="anchor" name="v2_06_dev">
+Changes with libapreq2-2.06-dev (released July 20, 2005)</a></h2>
+<ul>
+<li>C API [Marc Gràcia, joes] Fix apreq_decode(v) when iso-latin-1 chars appear at the end of an encoded string.</li></ul>
+<p>
+<ul>
+<li>Perl API [Philip M. Gollucci] Fix "Attempt to free temp prematurely" error in apreq_xs_croak().</li></ul>
+<p>
+<ul>
+<li>C API [Philip M. Gollucci] Add mod_apreq2 to httpd's server tokens.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Drop support for $req-&gt;env(), which also died with 2.05-dev.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Support for table set/add/delete methods is formally withdrawn. Technically this feature died with the module API refactoring in 2.05-dev.</li></ul>
+<p>
+<ul>
+<li>C API [max] Right-hand limit of <a class="el" href="apreq__util_8h.html#a23561a0d169b50454a815926ccc0ba5">apreq_brigade_move()</a> is declared as "excluding", but APR_RING_UNSPLICE() wants an "including" right-hand limit. Fixed this by passing the previous bucket.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Drop support for Apache2::Request::new's HOOK_DATA. UPLOAD_HOOK now takes only two arguments: ($upload, $data).</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Drop support for Apache2::Cookie::Jar::new's VALUE_CLASS. 2.05-dev broke that API, and it's not worth trying to fix. People who need that should use APR::Request::Cookie::Table's cookie_class() API instead.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Fix cookie domain/path munging in Apache2::Cookie::new().</li></ul>
+<h2><a class="anchor" name="v2_05_dev">
+Changes with libapreq2-2.05-dev (released May 5, 2005)</a></h2>
+<ul>
+<li>Win32 build [Randy Kobes] Have top-level 'nmake', 'nmake test', and 'nmake install' targets, respectively, also include building, testing, and installing the corresponding perl glue targets.</li></ul>
+<p>
+<ul>
+<li>C API [geoff] Minimum httpd version is now 2.0.48, which includes the official apr 0.9.4 release.</li></ul>
+<p>
+<ul>
+<li>C API [Max Kellermann] Fix apreq_quote.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Remove Apache2::Request::args. WARNING: through inheritance, args() now maps to Apache2::RequestRec::args. Folks that want the pre-2.05-dev behavior need to invoke APR::Request::args by name.</li></ul>
+<p>
+<ul>
+<li>C API [joes, Max Kellermann] Add apreq_initialize, apreq_pre_initialize and apreq_post_initialize. These are not thread-safe operations, so applications need to ensure they are invoked (in the correct sequence) prior to using any apreq2 modules.</li></ul>
+<p>
+<ul>
+<li>C, Perl API [joes] Add pool, bucket_alloc to <a class="el" href="structapreq__handle__t.html">apreq_handle_t</a>.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Drop $data argument from UPLOAD_HOOK, and also drop HOOK_DATA option. Perl folks should use a closure instead of passing in context data.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Move bake, bake2 to Apache2::Cookie, now requiring an extra $r argument. Also ""-operator is mapped to as_string() for Apache2::Cookie; but APR::Request::Cookie maps it to value().</li></ul>
+<p>
+<ul>
+<li>C API [joes] Remove header_in &amp; header_out from <a class="el" href="structapreq__module__t.html" title="Vtable describing the necessary module functions.">apreq_module_t</a>. Remove apreq_ua_cookie_version() and apreq_cookie_bake*(). Remove cookie2 argument to <a class="el" href="apreq__module_8h.html#beaaad6c03b54ca963f9f14a3031e912">apreq_handle_custom()</a>.</li></ul>
+<p>
+<ul>
+<li>C API [joes] s/APREQ/APREQ2/g in webserver configuration directives.</li></ul>
+<p>
+<ul>
+<li>C API [Igor Shevchenko, Philip Gollucci] Fix segfault in mfd parser caused by parts w/ empty param names.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Add <a class="el" href="apreq__util_8h.html#801aa204656988ff4aa32cec6dd80e5a">apreq_cp1252_to_utf8()</a>.</li></ul>
+<p>
+<ul>
+<li>C, Perl API [joes] Add charset support for params and couple the SvUTF8 flag to the param's taint flag.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Replace v-&gt;size with v-&gt;nlen + v-&gt;dlen. Added supporting <a class="el" href="apreq_8h.html#0d27c51db1532fa3f829838ed90f6226">apreq_value_table_add()</a>.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Remove apreq_cookie_attr().</li></ul>
+<p>
+<ul>
+<li>C API [joes]<ul>
+<li>Add <a class="el" href="apreq__error_8h.html" title="Error status codes.Define the APREQ_ error codes.">apreq_error.h</a>, <a class="el" href="apreq__module_8h.html" title="Module API.">apreq_module.h</a>.</li><li>Rename apreq_run* and apreq_make* funcs to conform with apreq_$obj_$meth scheme.</li><li>Replace c-&gt;version &amp; c-&gt;secure with flags.</li><li>Parsers are assumed to be working with external data, so the cookies &amp; params they produce are marked tainted.</li></ul>
+</li></ul>
+<p>
+<ul>
+<li>C API [joes] <a class="el" href="apreq__cookie_8h.html#113be08c01bc82605ec52d80c054cbf6">apreq_parse_cookie_header()</a> failed to parse RFC Cookie headers which contained no space chars after the '$Version=1' preamble.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Reorganize around include/, library/, and module/ dirs.</li></ul>
+<p>
+<ul>
+<li>C Tests [joes] Replace CuTest-based tests with custom TAP-compliant framework.</li></ul>
+<p>
+<ul>
+<li>C API [Max Kellermann] Continue the API improvements:</li></ul>
+<p>
+<ul>
+<li>Convert APREQ_RUN_PARSER and APREQ_RUN_HOOK to inline, and downcase them.</li><li>Remove apreq_memmem.</li><li>Convert apreq_(un)escape to inline.</li><li>apreq_escape does not create an apreq_value_t*.</li><li>Initialize default_parsers explicitly to NULL.</li><li>Convert APREQ_BRIGADE_COPY to inline, and downcase it.</li><li>Lowercase APREQ_BRIGADE_SETASIDE, APREQ_BRIGADE_COPY.</li><li>Convert apreq_cookie_name and apreq_cookie_value macros to inline.</li><li>Convert apreq_param_name, apreq_param_value, apreq_param_info, and apreq_param_brigade to inline.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Widespread API refactorization to remove apreq_jar_t and apreq_request_t:</li></ul>
+<p>
+<ul>
+<li>Header includes reorganized; apreq_parsers.h added (back again).</li><li>Replaced apreq_jar_t and apreq_request_t with single apreq_env_handle_t.</li><li>Added const qualifier to "v" attribute of <a class="el" href="structapreq__cookie__t.html" title="Cookie type, supporting both Netscape and RFC cookie specifications.">apreq_cookie_t</a> and <a class="el" href="structapreq__param__t.html">apreq_param_t</a>.</li><li>Use union type-puns to drop const qualifiers inside the new apreq_value_to_cookie and apreq_value_to_param implementations (gcc generates same object code as the macro versions did).</li><li>Moved "flags" attribute from <a class="el" href="structapreq__value__t.html" title="libapreq&#39;s pre-extensible string type">apreq_value_t</a> to <a class="el" href="structapreq__cookie__t.html" title="Cookie type, supporting both Netscape and RFC cookie specifications.">apreq_cookie_t</a> and <a class="el" href="structapreq__param__t.html">apreq_param_t</a>.</li><li>Re
 move env argument from hooks and parsers.</li><li>Reduce apreq_env_module to minimal set of operations.</li><li>Replace apreq_log calls with apreq-specific error codes.</li><li>Hooks are called on each body param now, not just during file uploads.</li><li>Tie the cgi handle to its creator pool.</li></ul>
+<p>
+Detailed changes by header file:<p>
+[<a class="el" href="apreq_8h.html" title="Main header file...Define the generic APREQ_ macros and common data structures.">apreq.h</a>]<ul>
+<li>Remove flags from <a class="el" href="structapreq__value__t.html" title="libapreq&#39;s pre-extensible string type">apreq_value_t</a>.</li><li>Remove const qualifier from apreq_value_t's "name" attribute.</li><li>Remove apreq_value_merge* and apreq_value_copy*.</li><li>Remove apreq_char_to_value, apreq_strtoval, and apreq_strlen.</li><li>Move apreq_enctype to apreq_env.h.</li><li>Move apreq_env_handle_t struct definition to apreq_env.h</li><li>Change signature of apreq_decode.</li><li>Move apreq_brigade_concat here, changed its signature and improved it alot.</li><li>Remove apreq_brigade_spoolfile.</li><li>Dropped APREQ_*_ENCTYPE, renamed some APREQ_$foo defaults APREQ_DEFAULT_$foo.</li><li>Added APREQ_ERROR_*.</li></ul>
+<p>
+[<a class="el" href="apreq__cookie_8h.html" title="Cookies and Jars.apreq_cookie.h describes a common server-side API for request (incoming)...">apreq_cookie.h</a>]<ul>
+<li>Remove apreq_env.h include.</li><li>Remove apreq_jar_t.</li><li>Add "flags" to <a class="el" href="structapreq__cookie__t.html" title="Cookie type, supporting both Netscape and RFC cookie specifications.">apreq_cookie_t</a>, add const qualifier to its "v" attr.</li><li>Remove apreq_jar* functions.</li><li>Add apreq_parse_cookie_header.</li><li>Move apreq_cookie, apreq_cookie_bake(2), and apreq_ua_cookie_version to apreq_env.h.</li></ul>
+<p>
+[apreq_params.h]<ul>
+<li>Remove apreq_env.h include.</li><li>Remove apreq_request_t.</li><li>Add "flags" to <a class="el" href="structapreq__param__t.html">apreq_param_t</a>, and const qualifier to its "v" attr.</li><li>Rename "bb" attribute "upload" in <a class="el" href="structapreq__param__t.html">apreq_param_t</a>.</li><li>Remove apreq_request* functions.</li><li>Remove apreq_parse_request.</li><li>Changed apreq_decode_param signature.</li><li>Replace env argument with apr_table_t in apreq_params_as_array, apreq_params_as_string,</li><li>Move remaining apreq_param* to apreq_env.h.</li><li>Move parser and hook sections to apreq_parsers.h.</li><li>Change apreq_upload(s) old apreq_request_t arg to apr_table_t.</li></ul>
+<p>
+[apreq_parsers.h]<ul>
+<li>Acquire the hook and parser sections of original apreq_params.h.</li><li>Remove env argument from APREQ_PARSER_ARGS and APREQ_HOOK_ARGS</li><li>Augment <a class="el" href="structapreq__hook__t.html">apreq_hook_t</a> and <a class="el" href="structapreq__parser__t.html">apreq_parser_t</a> to replace missing env features.</li><li>Change apreq_make_parser and apreq_make_hook signatures.</li><li>Rename apreq_add_hook to apreq_parser_add_hook, returning apr_status_t.</li><li>Change apreq_parser signature.</li></ul>
+<p>
+[apreq_env.h]<ul>
+<li>Remove read, log, pool, bucket_alloc, request, jar, and query_string methods.</li><li>Include apreq_parsers.h.</li><li>Reorganize apreq_env_module_t to provide hook, parser, jar, args, &amp; body table ops.</li><li>Rename max_brigade to "brigade_limit", max_body to "read_limit".</li><li>Change related module sigs, including temp_dir, to get/set methods.</li><li>Add parser and read_limit args to apreq_env_make_custom_handle.</li><li>Drop "name" arg and APREQ_ENV_MODULE =~ s/_ENV//.</li><li>s/apreq_env_make/apreq_handle/ in the handle constructor names.</li></ul>
+<p>
+[mod_apreq.c, apreq_env_apache2.h]<ul>
+<li>Changed APREQ_Max* configs to APREQ_BrigadeLimit and APREQ_ReadLimit.</li><li>Handle constructor renamed apreq_handle_apache2.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Make our "libtool current interface" number depend on apr's major number. This allows libapreq2 to be installed into a system-wide location while avoiding ABI conflicts arising from our apr-based interfaces.</li></ul>
+<p>
+<ul>
+<li>C API [Max Kellermann] Introduce apreq_env_handle_t to replace the void *env usage. Also added apreq_env_custom for making private handles, and new apreq_env_apache2.h to let mod_apreq export apreq_env_make_apache2.</li></ul>
+<p>
+<ul>
+<li>C API [Max Kellermann] Rename apreq_env_t to apreq_env_module_t, to prepare for a new thread-safe apreq_env API.</li></ul>
+<p>
+<ul>
+<li>C API [Max Kellermann] mod_apreq must check the return value of apreq_brigade_concat to avoid a RAM-consuming infinite loop. A bad APREQ_TempDir setting can cause this situation.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Provide workaround for chunked trailers bug in ap_http_filter.</li></ul>
+<p>
+<ul>
+<li>C, Perl API [joes] Several upload-related bugfixes: 1) apreq_upload and apreq_uploads did not search the full body table, 2) $upload-&gt;slurp and $io-&gt;read did not autovivify the resultant string.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Add "flags" attribute to <a class="el" href="structapreq__value__t.html" title="libapreq&#39;s pre-extensible string type">apreq_value_t</a>, planning for charset support. This is an ABI change, starting with libapreq2.so.2.0.24.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Add apreq_env_bucket_alloc() to get an allocator directly from the environment instead of creating them from a pool. This is an ABI change, starting with libapreq2.so.2.0.23.</li></ul>
+<p>
+<ul>
+<li>Build system [joes] Add --with-apache2-httpd option so users can override apxs's notion of where the httpd executable is. XSBuilder's header parser runs from buildconf now instead of configure, so we will include those tables in the release tarball. buildconf gets an additional --with-perl option for running the xsbuilder.pl parsing script. The XS generation code in xsbuilder.pl has moved to glue/perl/Makefile.PL.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Allow ctors for Apache::Cookie, Apache::Cookie::Jar and <a class="elRef" doxygen="apu.tag:http://apr.apache.org/docs/apr-util/1.3/" href="http://apr.apache.org/docs/apr-util/1.3/namespace_apache.html">Apache</a>:Request to accept Apache::Request objects (instead of requiring an Apache::RequestRec object). This thread details the bug <a href="http://thread.gmane.org/gmane.comp.apache.mod-perl/15727">http://thread.gmane.org/gmane.comp.apache.mod-perl/15727</a></li></ul>
+<p>
+<ul>
+<li>C API [Bojan Smojver] Bake cookies with err_headers_out so they are sent on non-2xx server responses (ie. a 304 redirect). Also ensure that headers are copied with apr_table_add instead of apr_table_addn. Since apreq_cookie_bake() allocates from the stack, the Set-Cookie headers would occasionally get mangled without this patch.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Add <a class="el" href="apreq__parser_8h.html#595f05be3d241a5b339fd6ef948bfbc8">apreq_register_parser()</a>, which allows users to add their own parsers to <a class="el" href="apreq__parser_8h.html#73013ecad087f14075d319a4a983dd82">apreq_parser()</a>'s recognized MIME types.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Support "multipart/mixed" file uploads. Support XForms' "multipart/related" enctype.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Add apreq_hook_apr_xml_parser(), which is a simple wrapper hook around APR's expat-based apr_xml_parser. Add a generic parser apreq_parse_generic() to parse arbitrary enctypes using the hook API.</li></ul>
+<h2><a class="anchor" name="v2_04_dev">
+Changes with libapreq2-2.04-dev (released August 30, 2004)</a></h2>
+<ul>
+<li>Perl API [joes] Add TAINT checks, marking all parsed data as tainted.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Add body_status attribute to apreq_request_t, to allow the both environment and the parser to report any errors encountered.</li></ul>
+<p>
+<ul>
+<li>C API [randyk, joes] Cookie parser was locking up on non-alphanumeric chars in cookie names. Also RFC Cookie attributes are always checked for quotes during bake(2), and the quotes are now stripped from incoming RFC cookies during parsing (but they are never stripped from the actual cookie value).</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Apache::Cookie::Jar-&gt;new accepts a VALUE_CLASS argument, which effectively blesses all the jar's cookies into that class, which simplifies subclassing Apache::Cookie. Accordingly Apache::Cookie-&gt;freeze($value) no longer accepts a freeze()-able object in $value.</li></ul>
+<p>
+<ul>
+<li>C API [Markus Wichitill, randyk, joes] Drop APR_DELONCLOSE from apreq_file_mktemp implementation and install apreq_file_cleanup. When passed to apr_file_open on Win32, APR_DELONCLOSE sets the FILE_SHARED_DELETE flag, which is, unfortunately, a property that is preserved across NTFS "hard" links. This breaks apps that link() the temp file to a permanent location, and subsequently expect to open it without FILE_SHARED_DELETE before the original tempfile is closed+deleted. In fact, even Apache::Upload does this, so it is a common enough event that the apreq_file_cleanup workaround is necessary.</li></ul>
+<p>
+<ul>
+<li>C API [Ken Burcham, joes] Fix bug in url parser that occurs when a XX-encoded sequence is split across multiple buckets. Added apreq_decode_decodev to make this problem less inconvenient.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Exception objects inherit from the object which raised it, which allows $@ to invoke its methods with impunity (exceptions are disabled for objects which derive from an exception class).</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Implement HOOK_DATA and UPLOAD_HOOK.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Add safe XS wrappers for $table-&gt;add, $table-&gt;set, $table-&gt;STORE, and $table_class-&gt;new.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Add exceptions to $upload-&gt;link, $upload-&gt;tempname, $upload-&gt;slurp, and $cookie-&gt;set_attr. Return value of $upload-&gt;slurp is now the upload length. Also document new $upload-&gt;io.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Restrict all apr_status_t codes to APR_SUCCESS, APR_INCOMPLETE, APR_EGENERAL, APR_EINIT, APR_ENOTIMPL, since any others will generate confusing error messages from apr_strerror.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Added $upload-&gt;io with a TIEHANDLE API layered over APR::Brigade. $upload-&gt;fh remains implemented as an APR::PerlIO object, which is seekable but less efficient and currently suffers some portability issues associated with largefile support in perl and apr.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Added apreq_xs_croak for throwing APR::Error exceptions and included error-checking on $req-&gt;param, $req-&gt;args, $req-&gt;body, $req-&gt;upload, and $jar-&gt;get.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Added $jar-&gt;status, $req-&gt;args_status and $req-&gt;body_status to report parsing errors. Also add $upload-&gt;tempname per user request.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Dropped status attribute of <a class="el" href="structapreq__value__t.html" title="libapreq&#39;s pre-extensible string type">apreq_value_t</a>. Added status field to apreq_jar_t and added args_status field to apreq_request_t. Parsers also must return their public status code when a NULL brigade is passed. apreq_hook_disable_uploads() is also added.</li></ul>
+<p>
+This is an ABI change affecting all versions of libapreq2 prior to 2.0.12.<p>
+<ul>
+<li>Perl API [joes] $upload-&gt;info returns a proper APR::Table object now. Also implemented $upload-&gt;size, $upload-&gt;fh, and $upload-&gt;type.</li></ul>
+<p>
+<ul>
+<li>C API [Jean-François Meesse] mfd parser fails to parse CRLF-terminated files when the terminating boundary string is at the start of a new bucket. This is reportedly a common event for PDF files uploaded with Netscape 7.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Add back-compat support for Apache::Cookie-&gt;fetch() via Apache-&gt;request.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Add MaxBody, MaxBrigade, and TempDir per-dir directives to mod_apreq filter.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Replace free/tempnam dependency in <a class="el" href="apreq__util_8h.html#b266a81c528de92654eb37f9890c4a7d">apreq_file_mktemp()</a> with <a class="elRef" doxygen="apr.tag:http://apr.apache.org/docs/apr/1.3/" href="http://apr.apache.org/docs/apr/1.3/group__apr__file__io.html#g5cc19828a668c362be0ad7a12b805cc0">apr_temp_dir_get()</a>. Add additional gcc warning flags when --enable-maintainer-mode is set.</li></ul>
+<p>
+<ul>
+<li>C API [joes, Scott Hutton] Replace apreq_brigade_copy with more effective APREQ_BRIGADE_COPY macro. Also introduce APREQ_BRIGADE_SETASIDE to deal with buckets that need to be set aside for use in future function calls. mod_ssl generates transient buckets which tickled this bug.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Separate Apache::Upload module from Apache::Request for better organization.</li></ul>
+<h2><a class="anchor" name="v2_03_dev">
+Changes with libapreq2-2.03-dev (released June 12, 2004)</a></h2>
+<ul>
+<li>C API [joes] "Objectify" cookie/jar API: s/apreq_(make|serialize)_cookie/apreq_cookie_$1/ and reordering args so the cookie/jar object is always the first argument. Macros added to provide source-compatibility with the old names.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Added $upload-&gt;slurp($data), which reads the contents of the file upload "$upload" into the scalar "$data".</li></ul>
+<p>
+<ul>
+<li>C API [joes, randyk] apreq_run_(hook|parser) are macros, so they are capitalized now. Fixed <a class="el" href="apreq__param_8h.html#0f1db12120bb2307f5e33186f094b0d6">apreq_params_as_string()</a> and added <a class="el" href="apreq__param_8h.html#76c7e698fd45f3f3e07db60fcba15e52">apreq_params_as_array()</a>. Reworked definitions of APREQ_DECLARE_HOOK, APREQ_DECLARE_PARSER and apreq_(parser|hook)_t, hopefully to be more Win32 friendly. Also updated the documentation.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Compensate for a missing CRLF in empty file upload block, which actually complies with RFC 2046 Section 5.1.1. Konqueror (version unknown) and Mozilla 0.9.7 are known to emit such blocks.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] $req-&gt;upload() in list context failed to filter out non-uploads. Also $req-&gt;upload("nonexistent-key-name") segfaults.</li></ul>
+<p>
+<ul>
+<li>Perl test suite t/TEST.PL must run parent class' pre_configure to get the configuration right</li></ul>
+<p>
+<ul>
+<li>C API [joes] <a class="el" href="apreq__util_8h.html#4ddf563c9902474bdedbf014e24aafc8">apreq_brigade_concat()</a> wasn't supplying the final EOS bucket to large brigades (&gt;256K), which somtimes caused the prefetch loop in mod_apreq.c's apreq_filter() to hang.</li></ul>
+<p>
+<ul>
+<li>Documentation [joes] CHANGES file reformatted, removing dates &amp; other clutter as Stas suggests.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Rewrote cgi_read() in apreq_env.c and reworked mod_apreq.c to enforce apreq_env_max_body() settings.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Fixed bug in url_parser code- missing context brigade was needed to track key-value pairs which span multiple buckets.</li></ul>
+<p>
+<ul>
+<li>C API [joes] API modifications: removed struct apreq_cfg_t, adding new apreq_env hooks max_body, max_brigade_len, and temp_dir. Folded apreq_parsers.h into apreq_params.h and modified the arguments to apreq_run_parser() and apreq_run_hook(). Renamed apreq_parser_t's content_type as enctype and apreq_copy_brigade() as <a class="el" href="apreq__util_8h.html#b4def9e77622cf22cfa427e7fbf2ac45">apreq_brigade_copy()</a>. These changes make libapreq2.so.2.0.5 incompatible with earlier versions.</li></ul>
+<p>
+<ul>
+<li>Perl API [stas] Include ppport.h from blead-perl to support older perls. Add a proper support for ithreads.</li></ul>
+<p>
+<ul>
+<li>C API [Swen Schillig, joes] Fixed bug in calculation of Netscape cookie expiration dates. apr_time_t is measured in microseconds, not seconds, which threw off the arithmetic; apr_time_from_sec was needed for the conversion.</li></ul>
+<p>
+<ul>
+<li>C API [Max Kellermann] Fix segfault caused by invalid -escape sequence in query string.</li></ul>
+<h2><a class="anchor" name="v2_02_dev">
+Changes with libapreq2-2.02-dev (released Nov 15, 2003)</a></h2>
+<ul>
+<li>Perl API [joes] Fix bogus pool/cookie initializers in Apache::Cookie::set_attr(), which caused Apache::Cookie::new to segfault. Bug first reported to modperl list by Wolfgang Kubens.</li></ul>
+<h2><a class="anchor" name="v2_01_dev">
+Changes with libapreq2-2.01-dev (released Nov 10, 2003)</a></h2>
+<ul>
+<li>build system [joes] Skip Apache::Test tests in env/ when Apache::Test is unavailable. This allows the C API to be build and installed without requiring Apache::Test (it is still a requirement for compiling the perl glue).</li></ul>
+<p>
+<ul>
+<li>C API mod_apreq.c [joes] Parser errors were creeping into the return value of apreq_filter, which breaks the "transparent tee" paradigm. This caused bogus "400 Bad Request" responses (first reported by Vladimir Dudo) to occur when libapreq2 was used by an output filter during a GET request (handled by apache2's default handler). The test suite has been updated accordingly.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Incorporate libapreq_cgi into libapreq2 as the default environment, and add apreq_env_t and initializer apreq_env_module() to manage the environment at runtime (determining the environment at load-time was problematic on non-ELF systems).</li></ul>
+<h2><a class="anchor" name="v2_0_0">
+Changes with libapreq2-2.00-dev (Oct 25, 2003)</a></h2>
+<ul>
+<li>C API: libapreq_cgi.c [randyk, joes] CGI environment defined by env/libapreq_cgi.c is functional (with tests added to env/t). This library may soon be incorporated directly into libapreq2 as a default enviroment.</li></ul>
+<p>
+<ul>
+<li>C API: mod_apreq.c [joes] Added ctx-&gt;saw_eos to ensure we don't read from upstream filters after receiving an eos bucket. Otherwise it was possible for two eos buckets to appear when a prefetch read is involved, which breaks other modules like mod_proxy. This bug was uncovered by Philippe Chiasson. mod_apreq's apreq_env_majic_number bumped to reflect the added fixes.</li></ul>
+<p>
+<ul>
+<li>configure: --enable-perl-glue [joes] The --enable-perl-glue option integrates the perl glue into the normal Unix build cycle. It is disabled by default, but is silently reenabled if the user configures the source tree via Makefile.PL.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Added <a class="el" href="apreq__util_8h.html#8195b6a32954928a6088e7cea077dd75">apreq_header_attribute()</a> and fixed mfd parser to allow "charset" attribute to appear in the Content-Type header. Sven Geisler points out that Opera 7.20 does generate such headers.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Added versioning API following <a href="http://apr.apache.org/versioning.html">http://apr.apache.org/versioning.html</a> apreq_env renamed apreq_env_name, and apreq_env_magic_number added to provide versioning for environments (modules). The header files are now installed to "include/apreq2", and the library is renamed "libapreq2". Also added an apreq2-config script based on apu-config.</li></ul>
+<p>
+<ul>
+<li>configure: static mod_apreq.c [Bojan Smojver, joes] Add --with-apache2-src configure option, along with --with-apr-config and --with-apu-config, and provide support for compiling mod_apreq into httpd as a static apache module.</li></ul>
+<p>
+<ul>
+<li>C API: mod_apreq.c [joes] Support for internal redirects added to the mod_apreq filter. This ensures any POST data prefetched in the main request gets passed along to the subrequest handler(s).</li></ul>
+<p>
+<ul>
+<li>C bugfix: apreq_decode [Graham Clark] If the source and destination strings are represented by the same pointer - e.g. if called as apreq_unescape(s) - string s is modified incorrectly in general. Patch includes new unit test.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Added $req-&gt;parse, $req-&gt;status, &amp; "preparse" logic to $req-&gt;param &amp; $req-&gt;upload.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Added "preparse" logic to apreq_params &amp; apreq_uploads to bring behavior in line with libapreq-1.x.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Dropped param-&gt;charset. Make apreq_brigade_concat public, so mod_apreq can use it for its ctx-&gt;spool brigade.</li></ul>
+<p>
+<ul>
+<li>Documentation [joes] Updated Cookie_pod to reflect API changes over v1.X.</li></ul>
+<p>
+<ul>
+<li>Documentation [joes] Added doxygen links to Apache::Request and Apache::Cookie perl docs.</li></ul>
+<p>
+<ul>
+<li>C API [joes] Added apreq_copy_brigade(bb) to <a class="el" href="apreq_8h.html" title="Main header file...Define the generic APREQ_ macros and common data structures.">apreq.h</a>.</li></ul>
+<p>
+<ul>
+<li>C API [joes] The new filter-based design required a complete departure from libapreq-1.X codebase. libapreq-2 is based solely on APR, and to be fully functional, requires a supporting environment similar to Apache-2. A person wishing to port libapreq-2 to a new environment needs to provide definitions for the declarations in apreq_env.h.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Aggregates are always collected into an APR::Table-based package. New table packages: Apache::Cookie::Table, Apache::Request::Table, and Apache::Upload::Table.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Apache::Cookie-&gt;fetch now requires an "environment" argument ($r). Its return value is blessed into the Apache::Cookie::Jar class.</li></ul>
+<p>
+<ul>
+<li>Perl API [joes] Two new request lookup functions:<ol type=a>
+<li>$req-&gt;args - param lookup using only the query string</li><li>$req-&gt;body - param lookup using only the POST data </li></ol>
+</li></ul>
+</div>
+<div id="footer">
+<p class="apache">
+Copyright &copy; 2003-2006 <a href="http://www.apache.org">The Apache Software Foundation</a>.<br/>
+See <a href="apreq_license.html">LICENSE</a>.</p>
+<p class="menu">
+<span style="color:#aaa">page generated by <a href="http://www.doxygen.org/"><code>doxygen</code></a>
+version 1.5.6 on 3 Dec 2010</span>
+</p>
+</div>
+</body>
+</html>

Added: websites/staging/httpd/trunk/content/apreq/docs/libapreq2/apreq_faq.html
==============================================================================
--- websites/staging/httpd/trunk/content/apreq/docs/libapreq2/apreq_faq.html (added)
+++ websites/staging/httpd/trunk/content/apreq/docs/libapreq2/apreq_faq.html Sun May  6 14:18:02 2012
@@ -0,0 +1,179 @@
+<html>
+<head>
+  <link rel="stylesheet" type="text/css" href="dox.css" />
+  <title>libapreq2-2.13: libapreq2: FAQ</title> 
+</head>
+<body>
+<div id="page-header">
+<p class="menu">
+   <a href="http://www.apache.org/">Apache Software Foundation</a> &gt; <a href="http://httpd.apache.org">HTTP Server Project</a> &gt;
+<a href="http://httpd.apache.org/apreq/">Request Library Subproject</a></p>
+<p class="apache">Apache HTTP Server Request Library</p>
+<img alt="" src="feather.gif" /></div>
+<!-- Generated by Doxygen 1.5.6 -->
+<div class="navigation" id="top">
+  <div class="tabs">
+    <ul>
+      <li><a href="index.html"><span>Main&nbsp;Page</span></a></li>
+      <li><a href="pages.html"><span>Related&nbsp;Pages</span></a></li>
+      <li><a href="modules.html"><span>Modules</span></a></li>
+      <li><a href="annotated.html"><span>Data&nbsp;Structures</span></a></li>
+      <li><a href="files.html"><span>Files</span></a></li>
+      <li><a href="examples.html"><span>Examples</span></a></li>
+    </ul>
+  </div>
+</div>
+<div class="contents">
+<h1><a class="anchor" name="apreq_faq">FAQ </a></h1>
+
+
+
+<!-- INDEX BEGIN -->
+<div name="index">
+<p><a name="__index__"></a></p>
+
+<ul>
+
+	<li><a href="#issues_during_installation_">Issues during installation.</a></li>
+	<li><a href="#using_libapreq2_with_apache2_and_mod_perl2_">Using libapreq2 with Apache2 and mod_perl2.</a></li>
+	<ul>
+
+		<li><a href="#i_keep_getting_undefined_symbol_errors_whenever">I keep getting &quot;undefined symbol&quot; errors whenever</a></li>
+		<li><a href="#when_i_use_apache2__request_in_my_output_filter__it_seems_to_lose">When I use Apache2::Request in my output filter, it seems to lose</a></li>
+		<li><a href="#when_i_try_to_upload_a_file__why_do_i_get_this_error">When I try to upload a file, why do I get this error</a></li>
+	</ul>
+
+	<li><a href="#using_libapreq2_outside_of_apache_">Using libapreq2 outside of Apache.</a></li>
+	<li><a href="#contributing_to_apreq_development_">Contributing to apreq development.</a></li>
+	<ul>
+
+		<li><a href="#how_is_the_subversion_repository_managed">How is the subversion repository managed?</a></li>
+	</ul>
+
+</ul>
+
+<hr name="index" />
+</div>
+<!-- INDEX END -->
+
+
+<p>
+
+</p>
+
+<h1><a name="issues_during_installation_">Issues during installation.</a></h1>
+
+<p>[...]</p>
+
+<p>
+
+</p>
+<hr />
+
+<h1><a name="using_libapreq2_with_apache2_and_mod_perl2_">Using libapreq2 with Apache2 and mod_perl2.</a></h1>
+
+<p>
+
+</p>
+
+<h2><a name="i_keep_getting_undefined_symbol_errors_whenever_i_use_apache2__request_or_apr__request__apache2_">I keep getting &quot;undefined symbol&quot; errors whenever 
+       I use Apache2::Request or APR::Request::Apache2.</a></h2>
+
+<p>You need to load mod_apreq2.so at server startup, which grabs
+all the required symbols at server startup.  Be sure your server
+config contains a line like</p>
+
+<pre>
+        LoadModule apreq_module   modules/mod_apreq2.so</pre>
+
+<p>
+
+</p>
+
+<h2><a name="when_i_use_apache2__request_in_my_output_filter__it_seems_to_lose_the_incoming_post_variables_">When I use Apache2::Request in my output filter, it seems to lose
+       the incoming POST variables.</a></h2>
+
+<p>The problem is likely that the mod_apreq2 filter has not been 
+added to the input filter chain in time to read the POST data.</p>
+
+<p>There are two solutions to this problem:</p>
+
+<pre>
+ 1) Write a filter init handler for you filter that instantiates an
+    Apache2::Request object.</pre>
+
+<pre>
+    <a href="http://perl.apache.org/docs/2.0/api/Apache2/Filter.html#C_FilterInitHandler_">http://perl.apache.org/docs/2.0/api/Apache2/Filter.html#C_FilterInitHandler_</a></pre>
+
+<pre>
+ 2) Use .htaccess or your server config to ensure the apreq input filter
+    is active for this request with &quot;AddInputFilter APREQ&quot; or somesuch.</pre>
+
+<p>We recommend using (1), and falling back to (2) until you get (1) working.</p>
+
+<p>
+
+</p>
+
+<h2><a name="when_i_try_to_upload_a_file__why_do_i_get_this_error__error__can_t_locate_____apache2_request_upload_al_in__inc">When I try to upload a file, why do I get this error 
+       &quot;[error] Can't locate .../Apache2/Request/upload.al in @INC&quot;?</a></h2>
+
+<p><em>Apache2::Upload</em> is now a separate module in apreq2, so you need to 
+<code>use Apache2::Upload</code> to load the <code>Apache2::Request::upload</code> function.</p>
+
+<p>This also applies to &quot;Can't locate auto/APR/Request/Param/slurp.al in @INC&quot;.
+This is because <em>Apache2::Upload</em> is implement by wrapping the <em>APR::Request::*</em>
+packages.</p>
+
+<p>
+
+</p>
+<hr />
+
+<h1><a name="using_libapreq2_outside_of_apache_">Using libapreq2 outside of Apache.</a></h1>
+
+<p>[...]</p>
+
+<p>
+
+</p>
+<hr />
+
+<h1><a name="contributing_to_apreq_development_">Contributing to apreq development.</a></h1>
+
+<p>
+
+</p>
+
+<h2><a name="how_is_the_subversion_repository_managed">How is the subversion repository managed?</a></h2>
+
+<p>apreq's repository is broken into three subdirectories:</p>
+
+<pre>
+    /trunk    - the current codebase for active development.
+    /tags     - release snapshots.
+    /branches - where older releases and experimental development lines live.</pre>
+
+<p>apreq follows a Commit-then-Review policy for its entire repository,
+but being a shared library places certain restrictions on the admissible
+changes for stable trees.   Basically the header files cannot be modified;
+only new functions and structures may be added to them.  Any time that 
+happens, the minor-version needs to be bumped, and the patch-level gets
+reset to zero.  Changes that only modify the library's implementation (.c)
+files require a bump to the patch-level.  On stable trees, this version 
+tracking should happen on each commit, to make auditing easy for other 
+developers without resorting to a draconian Review-then-Commit policy.</p>
+
+
+ </div>
+<div id="footer">
+<p class="apache">
+Copyright &copy; 2003-2006 <a href="http://www.apache.org">The Apache Software Foundation</a>.<br/>
+See <a href="apreq_license.html">LICENSE</a>.</p>
+<p class="menu">
+<span style="color:#aaa">page generated by <a href="http://www.doxygen.org/"><code>doxygen</code></a>
+version 1.5.6 on 3 Dec 2010</span>
+</p>
+</div>
+</body>
+</html>

Added: websites/staging/httpd/trunk/content/apreq/docs/libapreq2/apreq_install.html
==============================================================================
--- websites/staging/httpd/trunk/content/apreq/docs/libapreq2/apreq_install.html (added)
+++ websites/staging/httpd/trunk/content/apreq/docs/libapreq2/apreq_install.html Sun May  6 14:18:02 2012
@@ -0,0 +1,106 @@
+<html>
+<head>
+  <link rel="stylesheet" type="text/css" href="dox.css" />
+  <title>libapreq2-2.13: libapreq2: INSTALL</title> 
+</head>
+<body>
+<div id="page-header">
+<p class="menu">
+   <a href="http://www.apache.org/">Apache Software Foundation</a> &gt; <a href="http://httpd.apache.org">HTTP Server Project</a> &gt;
+<a href="http://httpd.apache.org/apreq/">Request Library Subproject</a></p>
+<p class="apache">Apache HTTP Server Request Library</p>
+<img alt="" src="feather.gif" /></div>
+<!-- Generated by Doxygen 1.5.6 -->
+<div class="navigation" id="top">
+  <div class="tabs">
+    <ul>
+      <li><a href="index.html"><span>Main&nbsp;Page</span></a></li>
+      <li><a href="pages.html"><span>Related&nbsp;Pages</span></a></li>
+      <li><a href="modules.html"><span>Modules</span></a></li>
+      <li><a href="annotated.html"><span>Data&nbsp;Structures</span></a></li>
+      <li><a href="files.html"><span>Files</span></a></li>
+      <li><a href="examples.html"><span>Examples</span></a></li>
+    </ul>
+  </div>
+</div>
+<div class="contents">
+<h1><a class="anchor" name="apreq_install">INSTALL </a></h1><div class="fragment"><pre class="fragment">PREREQUISITES:
+
+Please see the PREREQUISITES file.  If you are building httpd-apreq-2 
+directly from svn, you can generate the list of prerequisites:
+
+            % perl build/version_check.pl
+
+
+INSTRUCTIONS:
+
+FreeBSD/Solaris users must substitute "gmake" for "make" below.
+
+Unix build, where libtool/automake/autoconf works:
+
+            % ./configure --with-apache2-apxs=/path/to/apache2/bin/apxs
+            % make
+  (optional)% make test
+            % make install
+  (optional)% make docs_install
+
+Or using the CPAN/perlish way (which includes the Apache2::Request and
+Apache2::Cookie modules):
+
+            % perl Makefile.PL --with-apache2-apxs=/path/to/apache2/bin/apxs
+            % make
+  (optional)% make test
+            % make install
+  (optional)% make docs_install
+
+Developers and other folks using httpd-apreq-2 directly from svn need to
+execute "./buildconf" prior to running "./configure".
+
+
+Win32 build:
+  C:\httpd-apreq-2&gt; perl Makefile.PL
+  C:\httpd-apreq-2&gt; nmake
+  C:\httpd-apreq-2&gt; nmake test
+  C:\httpd-apreq-2&gt; nmake docs
+  C:\httpd-apreq-2&gt; nmake install
+
+SVN (Subversion) ACCESS
+
+Development of httpd-apreq-2 can be followed through the svn repository:
+
+  $ svn checkout http://svn.apache.org/repos/asf/httpd/apreq/trunk/ httpd-apreq-2
+
+Developers with commit access must use the https protocol instead;
+note that, if you are compiling svn from sources, you must
+supply the configure script with the appropriate switch to
+enable ssl.
+
+Subversion sources, and binaries for some platforms, may be obtained
+through the home page:
+
+     http://subversion.tigris.org/
+
+Documentation on using svn is available at
+
+     http://svnbook.red-bean.com/
+
+In particular,
+
+     http://svnbook.red-bean.com/en/1.0/apa.html
+
+contains a guide for users familiar with cvs.
+
+
+
+</pre></div> </div>
+<div id="footer">
+<p class="apache">
+Copyright &copy; 2003-2006 <a href="http://www.apache.org">The Apache Software Foundation</a>.<br/>
+See <a href="apreq_license.html">LICENSE</a>.</p>
+<p class="menu">
+<span style="color:#aaa">page generated by <a href="http://www.doxygen.org/"><code>doxygen</code></a>
+version 1.5.6 on 3 Dec 2010</span>
+</p>
+</div>
+</body>
+</html>

Added: websites/staging/httpd/trunk/content/apreq/docs/libapreq2/apreq_license.html
==============================================================================
--- websites/staging/httpd/trunk/content/apreq/docs/libapreq2/apreq_license.html (added)
+++ websites/staging/httpd/trunk/content/apreq/docs/libapreq2/apreq_license.html Sun May  6 14:18:02 2012
@@ -0,0 +1,240 @@
+<html>
+<head>
+  <link rel="stylesheet" type="text/css" href="dox.css" />
+  <title>libapreq2-2.13: libapreq2: LICENSE</title> 
+</head>
+<body>
+<div id="page-header">
+<p class="menu">
+   <a href="http://www.apache.org/">Apache Software Foundation</a> &gt; <a href="http://httpd.apache.org">HTTP Server Project</a> &gt;
+<a href="http://httpd.apache.org/apreq/">Request Library Subproject</a></p>
+<p class="apache">Apache HTTP Server Request Library</p>
+<img alt="" src="feather.gif" /></div>
+<!-- Generated by Doxygen 1.5.6 -->
+<div class="navigation" id="top">
+  <div class="tabs">
+    <ul>
+      <li><a href="index.html"><span>Main&nbsp;Page</span></a></li>
+      <li><a href="pages.html"><span>Related&nbsp;Pages</span></a></li>
+      <li><a href="modules.html"><span>Modules</span></a></li>
+      <li><a href="annotated.html"><span>Data&nbsp;Structures</span></a></li>
+      <li><a href="files.html"><span>Files</span></a></li>
+      <li><a href="examples.html"><span>Examples</span></a></li>
+    </ul>
+  </div>
+</div>
+<div class="contents">
+<h1><a class="anchor" name="apreq_license">LICENSE </a></h1><div class="fragment"><pre class="fragment">
+                                 Apache License
+                           Version 2.0, January 2004
+                        http://www.apache.org/licenses/
+
+   TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+   1. Definitions.
+
+      "License" shall mean the terms and conditions for use, reproduction,
+      and distribution as defined by Sections 1 through 9 of this document.
+
+      "Licensor" shall mean the copyright owner or entity authorized by
+      the copyright owner that is granting the License.
+
+      "Legal Entity" shall mean the union of the acting entity and all
+      other entities that control, are controlled by, or are under common
+      control with that entity. For the purposes of this definition,
+      "control" means (i) the power, direct or indirect, to cause the
+      direction or management of such entity, whether by contract or
+      otherwise, or (ii) ownership of fifty percent (50%) or more of the
+      outstanding shares, or (iii) beneficial ownership of such entity.
+
+      "You" (or "Your") shall mean an individual or Legal Entity
+      exercising permissions granted by this License.
+
+      "Source" form shall mean the preferred form for making modifications,
+      including but not limited to software source code, documentation
+      source, and configuration files.
+
+      "Object" form shall mean any form resulting from mechanical
+      transformation or translation of a Source form, including but
+      not limited to compiled object code, generated documentation,
+      and conversions to other media types.
+
+      "Work" shall mean the work of authorship, whether in Source or
+      Object form, made available under the License, as indicated by a
+      copyright notice that is included in or attached to the work
+      (an example is provided in the Appendix below).
+
+      "Derivative Works" shall mean any work, whether in Source or Object
+      form, that is based on (or derived from) the Work and for which the
+      editorial revisions, annotations, elaborations, or other modifications
+      represent, as a whole, an original work of authorship. For the purposes
+      of this License, Derivative Works shall not include works that remain
+      separable from, or merely link (or bind by name) to the interfaces of,
+      the Work and Derivative Works thereof.
+
+      "Contribution" shall mean any work of authorship, including
+      the original version of the Work and any modifications or additions
+      to that Work or Derivative Works thereof, that is intentionally
+      submitted to Licensor for inclusion in the Work by the copyright owner
+      or by an individual or Legal Entity authorized to submit on behalf of
+      the copyright owner. For the purposes of this definition, "submitted"
+      means any form of electronic, verbal, or written communication sent
+      to the Licensor or its representatives, including but not limited to
+      communication on electronic mailing lists, source code control systems,
+      and issue tracking systems that are managed by, or on behalf of, the
+      Licensor for the purpose of discussing and improving the Work, but
+      excluding communication that is conspicuously marked or otherwise
+      designated in writing by the copyright owner as "Not a Contribution."
+
+      "Contributor" shall mean Licensor and any individual or Legal Entity
+      on behalf of whom a Contribution has been received by Licensor and
+      subsequently incorporated within the Work.
+
+   2. Grant of Copyright License. Subject to the terms and conditions of
+      this License, each Contributor hereby grants to You a perpetual,
+      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+      copyright license to reproduce, prepare Derivative Works of,
+      publicly display, publicly perform, sublicense, and distribute the
+      Work and such Derivative Works in Source or Object form.
+
+   3. Grant of Patent License. Subject to the terms and conditions of
+      this License, each Contributor hereby grants to You a perpetual,
+      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+      (except as stated in this section) patent license to make, have made,
+      use, offer to sell, sell, import, and otherwise transfer the Work,
+      where such license applies only to those patent claims licensable
+      by such Contributor that are necessarily infringed by their
+      Contribution(s) alone or by combination of their Contribution(s)
+      with the Work to which such Contribution(s) was submitted. If You
+      institute patent litigation against any entity (including a
+      cross-claim or counterclaim in a lawsuit) alleging that the Work
+      or a Contribution incorporated within the Work constitutes direct
+      or contributory patent infringement, then any patent licenses
+      granted to You under this License for that Work shall terminate
+      as of the date such litigation is filed.
+
+   4. Redistribution. You may reproduce and distribute copies of the
+      Work or Derivative Works thereof in any medium, with or without
+      modifications, and in Source or Object form, provided that You
+      meet the following conditions:
+
+      (a) You must give any other recipients of the Work or
+          Derivative Works a copy of this License; and
+
+      (b) You must cause any modified files to carry prominent notices
+          stating that You changed the files; and
+
+      (c) You must retain, in the Source form of any Derivative Works
+          that You distribute, all copyright, patent, trademark, and
+          attribution notices from the Source form of the Work,
+          excluding those notices that do not pertain to any part of
+          the Derivative Works; and
+
+      (d) If the Work includes a "NOTICE" text file as part of its
+          distribution, then any Derivative Works that You distribute must
+          include a readable copy of the attribution notices contained
+          within such NOTICE file, excluding those notices that do not
+          pertain to any part of the Derivative Works, in at least one
+          of the following places: within a NOTICE text file distributed
+          as part of the Derivative Works; within the Source form or
+          documentation, if provided along with the Derivative Works; or,
+          within a display generated by the Derivative Works, if and
+          wherever such third-party notices normally appear. The contents
+          of the NOTICE file are for informational purposes only and
+          do not modify the License. You may add Your own attribution
+          notices within Derivative Works that You distribute, alongside
+          or as an addendum to the NOTICE text from the Work, provided
+          that such additional attribution notices cannot be construed
+          as modifying the License.
+
+      You may add Your own copyright statement to Your modifications and
+      may provide additional or different license terms and conditions
+      for use, reproduction, or distribution of Your modifications, or
+      for any such Derivative Works as a whole, provided Your use,
+      reproduction, and distribution of the Work otherwise complies with
+      the conditions stated in this License.
+
+   5. Submission of Contributions. Unless You explicitly state otherwise,
+      any Contribution intentionally submitted for inclusion in the Work
+      by You to the Licensor shall be under the terms and conditions of
+      this License, without any additional terms or conditions.
+      Notwithstanding the above, nothing herein shall supersede or modify
+      the terms of any separate license agreement you may have executed
+      with Licensor regarding such Contributions.
+
+   6. Trademarks. This License does not grant permission to use the trade
+      names, trademarks, service marks, or product names of the Licensor,
+      except as required for reasonable and customary use in describing the
+      origin of the Work and reproducing the content of the NOTICE file.
+
+   7. Disclaimer of Warranty. Unless required by applicable law or
+      agreed to in writing, Licensor provides the Work (and each
+      Contributor provides its Contributions) on an "AS IS" BASIS,
+      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+      implied, including, without limitation, any warranties or conditions
+      of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
+      PARTICULAR PURPOSE. You are solely responsible for determining the
+      appropriateness of using or redistributing the Work and assume any
+      risks associated with Your exercise of permissions under this License.
+
+   8. Limitation of Liability. In no event and under no legal theory,
+      whether in tort (including negligence), contract, or otherwise,
+      unless required by applicable law (such as deliberate and grossly
+      negligent acts) or agreed to in writing, shall any Contributor be
+      liable to You for damages, including any direct, indirect, special,
+      incidental, or consequential damages of any character arising as a
+      result of this License or out of the use or inability to use the
+      Work (including but not limited to damages for loss of goodwill,
+      work stoppage, computer failure or malfunction, or any and all
+      other commercial damages or losses), even if such Contributor
+      has been advised of the possibility of such damages.
+
+   9. Accepting Warranty or Additional Liability. While redistributing
+      the Work or Derivative Works thereof, You may choose to offer,
+      and charge a fee for, acceptance of support, warranty, indemnity,
+      or other liability obligations and/or rights consistent with this
+      License. However, in accepting such obligations, You may act only
+      on Your own behalf and on Your sole responsibility, not on behalf
+      of any other Contributor, and only if You agree to indemnify,
+      defend, and hold each Contributor harmless for any liability
+      incurred by, or claims asserted against, such Contributor by reason
+      of your accepting any such warranty or additional liability.
+
+   END OF TERMS AND CONDITIONS
+
+   APPENDIX: How to apply the Apache License to your work.
+
+      To apply the Apache License to your work, attach the following
+      boilerplate notice, with the fields enclosed by brackets "[]"
+      replaced with your own identifying information. (Don't include
+      the brackets!)  The text should be enclosed in the appropriate
+      comment syntax for the file format. We also recommend that a
+      file or class name and description of purpose be included on the
+      same "printed page" as the copyright notice for easier
+      identification within third-party archives.
+
+   Copyright [yyyy] [name of copyright owner]
+
+   Licensed under the Apache License, Version 2.0 (the "License");
+   you may not use this file except in compliance with the License.
+   You may obtain a copy of the License at
+
+       http://www.apache.org/licenses/LICENSE-2.0
+
+   Unless required by applicable law or agreed to in writing, software
+   distributed under the License is distributed on an "AS IS" BASIS,
+   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+   See the License for the specific language governing permissions and
+   limitations under the License.
+</pre></div> </div>
+<div id="footer">
+<p class="apache">
+Copyright &copy; 2003-2006 <a href="http://www.apache.org">The Apache Software Foundation</a>.<br/>
+See <a href="apreq_license.html">LICENSE</a>.</p>
+<p class="menu">
+<span style="color:#aaa">page generated by <a href="http://www.doxygen.org/"><code>doxygen</code></a>
+version 1.5.6 on 3 Dec 2010</span>
+</p>
+</div>
+</body>
+</html>

Added: websites/staging/httpd/trunk/content/apreq/docs/libapreq2/apreq_notice.html
==============================================================================
--- websites/staging/httpd/trunk/content/apreq/docs/libapreq2/apreq_notice.html (added)
+++ websites/staging/httpd/trunk/content/apreq/docs/libapreq2/apreq_notice.html Sun May  6 14:18:02 2012
@@ -0,0 +1,40 @@
+<html>
+<head>
+  <link rel="stylesheet" type="text/css" href="dox.css" />
+  <title>libapreq2-2.13: libapreq2: NOTICE</title> 
+</head>
+<body>
+<div id="page-header">
+<p class="menu">
+   <a href="http://www.apache.org/">Apache Software Foundation</a> &gt; <a href="http://httpd.apache.org">HTTP Server Project</a> &gt;
+<a href="http://httpd.apache.org/apreq/">Request Library Subproject</a></p>
+<p class="apache">Apache HTTP Server Request Library</p>
+<img alt="" src="feather.gif" /></div>
+<!-- Generated by Doxygen 1.5.6 -->
+<div class="navigation" id="top">
+  <div class="tabs">
+    <ul>
+      <li><a href="index.html"><span>Main&nbsp;Page</span></a></li>
+      <li><a href="pages.html"><span>Related&nbsp;Pages</span></a></li>
+      <li><a href="modules.html"><span>Modules</span></a></li>
+      <li><a href="annotated.html"><span>Data&nbsp;Structures</span></a></li>
+      <li><a href="files.html"><span>Files</span></a></li>
+      <li><a href="examples.html"><span>Examples</span></a></li>
+    </ul>
+  </div>
+</div>
+<div class="contents">
+<h1><a class="anchor" name="apreq_notice">NOTICE </a></h1><div class="fragment"><pre class="fragment">This product includes software developed by
+The Apache Software Foundation (http://www.apache.org/).
+</pre></div> </div>
+<div id="footer">
+<p class="apache">
+Copyright &copy; 2003-2006 <a href="http://www.apache.org">The Apache Software Foundation</a>.<br/>
+See <a href="apreq_license.html">LICENSE</a>.</p>
+<p class="menu">
+<span style="color:#aaa">page generated by <a href="http://www.doxygen.org/"><code>doxygen</code></a>
+version 1.5.6 on 3 Dec 2010</span>
+</p>
+</div>
+</body>
+</html>

Added: websites/staging/httpd/trunk/content/apreq/docs/libapreq2/apreq_status.html
==============================================================================
--- websites/staging/httpd/trunk/content/apreq/docs/libapreq2/apreq_status.html (added)
+++ websites/staging/httpd/trunk/content/apreq/docs/libapreq2/apreq_status.html Sun May  6 14:18:02 2012
@@ -0,0 +1,116 @@
+<html>
+<head>
+  <link rel="stylesheet" type="text/css" href="dox.css" />
+  <title>libapreq2-2.13: libapreq2: STATUS</title> 
+</head>
+<body>
+<div id="page-header">
+<p class="menu">
+   <a href="http://www.apache.org/">Apache Software Foundation</a> &gt; <a href="http://httpd.apache.org">HTTP Server Project</a> &gt;
+<a href="http://httpd.apache.org/apreq/">Request Library Subproject</a></p>
+<p class="apache">Apache HTTP Server Request Library</p>
+<img alt="" src="feather.gif" /></div>
+<!-- Generated by Doxygen 1.5.6 -->
+<div class="navigation" id="top">
+  <div class="tabs">
+    <ul>
+      <li><a href="index.html"><span>Main&nbsp;Page</span></a></li>
+      <li><a href="pages.html"><span>Related&nbsp;Pages</span></a></li>
+      <li><a href="modules.html"><span>Modules</span></a></li>
+      <li><a href="annotated.html"><span>Data&nbsp;Structures</span></a></li>
+      <li><a href="files.html"><span>Files</span></a></li>
+      <li><a href="examples.html"><span>Examples</span></a></li>
+    </ul>
+  </div>
+</div>
+<div class="contents">
+<h1><a class="anchor" name="apreq_status">STATUS </a></h1>2.13 Released on December 3, 2010<p>
+Contributors looking for a mission:<p>
+<ul>
+<li>just do an egrep on "TODO" or "XXX" and see what's there</li></ul>
+<p>
+CURRENT RELEASE NOTES:<p>
+RELEASE SHOWSTOPPERS:<p>
+CURRENT VOTES:<p>
+<ul>
+<li>Should we switch to EU::MM for determining the full path to perl? The problem is that some folks move their perl binary post-installation, but never adjust Config.pm. EU::MM is smart, by accepting a full path in $^X or by searching the user's $PATH for $^X, before resorting to Config.pm. However, if we change apreq2, we should also lobby test-dev to adopt the same solution for Apache::Test. Otherwise our test suite will likely fail, even though the rest of the perl build system will presumably still work.</li></ul>
+<p>
++1: joes 0: -1:<p>
+<ul>
+<li>Drop ExtUtils::XSBuilder as the C API is fairly stable now. The header parsing + xs generation stuff may be too difficult for the community to maintain over ordinary .xs files.</li></ul>
+<p>
++1: pgollucci<p>
+TODO:<p>
+<ul>
+<li>Get -libmodperl to work like it does in mod_perl land.</li></ul>
+<p>
+<ul>
+<li>Get static builds working again.</li></ul>
+<p>
+<ul>
+<li>Implement (some of) RFC 2184 in the multipart parser.</li></ul>
+<p>
+<ul>
+<li>Dump automake, preferably replacing that with more stuff from httpd/apr's build system.</li></ul>
+<p>
+<ul>
+<li>Move module/t to module/apache2/t.</li></ul>
+<p>
+<ul>
+<li>Figure out how and where the apreq_xs_ headers, and typemap file, should be installed.</li></ul>
+<p>
+<ul>
+<li>Write tests for the apache 1.3.x module.</li></ul>
+<p>
+<ul>
+<li>Fix the broken make dependencies, especially in the module and glue subdirs. The libtool workaround (for OSX IIRC) that copies module/.libs to module/t is especially bogus.</li></ul>
+<p>
+<ul>
+<li>Round out the unit tests in library/t. Ideally each API function should have its own tests, and each possible error status should be both tested &amp; documented. Also upgrade these tests to use the Apache::Test framework.</li></ul>
+<p>
+<ul>
+<li>in glue/perl/t/apreq/cgi.t on Win32, printing to the error log hangs if the strings involved are about 10000 in size. This doesn't occur in the env/cgi tests - why?</li></ul>
+<p>
+<ul>
+<li>Why must fprintf(stderr, ...), rather than apr_file_printf(err, ...), be used on Win32 in cgi_log() of src/apreq_env.c?</li></ul>
+<p>
+<ul>
+<li>Get env/ (Apache::Test) tests to work for --with-apache2-src option. Also add a test to configure that prevents simultaneous use of --with-apache2-src and --with-apache2-apxs.</li></ul>
+<p>
+<ul>
+<li>symbol exports files:<ol type=a>
+<li>aix needs .exp files</li></ol>
+</li></ul>
+<p>
+<ul>
+<li>Install the html dox during "make install". Should we do this for the doxy manpages also?</li></ul>
+<p>
+<ul>
+<li>Rework glue/perl build system to use apreq2-config instead of relying on paths like "../../src".</li></ul>
+<p>
+OPEN ISSUES:<p>
+<ul>
+<li>Should we bundle an apr-based "application/xml" parser? If so, how should we parse the xml data into an apr_table?</li></ul>
+<p>
+BUGS:<p>
+<ul>
+<li>Fix build automake/libtool/autoconf build system so it works properly on OSX &amp; AIX.</li></ul>
+<p>
+WISH LIST:<p>
+<ul>
+<li>I [joes] wish folks would contribute some glue code for one of these:</li></ul>
+<p>
+<ul>
+<li>php,</li><li>Rivet,</li><li>mod_dtcl,</li><li>mod_python,</li><li>mod_jk,</li><li>tomcat,</li><li>mod_ruby,</li><li>mod_parrot. </li></ul>
+</div>
+<div id="footer">
+<p class="apache">
+Copyright &copy; 2003-2006 <a href="http://www.apache.org">The Apache Software Foundation</a>.<br/>
+See <a href="apreq_license.html">LICENSE</a>.</p>
+<p class="menu">
+<span style="color:#aaa">page generated by <a href="http://www.doxygen.org/"><code>doxygen</code></a>
+version 1.5.6 on 3 Dec 2010</span>
+</p>
+</div>
+</body>
+</html>

Added: websites/staging/httpd/trunk/content/apreq/docs/libapreq2/dir_000000.html
==============================================================================
--- websites/staging/httpd/trunk/content/apreq/docs/libapreq2/dir_000000.html (added)
+++ websites/staging/httpd/trunk/content/apreq/docs/libapreq2/dir_000000.html Sun May  6 14:18:02 2012
@@ -0,0 +1,75 @@
+<html>
+<head>
+  <link rel="stylesheet" type="text/css" href="dox.css" />
+  <title>libapreq2-2.06-dev: libapreq2: include/ Directory Reference</title> 
+</head>
+<body>
+<div id="page-header">
+<p class="menu">
+   <a href="http://www.apache.org/">Apache Software Foundation</a> &gt; <a href="http://httpd.apache.org">HTTP Server Project</a> &gt;
+<a href="http://httpd.apache.org/apreq/">Request Library Subproject</a></p>
+<p class="apache">Apache HTTP Server Request Library</p>
+<img alt="" src="feather.gif" /></div>
+<!-- Generated by Doxygen 1.4.3-20050530 -->
+<div class="qindex"><a class="qindex" href="index.html">Main&nbsp;Page</a> | <a class="qindex" href="modules.html">Modules</a> | <a class="qindex" href="annotated.html">Data&nbsp;Structures</a> | <a class="qindex" href="dirs.html">Directories</a> | <a class="qindex" href="files.html">File&nbsp;List</a> | <a class="qindex" href="functions.html">Data&nbsp;Fields</a> | <a class="qindex" href="globals.html">Globals</a> | <a class="qindex" href="pages.html">Related&nbsp;Pages</a></div>
+<div class="nav">
+<a class="el" href="dir_000000.html">include</a></div>
+<h1>include Directory Reference</h1><table border="0" cellpadding="0" cellspacing="0">
+<tr><td></td></tr>
+<tr><td colspan="2"><br><h2>Files</h2></td></tr>
+<tr><td class="memItemLeft" nowrap align="right" valign="top">file &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="apreq_8h.html">apreq.h</a> <a href="apreq_8h-source.html">[code]</a></td></tr>
+
+<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Main header file...<p>
+Define the generic APREQ_ macros and common data structures. <br></td></tr>
+
+<p>
+<tr><td class="memItemLeft" nowrap align="right" valign="top">file &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="apreq__cookie_8h.html">apreq_cookie.h</a> <a href="apreq__cookie_8h-source.html">[code]</a></td></tr>
+
+<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Cookies and Jars.<p>
+<a class="el" href="apreq__cookie_8h.html">apreq_cookie.h</a> describes a common server-side API for request (incoming) and response (outgoing) cookies. It aims towards compliance with the standard cookie specifications listed below. <br></td></tr>
+
+<p>
+<tr><td class="memItemLeft" nowrap align="right" valign="top">file &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="apreq__error_8h.html">apreq_error.h</a> <a href="apreq__error_8h-source.html">[code]</a></td></tr>
+
+<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Error status codes.<p>
+Define the APREQ_ error codes. <br></td></tr>
+
+<p>
+<tr><td class="memItemLeft" nowrap align="right" valign="top">file &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="apreq__module_8h.html">apreq_module.h</a> <a href="apreq__module_8h-source.html">[code]</a></td></tr>
+
+<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Module API. <br></td></tr>
+
+<p>
+<tr><td class="memItemLeft" nowrap align="right" valign="top">file &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="apreq__param_8h.html">apreq_param.h</a> <a href="apreq__param_8h-source.html">[code]</a></td></tr>
+
+<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Request parsing and parameter API. <br></td></tr>
+
+<p>
+<tr><td class="memItemLeft" nowrap align="right" valign="top">file &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="apreq__parser_8h.html">apreq_parser.h</a> <a href="apreq__parser_8h-source.html">[code]</a></td></tr>
+
+<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Request body parser API. <br></td></tr>
+
+<p>
+<tr><td class="memItemLeft" nowrap align="right" valign="top">file &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="apreq__util_8h.html">apreq_util.h</a> <a href="apreq__util_8h-source.html">[code]</a></td></tr>
+
+<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Utility functions for apreq. <br></td></tr>
+
+<p>
+<tr><td class="memItemLeft" nowrap align="right" valign="top">file &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="apreq__version_8h.html">apreq_version.h</a> <a href="apreq__version_8h-source.html">[code]</a></td></tr>
+
+<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Versioning API for libapreq<p>
+There are several different mechanisms for accessing the version. There is a string form, and a set of numbers; in addition, there are constants which can be compiled into your application, and you can query the library being used for its actual version. <br></td></tr>
+
+<p>
+</table>
+<div id="footer">
+<p class="apache">
+Copyright &copy; 2003-2005 <a href="http://www.apache.org">The Apache Software Foundation</a>.<br/>
+See <a href="apreq_license.html">LICENSE</a>.</p>
+<p class="menu">
+<span style="color:#aaa">page generated by <a href="http://www.doxygen.org/"><code>doxygen</code></a>
+version 1.4.3-20050530 on 19 Jul 2005</span>
+</p>
+</div>
+</body>
+</html>

Added: websites/staging/httpd/trunk/content/apreq/docs/libapreq2/dir_000001.html
==============================================================================
--- websites/staging/httpd/trunk/content/apreq/docs/libapreq2/dir_000001.html (added)
+++ websites/staging/httpd/trunk/content/apreq/docs/libapreq2/dir_000001.html Sun May  6 14:18:02 2012
@@ -0,0 +1,35 @@
+<html>
+<head>
+  <link rel="stylesheet" type="text/css" href="dox.css" />
+  <title>libapreq2-2.06-dev: libapreq2: module/ Directory Reference</title> 
+</head>
+<body>
+<div id="page-header">
+<p class="menu">
+   <a href="http://www.apache.org/">Apache Software Foundation</a> &gt; <a href="http://httpd.apache.org">HTTP Server Project</a> &gt;
+<a href="http://httpd.apache.org/apreq/">Request Library Subproject</a></p>
+<p class="apache">Apache HTTP Server Request Library</p>
+<img alt="" src="feather.gif" /></div>
+<!-- Generated by Doxygen 1.4.3-20050530 -->
+<div class="qindex"><a class="qindex" href="index.html">Main&nbsp;Page</a> | <a class="qindex" href="modules.html">Modules</a> | <a class="qindex" href="annotated.html">Data&nbsp;Structures</a> | <a class="qindex" href="dirs.html">Directories</a> | <a class="qindex" href="files.html">File&nbsp;List</a> | <a class="qindex" href="functions.html">Data&nbsp;Fields</a> | <a class="qindex" href="globals.html">Globals</a> | <a class="qindex" href="pages.html">Related&nbsp;Pages</a></div>
+<div class="nav">
+<a class="el" href="dir_000001.html">module</a></div>
+<h1>module Directory Reference</h1><table border="0" cellpadding="0" cellspacing="0">
+<tr><td></td></tr>
+<tr><td colspan="2"><br><h2>Directories</h2></td></tr>
+<tr><td class="memItemLeft" nowrap align="right" valign="top">directory &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_000002.html">apache</a></td></tr>
+
+<tr><td class="memItemLeft" nowrap align="right" valign="top">directory &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_000003.html">apache2</a></td></tr>
+
+</table>
+<div id="footer">
+<p class="apache">
+Copyright &copy; 2003-2005 <a href="http://www.apache.org">The Apache Software Foundation</a>.<br/>
+See <a href="apreq_license.html">LICENSE</a>.</p>
+<p class="menu">
+<span style="color:#aaa">page generated by <a href="http://www.doxygen.org/"><code>doxygen</code></a>
+version 1.4.3-20050530 on 19 Jul 2005</span>
+</p>
+</div>
+</body>
+</html>

Added: websites/staging/httpd/trunk/content/apreq/docs/libapreq2/dir_000002.html
==============================================================================
--- websites/staging/httpd/trunk/content/apreq/docs/libapreq2/dir_000002.html (added)
+++ websites/staging/httpd/trunk/content/apreq/docs/libapreq2/dir_000002.html Sun May  6 14:18:02 2012
@@ -0,0 +1,33 @@
+<html>
+<head>
+  <link rel="stylesheet" type="text/css" href="dox.css" />
+  <title>libapreq2-2.06-dev: libapreq2: module/apache/ Directory Reference</title> 
+</head>
+<body>
+<div id="page-header">
+<p class="menu">
+   <a href="http://www.apache.org/">Apache Software Foundation</a> &gt; <a href="http://httpd.apache.org">HTTP Server Project</a> &gt;
+<a href="http://httpd.apache.org/apreq/">Request Library Subproject</a></p>
+<p class="apache">Apache HTTP Server Request Library</p>
+<img alt="" src="feather.gif" /></div>
+<!-- Generated by Doxygen 1.4.3-20050530 -->
+<div class="qindex"><a class="qindex" href="index.html">Main&nbsp;Page</a> | <a class="qindex" href="modules.html">Modules</a> | <a class="qindex" href="annotated.html">Data&nbsp;Structures</a> | <a class="qindex" href="dirs.html">Directories</a> | <a class="qindex" href="files.html">File&nbsp;List</a> | <a class="qindex" href="functions.html">Data&nbsp;Fields</a> | <a class="qindex" href="globals.html">Globals</a> | <a class="qindex" href="pages.html">Related&nbsp;Pages</a></div>
+<div class="nav">
+<a class="el" href="dir_000001.html">module</a>&nbsp;&raquo&nbsp;<a class="el" href="dir_000002.html">apache</a></div>
+<h1>apache Directory Reference</h1><table border="0" cellpadding="0" cellspacing="0">
+<tr><td></td></tr>
+<tr><td colspan="2"><br><h2>Files</h2></td></tr>
+<tr><td class="memItemLeft" nowrap align="right" valign="top">file &nbsp;</td><td class="memItemRight" valign="bottom"><b>apreq_module_apache.h</b> <a href="apreq__module__apache_8h-source.html">[code]</a></td></tr>
+
+</table>
+<div id="footer">
+<p class="apache">
+Copyright &copy; 2003-2005 <a href="http://www.apache.org">The Apache Software Foundation</a>.<br/>
+See <a href="apreq_license.html">LICENSE</a>.</p>
+<p class="menu">
+<span style="color:#aaa">page generated by <a href="http://www.doxygen.org/"><code>doxygen</code></a>
+version 1.4.3-20050530 on 19 Jul 2005</span>
+</p>
+</div>
+</body>
+</html>

Added: websites/staging/httpd/trunk/content/apreq/docs/libapreq2/dir_000003.html
==============================================================================
--- websites/staging/httpd/trunk/content/apreq/docs/libapreq2/dir_000003.html (added)
+++ websites/staging/httpd/trunk/content/apreq/docs/libapreq2/dir_000003.html Sun May  6 14:18:02 2012
@@ -0,0 +1,33 @@
+<html>
+<head>
+  <link rel="stylesheet" type="text/css" href="dox.css" />
+  <title>libapreq2-2.06-dev: libapreq2: module/apache2/ Directory Reference</title> 
+</head>
+<body>
+<div id="page-header">
+<p class="menu">
+   <a href="http://www.apache.org/">Apache Software Foundation</a> &gt; <a href="http://httpd.apache.org">HTTP Server Project</a> &gt;
+<a href="http://httpd.apache.org/apreq/">Request Library Subproject</a></p>
+<p class="apache">Apache HTTP Server Request Library</p>
+<img alt="" src="feather.gif" /></div>
+<!-- Generated by Doxygen 1.4.3-20050530 -->
+<div class="qindex"><a class="qindex" href="index.html">Main&nbsp;Page</a> | <a class="qindex" href="modules.html">Modules</a> | <a class="qindex" href="annotated.html">Data&nbsp;Structures</a> | <a class="qindex" href="dirs.html">Directories</a> | <a class="qindex" href="files.html">File&nbsp;List</a> | <a class="qindex" href="functions.html">Data&nbsp;Fields</a> | <a class="qindex" href="globals.html">Globals</a> | <a class="qindex" href="pages.html">Related&nbsp;Pages</a></div>
+<div class="nav">
+<a class="el" href="dir_000001.html">module</a>&nbsp;&raquo&nbsp;<a class="el" href="dir_000003.html">apache2</a></div>
+<h1>apache2 Directory Reference</h1><table border="0" cellpadding="0" cellspacing="0">
+<tr><td></td></tr>
+<tr><td colspan="2"><br><h2>Files</h2></td></tr>
+<tr><td class="memItemLeft" nowrap align="right" valign="top">file &nbsp;</td><td class="memItemRight" valign="bottom"><b>apreq_module_apache2.h</b> <a href="apreq__module__apache2_8h-source.html">[code]</a></td></tr>
+
+</table>
+<div id="footer">
+<p class="apache">
+Copyright &copy; 2003-2005 <a href="http://www.apache.org">The Apache Software Foundation</a>.<br/>
+See <a href="apreq_license.html">LICENSE</a>.</p>
+<p class="menu">
+<span style="color:#aaa">page generated by <a href="http://www.doxygen.org/"><code>doxygen</code></a>
+version 1.4.3-20050530 on 19 Jul 2005</span>
+</p>
+</div>
+</body>
+</html>

Added: websites/staging/httpd/trunk/content/apreq/docs/libapreq2/dirs.html
==============================================================================
--- websites/staging/httpd/trunk/content/apreq/docs/libapreq2/dirs.html (added)
+++ websites/staging/httpd/trunk/content/apreq/docs/libapreq2/dirs.html Sun May  6 14:18:02 2012
@@ -0,0 +1,33 @@
+<html>
+<head>
+  <link rel="stylesheet" type="text/css" href="dox.css" />
+  <title>libapreq2-2.06-dev: libapreq2: Directory Hierarchy</title> 
+</head>
+<body>
+<div id="page-header">
+<p class="menu">
+   <a href="http://www.apache.org/">Apache Software Foundation</a> &gt; <a href="http://httpd.apache.org">HTTP Server Project</a> &gt;
+<a href="http://httpd.apache.org/apreq/">Request Library Subproject</a></p>
+<p class="apache">Apache HTTP Server Request Library</p>
+<img alt="" src="feather.gif" /></div>
+<!-- Generated by Doxygen 1.4.3-20050530 -->
+<div class="qindex"><a class="qindex" href="index.html">Main&nbsp;Page</a> | <a class="qindex" href="modules.html">Modules</a> | <a class="qindex" href="annotated.html">Data&nbsp;Structures</a> | <a class="qindexHL" href="dirs.html">Directories</a> | <a class="qindex" href="files.html">File&nbsp;List</a> | <a class="qindex" href="functions.html">Data&nbsp;Fields</a> | <a class="qindex" href="globals.html">Globals</a> | <a class="qindex" href="pages.html">Related&nbsp;Pages</a></div>
+<h1>libapreq2 Directories</h1>This directory hierarchy is sorted roughly, but not completely, alphabetically:<ul>
+<li><a class="el" href="dir_000000.html">include</a>
+<li><a class="el" href="dir_000001.html">module</a>
+<ul>
+<li><a class="el" href="dir_000002.html">apache</a>
+<li><a class="el" href="dir_000003.html">apache2</a>
+</ul>
+</ul>
+<div id="footer">
+<p class="apache">
+Copyright &copy; 2003-2005 <a href="http://www.apache.org">The Apache Software Foundation</a>.<br/>
+See <a href="apreq_license.html">LICENSE</a>.</p>
+<p class="menu">
+<span style="color:#aaa">page generated by <a href="http://www.doxygen.org/"><code>doxygen</code></a>
+version 1.4.3-20050530 on 19 Jul 2005</span>
+</p>
+</div>
+</body>
+</html>