]> granicus.if.org Git - php/commitdiff
Move rot13 filter into a new filters.c source file.
authorWez Furlong <wez@php.net>
Wed, 1 Jan 2003 11:04:44 +0000 (11:04 +0000)
committerWez Furlong <wez@php.net>
Wed, 1 Jan 2003 11:04:44 +0000 (11:04 +0000)
Tidy up some other filter related code.

# win32 -> someone please add user_filters.c and filters.c to the .dsp

ext/standard/basic_functions.c
ext/standard/config.m4
ext/standard/filters.c [new file with mode: 0644]
ext/standard/php_standard.h
ext/standard/php_string.h
ext/standard/string.c
ext/standard/tests/file/userfilters.phpt
ext/standard/user_filters.c

index ff7418c588fd4ef7b0fdbea5e09d77362aae5d32..f23eb6b5ba99edbf74e2ef29c9ba4a214442a5ed 100644 (file)
@@ -1031,7 +1031,7 @@ PHP_MINIT_FUNCTION(basic)
        PHP_MINIT(file) (INIT_FUNC_ARGS_PASSTHRU);
        PHP_MINIT(pack) (INIT_FUNC_ARGS_PASSTHRU);
        PHP_MINIT(browscap) (INIT_FUNC_ARGS_PASSTHRU);
-       PHP_MINIT(string_filters) (INIT_FUNC_ARGS_PASSTHRU);
+       PHP_MINIT(standard_filters) (INIT_FUNC_ARGS_PASSTHRU);
        PHP_MINIT(user_filters) (INIT_FUNC_ARGS_PASSTHRU);
 
 #if defined(HAVE_LOCALECONV) && defined(ZTS)
@@ -1104,7 +1104,7 @@ PHP_MSHUTDOWN_FUNCTION(basic)
        PHP_MSHUTDOWN(assert) (SHUTDOWN_FUNC_ARGS_PASSTHRU);
        PHP_MSHUTDOWN(url_scanner_ex) (SHUTDOWN_FUNC_ARGS_PASSTHRU);
        PHP_MSHUTDOWN(file) (SHUTDOWN_FUNC_ARGS_PASSTHRU);
-       PHP_MSHUTDOWN(string_filters) (SHUTDOWN_FUNC_ARGS_PASSTHRU);
+       PHP_MSHUTDOWN(standard_filters) (SHUTDOWN_FUNC_ARGS_PASSTHRU);
 #if defined(HAVE_LOCALECONV) && defined(ZTS)
        PHP_MSHUTDOWN(localeconv) (SHUTDOWN_FUNC_ARGS_PASSTHRU);
 #endif
index 98964bce2e5338d3240889cd713fd7f6c0cd98a9..f74c7ed7e44773e99f944bd151fdbe95cf5bee39 100644 (file)
@@ -255,6 +255,7 @@ PHP_NEW_EXTENSION(standard, array.c base64.c basic_functions.c browscap.c crc32.
                             url_scanner.c var.c versioning.c assert.c strnatcmp.c levenshtein.c \
                             incomplete_class.c url_scanner_ex.c ftp_fopen_wrapper.c \
                             http_fopen_wrapper.c php_fopen_wrapper.c credits.c css.c \
-                            var_unserializer.c ftok.c aggregation.c sha1.c user_filters.c )
+                            var_unserializer.c ftok.c aggregation.c sha1.c user_filters.c \
+                                                       filters.c )
 
 PHP_ADD_MAKEFILE_FRAGMENT
diff --git a/ext/standard/filters.c b/ext/standard/filters.c
new file mode 100644 (file)
index 0000000..8a70179
--- /dev/null
@@ -0,0 +1,136 @@
+/*
+   +----------------------------------------------------------------------+
+   | PHP Version 4                                                        |
+   +----------------------------------------------------------------------+
+   | Copyright (c) 1997-2003 The PHP Group                                |
+   +----------------------------------------------------------------------+
+   | This source file is subject to version 2.02 of the PHP license,      |
+   | that is bundled with this package in the file LICENSE, and is        |
+   | available at through the world-wide-web at                           |
+   | http://www.php.net/license/2_02.txt.                                 |
+   | If you did not receive a copy of the PHP license and are unable to   |
+   | obtain it through the world-wide-web, please send a note to          |
+   | license@php.net so we can mail you a copy immediately.               |
+   +----------------------------------------------------------------------+
+   | Authors:                                                             |
+   | Wez Furlong (wez@thebrainroom.com)                                   |
+   +----------------------------------------------------------------------+
+*/
+
+/* $Id$ */
+
+#include "php.h"
+#include "php_globals.h"
+#include "ext/standard/basic_functions.h"
+#include "ext/standard/file.h"
+
+/* {{{ rot13 stream filter implementation */
+static char rot13_from[] = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
+static char rot13_to[] = "nopqrstuvwxyzabcdefghijklmNOPQRSTUVWXYZABCDEFGHIJKLM";
+
+static size_t strfilter_rot13_write(php_stream *stream, php_stream_filter *thisfilter,
+                       const char *buf, size_t count TSRMLS_DC)
+{
+       char rotbuf[1024];
+       size_t chunk;
+       size_t wrote = 0;
+
+       while (count > 0) {
+               chunk = count;
+               if (chunk > sizeof(rotbuf))
+                       chunk = sizeof(rotbuf);
+
+               PHP_STRLCPY(rotbuf, buf, sizeof(rotbuf), chunk);
+               buf += chunk;
+               count -= chunk;
+
+               php_strtr(rotbuf, chunk, rot13_from, rot13_to, 52);
+               wrote += php_stream_filter_write_next(stream, thisfilter, rotbuf, chunk);
+       }
+
+       return wrote;
+}
+
+static size_t strfilter_rot13_read(php_stream *stream, php_stream_filter *thisfilter,
+                       char *buf, size_t count TSRMLS_DC)
+{
+       size_t read;
+
+       read = php_stream_filter_read_next(stream, thisfilter, buf, count);
+       php_strtr(buf, read, rot13_from, rot13_to, 52);
+
+       return read;
+}
+
+static int strfilter_rot13_flush(php_stream *stream, php_stream_filter *thisfilter, int closing TSRMLS_DC)
+{
+       return php_stream_filter_flush_next(stream, thisfilter, closing);
+}
+
+static int strfilter_rot13_eof(php_stream *stream, php_stream_filter *thisfilter TSRMLS_DC)
+{
+       return php_stream_filter_eof_next(stream, thisfilter);
+}
+
+static php_stream_filter_ops strfilter_rot13_ops = {
+       strfilter_rot13_write,
+       strfilter_rot13_read,
+       strfilter_rot13_flush,
+       strfilter_rot13_eof,
+       NULL,
+       "string.rot13"
+};
+
+static php_stream_filter *strfilter_rot13_create(const char *filtername, const char *filterparams,
+               int filterparamslen, int persistent TSRMLS_DC)
+{
+       return php_stream_filter_alloc(&strfilter_rot13_ops, NULL, persistent);
+}
+
+static php_stream_filter_factory strfilter_rot13_factory = {
+       strfilter_rot13_create
+};
+/* }}} */
+
+static const struct {
+       php_stream_filter_ops *ops;
+       php_stream_filter_factory *factory;
+} standard_filters[] = {
+       { &strfilter_rot13_ops, &strfilter_rot13_factory },
+       { NULL, NULL }
+};
+
+PHP_MINIT_FUNCTION(standard_filters)
+{
+       int i;
+
+       for (i = 0; standard_filters[i].ops; i++) {
+               if (FAILURE == php_stream_filter_register_factory(
+                                       standard_filters[i].ops->label,
+                                       standard_filters[i].factory
+                                       TSRMLS_CC)) {
+                       return FAILURE;
+               }
+       }
+
+       return SUCCESS;
+}
+
+PHP_MSHUTDOWN_FUNCTION(standard_filters)
+{
+       int i;
+
+       for (i = 0; standard_filters[i].ops; i++) {
+               php_stream_filter_unregister_factory(standard_filters[i].ops->label TSRMLS_CC);
+       }
+       return SUCCESS;
+}
+
+/*
+ * Local variables:
+ * tab-width: 4
+ * c-basic-offset: 4
+ * End:
+ * vim600: sw=4 ts=4 fdm=marker
+ * vim<600: sw=4 ts=4
+ */
index 97403571e4c0771a6194d034ba2cce7437b372fe..c160da40cc4a0248a8f939586cfc646196a5a7d0 100644 (file)
@@ -62,6 +62,9 @@
 #include "aggregation.h"
 
 #define phpext_standard_ptr basic_functions_module_ptr
+PHP_MINIT_FUNCTION(standard_filters);
+PHP_MSHUTDOWN_FUNCTION(standard_filters);
+
 
 /*
  * Local variables:
index df2bd6376a18097fae937520e330ed09bf23eaf0..5f07c31ea38f07e0d6f10c1fd08799a47e5bf786 100644 (file)
@@ -91,9 +91,6 @@ PHP_FUNCTION(strcoll);
 PHP_FUNCTION(money_format);
 #endif
 
-PHP_MINIT_FUNCTION(string_filters);
-PHP_MSHUTDOWN_FUNCTION(string_filters);
-
 #if defined(HAVE_LOCALECONV) && defined(ZTS)
 PHP_MINIT_FUNCTION(localeconv);
 PHP_MSHUTDOWN_FUNCTION(localeconv);
index 8842b24145053914f002d52a8919af936814416b..722812c56e93de2677bab2c2e7c92322dcdcc464 100644 (file)
@@ -4167,82 +4167,6 @@ PHP_FUNCTION(money_format) {
 /* }}} */
 #endif
 
-/* {{{ rot13 stream filter implementation */
-static size_t strfilter_rot13_write(php_stream *stream, php_stream_filter *thisfilter,
-                       const char *buf, size_t count TSRMLS_DC)
-{
-       char rotbuf[1024];
-       size_t chunk;
-       size_t wrote = 0;
-
-       while (count > 0) {
-               chunk = count;
-               if (chunk > sizeof(rotbuf))
-                       chunk = sizeof(rotbuf);
-
-               PHP_STRLCPY(rotbuf, buf, sizeof(rotbuf), chunk);
-               buf += chunk;
-               count -= chunk;
-
-               php_strtr(rotbuf, chunk, rot13_from, rot13_to, 52);
-               wrote += php_stream_filter_write_next(stream, thisfilter, rotbuf, chunk);
-       }
-
-       return wrote;
-}
-
-static size_t strfilter_rot13_read(php_stream *stream, php_stream_filter *thisfilter,
-                       char *buf, size_t count TSRMLS_DC)
-{
-       size_t read;
-
-       read = php_stream_filter_read_next(stream, thisfilter, buf, count);
-       php_strtr(buf, read, rot13_from, rot13_to, 52);
-
-       return read;
-}
-
-static int strfilter_rot13_flush(php_stream *stream, php_stream_filter *thisfilter, int closing TSRMLS_DC)
-{
-       return php_stream_filter_flush_next(stream, thisfilter, closing);
-}
-
-static int strfilter_rot13_eof(php_stream *stream, php_stream_filter *thisfilter TSRMLS_DC)
-{
-       return php_stream_filter_eof_next(stream, thisfilter);
-}
-
-
-static php_stream_filter_ops strfilter_rot13_ops = {
-       strfilter_rot13_write,
-       strfilter_rot13_read,
-       strfilter_rot13_flush,
-       strfilter_rot13_eof,
-       NULL,
-       "string.rot13"
-};
-
-static php_stream_filter *strfilter_rot13_create(const char *filtername, const char *filterparams,
-               int filterparamslen, int persistent TSRMLS_DC)
-{
-       return php_stream_filter_alloc(&strfilter_rot13_ops, NULL, persistent);
-}
-
-static php_stream_filter_factory strfilter_rot13_factory = {
-       strfilter_rot13_create
-};
-
-PHP_MINIT_FUNCTION(string_filters)
-{
-       return php_stream_filter_register_factory("string.rot13", &strfilter_rot13_factory TSRMLS_CC);
-}
-
-PHP_MSHUTDOWN_FUNCTION(string_filters)
-{
-       return php_stream_filter_unregister_factory("string.rot13" TSRMLS_CC);
-}
-/* }}} */
-
 /*
  * Local variables:
  * tab-width: 4
index 543e6a3db7c5e4e114e6047f37fad411bab6a045..817c48b4eec4e0e1b2dbbb3d2993a51241ebfec0 100644 (file)
@@ -45,7 +45,7 @@ rewind($fp);
 
 var_dump(stream_filter_prepend($fp, "string.uppercase"));
 var_dump(fgets($fp));
-
+fclose($fp);
 ?>
 --EXPECT--
 bool(true)
index 0edca8142523527231bdf34c8eb630ea79a83945..ed04223ef5a979dab6141f1f80e99bd165522d13 100644 (file)
@@ -445,3 +445,13 @@ PHP_FUNCTION(stream_register_filter)
        efree(fdat);
 }
 /* }}} */
+
+
+/*
+ * Local variables:
+ * tab-width: 4
+ * c-basic-offset: 4
+ * End:
+ * vim600: sw=4 ts=4 fdm=marker
+ * vim<600: sw=4 ts=4
+ */