The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

NAME

Apache::*::Table - Table classes for Apache::Request, Apache::Upload, and Apache::Cookie.

SYNOPSIS

    my $table = Apache::Request::Table->new($r);
    $table->{test} = 1;
    $table->{foo} = "bar1";
    $table->add(foo => "bar2");

    {
        my $do_data = "";
        $table->do( sub { $do_data .= "@_,"; 1 } );
        ok $do_data eq "test 1,foo bar1,foo bar2,";
    }

DESCRIPTION

This manpage documents the Apache::*::Table classes provided by the Apache::Request, Apache::Upload, and Apache::Cookie modules. Table classes are all derived from APR::Table, however since the underlying values they contain are not simple character arrays, the merge, compress, and overlap methods from APR::Table are not implemented.

Apache::Request::Table

These tables arise as parameter tables generated by the args, body, and param methods of Apache::Request. Their values are representable by orinary perl scalars, but unlike APR::Table, the '\0' character may be safely embedded in a value without truncating it.

    my $table = Apache::Request::Table->new($r);
    my $value = "bar\0quux";
    $table->{foo} = $value;

Apache::Upload::Table

These tables arise from the Apache::Request::upload method (which is provided by Apache::Upload). Their values are Apache::Upload objects.

    my $upload = Apache::Upload->new($r, name => "foo", file => __FILE__);
    my $table = Apache::Upload::Table->new($r);
    $table->add($upload);
    $upload = $table->{foo};

Apache::Cookie::Table

These tables arise from the cookies method of Apache::Cookie::Jar, and their values are Apache::Cookie objects (or Apache::Cookie derived objects- see the discussion of VALUE_CLASS in Apache::Cookie).

    my $cookie = Apache::Cookie->new($r, name =>"foo", value => "bar");
    my $table = Apache::Cookie::Table->new($r);
    $table->{foo} = $cookie;
    $cookie = $table->{foo};

SEE ALSO

Apache::Request, Apache::Cookie, Apache::Upload APR::Table(3)

COPYRIGHT

  Copyright 2003-2004  The Apache Software Foundation

  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.