📄 jk_channel.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 + -