]> granicus.if.org Git - apache/blob - include/ap_mmn.h
Change common but incorrect usage of 'depreciated'
[apache] / include / ap_mmn.h
1 /* Licensed to the Apache Software Foundation (ASF) under one or more
2  * contributor license agreements.  See the NOTICE file distributed with
3  * this work for additional information regarding copyright ownership.
4  * The ASF licenses this file to You under the Apache License, Version 2.0
5  * (the "License"); you may not use this file except in compliance with
6  * the License.  You may obtain a copy of the License at
7  *
8  *     http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 /**
18  * @file  ap_mpm.h
19  * @brief Module Magic Number
20  *
21  * @defgroup APACHE_CORE_MMN Module Magic Number
22  * @ingroup  APACHE_CORE
23  * @{
24  */
25
26 #ifndef APACHE_AP_MMN_H
27 #define APACHE_AP_MMN_H
28
29 /*
30  * MODULE_MAGIC_NUMBER_MAJOR
31  * Major API changes that could cause compatibility problems for older modules
32  * such as structure size changes.  No binary compatibility is possible across
33  * a change in the major version.
34  *
35  * MODULE_MAGIC_NUMBER_MINOR
36  * Minor API changes that do not cause binary compatibility problems.
37  * Should be reset to 0 when upgrading MODULE_MAGIC_NUMBER_MAJOR.
38  *
39  * See the MODULE_MAGIC_AT_LEAST macro below for an example.
40  */
41
42 /*
43  * 20010224   (2.0.13-dev) MODULE_MAGIC_COOKIE reset to "AP20"
44  * 20010523   (2.0.19-dev) bump for scoreboard structure reordering
45  * 20010627   (2.0.19-dev) more API changes than I can count
46  * 20010726   (2.0.22-dev) more big API changes
47  * 20010808   (2.0.23-dev) dir d_is_absolute bit introduced, bucket changes, etc
48  * 20010825   (2.0.25-dev) removed d_is_absolute, introduced map_to_storage hook
49  * 20011002   (2.0.26-dev) removed 1.3-deprecated request_rec.content_language
50  * 20011127   (2.0.29-dev) bump for postconfig hook change, and removal of
51  *                         socket from connection record
52  * 20011212   (2.0.30-dev) bump for new used_path_info member of request_rec
53  * 20011218   (2.0.30-dev) bump for new sbh member of conn_rec, different
54  *                         declarations for scoreboard, new parameter to
55  *                         create_connection hook
56  * 20020102   (2.0.30-dev) bump for changed type of limit_req_body in
57  *                         core_dir_config
58  * 20020109   (2.0.31-dev) bump for changed shm and scoreboard declarations
59  * 20020111   (2.0.31-dev) bump for ETag fields added at end of cor_dir_config
60  * 20020114   (2.0.31-dev) mod_dav changed how it asks its provider to fulfill
61  *                         a GET request
62  * 20020118   (2.0.31-dev) Input filtering split of blocking and mode
63  * 20020127   (2.0.31-dev) bump for pre_mpm hook change
64  * 20020128   (2.0.31-dev) bump for pre_config hook change
65  * 20020218   (2.0.33-dev) bump for AddOutputFilterByType directive
66  * 20020220   (2.0.33-dev) bump for scoreboard.h structure change
67  * 20020302   (2.0.33-dev) bump for protocol_filter additions.
68  * 20020306   (2.0.34-dev) bump for filter type renames.
69  * 20020318   (2.0.34-dev) mod_dav's API for REPORT generation changed
70  * 20020319   (2.0.34-dev) M_INVALID changed, plus new M_* methods for RFC 3253
71  * 20020327   (2.0.35-dev) Add parameter to quick_handler hook
72  * 20020329   (2.0.35-dev) bump for addition of freelists to bucket API
73  * 20020329.1 (2.0.36)     minor bump for new arg to opt fn ap_cgi_build_command
74  * 20020506   (2.0.37-dev) Removed r->boundary in request_rec.
75  * 20020529   (2.0.37-dev) Standardized the names of some apr_pool_*_set funcs
76  * 20020602   (2.0.37-dev) Bucket API change (metadata buckets)
77  * 20020612   (2.0.38-dev) Changed server_rec->[keep_alive_]timeout to apr time
78  * 20020625   (2.0.40-dev) Changed conn_rec->keepalive to an enumeration
79  * 20020628   (2.0.40-dev) Added filter_init to filter registration functions
80  * 20020903   (2.0.41-dev) APR's error constants changed
81  * 20020903.1 (2.1.0-dev)  allow_encoded_slashes added to core_dir_config
82  * 20020903.2 (2.0.46-dev) add ap_escape_logitem
83  * 20030213.1 (2.1.0-dev)  changed log_writer optional fn's to return previous
84  *                         handler
85  * 20030821   (2.1.0-dev)  bumped mod_include's entire API
86  * 20030821.1 (2.1.0-dev)  added XHTML doctypes
87  * 20030821.2 (2.1.0-dev)  added ap_escape_errorlog_item
88  * 20030821.3 (2.1.0-dev)  added ap_get_server_revision / ap_version_t
89  * 20040425   (2.1.0-dev)  removed ap_add_named_module API
90  *                         changed ap_add_module, ap_add_loaded_module,
91  *                         ap_setup_prelinked_modules,
92  *                         ap_process_resource_config
93  * 20040425.1 (2.1.0-dev)  Added ap_module_symbol_t and
94  *                         ap_prelinked_module_symbols
95  * 20050101.0 (2.1.2-dev)  Axed misnamed http_method for http_scheme
96  *                         (which it was!)
97  * 20050127.0 (2.1.3-dev)  renamed regex_t->ap_regex_t,
98  *                         regmatch_t->ap_regmatch_t, REG_*->AP_REG_*,
99  *                         removed reg* in place of ap_reg*; added ap_regex.h
100  * 20050217.0 (2.1.3-dev)  Axed find_child_by_pid, mpm_*_completion_context
101  *                         (winnt mpm) symbols from the public sector, and
102  *                         decorated real_exit_code with ap_ in the win32/os.h.
103  * 20050305.0 (2.1.4-dev)  added pid and generation fields to worker_score
104  * 20050305.1 (2.1.5-dev)  added ap_vhost_iterate_given_conn.
105  * 20050305.2 (2.1.5-dev)  added AP_INIT_TAKE_ARGV.
106  * 20050305.3 (2.1.5-dev)  added Protocol Framework.
107  * 20050701.0 (2.1.7-dev)  Bump MODULE_MAGIC_COOKIE to "AP21"!
108  * 20050701.1 (2.1.7-dev)  trace_enable member added to core server_config
109  * 20050708.0 (2.1.7-dev)  Bump MODULE_MAGIC_COOKIE to "AP22"!
110  * 20050708.1 (2.1.7-dev)  add proxy request_status hook (minor)
111  * 20050919.0 (2.1.8-dev)  mod_ssl ssl_ext_list optional function added
112  * 20051005.0 (2.1.8-dev)  NET_TIME filter eliminated
113  * 20051005.0 (2.3.0-dev)  Bump MODULE_MAGIC_COOKIE to "AP24"!
114  * 20051115.0 (2.3.0-dev)  Added use_canonical_phys_port to core_dir_config
115  * 20060110.0 (2.3.0-dev)  Conversion of Authz to be provider based
116  *                         addition of <SatisfyAll><SatisfyOne>
117  *                         removal of Satisfy, Allow, Deny, Order
118  * 20060110.1 (2.3.0-dev)  minex and minex_set members added to
119  *                         cache_server_conf (minor)
120  * 20060110.2 (2.3.0-dev)  flush_packets and flush_wait members added to
121  *                         proxy_server (minor)
122  * 20060110.3 (2.3.0-dev)  added inreslist member to proxy_conn_rec (minor)
123  * 20060110.4 (2.3.0-dev)  Added server_scheme member to server_rec (minor)
124  * 20060905.0 (2.3.0-dev)  Replaced ap_get_server_version() with
125  *                         ap_get_server_banner() and ap_get_server_description()
126  * 20060905.1 (2.3.0-dev)  Enable retry=0 for the worker (minor)
127  * 20060905.2 (2.3.0-dev)  Added ap_all_available_mutexes_string,
128  *                         ap_available_mutexes_string and
129  *                         ap_parse_mutex()
130  *
131  */
132
133 #define MODULE_MAGIC_COOKIE 0x41503234UL /* "AP24" */
134
135 #ifndef MODULE_MAGIC_NUMBER_MAJOR
136 #define MODULE_MAGIC_NUMBER_MAJOR 20060905
137 #endif
138 #define MODULE_MAGIC_NUMBER_MINOR 2                    /* 0...n */
139
140 /**
141  * Determine if the server's current MODULE_MAGIC_NUMBER is at least a
142  * specified value.
143  * <pre>
144  * Useful for testing for features.
145  * For example, suppose you wish to use the apr_table_overlap
146  *    function.  You can do this:
147  * 
148  * #if AP_MODULE_MAGIC_AT_LEAST(19980812,2)
149  *     ... use apr_table_overlap()
150  * #else
151  *     ... alternative code which doesn't use apr_table_overlap()
152  * #endif
153  * </pre>
154  * @param major The major module magic number
155  * @param minor The minor module magic number
156  * @deffunc AP_MODULE_MAGIC_AT_LEAST(int major, int minor)
157  */
158 #define AP_MODULE_MAGIC_AT_LEAST(major,minor)           \
159     ((major) < MODULE_MAGIC_NUMBER_MAJOR                \
160         || ((major) == MODULE_MAGIC_NUMBER_MAJOR        \
161             && (minor) <= MODULE_MAGIC_NUMBER_MINOR))
162
163 /** @deprecated present for backwards compatibility */
164 #define MODULE_MAGIC_NUMBER MODULE_MAGIC_NUMBER_MAJOR
165 #define MODULE_MAGIC_AT_LEAST old_broken_macro_we_hope_you_are_not_using
166
167 #endif /* !APACHE_AP_MMN_H */
168 /** @} */