⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 apr_portable.h

📁 Apache V2.0.15 Alpha For Linuxhttpd-2_0_15-alpha.tar.Z
💻 H
字号:
/* ==================================================================== * The Apache Software License, Version 1.1 * * Copyright (c) 2000-2001 The Apache Software Foundation.  All rights * reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in *    the documentation and/or other materials provided with the *    distribution. * * 3. The end-user documentation included with the redistribution, *    if any, must include the following acknowledgment: *       "This product includes software developed by the *        Apache Software Foundation (http://www.apache.org/)." *    Alternately, this acknowledgment may appear in the software itself, *    if and wherever such third-party acknowledgments normally appear. * * 4. The names "Apache" and "Apache Software Foundation" must *    not be used to endorse or promote products derived from this *    software without prior written permission. For written *    permission, please contact apache@apache.org. * * 5. Products derived from this software may not be called "Apache", *    nor may "Apache" appear in their name, without prior written *    permission of the Apache Software Foundation. * * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * ==================================================================== * * This software consists of voluntary contributions made by many * individuals on behalf of the Apache Software Foundation.  For more * information on the Apache Software Foundation, please see * <http://www.apache.org/>. *//* This header file is where you should put ANY platform specific information. * This should be the only header file that programs need to include that  * actually has platform dependant code which refers to the . */#ifndef APR_PORTABLE_H#define APR_PORTABLE_H/** * @package APR portability Routines */#include "apr.h"#include "apr_pools.h"#include "apr_thread_proc.h"#include "apr_file_io.h"#include "apr_network_io.h"#include "apr_errno.h"#include "apr_lock.h"#include "apr_time.h"#include "apr_dso.h"#if APR_HAVE_DIRENT_H#include <dirent.h>#endif#if APR_HAVE_FCNTL_H#include <fcntl.h>#endif#if APR_HAVE_PTHREAD_H#include <pthread.h>#endif#if APR_HAVE_UNION_SEMUN#include <sys/sem.h>#endif#ifdef __cplusplusextern "C" {#endif /* __cplusplus */#ifdef WIN32/* The primitives for Windows types */typedef HANDLE                apr_os_file_t;typedef HANDLE                apr_os_dir_t;typedef SOCKET                apr_os_sock_t;typedef HANDLE                apr_os_lock_t;typedef HANDLE                apr_os_thread_t;typedef PROCESS_INFORMATION   apr_os_proc_t;typedef DWORD                 apr_os_threadkey_t; typedef FILETIME              apr_os_imp_time_t;typedef SYSTEMTIME            apr_os_exp_time_t;#elif defined(OS2)typedef HFILE                 apr_os_file_t;typedef HDIR                  apr_os_dir_t;typedef int                   apr_os_sock_t;typedef HMTX                  apr_os_lock_t;typedef TID                   apr_os_thread_t;typedef PID                   apr_os_proc_t;typedef PULONG                apr_os_threadkey_t; typedef struct timeval        apr_os_imp_time_t;typedef struct tm             apr_os_exp_time_t;#elif defined(__BEOS__)#include <kernel/OS.h>struct apr_os_lock_t {	/* Inter proc */	sem_id sem_interproc;	int32  ben_interproc;	/* Intra Proc */	sem_id sem_intraproc;	int32  ben_intraproc;};typedef int                   apr_os_file_t;typedef DIR                   apr_os_dir_t;typedef int                   apr_os_sock_t;typedef struct apr_os_lock_t  apr_os_lock_t;typedef thread_id             apr_os_thread_t;typedef thread_id             apr_os_proc_t;typedef int                   apr_os_threadkey_t;typedef struct timeval        apr_os_imp_time_t;typedef struct tm             apr_os_exp_time_t;#else/* Any other OS should go above this one.  This is the lowest common * denominator typedefs for  all UNIX-like systems.  :) */#ifdef NEED_UNION_SEMUN/* it makes no sense, but this isn't defined on solaris */union semun {    long val;    struct semid_ds *buf;    ushort *array;};#endifstruct apr_os_lock_t {#if APR_USE_SYSVSEM_SERIALIZE    int crossproc;#elif APR_USE_FCNTL_SERIALIZE    int crossproc;#elif APR_USE_PROC_PTHREAD_SERIALIZE    pthread_mutex_t *crossproc; #elif APR_USE_FLOCK_SERIALIZE    int crossproc;#else    /* No Interprocess serialization, too bad. */#endif#if APR_HAS_THREADS    /* If no threads, no need for thread locks */#if APR_USE_PTHREAD_SERIALIZE    pthread_mutex_t *intraproc;#endif#endif};typedef int                   apr_os_file_t;typedef DIR                   apr_os_dir_t;typedef int                   apr_os_sock_t;typedef struct apr_os_lock_t  apr_os_lock_t;#if APR_HAS_THREADS && APR_HAVE_PTHREAD_H typedef pthread_t             apr_os_thread_t;typedef pthread_key_t         apr_os_threadkey_t;#endiftypedef pid_t                 apr_os_proc_t;typedef struct timeval        apr_os_imp_time_t;typedef struct tm             apr_os_exp_time_t;#endif/** * everything APR needs to know about an active socket to construct * an APR socket from it; currently, this is platform-independent */struct apr_os_sock_info_t {    apr_os_sock_t *os_sock; /* always required */    struct sockaddr *local; /* NULL if not yet bound */    struct sockaddr *remote; /* NULL if not connected */    int family;             /* always required (APR_INET, APR_INET6, etc. */    int type;               /* always required (SOCK_STREAM, SOCK_DGRAM, etc. */};typedef struct apr_os_sock_info_t apr_os_sock_info_t;/** * convert the file from apr type to os specific type. * @param thefile The os specific file we are converting to * @param file The apr file to convert. * @deffunc apr_status_t apr_os_file_get(apr_os_file_t *thefile, apr_file_t *file) * @tip On Unix, it is only possible to get a file descriptor from  *      an apr file type. */APR_DECLARE(apr_status_t) apr_os_file_get(apr_os_file_t *thefile,                                          apr_file_t *file);/** * convert the dir from apr type to os specific type. * @param thedir The os specific dir we are converting to * @param dir The apr dir to convert. * @deffunc apr_status_t apr_os_dir_get(apr_os_dir_t **thedir, apr_dir_t *dir) */   APR_DECLARE(apr_status_t) apr_os_dir_get(apr_os_dir_t **thedir,                                          apr_dir_t *dir);/** * Convert the socket from an apr type to an OS specific socket * @param thesock The socket to convert. * @param sock The os specifc equivelant of the apr socket.. * @deffunc apr_status_t apr_os_sock_get(apr_os_sock_t *thesock, apr_socket_t *sock) */APR_DECLARE(apr_status_t) apr_os_sock_get(apr_os_sock_t *thesock,                                          apr_socket_t *sock);/** * Convert the lock from os specific type to apr type * @param oslock The os specific lock we are converting to. * @param lock The apr lock to convert. * @deffunc apr_status_t apr_os_lock_get(apr_os_lock_t *oslock, apr_lock_t *lock) */APR_DECLARE(apr_status_t) apr_os_lock_get(apr_os_lock_t *oslock,                                           apr_lock_t *lock);/** * Get the exploded time in the platforms native format. * @param ostime the native time format * @param aprtime the time to convert * @deffunc apr_status_t apr_os_exp_time_get(apr_os_exp_time_t **ostime, apr_exploded_time_t *aprtime) */APR_DECLARE(apr_status_t) apr_os_exp_time_get(apr_os_exp_time_t **ostime,                                 apr_exploded_time_t *aprtime);/** * Get the imploded time in the platforms native format. * @param ostime the native time format * @param aprtimethe time to convert * @deffunc apr_status_t apr_os_imp_time_get(apr_os_imp_time_t **ostime, apr_time_t *aprtime) */APR_DECLARE(apr_status_t) apr_os_imp_time_get(apr_os_imp_time_t **ostime,                                               apr_time_t *aprtime);#if APR_HAS_THREADS/** * convert the thread to os specific type from apr type. * @param thethd The apr thread to convert * @param thd The os specific thread we are converting to * @deffunc apr_status_t apr_os_thread_get(apr_os_thread_t **thethd, apr_thread_t *thd) */APR_DECLARE(apr_status_t) apr_os_thread_get(apr_os_thread_t **thethd,                                             apr_thread_t *thd);/** * convert the thread private memory key to os specific type from an apr type. * @param thekey The apr handle we are converting from. * @param key The os specific handle we are converting to. * @deffunc apr_status_t apr_os_threadkey_get(apr_os_threadkey_t *thekey, apr_threadkey_t *key) */APR_DECLARE(apr_status_t) apr_os_threadkey_get(apr_os_threadkey_t *thekey,                                               apr_threadkey_t *key);#endif /* APR_HAS_THREADS *//** * convert the file from os specific type to apr type. * @param file The apr file we are converting to. * @param thefile The os specific file to convert * @param cont The pool to use if it is needed. * @deffunc apr_status_t apr_os_file_put(apr_file_t **file, apr_os_file_t *thefile, apr_pool_t *cont) * @tip On Unix, it is only possible to put a file descriptor into *      an apr file type. */APR_DECLARE(apr_status_t) apr_os_file_put(apr_file_t **file,                                          apr_os_file_t *thefile,                                          apr_pool_t *cont); /** * convert the dir from os specific type to apr type. * @param dir The apr dir we are converting to. * @param thedir The os specific dir to convert * @param cont The pool to use when creating to apr directory. * @deffunc apr_status_t apr_os_dir_put(apr_dir_t **dir, apr_os_dir_t *thedir, apr_pool_t *cont) */APR_DECLARE(apr_status_t) apr_os_dir_put(apr_dir_t **dir,                                         apr_os_dir_t *thedir,                                         apr_pool_t *cont); /** * Convert a socket from the os specific type to the apr type * @param sock The pool to use. * @param thesock The socket to convert to. * @param cont The socket we are converting to an apr type. * @deffunc apr_status_t apr_os_sock_put(apr_socket_t **sock, apr_os_sock_t *thesock, apr_pool_t *cont) */APR_DECLARE(apr_status_t) apr_os_sock_put(apr_socket_t **sock,                                           apr_os_sock_t *thesock,                                           apr_pool_t *cont);/** * Create a socket from an existing descriptor and local and remote * socket addresses. * @param apr_sock The new socket that has been set up * @param os_sock_info The os representation of the socket handle and *        other characteristics of the socket * @param cont The pool to use * @deffunc apr_status_t apr_os_sock_make(apr_socket_t **apr_sock, apr_os_sock_info_t *os_sock_info, apr_pool_t *cont) * @tip If you only know the descriptor/handle or if it isn't really *      a true socket, use apr_os_sock_put() instead. */APR_DECLARE(apr_status_t) apr_os_sock_make(apr_socket_t **apr_sock,                                           apr_os_sock_info_t *os_sock_info,                                           apr_pool_t *cont);/** * Convert the lock from os specific type to apr type * @param lock The apr lock we are converting to. * @param thelock The os specific lock to convert. * @param cont The pool to use if it is needed. * @deffunc apr_status_t apr_os_lock_put(apr_lock_t **lock, apr_os_lock_t *thelock, apr_pool_t *cont) */APR_DECLARE(apr_status_t) apr_os_lock_put(apr_lock_t **lock,                                          apr_os_lock_t *thelock,                                          apr_pool_t *cont); /** * Put the imploded time in the APR format. * @param aprtime the APR time format * @param ostime the time to convert * @param cont the pool to use if necessary * @deffunc apr_status_t apr_os_imp_time_put(apr_time_t *aprtime, apr_os_imp_time_t **ostime, apr_pool_t *cont) */APR_DECLARE(apr_status_t) apr_os_imp_time_put(apr_time_t *aprtime,                                              apr_os_imp_time_t **ostime,                                              apr_pool_t *cont); /** * Put the exploded time in the APR format. * @param aprtime the APR time format * @param ostime the time to convert * @param cont the pool to use if necessary * @deffunc apr_status_t apr_os_exp_time_put(apr_exploded_time_t *aprtime, apr_os_exp_time_t **ostime, apr_pool_t *cont) */APR_DECLARE(apr_status_t) apr_os_exp_time_put(apr_exploded_time_t *aprtime,                                              apr_os_exp_time_t **ostime,                                              apr_pool_t *cont); #if APR_HAS_THREADS/** * convert the thread from os specific type to apr type. * @param thd The apr thread we are converting to. * @param thethd The os specific thread to convert * @param cont The pool to use if it is needed. * @deffunc apr_status_t apr_os_thread_put(apr_thread_t **thd, apr_os_thread_t *thethd, */APR_DECLARE(apr_status_t) apr_os_thread_put(apr_thread_t **thd,                                            apr_os_thread_t *thethd,                                            apr_pool_t *cont);/** * convert the thread private memory key from os specific type to apr type. * @param key The apr handle we are converting to. * @param thekey The os specific handle to convert * @param cont The pool to use if it is needed. * @deffunc apr_status_t apr_os_threadkey_put(apr_threadkey_t **key, apr_os_threadkey_t *thekey, apr_pool_t *cont) */APR_DECLARE(apr_status_t) apr_os_threadkey_put(apr_threadkey_t **key,                                               apr_os_threadkey_t *thekey,                                               apr_pool_t *cont);#endif /* APR_HAS_THREADS */#ifdef __cplusplus}#endif#endif  /* ! APR_PORTABLE_H */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -