tomcat-dev mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From cos...@apache.org
Subject cvs commit: jakarta-tomcat-connectors/jk/native2/jni jk_jnicb.c jk_jnicb.exp jk_jnicb.h
Date Sat, 01 Dec 2001 22:42:33 GMT
costin      01/12/01 14:42:33

  Added:       jk/native2/jni jk_jnicb.c jk_jnicb.exp jk_jnicb.h
  Log:
  The jni code, imported from native/
  
  Revision  Changes    Path
  1.1                  jakarta-tomcat-connectors/jk/native2/jni/jk_jnicb.c
  
  Index: jk_jnicb.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 <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/>.   *
   *                                                                           *
   * ========================================================================= */
  
  /***************************************************************************
   * Description: JNI callbacks implementation for the JNI in process adapter*
   * Author:      Gal Shachor <shachor@il.ibm.com>                           *
   * Version:     $Revision: 1.1 $                                           *
   ***************************************************************************/
  
  #include "jk_jnicb.h"
  #include "jk_service.h"
  #include "jk_util.h"
  #include "jk_pool.h"
  
  /*
   * Class:     org_apache_tomcat_modules_server_JNIConnectionHandler
   * Method:    getNumberOfHeaders
   * Signature: (JJ)I
   */
  JNIEXPORT jint JNICALL 
  Java_org_apache_tomcat_modules_server_JNIConnectionHandler_getNumberOfHeaders
    (JNIEnv *env, jobject o, jlong s, jlong l)
  {
      /* [V] Convert indirectly from jlong -> int -> pointer to shut up gcc */
      /*     I hope it's okay on other compilers and/or machines...         */
      jk_ws_service_t *ps = (jk_ws_service_t *)(int)s;
      jk_logger_t *pl = (jk_logger_t *)(int)l;
  
      jk_log(pl, JK_LOG_DEBUG, "Into JNIConnectionHandler::getNumberOfHeaders\n");
  
      if(!ps) {
  	jk_log(pl, JK_LOG_ERROR, 
                 "In JNIConnectionHandler::getNumberOfHeaders, NULL ws service object\n");
  	/* [V] JNIConnectionHandler doesn't handle this */
  	return -1;
      }
  
      jk_log(pl, JK_LOG_DEBUG,
  	   "Done JNIConnectionHandler::getNumberOfHeaders, found %d headers\n",
  	   ps->num_headers);
      return (jint)ps->num_headers;
  }
  
  /*
   * Class:     org_apache_tomcat_modules_server_JNIConnectionHandler
   * Method:    read
   * Signature: (JJ[BII)I
   */
  JNIEXPORT jint JNICALL 
  Java_org_apache_tomcat_modules_server_JNIConnectionHandler_read
    (JNIEnv *env, jobject o, jlong s, jlong l, jbyteArray buf, jint from, jint cnt)
  {
      jk_ws_service_t *ps = (jk_ws_service_t *)(int)s;
      jk_logger_t *pl = (jk_logger_t *)(int)l;
      jint rc = -1;
      jboolean iscommit;
      jbyte *nbuf;
      unsigned nfrom = (unsigned)from;
      unsigned ncnt = (unsigned)cnt;
      unsigned acc = 0;
  
      jk_log(pl, JK_LOG_DEBUG, "Into JNIConnectionHandler::read\n");
  
      if(!ps) {
          jk_log(pl, JK_LOG_ERROR, 
                 "In JNIConnectionHandler::read, NULL ws service object\n");
  	return -1;
      }
  
      nbuf = (*env)->GetByteArrayElements(env, buf, &iscommit);
  
      if(!nbuf) {
          jk_log(pl, JK_LOG_ERROR, 
                 "In JNIConnectionHandler::read, GetByteArrayElements error\n");
  	return -1;
      }
      
      if(!ps->read(ps, nbuf + nfrom, ncnt, &acc)) {
          jk_log(pl, JK_LOG_ERROR, 
                 "In JNIConnectionHandler::read, failed to read from web server\n");
      } else {
          rc = (jint)acc;
      }
  
      (*env)->ReleaseByteArrayElements(env, buf, nbuf, 0);
  
      jk_log(pl, JK_LOG_DEBUG, "Done JNIConnectionHandler::read\n");
      return rc;
  }
  
  /*
   * Class:     org_apache_tomcat_modules_server_JNIConnectionHandler
   * Method:    readEnvironment
   * Signature: (JJ[Ljava/lang/String;)I
   */
  JNIEXPORT jint JNICALL 
  Java_org_apache_tomcat_modules_server_JNIConnectionHandler_readEnvironment
    (JNIEnv *env, jobject o, jlong s, jlong l, jobjectArray envbuf)
  {
      jk_ws_service_t *ps = (jk_ws_service_t *)(int)s;
      jk_logger_t *pl = (jk_logger_t *)(int)l;
      char port[10];
  
      jk_log(pl, JK_LOG_DEBUG, 
             "Into JNIConnectionHandler::readEnvironment. Environment follows --->\n");
  
      if(!ps) {
          jk_log(pl, JK_LOG_ERROR, 
                 "In JNIConnectionHandler::readEnvironment, NULL ws service object\n");
  	return JK_FALSE;
      }
  
      sprintf(port, "%d", ps->server_port);
          
      if(ps->method) {
          (*env)->SetObjectArrayElement(env, 
                                        envbuf, 
                                        0, 
                                        (*env)->NewStringUTF(env, ps->method));
  	jk_log(pl, JK_LOG_DEBUG, "---> method: %s\n", ps->method);
      }
      if(ps->req_uri) {
          (*env)->SetObjectArrayElement(env, 
                                        envbuf, 
                                        1, 
                                        (*env)->NewStringUTF(env, ps->req_uri));
  	jk_log(pl, JK_LOG_DEBUG, "---> req_uri: %s\n", ps->req_uri);
      }
      if(ps->query_string) {
          (*env)->SetObjectArrayElement(env, 
                                        envbuf, 
                                        2, 
                                        (*env)->NewStringUTF(env, ps->query_string));
          jk_log(pl, JK_LOG_DEBUG, "---> query_string: %s\n", ps->query_string);
      }
      if(ps->remote_addr) {
          (*env)->SetObjectArrayElement(env, 
                                        envbuf, 
                                        3, 
                                        (*env)->NewStringUTF(env, ps->remote_addr));
  	jk_log(pl, JK_LOG_DEBUG, "---> remote_addr: %s\n", ps->remote_addr);
      }
      if(ps->remote_host) {
          (*env)->SetObjectArrayElement(env, 
                                        envbuf, 
                                        4, 
                                        (*env)->NewStringUTF(env, ps->remote_host));
  	jk_log(pl, JK_LOG_DEBUG, "---> remote_host: %s\n", ps->remote_host);
      }
      if(ps->server_name) {
          (*env)->SetObjectArrayElement(env, 
                                        envbuf, 
                                        5, 
                                        (*env)->NewStringUTF(env, ps->server_name));
  	jk_log(pl, JK_LOG_DEBUG, "---> server_name: %s\n", ps->server_name);
      }
  
      (*env)->SetObjectArrayElement(env, 
                                    envbuf, 
                                    6, 
                                    (*env)->NewStringUTF(env, port));
      jk_log(pl, JK_LOG_DEBUG, "---> server_port: %s\n", port);
  
      if(ps->auth_type) {
          (*env)->SetObjectArrayElement(env, 
                                        envbuf, 
                                        7, 
                                        (*env)->NewStringUTF(env, ps->auth_type));
  	jk_log(pl, JK_LOG_DEBUG, "---> auth_type: %s\n", ps->auth_type);
      }
      if(ps->remote_user) {
          (*env)->SetObjectArrayElement(env, 
                                        envbuf, 
                                        8, 
                                        (*env)->NewStringUTF(env, ps->remote_user));
  	jk_log(pl, JK_LOG_DEBUG, "---> remote_user: %s\n", ps->remote_user);
      }
      if(ps->is_ssl) {
          (*env)->SetObjectArrayElement(env, 
                                        envbuf, 
                                        9, 
                                        (*env)->NewStringUTF(env, "https"));
      } else {
          (*env)->SetObjectArrayElement(env, 
                                        envbuf, 
                                        9, 
                                        (*env)->NewStringUTF(env, "http"));
      }
      jk_log(pl, JK_LOG_DEBUG, "---> is_ssl: %s\n", ps->is_ssl ? "yes" : "no");
  
      if(ps->protocol) {
          (*env)->SetObjectArrayElement(env, 
                                        envbuf, 
                                        10, 
                                        (*env)->NewStringUTF(env, ps->protocol));
          jk_log(pl, JK_LOG_DEBUG, "---> protocol: %s\n", ps->protocol);
      }
      if(ps->server_software) {
          (*env)->SetObjectArrayElement(env, 
                                        envbuf, 
                                        11, 
                                        (*env)->NewStringUTF(env, ps->server_software));
          jk_log(pl, JK_LOG_DEBUG, "---> server_software: %s\n", ps->server_software);
      }
      if(ps->is_ssl) {
          if(ps->ssl_cert) {
              (*env)->SetObjectArrayElement(env, 
                                            envbuf, 
                                            12, 
                                            (*env)->NewStringUTF(env, ps->ssl_cert));
              jk_log(pl, JK_LOG_DEBUG, "---> ssl_cert: %s\n", ps->ssl_cert);
          }
          
          if(ps->ssl_cipher) {
              (*env)->SetObjectArrayElement(env, 
                                            envbuf, 
                                            13, 
                                            (*env)->NewStringUTF(env, ps->ssl_cipher));
              jk_log(pl, JK_LOG_DEBUG, "---> ssl_cipher: %s\n", ps->ssl_cipher);
          }
  
          if(ps->ssl_session) {
              (*env)->SetObjectArrayElement(env, 
                                            envbuf, 
                                            14, 
                                            (*env)->NewStringUTF(env, ps->ssl_session));
              jk_log(pl, JK_LOG_DEBUG, "---> ssl_session: %s\n", ps->ssl_session);
          }
      }
  
      jk_log(pl, JK_LOG_DEBUG, 
             "Done JNIConnectionHandler::readEnvironment\n");
  
  
      return JK_TRUE;
  }
  
  /*
   * Class:     org_apache_tomcat_modules_server_JNIConnectionHandler
   * Method:    readHeaders
   * Signature: (JJ[Ljava/lang/String;[Ljava/lang/String;)I
   */
  JNIEXPORT jint JNICALL 
  Java_org_apache_tomcat_modules_server_JNIConnectionHandler_readHeaders
    (JNIEnv *env, jobject o, jlong s, jlong l, jobjectArray hnames, jobjectArray hvalues)
  {
      jk_ws_service_t *ps = (jk_ws_service_t *)(int)s;
      jk_logger_t *pl = (jk_logger_t *)(int)l;
      unsigned i;
  
      jk_log(pl, JK_LOG_DEBUG, "Into JNIConnectionHandler::readHeaders\n");
  
      if(!ps) {
          jk_log(pl, JK_LOG_ERROR, 
             "In JNIConnectionHandler::readHeaders, NULL ws service object\n");
  	   return JK_FALSE;
      }
  
      jk_log(pl, JK_LOG_DEBUG, "In JNIConnectionHandler::readHeaders, %d headers follow --->\n",
  	   ps->num_headers);
  
      for(i = 0 ; i < ps->num_headers ; i++) {
          (*env)->SetObjectArrayElement(env, 
                                        hnames, 
                                        i, 
                                        (*env)->NewStringUTF(env, ps->headers_names[i]));
          (*env)->SetObjectArrayElement(env, 
                                        hvalues, 
                                        i, 
                                        (*env)->NewStringUTF(env, ps->headers_values[i]));
  	jk_log(pl, JK_LOG_DEBUG, "---> %s = %s\n",
  	       ps->headers_names[i], ps->headers_values[i]);
      }
      jk_log(pl, JK_LOG_DEBUG, 
  	   "Done JNIConnectionHandler::readHeaders\n");
  
      return JK_TRUE;
  }
  
  /*
   * Class:     org_apache_tomcat_modules_server_JNIConnectionHandler
   * Method:    startReasponse
   * Signature: (JJILjava/lang/String;[Ljava/lang/String;[Ljava/lang/String;I)I
   */
  JNIEXPORT jint JNICALL 
  Java_org_apache_tomcat_modules_server_JNIConnectionHandler_startReasponse
    (JNIEnv *env, jobject o, jlong s, jlong l, 
     jint sc, jstring msg, jobjectArray hnames, jobjectArray hvalues, jint hcnt)
  {
      jk_ws_service_t *ps = (jk_ws_service_t *)(int)s;
      jk_logger_t *pl = (jk_logger_t *)(int)l;
      const char *nmsg = NULL;
      char **nhnames = NULL;
      char **nhvalues = NULL;
      jstring *shnames = NULL;
      jstring *shvalues = NULL;
      int i = 0;
      int ok = JK_TRUE;
  
      jk_log(pl, JK_LOG_DEBUG, "Into JNIConnectionHandler::startReasponse\n");
  
      if(!ps) {
          jk_log(pl, JK_LOG_ERROR, 
  	       "In JNIConnectionHandler::startReasponse, NULL ws service object\n");
  	return JK_FALSE;
      }
  
      jk_log(pl, JK_LOG_DEBUG, "In JNIConnectionHandler::startReasponse, %d headers follow
--->\n",
  	   hcnt);
  
      if(hcnt) {
          ok = JK_FALSE;
  
          nhnames = (char **)jk_pool_alloc(ps->pool, hcnt * sizeof(char *));
          nhvalues = (char **)jk_pool_alloc(ps->pool, hcnt * sizeof(char *));         
  
          shnames = (jstring *)jk_pool_alloc(ps->pool, hcnt * sizeof(jstring));
          shvalues = (jstring *)jk_pool_alloc(ps->pool, hcnt * sizeof(jstring));
  
          if(nhvalues && nhnames && shnames && shnames) {	    
              for( ; i < hcnt ; i++) {
                  jboolean iscommit;
  
                  shvalues[i] = shnames[i] = NULL;
                  nhnames[i] = nhvalues[i] = NULL;
  
                  shnames[i] = (*env)->GetObjectArrayElement(env, hnames, i);
                  shvalues[i] = (*env)->GetObjectArrayElement(env, hvalues, i);
  
                  if(!shvalues[i] || !shnames[i]) {
                      jk_log(pl, JK_LOG_ERROR, 
                             "In JNIConnectionHandler::startReasponse, GetObjectArrayElement
error\n");
                      break;
                  }
  
                  nhnames[i] = (char *)(*env)->GetStringUTFChars(env, shnames[i], &iscommit);
                  nhvalues[i] = (char *)(*env)->GetStringUTFChars(env, shvalues[i], &iscommit);
  
                  if(!nhvalues[i] || !nhnames[i]) {
                      jk_log(pl, JK_LOG_ERROR, 
                             "In JNIConnectionHandler::startReasponse, GetStringUTFChars error\n");
                      break;
                  }
  		
  		jk_log(pl, JK_LOG_DEBUG, "---> %s=%s\n", nhnames[i], nhvalues[i]);	
              }
              if(i == hcnt) {
                  ok = JK_TRUE;
  		jk_log(pl, JK_LOG_DEBUG, 
                         "In JNIConnectionHandler::startReasponse. ----- End headers.\n",
hcnt);
              }
  	} else {
  	    jk_log(pl, JK_LOG_ERROR,
  	           "In JNIConnectionHandler::startReasponse, memory allocation error\n");
  	}
      }			        
  
      if(msg && ok) {
          jboolean iscommit;
          nmsg = (*env)->GetStringUTFChars(env, msg, &iscommit);
          if(!nmsg) {
              ok = JK_FALSE;
          }
      }
  
      if(ok) {
          if(!ps->start_response(ps, sc, nmsg, (const char**)nhnames, (const char**)nhvalues,
hcnt)) {
              ok = JK_FALSE;
              jk_log(pl, JK_LOG_ERROR, 
                     "In JNIConnectionHandler::startReasponse, servers startReasponse failed\n");
          }
      }
  
      if(nmsg) {
          (*env)->ReleaseStringUTFChars(env, msg, nmsg);
      }
          
      if(i < hcnt) {
          i++;
      }
  
      if(nhvalues) {
          int j;
  
          for(j = 0 ; j < i ; j++) {
              if(nhvalues[j]) {
                  (*env)->ReleaseStringUTFChars(env, shvalues[j], nhvalues[j]);
              }
          }
      }
  
      if(nhnames) {
          int j;
  
          for(j = 0 ; j < i ; j++) {
              if(nhnames[j]) {
                  (*env)->ReleaseStringUTFChars(env, shnames[j], nhnames[j]);
              }
          }
      }
      jk_log(pl, JK_LOG_DEBUG, "Done JNIConnectionHandler::startReasponse.\n");
  
      return ok;
  }
  
  /*
   * Class:     org_apache_tomcat_modules_server_JNIConnectionHandler
   * Method:    write
   * Signature: (JJ[BII)I
   */
  JNIEXPORT jint JNICALL 
  Java_org_apache_tomcat_modules_server_JNIConnectionHandler_write
    (JNIEnv *env, jobject o, jlong s, jlong l, jbyteArray buf, jint from, jint cnt)
  {
      jk_ws_service_t *ps = (jk_ws_service_t *)(int)s;
      jk_logger_t *pl = (jk_logger_t *)(int)l;
      jint rc = JK_FALSE;   
      jboolean iscommit;
      jbyte *nbuf;
      unsigned nfrom = (unsigned)from;
      unsigned ncnt = (unsigned)cnt;
  
      jk_log(pl, JK_LOG_DEBUG, 
             "In JNIConnectionHandler::write\n");
  
      if(!ps) {
      	jk_log(pl, JK_LOG_ERROR, 
  	    "In JNIConnectionHandler::write, NULL ws service object\n");
  	return JK_FALSE;
      }
      
      nbuf = (*env)->GetByteArrayElements(env, buf, &iscommit);
  
      if(!nbuf) {
          jk_log(pl, JK_LOG_ERROR, 
                 "In JNIConnectionHandler::write, GetByteArrayElements error\n");
  	return JK_FALSE;
      }
  
      if(!ps->write(ps, nbuf + nfrom, ncnt)) {
          jk_log(pl, JK_LOG_ERROR, 
                     "In JNIConnectionHandler::write, failed to write to the web server\n");
      } else {
          rc = (jint)JK_TRUE;
      }
  
      (*env)->ReleaseByteArrayElements(env, buf, nbuf, JNI_ABORT);
  
      return rc; 
  }
  
  
  
  1.1                  jakarta-tomcat-connectors/jk/native2/jni/jk_jnicb.exp
  
  Index: jk_jnicb.exp
  ===================================================================
  Java_org_apache_tomcat_modules_server_JNIConnectionHandler_getNumberOfHeaders,
  Java_org_apache_tomcat_modules_server_JNIConnectionHandler_read,
  Java_org_apache_tomcat_modules_server_JNIConnectionHandler_readEnvironment,
  Java_org_apache_tomcat_modules_server_JNIConnectionHandler_readHeaders,
  Java_org_apache_tomcat_modules_server_JNIConnectionHandler_startReasponse,
  Java_org_apache_tomcat_modules_server_JNIConnectionHandler_write
  
  
  
  
  1.1                  jakarta-tomcat-connectors/jk/native2/jni/jk_jnicb.h
  
  Index: jk_jnicb.h
  ===================================================================
  /* DO NOT EDIT THIS FILE - it is machine generated */
  #include <jni.h>
  /* Header for class org_apache_tomcat_modules_server_JNIConnectionHandler */
  
  #ifndef _Included_org_apache_tomcat_modules_server_JNIConnectionHandler
  #define _Included_org_apache_tomcat_modules_server_JNIConnectionHandler
  #ifdef __cplusplus
  extern "C" {
  #endif
  /*
   * Class:     org_apache_tomcat_modules_server_JNIConnectionHandler
   * Method:    getNumberOfHeaders
   * Signature: (JJ)I
   */
  JNIEXPORT jint JNICALL Java_org_apache_tomcat_modules_server_JNIConnectionHandler_getNumberOfHeaders
    (JNIEnv *, jobject, jlong, jlong);
  
  /*
   * Class:     org_apache_tomcat_modules_server_JNIConnectionHandler
   * Method:    read
   * Signature: (JJ[BII)I
   */
  JNIEXPORT jint JNICALL Java_org_apache_tomcat_modules_server_JNIConnectionHandler_read
    (JNIEnv *, jobject, jlong, jlong, jbyteArray, jint, jint);
  
  /*
   * Class:     org_apache_tomcat_modules_server_JNIConnectionHandler
   * Method:    readEnvironment
   * Signature: (JJ[Ljava/lang/String;)I
   */
  JNIEXPORT jint JNICALL Java_org_apache_tomcat_modules_server_JNIConnectionHandler_readEnvironment
    (JNIEnv *, jobject, jlong, jlong, jobjectArray);
  
  /*
   * Class:     org_apache_tomcat_modules_server_JNIConnectionHandler
   * Method:    readHeaders
   * Signature: (JJ[Ljava/lang/String;[Ljava/lang/String;)I
   */
  JNIEXPORT jint JNICALL Java_org_apache_tomcat_modules_server_JNIConnectionHandler_readHeaders
    (JNIEnv *, jobject, jlong, jlong, jobjectArray, jobjectArray);
  
  /*
   * Class:     org_apache_tomcat_modules_server_JNIConnectionHandler
   * Method:    startReasponse
   * Signature: (JJILjava/lang/String;[Ljava/lang/String;[Ljava/lang/String;I)I
   */
  JNIEXPORT jint JNICALL Java_org_apache_tomcat_modules_server_JNIConnectionHandler_startReasponse
    (JNIEnv *, jobject, jlong, jlong, jint, jstring, jobjectArray, jobjectArray, jint);
  
  /*
   * Class:     org_apache_tomcat_modules_server_JNIConnectionHandler
   * Method:    write
   * Signature: (JJ[BII)I
   */
  JNIEXPORT jint JNICALL Java_org_apache_tomcat_modules_server_JNIConnectionHandler_write
    (JNIEnv *, jobject, jlong, jlong, jbyteArray, jint, jint);
  
  #ifdef __cplusplus
  }
  #endif
  #endif
  
  
  

--
To unsubscribe, e-mail:   <mailto:tomcat-dev-unsubscribe@jakarta.apache.org>
For additional commands, e-mail: <mailto:tomcat-dev-help@jakarta.apache.org>


Mime
View raw message