Apache Portable Runtime
 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
apr_errno.h
Go to the documentation of this file.
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 #ifndef APR_ERRNO_H
18 #define APR_ERRNO_H
19 
20 /**
21  * @file apr_errno.h
22  * @brief APR Error Codes
23  */
24 
25 #include "apr.h"
26 
27 #if APR_HAVE_ERRNO_H
28 #include <errno.h>
29 #endif
30 
31 #ifdef __cplusplus
32 extern "C" {
33 #endif /* __cplusplus */
34 
35 /**
36  * @defgroup apr_errno Error Codes
37  * @ingroup APR
38  * @{
39  */
40 
41 /**
42  * Type for specifying an error or status code.
43  */
44 typedef int apr_status_t;
45 
46 /**
47  * Return a human readable string describing the specified error.
48  * @param statcode The error code the get a string for.
49  * @param buf A buffer to hold the error string.
50  * @param bufsize Size of the buffer to hold the string.
51  */
52 APR_DECLARE(char *) apr_strerror(apr_status_t statcode, char *buf,
53  apr_size_t bufsize);
54 
55 #if defined(DOXYGEN)
56 /**
57  * @def APR_FROM_OS_ERROR(os_err_type syserr)
58  * Fold a platform specific error into an apr_status_t code.
59  * @return apr_status_t
60  * @param e The platform os error code.
61  * @warning macro implementation; the syserr argument may be evaluated
62  * multiple times.
63  */
64 #define APR_FROM_OS_ERROR(e) (e == 0 ? APR_SUCCESS : e + APR_OS_START_SYSERR)
65 
66 /**
67  * @def APR_TO_OS_ERROR(apr_status_t statcode)
68  * @return os_err_type
69  * Fold an apr_status_t code back to the native platform defined error.
70  * @param e The apr_status_t folded platform os error code.
71  * @warning macro implementation; the statcode argument may be evaluated
72  * multiple times. If the statcode was not created by apr_get_os_error
73  * or APR_FROM_OS_ERROR, the results are undefined.
74  */
75 #define APR_TO_OS_ERROR(e) (e == 0 ? APR_SUCCESS : e - APR_OS_START_SYSERR)
76 
77 /** @def apr_get_os_error()
78  * @return apr_status_t the last platform error, folded into apr_status_t, on most platforms
79  * @remark This retrieves errno, or calls a GetLastError() style function, and
80  * folds it with APR_FROM_OS_ERROR. Some platforms (such as OS2) have no
81  * such mechanism, so this call may be unsupported. Do NOT use this
82  * call for socket errors from socket, send, recv etc!
83  */
84 
85 /** @def apr_set_os_error(e)
86  * Reset the last platform error, unfolded from an apr_status_t, on some platforms
87  * @param e The OS error folded in a prior call to APR_FROM_OS_ERROR()
88  * @warning This is a macro implementation; the statcode argument may be evaluated
89  * multiple times. If the statcode was not created by apr_get_os_error
90  * or APR_FROM_OS_ERROR, the results are undefined. This macro sets
91  * errno, or calls a SetLastError() style function, unfolding statcode
92  * with APR_TO_OS_ERROR. Some platforms (such as OS2) have no such
93  * mechanism, so this call may be unsupported.
94  */
95 
96 /** @def apr_get_netos_error()
97  * Return the last socket error, folded into apr_status_t, on all platforms
98  * @remark This retrieves errno or calls a GetLastSocketError() style function,
99  * and folds it with APR_FROM_OS_ERROR.
100  */
101 
102 /** @def apr_set_netos_error(e)
103  * Reset the last socket error, unfolded from an apr_status_t
104  * @param e The socket error folded in a prior call to APR_FROM_OS_ERROR()
105  * @warning This is a macro implementation; the statcode argument may be evaluated
106  * multiple times. If the statcode was not created by apr_get_os_error
107  * or APR_FROM_OS_ERROR, the results are undefined. This macro sets
108  * errno, or calls a WSASetLastError() style function, unfolding
109  * socketcode with APR_TO_OS_ERROR.
110  */
111 
112 #endif /* defined(DOXYGEN) */
113 
114 /**
115  * APR_OS_START_ERROR is where the APR specific error values start.
116  */
117 #define APR_OS_START_ERROR 20000
118 /**
119  * APR_OS_ERRSPACE_SIZE is the maximum number of errors you can fit
120  * into one of the error/status ranges below -- except for
121  * APR_OS_START_USERERR, which see.
122  */
123 #define APR_OS_ERRSPACE_SIZE 50000
124 /**
125  * APR_UTIL_ERRSPACE_SIZE is the size of the space that is reserved for
126  * use within apr-util. This space is reserved above that used by APR
127  * internally.
128  * @note This number MUST be smaller than APR_OS_ERRSPACE_SIZE by a
129  * large enough amount that APR has sufficient room for it's
130  * codes.
131  */
132 #define APR_UTIL_ERRSPACE_SIZE 20000
133 /**
134  * APR_OS_START_STATUS is where the APR specific status codes start.
135  */
136 #define APR_OS_START_STATUS (APR_OS_START_ERROR + APR_OS_ERRSPACE_SIZE)
137 /**
138  * APR_UTIL_START_STATUS is where APR-Util starts defining it's
139  * status codes.
140  */
141 #define APR_UTIL_START_STATUS (APR_OS_START_STATUS + \
142  (APR_OS_ERRSPACE_SIZE - APR_UTIL_ERRSPACE_SIZE))
143 /**
144  * APR_OS_START_USERERR are reserved for applications that use APR that
145  * layer their own error codes along with APR's. Note that the
146  * error immediately following this one is set ten times farther
147  * away than usual, so that users of apr have a lot of room in
148  * which to declare custom error codes.
149  *
150  * In general applications should try and create unique error codes. To try
151  * and assist in finding suitable ranges of numbers to use, the following
152  * ranges are known to be used by the listed applications. If your
153  * application defines error codes please advise the range of numbers it
154  * uses to dev@apr.apache.org for inclusion in this list.
155  *
156  * Ranges shown are in relation to APR_OS_START_USERERR
157  *
158  * Subversion - Defined ranges, of less than 100, at intervals of 5000
159  * starting at an offset of 5000, e.g.
160  * +5000 to 5100, +10000 to 10100
161  *
162  * Apache HTTPD - +2000 to 2999
163  */
164 #define APR_OS_START_USERERR (APR_OS_START_STATUS + APR_OS_ERRSPACE_SIZE)
165 /**
166  * APR_OS_START_USEERR is obsolete, defined for compatibility only.
167  * Use APR_OS_START_USERERR instead.
168  */
169 #define APR_OS_START_USEERR APR_OS_START_USERERR
170 /**
171  * APR_OS_START_CANONERR is where APR versions of errno values are defined
172  * on systems which don't have the corresponding errno.
173  */
174 #define APR_OS_START_CANONERR (APR_OS_START_USERERR \
175  + (APR_OS_ERRSPACE_SIZE * 10))
176 /**
177  * APR_OS_START_EAIERR folds EAI_ error codes from getaddrinfo() into
178  * apr_status_t values.
179  */
180 #define APR_OS_START_EAIERR (APR_OS_START_CANONERR + APR_OS_ERRSPACE_SIZE)
181 /**
182  * APR_OS_START_SYSERR folds platform-specific system error values into
183  * apr_status_t values.
184  */
185 #define APR_OS_START_SYSERR (APR_OS_START_EAIERR + APR_OS_ERRSPACE_SIZE)
186 
187 /**
188  * @defgroup APR_ERROR_map APR Error Space
189  * <PRE>
190  * The following attempts to show the relation of the various constants
191  * used for mapping APR Status codes.
192  *
193  * 0