costin      02/05/26 00:33:49

  Added:       jk/native2/common jk_channel.c
  Log:
  Common dispatcher for all channels - allow any jk channel to be called by
  the JNI code.
  
  This is not yet completed, but will reduce the work in 1/2, since the
  same code will be used on both sides and optimizations will be shared
  by all components.
  
  I hope to see in few months at least a doors channel, and maybe play
  with message queues and some windows-specific things - just for the fun
  of doing a small benchmark.
  
  Revision  Changes    Path
  1.1                  jakarta-tomcat-connectors/jk/native2/common/jk_channel.c
  
  Index: jk_channel.c
  ===================================================================
  /* ========================================================================= *
   *                                                                           *
   *                 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 <[EMAIL PROTECTED]>.                        *
   *                                                                           *
   * 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/>.   *
   *                                                                           *
   * ========================================================================= */
  
  /**
   * Common methods to all channels.
   * 
   * @author: Costin Manolache
   */
  
  #include "jk_map.h"
  #include "jk_env.h"
  #include "jk_channel.h"
  #include "jk_global.h"
  
  #include <string.h>
  #include "jk_registry.h"
  
  #define CH_SET_ATTRIBUTE 0
  #define CH_GET_ATTRIBUTE 1
  #define CH_INIT 2
  #define CH_DESTROY 3
  
  
  #define CH_OPEN 4
  #define CH_CLOSE 5
  #define CH_READ 6
  #define CH_WRITE 7
  
      
  /** Called by java ( local or remote ). 
   */
  int JK_METHOD jk2_channel_dispatch(jk_env_t *env, void *target, jk_endpoint_t *ep, 
jk_msg_t *msg)
  {
      jk_bean_t *bean=(jk_bean_t *)target;
      jk_channel_t *ch=(jk_channel_t *)bean->object;
      int rc=JK_OK;
  
      int code=msg->getByte(env, msg );
      
      if( ch->mbean->debug > 0 )
          env->l->jkLog(env, env->l, JK_LOG_INFO, 
                        "ch.%d() \n", code);
      
      switch( code ) {
      case CH_SET_ATTRIBUTE: {
          char *name=msg->getString( env, msg );
          char *value=msg->getString( env, msg );
          if( ch->mbean->debug > 0 )
              env->l->jkLog(env, env->l, JK_LOG_INFO, 
                            "ch.setAttribute() %s %s %p\n", name, value, 
bean->setAttribute);
          if( bean->setAttribute != NULL)
              bean->setAttribute(env, bean, name, value );
          return JK_OK;
      }
      case CH_INIT: { 
          if( ch->mbean->debug > 0 )
              env->l->jkLog(env, env->l, JK_LOG_INFO, "ch.init()\n");
          if( ch->mbean->init != NULL )
              rc=ch->mbean->init(env, ch->mbean);
          return rc;
      }
      case CH_DESTROY: {
          if( ch->mbean->debug > 0 )
              env->l->jkLog(env, env->l, JK_LOG_INFO, "ch.init()\n");
          if( ch->mbean->destroy != NULL )
              rc=ch->mbean->destroy(env, ch->mbean);
          return rc;
          return rc;
      }
      case CH_OPEN: {
          if( ch->mbean->debug > 0 )
              env->l->jkLog(env, env->l, JK_LOG_INFO, "ch.open()\n");
          if( ch->open != NULL )
              rc=ch->open(env, ch, ep);
          return rc;
      }
      case CH_CLOSE: {
          if( ch->mbean->debug > 0 )
              env->l->jkLog(env, env->l, JK_LOG_INFO, "ch.close()\n");
          if( ch->close != NULL )
              rc=ch->close(env, ch, ep);
          return rc;
      }
      case CH_READ: {
          if( ch->mbean->debug > 0 )
              env->l->jkLog(env, env->l, JK_LOG_INFO, "ch.recv()\n");
          if( ch->recv != NULL )
              rc=ch->recv(env, ch, ep, msg);
          return rc;
      }
      case CH_WRITE: {
          if( ch->mbean->debug > 0 )
              env->l->jkLog(env, env->l, JK_LOG_INFO, "ch.send()\n");
          if( ch->send != NULL )
              rc=ch->send(env, ch, ep, msg);
          return rc;
      }
      }/* switch */
      return JK_ERR;
  }
  
  int JK_METHOD jk2_channel_setWorkerEnv( jk_env_t *env, jk_channel_t *ch, 
jk_workerEnv_t *wEnv ) {
      wEnv->registerHandler( env, wEnv, "channel",
                             "channelDispatch", JK_HANDLE_CH_DISPATCH,
                             jk2_channel_dispatch, NULL );
      return JK_OK;
  }
  
  
  
  

--
To unsubscribe, e-mail:   <mailto:[EMAIL PROTECTED]>
For additional commands, e-mail: <mailto:[EMAIL PROTECTED]>

Reply via email to