summaryrefslogtreecommitdiff
path: root/packages/httpd22/src/util_cfgtree.inc
blob: f989ce7a5e6114da6d9dc6a63a73fd711d4fb1ff (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
{ Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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.
 }

{
 * @package Config Tree Package
 }

//#include "ap_config.h"

type
  Pap_directive_t = ^ap_directive_t;
  PPap_directive_t = ^Pap_directive_t;

{
 * Structure used to build the config tree.  The config tree only stores
 * the directives that will be active in the running server.  Directives
 * that contain other directions, such as <Directory ...> cause a sub-level
 * to be created, where the included directives are stored.  The closing
 * directive (</Directory>) is not stored in the tree.
 }
  ap_directive_t = record
    { The current directive }
    directive: PChar;
    { The arguments for the current directive, stored as a space
     *  separated list }
    args: PChar;
    { The next directive node in the tree
     *  @defvar ap_directive_t *next }
    next: Pap_directive_t;
    { The first child node of this directive
     *  @defvar ap_directive_t *first_child }
    first_child: Pap_directive_t;
    { The parent node of this directive
     *  @defvar ap_directive_t *parent }
    parent: Pap_directive_t;

    { directive's module can store add'l data here }
    data: Pointer;

    { ### these may go away in the future, but are needed for now }
    { The name of the file this directive was found in }
    filename: PChar;
    { The line number the directive was on }
    line_num: Integer;
  end;

{
 * The root of the configuration tree
 * @defvar ap_directive_t *conftree
 }
//AP_DECLARE_DATA extern ap_directive_t *ap_conftree;

{
 * Add a node to the configuration tree.
 * @param parent The current parent node.  If the added node is a first_child,
                 then this is changed to the current node
 * @param current The current node
 * @param toadd The node to add to the tree
 * @param child Is the node to add a child node
 * @return the added node
 }
//ap_directive_t *ap_add_node(ap_directive_t **parent, ap_directive_t *current,
//                            ap_directive_t *toadd, int child);