diff options
author | Jeff Trawick <trawick@apache.org> | 2000-05-25 22:51:25 +0200 |
---|---|---|
committer | Jeff Trawick <trawick@apache.org> | 2000-05-25 22:51:25 +0200 |
commit | 78aba7227ff0f5e89574c9cd80c499c93b825fe0 (patch) | |
tree | b1caa99b116ebd9c6443d2c331e8764d4520b5f0 /server | |
parent | Add '-n' option to make htpasswd send user:pw result to (diff) | |
download | apache2-78aba7227ff0f5e89574c9cd80c499c93b825fe0.tar.xz apache2-78aba7227ff0f5e89574c9cd80c499c93b825fe0.zip |
APACHE_XLATE, CHARSET_EBCDIC stuff:
Provide new function ap_set_content_xlate() to simplify what needs
to be done to set up translation of content. Use it where appropriate.
With this change, EBCDIC logic was tweaked so that ap_checkconv() does
not overlay a translation handle previously stored (e.g., by a module)
unless it is turning translation off. Unless ap_checkconv() determines
that translation is inappropriate, it should leave the translation handle
alone.
git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@85296 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'server')
-rw-r--r-- | server/Makefile.in | 3 | ||||
-rw-r--r-- | server/util_charset.c | 122 | ||||
-rw-r--r-- | server/util_ebcdic.c | 51 |
3 files changed, 128 insertions, 48 deletions
diff --git a/server/Makefile.in b/server/Makefile.in index 11998d31af..2401acf85d 100644 --- a/server/Makefile.in +++ b/server/Makefile.in @@ -7,7 +7,8 @@ LTLIBRARY_SOURCES = \ buff.c http_config.c http_core.c http_log.c http_main.c \ http_protocol.c http_request.c http_vhost.c util.c util_date.c \ util_script.c util_uri.c util_md5.c util_cfgtree.c util_ebcdic.c \ - rfc1413.c http_connection.c iol_file.c listen.c mpm_common.c + rfc1413.c http_connection.c iol_file.c listen.c mpm_common.c \ + util_charset.c include $(top_srcdir)/build/ltlib.mk diff --git a/server/util_charset.c b/server/util_charset.c new file mode 100644 index 0000000000..8a613f9075 --- /dev/null +++ b/server/util_charset.c @@ -0,0 +1,122 @@ +/* ==================================================================== + * The Apache Software License, Version 1.1 + * + * Copyright (c) 2000 The Apache Software Foundation. All rights + * reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * 1. Redistributions of source code must retain the above copyright + * 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 acknowledgment: + * "This product includes software developed by the + * Apache Software Foundation (http://www.apache.org/)." + * Alternately, this acknowledgment may appear in the software itself, + * if and wherever such third-party acknowledgments normally appear. + * + * 4. The names "Apache" 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 name, 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 + * individuals on behalf of the Apache Software Foundation. For more + * information on the Apache Software Foundation, please see + * <http://www.apache.org/>. + * + * Portions of this software are based upon public domain software + * originally written at the National Center for Supercomputing Applications, + * University of Illinois, Urbana-Champaign. + */ + +#include "ap_config.h" + +#ifdef APACHE_XLATE + +#include "httpd.h" +#include "http_log.h" +#include "http_core.h" +#include "util_charset.h" + +/* ap_hdrs_to_ascii, ap_hdrs_from_ascii + * + * These are the translation handles used to translate between the network + * format of protocol headers and the local machine format. + * + * For an EBCDIC machine, these are valid handles which are set up at + * initialization to translate between ISO-8859-1 and the code page of + * the source code. + * + * For an ASCII machine, these remain NULL so that when they are stored + * in the BUFF via ap_bsetop(BO_WXLATE or BO_RXLATE) it ensures that no + * translation is performed. + */ + +ap_xlate_t *ap_hdrs_to_ascii, *ap_hdrs_from_ascii; + +/* ap_locale_to_ascii, ap_locale_from_ascii + * + * These handles are used for the translation of content, unless a + * configuration module overrides them. + * + * For an EBCDIC machine, these are valid handles which are set up at + * initialization to translate between ISO-8859-1 and the code page of + * the httpd process's locale. + * + * For an ASCII machine, these remain NULL so that no translation is + * performed (unless a configuration module does something, of course). + */ + +ap_xlate_t *ap_locale_to_ascii, *ap_locale_from_ascii; + +API_EXPORT(ap_status_t) ap_set_content_xlate(request_rec *r, int output, + ap_xlate_t *xlate) +{ + ap_status_t rv; + + if (output) { + r->rrx->to_net = xlate; + rv = ap_bsetopt(r->connection->client, BO_WXLATE, &xlate); + } + else { + r->rrx->from_net = xlate; + rv = ap_bsetopt(r->connection->client, BO_RXLATE, &xlate); + } + + if (rv) { + ap_log_rerror(APLOG_MARK, APLOG_ERR, rv, r, + "BO_%sXLATE failed", + output ? "W" : "R"); + } + + return rv; +} + +#endif /*APACHE_XLATE*/ diff --git a/server/util_ebcdic.c b/server/util_ebcdic.c index fb8c041a3f..8affa18327 100644 --- a/server/util_ebcdic.c +++ b/server/util_ebcdic.c @@ -58,53 +58,13 @@ #include "ap_config.h" -#ifdef APACHE_XLATE +#ifdef CHARSET_EBCDIC #include "httpd.h" #include "http_log.h" #include "http_core.h" #include "util_ebcdic.h" -/* Note: these variables really belong in util_charset.c, but it seems silly - * to create util_charset.c at the moment since it would only contain the - * variables. - */ - -/* ap_hdrs_to_ascii, ap_hdrs_from_ascii - * - * These are the translation handles used to translate between the network - * format of protocol headers and the local machine format. - * - * For an EBCDIC machine, these are valid handles which are set up at - * initialization to translate between ISO-8859-1 and the code page of - * the source code. - * - * For an ASCII machine, these remain NULL so that when they are stored - * in the BUFF via ap_bsetop(BO_WXLATE or BO_RXLATE) it ensures that no - * translation is performed. - */ - -ap_xlate_t *ap_hdrs_to_ascii, *ap_hdrs_from_ascii; - -/* ap_locale_to_ascii, ap_locale_from_ascii - * - * These handles are used for the translation of content, unless a - * configuration module overrides them. - * - * For an EBCDIC machine, these are valid handles which are set up at - * initialization to translate between ISO-8859-1 and the code page of - * the httpd process's locale. - * - * For an ASCII machine, these remain NULL so that no translation is - * performed (unless a configuration module does something, of course). - */ - -ap_xlate_t *ap_locale_to_ascii, *ap_locale_from_ascii; - -#endif /*APACHE_XLATE*/ - -#ifdef CHARSET_EBCDIC - ap_status_t ap_init_ebcdic(ap_pool_t *pool) { ap_status_t rv; @@ -185,12 +145,9 @@ ap_xlate_t *ap_checkconv(struct request_rec *r) /* translate EBCDIC to ASCII */ convert_to_ascii = 1; } - /* Enable conversion if it's a text document */ - if (convert_to_ascii) { - ap_bsetopt(r->connection->client, BO_WXLATE, &ap_locale_to_ascii); - } - else { - ap_bsetopt(r->connection->client, BO_WXLATE, &zero); + /* Turn off conversion if it's a text document */ + if (!convert_to_ascii) { + ap_set_content_xlate(r, 1, zero); } return convert_to_ascii ? ap_locale_to_ascii : NULL; |