home *** CD-ROM | disk | FTP | other *** search
/ PC Online 1999 April / PCO0499.ISO / filesbbs / os2 / apach134.arj / APACH134.ZIP / src / os / tpf / os.c < prev    next >
Encoding:
C/C++ Source or Header  |  1999-01-01  |  5.8 KB  |  178 lines

  1. /* ====================================================================
  2.  * Copyright (c) 1998-1999 The Apache Group.  All rights reserved.
  3.  *
  4.  * Redistribution and use in source and binary forms, with or without
  5.  * modification, are permitted provided that the following conditions
  6.  * are met:
  7.  *
  8.  * 1. Redistributions of source code must retain the above copyright
  9.  *    notice, this list of conditions and the following disclaimer.
  10.  *
  11.  * 2. Redistributions in binary form must reproduce the above copyright
  12.  *    notice, this list of conditions and the following disclaimer in
  13.  *    the documentation and/or other materials provided with the
  14.  *    distribution.
  15.  *
  16.  * 3. All advertising materials mentioning features or use of this
  17.  *    software must display the following acknowledgment:
  18.  *    "This product includes software developed by the Apache Group
  19.  *    for use in the Apache HTTP server project (http://www.apache.org/)."
  20.  *
  21.  * 4. The names "Apache Server" and "Apache Group" must not be used to
  22.  *    endorse or promote products derived from this software without
  23.  *    prior written permission. For written permission, please contact
  24.  *    apache@apache.org.
  25.  *
  26.  * 5. Products derived from this software may not be called "Apache"
  27.  *    nor may "Apache" appear in their names without prior written
  28.  *    permission of the Apache Group.
  29.  *
  30.  * 6. Redistributions of any form whatsoever must retain the following
  31.  *    acknowledgment:
  32.  *    "This product includes software developed by the Apache Group
  33.  *    for use in the Apache HTTP server project (http://www.apache.org/)."
  34.  *
  35.  * THIS SOFTWARE IS PROVIDED BY THE APACHE GROUP ``AS IS'' AND ANY
  36.  * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  37.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  38.  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE APACHE GROUP OR
  39.  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  40.  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  41.  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  42.  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  43.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
  44.  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  45.  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
  46.  * OF THE POSSIBILITY OF SUCH DAMAGE.
  47.  * ====================================================================
  48.  *
  49.  * This software consists of voluntary contributions made by many
  50.  * individuals on behalf of the Apache Group and was originally based
  51.  * on public domain software written at the National Center for
  52.  * Supercomputing Applications, University of Illinois, Urbana-Champaign.
  53.  * For more information on the Apache Group and the Apache HTTP server
  54.  * project, please see <http://www.apache.org/>.
  55.  *
  56.  */
  57.  
  58. /*
  59.  * This file will include OS specific functions which are not inlineable.
  60.  * Any inlineable functions should be defined in os-inline.c instead.
  61.  */
  62.  
  63. #include "httpd.h"
  64. #include "http_core.h"
  65. #include "os.h"
  66.  
  67. /* Check the Content-Type to decide if conversion is needed */
  68. int ap_checkconv(struct request_rec *r)
  69. {
  70.     int convert_to_ascii;
  71.     const char *type;
  72.  
  73.     /* To make serving of "raw ASCII text" files easy (they serve faster 
  74.      * since they don't have to be converted from EBCDIC), a new
  75.      * "magic" type prefix was invented: text/x-ascii-{plain,html,...}
  76.      * If we detect one of these content types here, we simply correct
  77.      * the type to the real text/{plain,html,...} type. Otherwise, we
  78.      * set a flag that translation is required later on.
  79.      */
  80.  
  81.     type = (r->content_type == NULL) ? ap_default_type(r) : r->content_type;
  82.  
  83.     /* If no content type is set then treat it as (ebcdic) text/plain */
  84.     convert_to_ascii = (type == NULL);
  85.  
  86.     /* Conversion is applied to text/ files only, if ever. */
  87.     if (type && (strncasecmp(type, "text/", 5) == 0 ||
  88.          strncasecmp(type, "message/", 8) == 0)) {
  89.     if (strncasecmp(type, ASCIITEXT_MAGIC_TYPE_PREFIX,
  90.             sizeof(ASCIITEXT_MAGIC_TYPE_PREFIX)-1) == 0)
  91.         r->content_type = ap_pstrcat(r->pool, "text/",
  92.                      type+sizeof(ASCIITEXT_MAGIC_TYPE_PREFIX)-1,
  93.                      NULL);
  94.         else
  95.         /* translate EBCDIC to ASCII */
  96.         convert_to_ascii = 1;
  97.     }
  98.     /* Enable conversion if it's a text document */
  99.     ap_bsetflag(r->connection->client, B_EBCDIC2ASCII, convert_to_ascii);
  100.  
  101.     return convert_to_ascii;
  102. }
  103.  
  104. int tpf_select(int maxfds, fd_set *reads, fd_set *writes, fd_set *excepts, struct timeval *tv)
  105. {
  106.     int sockets[24];
  107.     int no_reads = 0;
  108.     int no_writes = 0;
  109.     int no_excepts = 0;
  110.     int timeout = 0;
  111.     int counter = 0;
  112.     int i;
  113.     fd_set *temp;
  114.     
  115.     if(maxfds) {
  116.         if(reads)
  117.             temp = reads;
  118.         else if(writes)
  119.             temp = writes;
  120.         else if(excepts)
  121.             temp = excepts;
  122.         else
  123.             temp = NULL;
  124.         
  125.         for(i=0; i<maxfds; i++) {
  126.             if(FD_ISSET(i,temp)) {
  127.                 sockets[counter] = i;
  128.                 counter++;
  129.             }
  130.         }
  131.     
  132.         if(tv)
  133.             timeout = tv->tv_sec * 1000 + tv->tv_usec;
  134.  
  135.         if(reads)
  136.             no_reads = counter;
  137.         else if(writes)
  138.             no_writes = counter;
  139.         else if(excepts)
  140.             no_excepts = counter;
  141.     }    
  142.     return select(sockets, no_reads, no_writes, no_excepts, timeout);
  143. }
  144.    
  145. /* pipe is not yet available on TPF */
  146. int pipe(int fildes[2])
  147. {
  148.     errno = ENOSYS;
  149.     return(-1);
  150. }
  151.   
  152. /* fork and exec functions are not defined on
  153.    TPF due to the implementation of tpf_fork() */
  154.  
  155. pid_t fork(void)
  156. {
  157.     errno = ENOSYS;
  158.     return(-1);
  159. }
  160.  
  161. int execl(const char *path, const char *arg0, ...)
  162. {
  163.     errno = ENOSYS;
  164.     return(-1);
  165. }
  166.  
  167. int execle(const char *path, const char *arg0, ...)
  168. {
  169.     errno = ENOSYS;
  170.     return(-1);
  171. }
  172.  
  173. int execve(const char *path, char *const argv[], char *const envp[])
  174. {
  175.     errno = ENOSYS;
  176.     return(-1);
  177. }
  178.