home *** CD-ROM | disk | FTP | other *** search
/ PC Online 1999 April / PCO0499.ISO / filesbbs / os2 / apach134.arj / APACH134.ZIP / src / os / bs2000 / os.c < prev    next >
Encoding:
C/C++ Source or Header  |  1999-01-01  |  4.3 KB  |  104 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.