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

📄 jk_channel.h

📁 Tomcat 4.1与WebServer集成组件的源代码包.
💻 H
字号:
/* ========================================================================= * *                                                                           * *                 The Apache Software License,  Version 1.1                 * *                                                                           * *          Copyright (c) 1999-2001 The Apache Software Foundation.          * *                           All rights reserved.                            * *                                                                           * * ========================================================================= * *                                                                           * * Redistribution and use in source and binary forms,  with or without modi- * * fication, are permitted provided that the following conditions are met:   * *                                                                           * * 1. Redistributions of source code  must retain the above copyright notice * *    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 acknowlegement:                             * *                                                                           * *       "This product includes  software developed  by the Apache  Software * *        Foundation <http://www.apache.org/>."                              * *                                                                           * *    Alternately, this acknowlegement may appear in the software itself, if * *    and wherever such third-party acknowlegements normally appear.         * *                                                                           * * 4. The names  "The  Jakarta  Project",  "Jk",  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 names 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 indivi- * * duals on behalf of the  Apache Software Foundation.  For more information * * on the Apache Software Foundation, please see <http://www.apache.org/>.   * *                                                                           * * ========================================================================= */#ifndef JK_CHANNEL_H#define JK_CHANNEL_H#include "jk_global.h"#include "jk_env.h"#include "jk_logger.h"#include "jk_pool.h"#include "jk_msg.h"#include "jk_service.h"#ifdef __cplusplusextern "C" {#endif /* __cplusplus */struct jk_env;struct jk_worker;struct jk_endpoint;struct jk_channel;#define CH_OPEN 4#define CH_CLOSE 5#define CH_READ 6#define CH_WRITE 7    typedef struct jk_channel jk_channel_t;/** * Abstraction (interface) for sending/receiving blocks of data ( packets ). * This will be used to replace the current TCP/socket code and allow other * transports. JNI, shmem, doors and other mechanisms can be tryed out, and  * we can also have a gradual transition to APR. The current tcp-based transport * will be refactored to this interface. *  * XXX Experimental *  * Issues: *  - Should the transport also check the packet integrity ( envelope ) ? *  - This is supposed to work for send/receive sequences, and the buffer *   shouldn't be modified until a send/receive is completed ( we want to *   avoid memcpy ) *  - We need to extend/generalize the mechanisms in 'worker' to support other *   types of internal interfaces. *  - this interface is using get/setProperty model, like in Java beans ( well,  *    just a generic get/set method, no individual setters ). This is different *    from worker, which gets a map at startup. This model should also allow  *    run-time queries for status, management, etc - but it may be too complex. *  * @author Costin Manolache */struct jk_channel {    struct jk_bean *mbean;    /* JK_TRUE if the channel is 'stream' based, i.e. it works using       send() followed by blocking reads().       XXX make it type and define an enum of supported types ?       The only alternative right now is JNI ( and doors ), where       a single thread is used. After the first packet is sent the       java side takes control and directly dispatch messages using the       jni  ( XXX review - it would be simple with continuations, but       send/receive flow is hard to replicate on jni )     */    int is_stream;        struct jk_workerEnv *workerEnv;    struct jk_worker *worker;     char *workerName;        int serverSide;        /** Open the communication channel     */    int (JK_METHOD *open)(struct jk_env *env, jk_channel_t *_this, 			  struct jk_endpoint *endpoint );        /** Close the communication channel     */    int (JK_METHOD *close)(struct jk_env *env, jk_channel_t *_this, 			   struct jk_endpoint *endpoint );      /** Send a packet   */    int (JK_METHOD *send)(struct jk_env *env, jk_channel_t *_this,			  struct jk_endpoint *endpoint,                          struct jk_msg *msg );        /** Receive a packet     */    int (JK_METHOD *recv)(struct jk_env *env, jk_channel_t *_this,			  struct jk_endpoint *endpoint,                          struct jk_msg *msg );    /** Called before request processing, to initialize resources.        All following calls will be in the same thread.     */    int (JK_METHOD *beforeRequest)(struct jk_env *env, jk_channel_t *_this,                                   struct jk_worker *worker,                                   struct jk_endpoint *endpoint,                                   struct jk_ws_service *r );			      /** Called after request processing. Used to be worker.done()     */    int (JK_METHOD *afterRequest)(struct jk_env *env, jk_channel_t *_this,                                  struct jk_worker *worker,                                  struct jk_endpoint *endpoint,                                  struct jk_ws_service *r );       /** Obtain the channel status code     */    int (JK_METHOD *status)(struct jk_env *env,                             struct jk_worker *worker,                            jk_channel_t *_this);    void *_privatePtr;};int JK_METHOD jk2_channel_invoke(struct jk_env *env, struct jk_bean *bean, struct jk_endpoint *ep, int code,                                 struct jk_msg *msg, int raw);int JK_METHOD jk2_channel_setAttribute(struct jk_env *env, struct jk_bean *mbean, char *name, void *valueP);#ifdef __cplusplus}#endif /* __cplusplus */#endif 

⌨️ 快捷键说明

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