forked from Mirrors/freeswitch
0488a5109a
git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@3733 d0543943-73ff-0310-b7d9-9358b9ac24b2
1235 lines
50 KiB
C
1235 lines
50 KiB
C
/* 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.
|
|
*/
|
|
|
|
#ifndef APR_ERRNO_H
|
|
#define APR_ERRNO_H
|
|
|
|
/**
|
|
* @file apr_errno.h
|
|
* @brief APR Error Codes
|
|
*/
|
|
|
|
#include "apr.h"
|
|
|
|
#if APR_HAVE_ERRNO_H
|
|
#include <errno.h>
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif /* __cplusplus */
|
|
|
|
/**
|
|
* @defgroup apr_errno Error Codes
|
|
* @ingroup APR
|
|
* @{
|
|
*/
|
|
|
|
/**
|
|
* Type for specifying an error or status code.
|
|
*/
|
|
typedef int apr_status_t;
|
|
|
|
/**
|
|
* Return a human readable string describing the specified error.
|
|
* @param statcode The error code the get a string for.
|
|
* @param buf A buffer to hold the error string.
|
|
* @param bufsize Size of the buffer to hold the string.
|
|
*/
|
|
APR_DECLARE(char *) apr_strerror(apr_status_t statcode, char *buf,
|
|
apr_size_t bufsize);
|
|
|
|
#if defined(DOXYGEN)
|
|
/**
|
|
* @def APR_FROM_OS_ERROR(os_err_type syserr)
|
|
* Fold a platform specific error into an apr_status_t code.
|
|
* @return apr_status_t
|
|
* @param e The platform os error code.
|
|
* @warning macro implementation; the syserr argument may be evaluated
|
|
* multiple times.
|
|
*/
|
|
#define APR_FROM_OS_ERROR(e) (e == 0 ? APR_SUCCESS : e + APR_OS_START_SYSERR)
|
|
|
|
/**
|
|
* @def APR_TO_OS_ERROR(apr_status_t statcode)
|
|
* @return os_err_type
|
|
* Fold an apr_status_t code back to the native platform defined error.
|
|
* @param e The apr_status_t folded platform os error code.
|
|
* @warning macro implementation; the statcode argument may be evaluated
|
|
* multiple times. If the statcode was not created by apr_get_os_error
|
|
* or APR_FROM_OS_ERROR, the results are undefined.
|
|
*/
|
|
#define APR_TO_OS_ERROR(e) (e == 0 ? APR_SUCCESS : e - APR_OS_START_SYSERR)
|
|
|
|
/** @def apr_get_os_error()
|
|
* @return apr_status_t the last platform error, folded into apr_status_t, on most platforms
|
|
* @remark This retrieves errno, or calls a GetLastError() style function, and
|
|
* folds it with APR_FROM_OS_ERROR. Some platforms (such as OS2) have no
|
|
* such mechanism, so this call may be unsupported. Do NOT use this
|
|
* call for socket errors from socket, send, recv etc!
|
|
*/
|
|
|
|
/** @def apr_set_os_error(e)
|
|
* Reset the last platform error, unfolded from an apr_status_t, on some platforms
|
|
* @param e The OS error folded in a prior call to APR_FROM_OS_ERROR()
|
|
* @warning This is a macro implementation; the statcode argument may be evaluated
|
|
* multiple times. If the statcode was not created by apr_get_os_error
|
|
* or APR_FROM_OS_ERROR, the results are undefined. This macro sets
|
|
* errno, or calls a SetLastError() style function, unfolding statcode
|
|
* with APR_TO_OS_ERROR. Some platforms (such as OS2) have no such
|
|
* mechanism, so this call may be unsupported.
|
|
*/
|
|
|
|
/** @def apr_get_netos_error()
|
|
* Return the last socket error, folded into apr_status_t, on all platforms
|
|
* @remark This retrieves errno or calls a GetLastSocketError() style function,
|
|
* and folds it with APR_FROM_OS_ERROR.
|
|
*/
|
|
|
|
/** @def apr_set_netos_error(e)
|
|
* Reset the last socket error, unfolded from an apr_status_t
|
|
* @param e The socket error folded in a prior call to APR_FROM_OS_ERROR()
|
|
* @warning This is a macro implementation; the statcode argument may be evaluated
|
|
* multiple times. If the statcode was not created by apr_get_os_error
|
|
* or APR_FROM_OS_ERROR, the results are undefined. This macro sets
|
|
* errno, or calls a WSASetLastError() style function, unfolding
|
|
* socketcode with APR_TO_OS_ERROR.
|
|
*/
|
|
|
|
#endif /* defined(DOXYGEN) */
|
|
|
|
/**
|
|
* APR_OS_START_ERROR is where the APR specific error values start.
|
|
*/
|
|
#define APR_OS_START_ERROR 20000
|
|
/**
|
|
* APR_OS_ERRSPACE_SIZE is the maximum number of errors you can fit
|
|
* into one of the error/status ranges below -- except for
|
|
* APR_OS_START_USERERR, which see.
|
|
*/
|
|
#define APR_OS_ERRSPACE_SIZE 50000
|
|
/**
|
|
* APR_OS_START_STATUS is where the APR specific status codes start.
|
|
*/
|
|
#define APR_OS_START_STATUS (APR_OS_START_ERROR + APR_OS_ERRSPACE_SIZE)
|
|
/**
|
|
* APR_OS_START_USERERR are reserved for applications that use APR that
|
|
* layer their own error codes along with APR's. Note that the
|
|
* error immediately following this one is set ten times farther
|
|
* away than usual, so that users of apr have a lot of room in
|
|
* which to declare custom error codes.
|
|
*/
|
|
#define APR_OS_START_USERERR (APR_OS_START_STATUS + APR_OS_ERRSPACE_SIZE)
|
|
/**
|
|
* APR_OS_START_USEERR is obsolete, defined for compatibility only.
|
|
* Use APR_OS_START_USERERR instead.
|
|
*/
|
|
#define APR_OS_START_USEERR APR_OS_START_USERERR
|
|
/**
|
|
* APR_OS_START_CANONERR is where APR versions of errno values are defined
|
|
* on systems which don't have the corresponding errno.
|
|
*/
|
|
#define APR_OS_START_CANONERR (APR_OS_START_USERERR \
|
|
+ (APR_OS_ERRSPACE_SIZE * 10))
|
|
/**
|
|
* APR_OS_START_EAIERR folds EAI_ error codes from getaddrinfo() into
|
|
* apr_status_t values.
|
|
*/
|
|
#define APR_OS_START_EAIERR (APR_OS_START_CANONERR + APR_OS_ERRSPACE_SIZE)
|
|
/**
|
|
* APR_OS_START_SYSERR folds platform-specific system error values into
|
|
* apr_status_t values.
|
|
*/
|
|
#define APR_OS_START_SYSERR (APR_OS_START_EAIERR + APR_OS_ERRSPACE_SIZE)
|
|
|
|
/** no error. */
|
|
#define APR_SUCCESS 0
|
|
|
|
/**
|
|
* @defgroup APR_Error APR Error Values
|
|
* <PRE>
|
|
* <b>APR ERROR VALUES</b>
|
|
* APR_ENOSTAT APR was unable to perform a stat on the file
|
|
* APR_ENOPOOL APR was not provided a pool with which to allocate memory
|
|
* APR_EBADDATE APR was given an invalid date
|
|
* APR_EINVALSOCK APR was given an invalid socket
|
|
* APR_ENOPROC APR was not given a process structure
|
|
* APR_ENOTIME APR was not given a time structure
|
|
* APR_ENODIR APR was not given a directory structure
|
|
* APR_ENOLOCK APR was not given a lock structure
|
|
* APR_ENOPOLL APR was not given a poll structure
|
|
* APR_ENOSOCKET APR was not given a socket
|
|
* APR_ENOTHREAD APR was not given a thread structure
|
|
* APR_ENOTHDKEY APR was not given a thread key structure
|
|
* APR_ENOSHMAVAIL There is no more shared memory available
|
|
* APR_EDSOOPEN APR was unable to open the dso object. For more
|
|
* information call apr_dso_error().
|
|
* APR_EGENERAL General failure (specific information not available)
|
|
* APR_EBADIP The specified IP address is invalid
|
|
* APR_EBADMASK The specified netmask is invalid
|
|
* APR_ESYMNOTFOUND Could not find the requested symbol
|
|
* </PRE>
|
|
*
|
|
* <PRE>
|
|
* <b>APR STATUS VALUES</b>
|
|
* APR_INCHILD Program is currently executing in the child
|
|
* APR_INPARENT Program is currently executing in the parent
|
|
* APR_DETACH The thread is detached
|
|
* APR_NOTDETACH The thread is not detached
|
|
* APR_CHILD_DONE The child has finished executing
|
|
* APR_CHILD_NOTDONE The child has not finished executing
|
|
* APR_TIMEUP The operation did not finish before the timeout
|
|
* APR_INCOMPLETE The operation was incomplete although some processing
|
|
* was performed and the results are partially valid
|
|
* APR_BADCH Getopt found an option not in the option string
|
|
* APR_BADARG Getopt found an option that is missing an argument
|
|
* and an argument was specified in the option string
|
|
* APR_EOF APR has encountered the end of the file
|
|
* APR_NOTFOUND APR was unable to find the socket in the poll structure
|
|
* APR_ANONYMOUS APR is using anonymous shared memory
|
|
* APR_FILEBASED APR is using a file name as the key to the shared memory
|
|
* APR_KEYBASED APR is using a shared key as the key to the shared memory
|
|
* APR_EINIT Ininitalizer value. If no option has been found, but
|
|
* the status variable requires a value, this should be used
|
|
* APR_ENOTIMPL The APR function has not been implemented on this
|
|
* platform, either because nobody has gotten to it yet,
|
|
* or the function is impossible on this platform.
|
|
* APR_EMISMATCH Two passwords do not match.
|
|
* APR_EABSOLUTE The given path was absolute.
|
|
* APR_ERELATIVE The given path was relative.
|
|
* APR_EINCOMPLETE The given path was neither relative nor absolute.
|
|
* APR_EABOVEROOT The given path was above the root path.
|
|
* APR_EBUSY The given lock was busy.
|
|
* APR_EPROC_UNKNOWN The given process wasn't recognized by APR
|
|
* </PRE>
|
|
* @{
|
|
*/
|
|
/** @see APR_STATUS_IS_ENOSTAT */
|
|
#define APR_ENOSTAT (APR_OS_START_ERROR + 1)
|
|
/** @see APR_STATUS_IS_ENOPOOL */
|
|
#define APR_ENOPOOL (APR_OS_START_ERROR + 2)
|
|
/* empty slot: +3 */
|
|
/** @see APR_STATUS_IS_EBADDATE */
|
|
#define APR_EBADDATE (APR_OS_START_ERROR + 4)
|
|
/** @see APR_STATUS_IS_EINVALSOCK */
|
|
#define APR_EINVALSOCK (APR_OS_START_ERROR + 5)
|
|
/** @see APR_STATUS_IS_ENOPROC */
|
|
#define APR_ENOPROC (APR_OS_START_ERROR + 6)
|
|
/** @see APR_STATUS_IS_ENOTIME */
|
|
#define APR_ENOTIME (APR_OS_START_ERROR + 7)
|
|
/** @see APR_STATUS_IS_ENODIR */
|
|
#define APR_ENODIR (APR_OS_START_ERROR + 8)
|
|
/** @see APR_STATUS_IS_ENOLOCK */
|
|
#define APR_ENOLOCK (APR_OS_START_ERROR + 9)
|
|
/** @see APR_STATUS_IS_ENOPOLL */
|
|
#define APR_ENOPOLL (APR_OS_START_ERROR + 10)
|
|
/** @see APR_STATUS_IS_ENOSOCKET */
|
|
#define APR_ENOSOCKET (APR_OS_START_ERROR + 11)
|
|
/** @see APR_STATUS_IS_ENOTHREAD */
|
|
#define APR_ENOTHREAD (APR_OS_START_ERROR + 12)
|
|
/** @see APR_STATUS_IS_ENOTHDKEY */
|
|
#define APR_ENOTHDKEY (APR_OS_START_ERROR + 13)
|
|
/** @see APR_STATUS_IS_EGENERAL */
|
|
#define APR_EGENERAL (APR_OS_START_ERROR + 14)
|
|
/** @see APR_STATUS_IS_ENOSHMAVAIL */
|
|
#define APR_ENOSHMAVAIL (APR_OS_START_ERROR + 15)
|
|
/** @see APR_STATUS_IS_EBADIP */
|
|
#define APR_EBADIP (APR_OS_START_ERROR + 16)
|
|
/** @see APR_STATUS_IS_EBADMASK */
|
|
#define APR_EBADMASK (APR_OS_START_ERROR + 17)
|
|
/* empty slot: +18 */
|
|
/** @see APR_STATUS_IS_EDSOPEN */
|
|
#define APR_EDSOOPEN (APR_OS_START_ERROR + 19)
|
|
/** @see APR_STATUS_IS_EABSOLUTE */
|
|
#define APR_EABSOLUTE (APR_OS_START_ERROR + 20)
|
|
/** @see APR_STATUS_IS_ERELATIVE */
|
|
#define APR_ERELATIVE (APR_OS_START_ERROR + 21)
|
|
/** @see APR_STATUS_IS_EINCOMPLETE */
|
|
#define APR_EINCOMPLETE (APR_OS_START_ERROR + 22)
|
|
/** @see APR_STATUS_IS_EABOVEROOT */
|
|
#define APR_EABOVEROOT (APR_OS_START_ERROR + 23)
|
|
/** @see APR_STATUS_IS_EBADPATH */
|
|
#define APR_EBADPATH (APR_OS_START_ERROR + 24)
|
|
/** @see APR_STATUS_IS_EPATHWILD */
|
|
#define APR_EPATHWILD (APR_OS_START_ERROR + 25)
|
|
/** @see APR_STATUS_IS_ESYMNOTFOUND */
|
|
#define APR_ESYMNOTFOUND (APR_OS_START_ERROR + 26)
|
|
/** @see APR_STATUS_IS_EPROC_UNKNOWN */
|
|
#define APR_EPROC_UNKNOWN (APR_OS_START_ERROR + 27)
|
|
/** @see APR_STATUS_IS_ENOTENOUGHENTROPY */
|
|
#define APR_ENOTENOUGHENTROPY (APR_OS_START_ERROR + 28)
|
|
/** @} */
|
|
|
|
/**
|
|
* @defgroup APR_STATUS_IS Status Value Tests
|
|
* @warning For any particular error condition, more than one of these tests
|
|
* may match. This is because platform-specific error codes may not
|
|
* always match the semantics of the POSIX codes these tests (and the
|
|
* corresponding APR error codes) are named after. A notable example
|
|
* are the APR_STATUS_IS_ENOENT and APR_STATUS_IS_ENOTDIR tests on
|
|
* Win32 platforms. The programmer should always be aware of this and
|
|
* adjust the order of the tests accordingly.
|
|
* @{
|
|
*/
|
|
/**
|
|
* APR was unable to perform a stat on the file
|
|
* @warning always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_ENOSTAT(s) ((s) == APR_ENOSTAT)
|
|
/**
|
|
* APR was not provided a pool with which to allocate memory
|
|
* @warning always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_ENOPOOL(s) ((s) == APR_ENOPOOL)
|
|
/** APR was given an invalid date */
|
|
#define APR_STATUS_IS_EBADDATE(s) ((s) == APR_EBADDATE)
|
|
/** APR was given an invalid socket */
|
|
#define APR_STATUS_IS_EINVALSOCK(s) ((s) == APR_EINVALSOCK)
|
|
/** APR was not given a process structure */
|
|
#define APR_STATUS_IS_ENOPROC(s) ((s) == APR_ENOPROC)
|
|
/** APR was not given a time structure */
|
|
#define APR_STATUS_IS_ENOTIME(s) ((s) == APR_ENOTIME)
|
|
/** APR was not given a directory structure */
|
|
#define APR_STATUS_IS_ENODIR(s) ((s) == APR_ENODIR)
|
|
/** APR was not given a lock structure */
|
|
#define APR_STATUS_IS_ENOLOCK(s) ((s) == APR_ENOLOCK)
|
|
/** APR was not given a poll structure */
|
|
#define APR_STATUS_IS_ENOPOLL(s) ((s) == APR_ENOPOLL)
|
|
/** APR was not given a socket */
|
|
#define APR_STATUS_IS_ENOSOCKET(s) ((s) == APR_ENOSOCKET)
|
|
/** APR was not given a thread structure */
|
|
#define APR_STATUS_IS_ENOTHREAD(s) ((s) == APR_ENOTHREAD)
|
|
/** APR was not given a thread key structure */
|
|
#define APR_STATUS_IS_ENOTHDKEY(s) ((s) == APR_ENOTHDKEY)
|
|
/** Generic Error which can not be put into another spot */
|
|
#define APR_STATUS_IS_EGENERAL(s) ((s) == APR_EGENERAL)
|
|
/** There is no more shared memory available */
|
|
#define APR_STATUS_IS_ENOSHMAVAIL(s) ((s) == APR_ENOSHMAVAIL)
|
|
/** The specified IP address is invalid */
|
|
#define APR_STATUS_IS_EBADIP(s) ((s) == APR_EBADIP)
|
|
/** The specified netmask is invalid */
|
|
#define APR_STATUS_IS_EBADMASK(s) ((s) == APR_EBADMASK)
|
|
/* empty slot: +18 */
|
|
/**
|
|
* APR was unable to open the dso object.
|
|
* For more information call apr_dso_error().
|
|
*/
|
|
#if defined(WIN32)
|
|
#define APR_STATUS_IS_EDSOOPEN(s) ((s) == APR_EDSOOPEN \
|
|
|| APR_TO_OS_ERROR(s) == ERROR_MOD_NOT_FOUND)
|
|
#else
|
|
#define APR_STATUS_IS_EDSOOPEN(s) ((s) == APR_EDSOOPEN)
|
|
#endif
|
|
/** The given path was absolute. */
|
|
#define APR_STATUS_IS_EABSOLUTE(s) ((s) == APR_EABSOLUTE)
|
|
/** The given path was relative. */
|
|
#define APR_STATUS_IS_ERELATIVE(s) ((s) == APR_ERELATIVE)
|
|
/** The given path was neither relative nor absolute. */
|
|
#define APR_STATUS_IS_EINCOMPLETE(s) ((s) == APR_EINCOMPLETE)
|
|
/** The given path was above the root path. */
|
|
#define APR_STATUS_IS_EABOVEROOT(s) ((s) == APR_EABOVEROOT)
|
|
/** The given path was bad. */
|
|
#define APR_STATUS_IS_EBADPATH(s) ((s) == APR_EBADPATH)
|
|
/** The given path contained wildcards. */
|
|
#define APR_STATUS_IS_EPATHWILD(s) ((s) == APR_EPATHWILD)
|
|
/** Could not find the requested symbol.
|
|
* For more information call apr_dso_error().
|
|
*/
|
|
#if defined(WIN32)
|
|
#define APR_STATUS_IS_ESYMNOTFOUND(s) ((s) == APR_ESYMNOTFOUND \
|
|
|| APR_TO_OS_ERROR(s) == ERROR_PROC_NOT_FOUND)
|
|
#else
|
|
#define APR_STATUS_IS_ESYMNOTFOUND(s) ((s) == APR_ESYMNOTFOUND)
|
|
#endif
|
|
/** The given process was not recognized by APR. */
|
|
#define APR_STATUS_IS_EPROC_UNKNOWN(s) ((s) == APR_EPROC_UNKNOWN)
|
|
|
|
/** APR could not gather enough entropy to continue. */
|
|
#define APR_STATUS_IS_ENOTENOUGHENTROPY(s) ((s) == APR_ENOTENOUGHENTROPY)
|
|
|
|
/** @} */
|
|
|
|
/**
|
|
* @addtogroup APR_Error
|
|
* @{
|
|
*/
|
|
/** @see APR_STATUS_IS_INCHILD */
|
|
#define APR_INCHILD (APR_OS_START_STATUS + 1)
|
|
/** @see APR_STATUS_IS_INPARENT */
|
|
#define APR_INPARENT (APR_OS_START_STATUS + 2)
|
|
/** @see APR_STATUS_IS_DETACH */
|
|
#define APR_DETACH (APR_OS_START_STATUS + 3)
|
|
/** @see APR_STATUS_IS_NOTDETACH */
|
|
#define APR_NOTDETACH (APR_OS_START_STATUS + 4)
|
|
/** @see APR_STATUS_IS_CHILD_DONE */
|
|
#define APR_CHILD_DONE (APR_OS_START_STATUS + 5)
|
|
/** @see APR_STATUS_IS_CHILD_NOTDONE */
|
|
#define APR_CHILD_NOTDONE (APR_OS_START_STATUS + 6)
|
|
/** @see APR_STATUS_IS_TIMEUP */
|
|
#define APR_TIMEUP (APR_OS_START_STATUS + 7)
|
|
/** @see APR_STATUS_IS_INCOMPLETE */
|
|
#define APR_INCOMPLETE (APR_OS_START_STATUS + 8)
|
|
/* empty slot: +9 */
|
|
/* empty slot: +10 */
|
|
/* empty slot: +11 */
|
|
/** @see APR_STATUS_IS_BADCH */
|
|
#define APR_BADCH (APR_OS_START_STATUS + 12)
|
|
/** @see APR_STATUS_IS_BADARG */
|
|
#define APR_BADARG (APR_OS_START_STATUS + 13)
|
|
/** @see APR_STATUS_IS_EOF */
|
|
#define APR_EOF (APR_OS_START_STATUS + 14)
|
|
/** @see APR_STATUS_IS_NOTFOUND */
|
|
#define APR_NOTFOUND (APR_OS_START_STATUS + 15)
|
|
/* empty slot: +16 */
|
|
/* empty slot: +17 */
|
|
/* empty slot: +18 */
|
|
/** @see APR_STATUS_IS_ANONYMOUS */
|
|
#define APR_ANONYMOUS (APR_OS_START_STATUS + 19)
|
|
/** @see APR_STATUS_IS_FILEBASED */
|
|
#define APR_FILEBASED (APR_OS_START_STATUS + 20)
|
|
/** @see APR_STATUS_IS_KEYBASED */
|
|
#define APR_KEYBASED (APR_OS_START_STATUS + 21)
|
|
/** @see APR_STATUS_IS_EINIT */
|
|
#define APR_EINIT (APR_OS_START_STATUS + 22)
|
|
/** @see APR_STATUS_IS_ENOTIMPL */
|
|
#define APR_ENOTIMPL (APR_OS_START_STATUS + 23)
|
|
/** @see APR_STATUS_IS_EMISMATCH */
|
|
#define APR_EMISMATCH (APR_OS_START_STATUS + 24)
|
|
/** @see APR_STATUS_IS_EBUSY */
|
|
#define APR_EBUSY (APR_OS_START_STATUS + 25)
|
|
/** @} */
|
|
|
|
/**
|
|
* @addtogroup APR_STATUS_IS
|
|
* @{
|
|
*/
|
|
/**
|
|
* Program is currently executing in the child
|
|
* @warning
|
|
* always use this test, as platform-specific variances may meet this
|
|
* more than one error code */
|
|
#define APR_STATUS_IS_INCHILD(s) ((s) == APR_INCHILD)
|
|
/**
|
|
* Program is currently executing in the parent
|
|
* @warning
|
|
* always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_INPARENT(s) ((s) == APR_INPARENT)
|
|
/**
|
|
* The thread is detached
|
|
* @warning
|
|
* always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_DETACH(s) ((s) == APR_DETACH)
|
|
/**
|
|
* The thread is not detached
|
|
* @warning
|
|
* always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_NOTDETACH(s) ((s) == APR_NOTDETACH)
|
|
/**
|
|
* The child has finished executing
|
|
* @warning
|
|
* always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_CHILD_DONE(s) ((s) == APR_CHILD_DONE)
|
|
/**
|
|
* The child has not finished executing
|
|
* @warning
|
|
* always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_CHILD_NOTDONE(s) ((s) == APR_CHILD_NOTDONE)
|
|
/**
|
|
* The operation did not finish before the timeout
|
|
* @warning
|
|
* always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_TIMEUP(s) ((s) == APR_TIMEUP)
|
|
/**
|
|
* The operation was incomplete although some processing was performed
|
|
* and the results are partially valid.
|
|
* @warning
|
|
* always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_INCOMPLETE(s) ((s) == APR_INCOMPLETE)
|
|
/* empty slot: +9 */
|
|
/* empty slot: +10 */
|
|
/* empty slot: +11 */
|
|
/**
|
|
* Getopt found an option not in the option string
|
|
* @warning
|
|
* always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_BADCH(s) ((s) == APR_BADCH)
|
|
/**
|
|
* Getopt found an option not in the option string and an argument was
|
|
* specified in the option string
|
|
* @warning
|
|
* always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_BADARG(s) ((s) == APR_BADARG)
|
|
/**
|
|
* APR has encountered the end of the file
|
|
* @warning
|
|
* always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_EOF(s) ((s) == APR_EOF)
|
|
/**
|
|
* APR was unable to find the socket in the poll structure
|
|
* @warning
|
|
* always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_NOTFOUND(s) ((s) == APR_NOTFOUND)
|
|
/* empty slot: +16 */
|
|
/* empty slot: +17 */
|
|
/* empty slot: +18 */
|
|
/**
|
|
* APR is using anonymous shared memory
|
|
* @warning
|
|
* always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_ANONYMOUS(s) ((s) == APR_ANONYMOUS)
|
|
/**
|
|
* APR is using a file name as the key to the shared memory
|
|
* @warning
|
|
* always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_FILEBASED(s) ((s) == APR_FILEBASED)
|
|
/**
|
|
* APR is using a shared key as the key to the shared memory
|
|
* @warning
|
|
* always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_KEYBASED(s) ((s) == APR_KEYBASED)
|
|
/**
|
|
* Ininitalizer value. If no option has been found, but
|
|
* the status variable requires a value, this should be used
|
|
* @warning
|
|
* always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_EINIT(s) ((s) == APR_EINIT)
|
|
/**
|
|
* The APR function has not been implemented on this
|
|
* platform, either because nobody has gotten to it yet,
|
|
* or the function is impossible on this platform.
|
|
* @warning
|
|
* always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_ENOTIMPL(s) ((s) == APR_ENOTIMPL)
|
|
/**
|
|
* Two passwords do not match.
|
|
* @warning
|
|
* always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_EMISMATCH(s) ((s) == APR_EMISMATCH)
|
|
/**
|
|
* The given lock was busy
|
|
* @warning always use this test, as platform-specific variances may meet this
|
|
* more than one error code
|
|
*/
|
|
#define APR_STATUS_IS_EBUSY(s) ((s) == APR_EBUSY)
|
|
|
|
/** @} */
|
|
|
|
/**
|
|
* @addtogroup APR_Error APR Error Values
|
|
* @{
|
|
*/
|
|
/* APR CANONICAL ERROR VALUES */
|
|
/** @see APR_STATUS_IS_EACCES */
|
|
#ifdef EACCES
|
|
#define APR_EACCES EACCES
|
|
#else
|
|
#define APR_EACCES (APR_OS_START_CANONERR + 1)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_EXIST */
|
|
#ifdef EEXIST
|
|
#define APR_EEXIST EEXIST
|
|
#else
|
|
#define APR_EEXIST (APR_OS_START_CANONERR + 2)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_ENAMETOOLONG */
|
|
#ifdef ENAMETOOLONG
|
|
#define APR_ENAMETOOLONG ENAMETOOLONG
|
|
#else
|
|
#define APR_ENAMETOOLONG (APR_OS_START_CANONERR + 3)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_ENOENT */
|
|
#ifdef ENOENT
|
|
#define APR_ENOENT ENOENT
|
|
#else
|
|
#define APR_ENOENT (APR_OS_START_CANONERR + 4)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_ENOTDIR */
|
|
#ifdef ENOTDIR
|
|
#define APR_ENOTDIR ENOTDIR
|
|
#else
|
|
#define APR_ENOTDIR (APR_OS_START_CANONERR + 5)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_ENOSPC */
|
|
#ifdef ENOSPC
|
|
#define APR_ENOSPC ENOSPC
|
|
#else
|
|
#define APR_ENOSPC (APR_OS_START_CANONERR + 6)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_ENOMEM */
|
|
#ifdef ENOMEM
|
|
#define APR_ENOMEM ENOMEM
|
|
#else
|
|
#define APR_ENOMEM (APR_OS_START_CANONERR + 7)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_EMFILE */
|
|
#ifdef EMFILE
|
|
#define APR_EMFILE EMFILE
|
|
#else
|
|
#define APR_EMFILE (APR_OS_START_CANONERR + 8)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_ENFILE */
|
|
#ifdef ENFILE
|
|
#define APR_ENFILE ENFILE
|
|
#else
|
|
#define APR_ENFILE (APR_OS_START_CANONERR + 9)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_EBADF */
|
|
#ifdef EBADF
|
|
#define APR_EBADF EBADF
|
|
#else
|
|
#define APR_EBADF (APR_OS_START_CANONERR + 10)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_EINVAL */
|
|
#ifdef EINVAL
|
|
#define APR_EINVAL EINVAL
|
|
#else
|
|
#define APR_EINVAL (APR_OS_START_CANONERR + 11)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_ESPIPE */
|
|
#ifdef ESPIPE
|
|
#define APR_ESPIPE ESPIPE
|
|
#else
|
|
#define APR_ESPIPE (APR_OS_START_CANONERR + 12)
|
|
#endif
|
|
|
|
/**
|
|
* @see APR_STATUS_IS_EAGAIN
|
|
* @warning use APR_STATUS_IS_EAGAIN instead of just testing this value
|
|
*/
|
|
#ifdef EAGAIN
|
|
#define APR_EAGAIN EAGAIN
|
|
#elif defined(EWOULDBLOCK)
|
|
#define APR_EAGAIN EWOULDBLOCK
|
|
#else
|
|
#define APR_EAGAIN (APR_OS_START_CANONERR + 13)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_EINTR */
|
|
#ifdef EINTR
|
|
#define APR_EINTR EINTR
|
|
#else
|
|
#define APR_EINTR (APR_OS_START_CANONERR + 14)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_ENOTSOCK */
|
|
#ifdef ENOTSOCK
|
|
#define APR_ENOTSOCK ENOTSOCK
|
|
#else
|
|
#define APR_ENOTSOCK (APR_OS_START_CANONERR + 15)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_ECONNREFUSED */
|
|
#ifdef ECONNREFUSED
|
|
#define APR_ECONNREFUSED ECONNREFUSED
|
|
#else
|
|
#define APR_ECONNREFUSED (APR_OS_START_CANONERR + 16)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_EINPROGRESS */
|
|
#ifdef EINPROGRESS
|
|
#define APR_EINPROGRESS EINPROGRESS
|
|
#else
|
|
#define APR_EINPROGRESS (APR_OS_START_CANONERR + 17)
|
|
#endif
|
|
|
|
/**
|
|
* @see APR_STATUS_IS_ECONNABORTED
|
|
* @warning use APR_STATUS_IS_ECONNABORTED instead of just testing this value
|
|
*/
|
|
|
|
#ifdef ECONNABORTED
|
|
#define APR_ECONNABORTED ECONNABORTED
|
|
#else
|
|
#define APR_ECONNABORTED (APR_OS_START_CANONERR + 18)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_ECONNRESET */
|
|
#ifdef ECONNRESET
|
|
#define APR_ECONNRESET ECONNRESET
|
|
#else
|
|
#define APR_ECONNRESET (APR_OS_START_CANONERR + 19)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_ETIMEDOUT
|
|
* @deprecated */
|
|
#ifdef ETIMEDOUT
|
|
#define APR_ETIMEDOUT ETIMEDOUT
|
|
#else
|
|
#define APR_ETIMEDOUT (APR_OS_START_CANONERR + 20)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_EHOSTUNREACH */
|
|
#ifdef EHOSTUNREACH
|
|
#define APR_EHOSTUNREACH EHOSTUNREACH
|
|
#else
|
|
#define APR_EHOSTUNREACH (APR_OS_START_CANONERR + 21)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_ENETUNREACH */
|
|
#ifdef ENETUNREACH
|
|
#define APR_ENETUNREACH ENETUNREACH
|
|
#else
|
|
#define APR_ENETUNREACH (APR_OS_START_CANONERR + 22)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_EFTYPE */
|
|
#ifdef EFTYPE
|
|
#define APR_EFTYPE EFTYPE
|
|
#else
|
|
#define APR_EFTYPE (APR_OS_START_CANONERR + 23)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_EPIPE */
|
|
#ifdef EPIPE
|
|
#define APR_EPIPE EPIPE
|
|
#else
|
|
#define APR_EPIPE (APR_OS_START_CANONERR + 24)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_EXDEV */
|
|
#ifdef EXDEV
|
|
#define APR_EXDEV EXDEV
|
|
#else
|
|
#define APR_EXDEV (APR_OS_START_CANONERR + 25)
|
|
#endif
|
|
|
|
/** @see APR_STATUS_IS_ENOTEMPTY */
|
|
#ifdef ENOTEMPTY
|
|
#define APR_ENOTEMPTY ENOTEMPTY
|
|
#else
|
|
#define APR_ENOTEMPTY (APR_OS_START_CANONERR + 26)
|
|
#endif
|
|
|
|
/** @} */
|
|
|
|
#if defined(OS2) && !defined(DOXYGEN)
|
|
|
|
#define APR_FROM_OS_ERROR(e) (e == 0 ? APR_SUCCESS : e + APR_OS_START_SYSERR)
|
|
#define APR_TO_OS_ERROR(e) (e == 0 ? APR_SUCCESS : e - APR_OS_START_SYSERR)
|
|
|
|
#define INCL_DOSERRORS
|
|
#define INCL_DOS
|
|
|
|
/* Leave these undefined.
|
|
* OS2 doesn't rely on the errno concept.
|
|
* The API calls always return a result codes which
|
|
* should be filtered through APR_FROM_OS_ERROR().
|
|
*
|
|
* #define apr_get_os_error() (APR_FROM_OS_ERROR(GetLastError()))
|
|
* #define apr_set_os_error(e) (SetLastError(APR_TO_OS_ERROR(e)))
|
|
*/
|
|
|
|
/* A special case, only socket calls require this;
|
|
*/
|
|
#define apr_get_netos_error() (APR_FROM_OS_ERROR(errno))
|
|
#define apr_set_netos_error(e) (errno = APR_TO_OS_ERROR(e))
|
|
|
|
/* And this needs to be greped away for good:
|
|
*/
|
|
#define APR_OS2_STATUS(e) (APR_FROM_OS_ERROR(e))
|
|
|
|
/* These can't sit in a private header, so in spite of the extra size,
|
|
* they need to be made available here.
|
|
*/
|
|
#define SOCBASEERR 10000
|
|
#define SOCEPERM (SOCBASEERR+1) /* Not owner */
|
|
#define SOCESRCH (SOCBASEERR+3) /* No such process */
|
|
#define SOCEINTR (SOCBASEERR+4) /* Interrupted system call */
|
|
#define SOCENXIO (SOCBASEERR+6) /* No such device or address */
|
|
#define SOCEBADF (SOCBASEERR+9) /* Bad file number */
|
|
#define SOCEACCES (SOCBASEERR+13) /* Permission denied */
|
|
#define SOCEFAULT (SOCBASEERR+14) /* Bad address */
|
|
#define SOCEINVAL (SOCBASEERR+22) /* Invalid argument */
|
|
#define SOCEMFILE (SOCBASEERR+24) /* Too many open files */
|
|
#define SOCEPIPE (SOCBASEERR+32) /* Broken pipe */
|
|
#define SOCEOS2ERR (SOCBASEERR+100) /* OS/2 Error */
|
|
#define SOCEWOULDBLOCK (SOCBASEERR+35) /* Operation would block */
|
|
#define SOCEINPROGRESS (SOCBASEERR+36) /* Operation now in progress */
|
|
#define SOCEALREADY (SOCBASEERR+37) /* Operation already in progress */
|
|
#define SOCENOTSOCK (SOCBASEERR+38) /* Socket operation on non-socket */
|
|
#define SOCEDESTADDRREQ (SOCBASEERR+39) /* Destination address required */
|
|
#define SOCEMSGSIZE (SOCBASEERR+40) /* Message too long */
|
|
#define SOCEPROTOTYPE (SOCBASEERR+41) /* Protocol wrong type for socket */
|
|
#define SOCENOPROTOOPT (SOCBASEERR+42) /* Protocol not available */
|
|
#define SOCEPROTONOSUPPORT (SOCBASEERR+43) /* Protocol not supported */
|
|
#define SOCESOCKTNOSUPPORT (SOCBASEERR+44) /* Socket type not supported */
|
|
#define SOCEOPNOTSUPP (SOCBASEERR+45) /* Operation not supported on socket */
|
|
#define SOCEPFNOSUPPORT (SOCBASEERR+46) /* Protocol family not supported */
|
|
#define SOCEAFNOSUPPORT (SOCBASEERR+47) /* Address family not supported by protocol family */
|
|
#define SOCEADDRINUSE (SOCBASEERR+48) /* Address already in use */
|
|
#define SOCEADDRNOTAVAIL (SOCBASEERR+49) /* Can't assign requested address */
|
|
#define SOCENETDOWN (SOCBASEERR+50) /* Network is down */
|
|
#define SOCENETUNREACH (SOCBASEERR+51) /* Network is unreachable */
|
|
#define SOCENETRESET (SOCBASEERR+52) /* Network dropped connection on reset */
|
|
#define SOCECONNABORTED (SOCBASEERR+53) /* Software caused connection abort */
|
|
#define SOCECONNRESET (SOCBASEERR+54) /* Connection reset by peer */
|
|
#define SOCENOBUFS (SOCBASEERR+55) /* No buffer space available */
|
|
#define SOCEISCONN (SOCBASEERR+56) /* Socket is already connected */
|
|
#define SOCENOTCONN (SOCBASEERR+57) /* Socket is not connected */
|
|
#define SOCESHUTDOWN (SOCBASEERR+58) /* Can't send after socket shutdown */
|
|
#define SOCETOOMANYREFS (SOCBASEERR+59) /* Too many references: can't splice */
|
|
#define SOCETIMEDOUT (SOCBASEERR+60) /* Connection timed out */
|
|
#define SOCECONNREFUSED (SOCBASEERR+61) /* Connection refused */
|
|
#define SOCELOOP (SOCBASEERR+62) /* Too many levels of symbolic links */
|
|
#define SOCENAMETOOLONG (SOCBASEERR+63) /* File name too long */
|
|
#define SOCEHOSTDOWN (SOCBASEERR+64) /* Host is down */
|
|
#define SOCEHOSTUNREACH (SOCBASEERR+65) /* No route to host */
|
|
#define SOCENOTEMPTY (SOCBASEERR+66) /* Directory not empty */
|
|
|
|
/* APR CANONICAL ERROR TESTS */
|
|
#define APR_STATUS_IS_EACCES(s) ((s) == APR_EACCES \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_ACCESS_DENIED \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_SHARING_VIOLATION)
|
|
#define APR_STATUS_IS_EEXIST(s) ((s) == APR_EEXIST \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_OPEN_FAILED \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_FILE_EXISTS \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_ALREADY_EXISTS \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_ACCESS_DENIED)
|
|
#define APR_STATUS_IS_ENAMETOOLONG(s) ((s) == APR_ENAMETOOLONG \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_FILENAME_EXCED_RANGE \
|
|
|| (s) == APR_OS_START_SYSERR + SOCENAMETOOLONG)
|
|
#define APR_STATUS_IS_ENOENT(s) ((s) == APR_ENOENT \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_FILE_NOT_FOUND \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_PATH_NOT_FOUND \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_NO_MORE_FILES \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_OPEN_FAILED)
|
|
#define APR_STATUS_IS_ENOTDIR(s) ((s) == APR_ENOTDIR)
|
|
#define APR_STATUS_IS_ENOSPC(s) ((s) == APR_ENOSPC \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_DISK_FULL)
|
|
#define APR_STATUS_IS_ENOMEM(s) ((s) == APR_ENOMEM)
|
|
#define APR_STATUS_IS_EMFILE(s) ((s) == APR_EMFILE \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_TOO_MANY_OPEN_FILES)
|
|
#define APR_STATUS_IS_ENFILE(s) ((s) == APR_ENFILE)
|
|
#define APR_STATUS_IS_EBADF(s) ((s) == APR_EBADF \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_INVALID_HANDLE)
|
|
#define APR_STATUS_IS_EINVAL(s) ((s) == APR_EINVAL \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_INVALID_PARAMETER \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_INVALID_FUNCTION)
|
|
#define APR_STATUS_IS_ESPIPE(s) ((s) == APR_ESPIPE \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_NEGATIVE_SEEK)
|
|
#define APR_STATUS_IS_EAGAIN(s) ((s) == APR_EAGAIN \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_NO_DATA \
|
|
|| (s) == APR_OS_START_SYSERR + SOCEWOULDBLOCK \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_LOCK_VIOLATION)
|
|
#define APR_STATUS_IS_EINTR(s) ((s) == APR_EINTR \
|
|
|| (s) == APR_OS_START_SYSERR + SOCEINTR)
|
|
#define APR_STATUS_IS_ENOTSOCK(s) ((s) == APR_ENOTSOCK \
|
|
|| (s) == APR_OS_START_SYSERR + SOCENOTSOCK)
|
|
#define APR_STATUS_IS_ECONNREFUSED(s) ((s) == APR_ECONNREFUSED \
|
|
|| (s) == APR_OS_START_SYSERR + SOCECONNREFUSED)
|
|
#define APR_STATUS_IS_EINPROGRESS(s) ((s) == APR_EINPROGRESS \
|
|
|| (s) == APR_OS_START_SYSERR + SOCEINPROGRESS)
|
|
#define APR_STATUS_IS_ECONNABORTED(s) ((s) == APR_ECONNABORTED \
|
|
|| (s) == APR_OS_START_SYSERR + SOCECONNABORTED)
|
|
#define APR_STATUS_IS_ECONNRESET(s) ((s) == APR_ECONNRESET \
|
|
|| (s) == APR_OS_START_SYSERR + SOCECONNRESET)
|
|
/* XXX deprecated */
|
|
#define APR_STATUS_IS_ETIMEDOUT(s) ((s) == APR_ETIMEDOUT \
|
|
|| (s) == APR_OS_START_SYSERR + SOCETIMEDOUT)
|
|
#undef APR_STATUS_IS_TIMEUP
|
|
#define APR_STATUS_IS_TIMEUP(s) ((s) == APR_TIMEUP \
|
|
|| (s) == APR_OS_START_SYSERR + SOCETIMEDOUT)
|
|
#define APR_STATUS_IS_EHOSTUNREACH(s) ((s) == APR_EHOSTUNREACH \
|
|
|| (s) == APR_OS_START_SYSERR + SOCEHOSTUNREACH)
|
|
#define APR_STATUS_IS_ENETUNREACH(s) ((s) == APR_ENETUNREACH \
|
|
|| (s) == APR_OS_START_SYSERR + SOCENETUNREACH)
|
|
#define APR_STATUS_IS_EFTYPE(s) ((s) == APR_EFTYPE)
|
|
#define APR_STATUS_IS_EPIPE(s) ((s) == APR_EPIPE \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_BROKEN_PIPE \
|
|
|| (s) == APR_OS_START_SYSERR + SOCEPIPE)
|
|
#define APR_STATUS_IS_EXDEV(s) ((s) == APR_EXDEV \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_NOT_SAME_DEVICE)
|
|
#define APR_STATUS_IS_ENOTEMPTY(s) ((s) == APR_ENOTEMPTY \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_DIR_NOT_EMPTY \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_ACCESS_DENIED)
|
|
|
|
/*
|
|
Sorry, too tired to wrap this up for OS2... feel free to
|
|
fit the following into their best matches.
|
|
|
|
{ ERROR_NO_SIGNAL_SENT, ESRCH },
|
|
{ SOCEALREADY, EALREADY },
|
|
{ SOCEDESTADDRREQ, EDESTADDRREQ },
|
|
{ SOCEMSGSIZE, EMSGSIZE },
|
|
{ SOCEPROTOTYPE, EPROTOTYPE },
|
|
{ SOCENOPROTOOPT, ENOPROTOOPT },
|
|
{ SOCEPROTONOSUPPORT, EPROTONOSUPPORT },
|
|
{ SOCESOCKTNOSUPPORT, ESOCKTNOSUPPORT },
|
|
{ SOCEOPNOTSUPP, EOPNOTSUPP },
|
|
{ SOCEPFNOSUPPORT, EPFNOSUPPORT },
|
|
{ SOCEAFNOSUPPORT, EAFNOSUPPORT },
|
|
{ SOCEADDRINUSE, EADDRINUSE },
|
|
{ SOCEADDRNOTAVAIL, EADDRNOTAVAIL },
|
|
{ SOCENETDOWN, ENETDOWN },
|
|
{ SOCENETRESET, ENETRESET },
|
|
{ SOCENOBUFS, ENOBUFS },
|
|
{ SOCEISCONN, EISCONN },
|
|
{ SOCENOTCONN, ENOTCONN },
|
|
{ SOCESHUTDOWN, ESHUTDOWN },
|
|
{ SOCETOOMANYREFS, ETOOMANYREFS },
|
|
{ SOCELOOP, ELOOP },
|
|
{ SOCEHOSTDOWN, EHOSTDOWN },
|
|
{ SOCENOTEMPTY, ENOTEMPTY },
|
|
{ SOCEPIPE, EPIPE }
|
|
*/
|
|
|
|
#elif defined(WIN32) && !defined(DOXYGEN) /* !defined(OS2) */
|
|
|
|
#define APR_FROM_OS_ERROR(e) (e == 0 ? APR_SUCCESS : e + APR_OS_START_SYSERR)
|
|
#define APR_TO_OS_ERROR(e) (e == 0 ? APR_SUCCESS : e - APR_OS_START_SYSERR)
|
|
|
|
#define apr_get_os_error() (APR_FROM_OS_ERROR(GetLastError()))
|
|
#define apr_set_os_error(e) (SetLastError(APR_TO_OS_ERROR(e)))
|
|
|
|
/* A special case, only socket calls require this:
|
|
*/
|
|
#define apr_get_netos_error() (APR_FROM_OS_ERROR(WSAGetLastError()))
|
|
#define apr_set_netos_error(e) (WSASetLastError(APR_TO_OS_ERROR(e)))
|
|
|
|
/* APR CANONICAL ERROR TESTS */
|
|
#define APR_STATUS_IS_EACCES(s) ((s) == APR_EACCES \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_ACCESS_DENIED \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_CANNOT_MAKE \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_CURRENT_DIRECTORY \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_DRIVE_LOCKED \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_FAIL_I24 \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_LOCK_VIOLATION \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_LOCK_FAILED \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_NOT_LOCKED \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_NETWORK_ACCESS_DENIED \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_SHARING_VIOLATION)
|
|
#define APR_STATUS_IS_EEXIST(s) ((s) == APR_EEXIST \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_FILE_EXISTS \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_ALREADY_EXISTS)
|
|
#define APR_STATUS_IS_ENAMETOOLONG(s) ((s) == APR_ENAMETOOLONG \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_FILENAME_EXCED_RANGE \
|
|
|| (s) == APR_OS_START_SYSERR + WSAENAMETOOLONG)
|
|
#define APR_STATUS_IS_ENOENT(s) ((s) == APR_ENOENT \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_FILE_NOT_FOUND \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_PATH_NOT_FOUND \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_OPEN_FAILED \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_NO_MORE_FILES)
|
|
#define APR_STATUS_IS_ENOTDIR(s) ((s) == APR_ENOTDIR \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_PATH_NOT_FOUND \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_BAD_NETPATH \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_BAD_NET_NAME \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_BAD_PATHNAME \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_INVALID_DRIVE)
|
|
#define APR_STATUS_IS_ENOSPC(s) ((s) == APR_ENOSPC \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_DISK_FULL)
|
|
#define APR_STATUS_IS_ENOMEM(s) ((s) == APR_ENOMEM \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_ARENA_TRASHED \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_NOT_ENOUGH_MEMORY \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_INVALID_BLOCK \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_NOT_ENOUGH_QUOTA \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_OUTOFMEMORY)
|
|
#define APR_STATUS_IS_EMFILE(s) ((s) == APR_EMFILE \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_TOO_MANY_OPEN_FILES)
|
|
#define APR_STATUS_IS_ENFILE(s) ((s) == APR_ENFILE)
|
|
#define APR_STATUS_IS_EBADF(s) ((s) == APR_EBADF \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_INVALID_HANDLE \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_INVALID_TARGET_HANDLE)
|
|
#define APR_STATUS_IS_EINVAL(s) ((s) == APR_EINVAL \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_INVALID_ACCESS \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_INVALID_DATA \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_INVALID_FUNCTION \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_INVALID_HANDLE \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_INVALID_PARAMETER \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_NEGATIVE_SEEK)
|
|
#define APR_STATUS_IS_ESPIPE(s) ((s) == APR_ESPIPE \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_SEEK_ON_DEVICE \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_NEGATIVE_SEEK)
|
|
#define APR_STATUS_IS_EAGAIN(s) ((s) == APR_EAGAIN \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_NO_DATA \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_NO_PROC_SLOTS \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_NESTING_NOT_ALLOWED \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_MAX_THRDS_REACHED \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_LOCK_VIOLATION \
|
|
|| (s) == APR_OS_START_SYSERR + WSAEWOULDBLOCK)
|
|
#define APR_STATUS_IS_EINTR(s) ((s) == APR_EINTR \
|
|
|| (s) == APR_OS_START_SYSERR + WSAEINTR)
|
|
#define APR_STATUS_IS_ENOTSOCK(s) ((s) == APR_ENOTSOCK \
|
|
|| (s) == APR_OS_START_SYSERR + WSAENOTSOCK)
|
|
#define APR_STATUS_IS_ECONNREFUSED(s) ((s) == APR_ECONNREFUSED \
|
|
|| (s) == APR_OS_START_SYSERR + WSAECONNREFUSED)
|
|
#define APR_STATUS_IS_EINPROGRESS(s) ((s) == APR_EINPROGRESS \
|
|
|| (s) == APR_OS_START_SYSERR + WSAEINPROGRESS)
|
|
#define APR_STATUS_IS_ECONNABORTED(s) ((s) == APR_ECONNABORTED \
|
|
|| (s) == APR_OS_START_SYSERR + WSAECONNABORTED)
|
|
#define APR_STATUS_IS_ECONNRESET(s) ((s) == APR_ECONNRESET \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_NETNAME_DELETED \
|
|
|| (s) == APR_OS_START_SYSERR + WSAECONNRESET)
|
|
/* XXX deprecated */
|
|
#define APR_STATUS_IS_ETIMEDOUT(s) ((s) == APR_ETIMEDOUT \
|
|
|| (s) == APR_OS_START_SYSERR + WSAETIMEDOUT \
|
|
|| (s) == APR_OS_START_SYSERR + WAIT_TIMEOUT)
|
|
#undef APR_STATUS_IS_TIMEUP
|
|
#define APR_STATUS_IS_TIMEUP(s) ((s) == APR_TIMEUP \
|
|
|| (s) == APR_OS_START_SYSERR + WSAETIMEDOUT \
|
|
|| (s) == APR_OS_START_SYSERR + WAIT_TIMEOUT)
|
|
#define APR_STATUS_IS_EHOSTUNREACH(s) ((s) == APR_EHOSTUNREACH \
|
|
|| (s) == APR_OS_START_SYSERR + WSAEHOSTUNREACH)
|
|
#define APR_STATUS_IS_ENETUNREACH(s) ((s) == APR_ENETUNREACH \
|
|
|| (s) == APR_OS_START_SYSERR + WSAENETUNREACH)
|
|
#define APR_STATUS_IS_EFTYPE(s) ((s) == APR_EFTYPE \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_EXE_MACHINE_TYPE_MISMATCH \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_INVALID_DLL \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_INVALID_MODULETYPE \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_BAD_EXE_FORMAT \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_INVALID_EXE_SIGNATURE \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_FILE_CORRUPT \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_BAD_FORMAT)
|
|
#define APR_STATUS_IS_EPIPE(s) ((s) == APR_EPIPE \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_BROKEN_PIPE)
|
|
#define APR_STATUS_IS_EXDEV(s) ((s) == APR_EXDEV \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_NOT_SAME_DEVICE)
|
|
#define APR_STATUS_IS_ENOTEMPTY(s) ((s) == APR_ENOTEMPTY \
|
|
|| (s) == APR_OS_START_SYSERR + ERROR_DIR_NOT_EMPTY)
|
|
|
|
#elif defined(NETWARE) && defined(USE_WINSOCK) && !defined(DOXYGEN) /* !defined(OS2) && !defined(WIN32) */
|
|
|
|
#define APR_FROM_OS_ERROR(e) (e == 0 ? APR_SUCCESS : e + APR_OS_START_SYSERR)
|
|
#define APR_TO_OS_ERROR(e) (e == 0 ? APR_SUCCESS : e - APR_OS_START_SYSERR)
|
|
|
|
#define apr_get_os_error() (errno)
|
|
#define apr_set_os_error(e) (errno = (e))
|
|
|
|
/* A special case, only socket calls require this: */
|
|
#define apr_get_netos_error() (APR_FROM_OS_ERROR(WSAGetLastError()))
|
|
#define apr_set_netos_error(e) (WSASetLastError(APR_TO_OS_ERROR(e)))
|
|
|
|
/* APR CANONICAL ERROR TESTS */
|
|
#define APR_STATUS_IS_EACCES(s) ((s) == APR_EACCES)
|
|
#define APR_STATUS_IS_EEXIST(s) ((s) == APR_EEXIST)
|
|
#define APR_STATUS_IS_ENAMETOOLONG(s) ((s) == APR_ENAMETOOLONG)
|
|
#define APR_STATUS_IS_ENOENT(s) ((s) == APR_ENOENT)
|
|
#define APR_STATUS_IS_ENOTDIR(s) ((s) == APR_ENOTDIR)
|
|
#define APR_STATUS_IS_ENOSPC(s) ((s) == APR_ENOSPC)
|
|
#define APR_STATUS_IS_ENOMEM(s) ((s) == APR_ENOMEM)
|
|
#define APR_STATUS_IS_EMFILE(s) ((s) == APR_EMFILE)
|
|
#define APR_STATUS_IS_ENFILE(s) ((s) == APR_ENFILE)
|
|
#define APR_STATUS_IS_EBADF(s) ((s) == APR_EBADF)
|
|
#define APR_STATUS_IS_EINVAL(s) ((s) == APR_EINVAL)
|
|
#define APR_STATUS_IS_ESPIPE(s) ((s) == APR_ESPIPE)
|
|
|
|
#define APR_STATUS_IS_EAGAIN(s) ((s) == APR_EAGAIN \
|
|
|| (s) == EWOULDBLOCK \
|
|
|| (s) == APR_OS_START_SYSERR + WSAEWOULDBLOCK)
|
|
#define APR_STATUS_IS_EINTR(s) ((s) == APR_EINTR \
|
|
|| (s) == APR_OS_START_SYSERR + WSAEINTR)
|
|
#define APR_STATUS_IS_ENOTSOCK(s) ((s) == APR_ENOTSOCK \
|
|
|| (s) == APR_OS_START_SYSERR + WSAENOTSOCK)
|
|
#define APR_STATUS_IS_ECONNREFUSED(s) ((s) == APR_ECONNREFUSED \
|
|
|| (s) == APR_OS_START_SYSERR + WSAECONNREFUSED)
|
|
#define APR_STATUS_IS_EINPROGRESS(s) ((s) == APR_EINPROGRESS \
|
|
|| (s) == APR_OS_START_SYSERR + WSAEINPROGRESS)
|
|
#define APR_STATUS_IS_ECONNABORTED(s) ((s) == APR_ECONNABORTED \
|
|
|| (s) == APR_OS_START_SYSERR + WSAECONNABORTED)
|
|
#define APR_STATUS_IS_ECONNRESET(s) ((s) == APR_ECONNRESET \
|
|
|| (s) == APR_OS_START_SYSERR + WSAECONNRESET)
|
|
/* XXX deprecated */
|
|
#define APR_STATUS_IS_ETIMEDOUT(s) ((s) == APR_ETIMEDOUT \
|
|
|| (s) == APR_OS_START_SYSERR + WSAETIMEDOUT \
|
|
|| (s) == APR_OS_START_SYSERR + WAIT_TIMEOUT)
|
|
#undef APR_STATUS_IS_TIMEUP
|
|
#define APR_STATUS_IS_TIMEUP(s) ((s) == APR_TIMEUP \
|
|
|| (s) == APR_OS_START_SYSERR + WSAETIMEDOUT \
|
|
|| (s) == APR_OS_START_SYSERR + WAIT_TIMEOUT)
|
|
#define APR_STATUS_IS_EHOSTUNREACH(s) ((s) == APR_EHOSTUNREACH \
|
|
|| (s) == APR_OS_START_SYSERR + WSAEHOSTUNREACH)
|
|
#define APR_STATUS_IS_ENETUNREACH(s) ((s) == APR_ENETUNREACH \
|
|
|| (s) == APR_OS_START_SYSERR + WSAENETUNREACH)
|
|
#define APR_STATUS_IS_ENETDOWN(s) ((s) == APR_OS_START_SYSERR + WSAENETDOWN)
|
|
#define APR_STATUS_IS_EFTYPE(s) ((s) == APR_EFTYPE)
|
|
#define APR_STATUS_IS_EPIPE(s) ((s) == APR_EPIPE)
|
|
#define APR_STATUS_IS_EXDEV(s) ((s) == APR_EXDEV)
|
|
#define APR_STATUS_IS_ENOTEMPTY(s) ((s) == APR_ENOTEMPTY)
|
|
|
|
#else /* !defined(NETWARE) && !defined(OS2) && !defined(WIN32) */
|
|
|
|
/*
|
|
* os error codes are clib error codes
|
|
*/
|
|
#define APR_FROM_OS_ERROR(e) (e)
|
|
#define APR_TO_OS_ERROR(e) (e)
|
|
|
|
#define apr_get_os_error() (errno)
|
|
#define apr_set_os_error(e) (errno = (e))
|
|
|
|
/* A special case, only socket calls require this:
|
|
*/
|
|
#define apr_get_netos_error() (errno)
|
|
#define apr_set_netos_error(e) (errno = (e))
|
|
|
|
/**
|
|
* @addtogroup APR_STATUS_IS
|
|
* @{
|
|
*/
|
|
|
|
/** permission denied */
|
|
#define APR_STATUS_IS_EACCES(s) ((s) == APR_EACCES)
|
|
/** file exists */
|
|
#define APR_STATUS_IS_EEXIST(s) ((s) == APR_EEXIST)
|
|
/** path name is too long */
|
|
#define APR_STATUS_IS_ENAMETOOLONG(s) ((s) == APR_ENAMETOOLONG)
|
|
/**
|
|
* no such file or directory
|
|
* @remark
|
|
* EMVSCATLG can be returned by the automounter on z/OS for
|
|
* paths which do not exist.
|
|
*/
|
|
#ifdef EMVSCATLG
|
|
#define APR_STATUS_IS_ENOENT(s) ((s) == APR_ENOENT \
|
|
|| (s) == EMVSCATLG)
|
|
#else
|
|
#define APR_STATUS_IS_ENOENT(s) ((s) == APR_ENOENT)
|
|
#endif
|
|
/** not a directory */
|
|
#define APR_STATUS_IS_ENOTDIR(s) ((s) == APR_ENOTDIR)
|
|
/** no space left on device */
|
|
#ifdef EDQUOT
|
|
#define APR_STATUS_IS_ENOSPC(s) ((s) == APR_ENOSPC \
|
|
|| (s) == EDQUOT)
|
|
#else
|
|
#define APR_STATUS_IS_ENOSPC(s) ((s) == APR_ENOSPC)
|
|
#endif
|
|
/** not enough memory */
|
|
#define APR_STATUS_IS_ENOMEM(s) ((s) == APR_ENOMEM)
|
|
/** too many open files */
|
|
#define APR_STATUS_IS_EMFILE(s) ((s) == APR_EMFILE)
|
|
/** file table overflow */
|
|
#define APR_STATUS_IS_ENFILE(s) ((s) == APR_ENFILE)
|
|
/** bad file # */
|
|
#define APR_STATUS_IS_EBADF(s) ((s) == APR_EBADF)
|
|
/** invalid argument */
|
|
#define APR_STATUS_IS_EINVAL(s) ((s) == APR_EINVAL)
|
|
/** illegal seek */
|
|
#define APR_STATUS_IS_ESPIPE(s) ((s) == APR_ESPIPE)
|
|
|
|
/** operation would block */
|
|
#if !defined(EWOULDBLOCK) || !defined(EAGAIN)
|
|
#define APR_STATUS_IS_EAGAIN(s) ((s) == APR_EAGAIN)
|
|
#elif (EWOULDBLOCK == EAGAIN)
|
|
#define APR_STATUS_IS_EAGAIN(s) ((s) == APR_EAGAIN)
|
|
#else
|
|
#define APR_STATUS_IS_EAGAIN(s) ((s) == APR_EAGAIN \
|
|
|| (s) == EWOULDBLOCK)
|
|
#endif
|
|
|
|
/** interrupted system call */
|
|
#define APR_STATUS_IS_EINTR(s) ((s) == APR_EINTR)
|
|
/** socket operation on a non-socket */
|
|
#define APR_STATUS_IS_ENOTSOCK(s) ((s) == APR_ENOTSOCK)
|
|
/** Connection Refused */
|
|
#define APR_STATUS_IS_ECONNREFUSED(s) ((s) == APR_ECONNREFUSED)
|
|
/** operation now in progress */
|
|
#define APR_STATUS_IS_EINPROGRESS(s) ((s) == APR_EINPROGRESS)
|
|
|
|
/**
|
|
* Software caused connection abort
|
|
* @remark
|
|
* EPROTO on certain older kernels really means ECONNABORTED, so we need to
|
|
* ignore it for them. See discussion in new-httpd archives nh.9701 & nh.9603
|
|
*
|
|
* There is potentially a bug in Solaris 2.x x<6, and other boxes that
|
|
* implement tcp sockets in userland (i.e. on top of STREAMS). On these
|
|
* systems, EPROTO can actually result in a fatal loop. See PR#981 for
|
|
* example. It's hard to handle both uses of EPROTO.
|
|
*/
|
|
#ifdef EPROTO
|
|
#define APR_STATUS_IS_ECONNABORTED(s) ((s) == APR_ECONNABORTED \
|
|
|| (s) == EPROTO)
|
|
#else
|
|
#define APR_STATUS_IS_ECONNABORTED(s) ((s) == APR_ECONNABORTED)
|
|
#endif
|
|
|
|
/** Connection Reset by peer */
|
|
#define APR_STATUS_IS_ECONNRESET(s) ((s) == APR_ECONNRESET)
|
|
/** Operation timed out
|
|
* @deprecated */
|
|
#define APR_STATUS_IS_ETIMEDOUT(s) ((s) == APR_ETIMEDOUT)
|
|
/** no route to host */
|
|
#define APR_STATUS_IS_EHOSTUNREACH(s) ((s) == APR_EHOSTUNREACH)
|
|
/** network is unreachable */
|
|
#define APR_STATUS_IS_ENETUNREACH(s) ((s) == APR_ENETUNREACH)
|
|
/** inappropiate file type or format */
|
|
#define APR_STATUS_IS_EFTYPE(s) ((s) == APR_EFTYPE)
|
|
/** broken pipe */
|
|
#define APR_STATUS_IS_EPIPE(s) ((s) == APR_EPIPE)
|
|
/** cross device link */
|
|
#define APR_STATUS_IS_EXDEV(s) ((s) == APR_EXDEV)
|
|
/** Directory Not Empty */
|
|
#define APR_STATUS_IS_ENOTEMPTY(s) ((s) == APR_ENOTEMPTY || \
|
|
(s) == APR_EEXIST)
|
|
/** @} */
|
|
|
|
#endif /* !defined(NETWARE) && !defined(OS2) && !defined(WIN32) */
|
|
|
|
/** @} */
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* ! APR_ERRNO_H */
|