summaryrefslogtreecommitdiff
path: root/ext
diff options
context:
space:
mode:
authorRui Hirokawa <hirokawa@php.net>2002-01-07 02:40:54 +0000
committerRui Hirokawa <hirokawa@php.net>2002-01-07 02:40:54 +0000
commit32c1b0fd2eef9b5ce90908bf6f85269046a01965 (patch)
tree59d505c4174e6867e9bd1266b19d7f9d7f6a8f11 /ext
parent687ce0d838222995e9a765f2bb7a329923d5e8a5 (diff)
downloadphp-git-32c1b0fd2eef9b5ce90908bf6f85269046a01965.tar.gz
@added mb_get_info() to get internal settings of mbstring.
Diffstat (limited to 'ext')
-rw-r--r--ext/mbstring/mbstring.c64
-rw-r--r--ext/mbstring/mbstring.h1
2 files changed, 65 insertions, 0 deletions
diff --git a/ext/mbstring/mbstring.c b/ext/mbstring/mbstring.c
index 8432be684b..24feee23eb 100644
--- a/ext/mbstring/mbstring.c
+++ b/ext/mbstring/mbstring.c
@@ -124,6 +124,7 @@ function_entry mbstring_functions[] = {
PHP_FE(mb_encode_numericentity, NULL)
PHP_FE(mb_decode_numericentity, NULL)
PHP_FE(mb_send_mail, NULL)
+ PHP_FE(mb_get_info, NULL)
PHP_FALIAS(mbstrlen, mb_strlen, NULL)
PHP_FALIAS(mbstrpos, mb_strpos, NULL)
PHP_FALIAS(mbstrrpos, mb_strrpos, NULL)
@@ -430,6 +431,9 @@ PHP_MINIT_FUNCTION(mbstring)
sapi_register_post_entries(mbstr_post_entries);
#endif
+ REGISTER_LONG_CONSTANT("MB_OVERLOAD_MAIL", MB_OVERLOAD_MAIL, CONST_CS | CONST_PERSISTENT);
+ REGISTER_LONG_CONSTANT("MB_OVERLOAD_STRING", MB_OVERLOAD_STRING, CONST_CS | CONST_PERSISTENT);
+
return SUCCESS;
}
@@ -2686,6 +2690,66 @@ PHP_FUNCTION(mb_send_mail)
#endif /* HAVE_SENDMAIL */
+/* {{{ proto string mb_get_info([string type])
+ Returns the current settings of mbstring. */
+PHP_FUNCTION(mb_get_info)
+{
+ zval **type;
+ char *name;
+ int argc = ZEND_NUM_ARGS();
+
+ if (argc < 0 || argc > 1 || zend_get_parameters_ex(1, &type) == FAILURE) {
+ WRONG_PARAM_COUNT;
+ }
+
+ convert_to_string_ex(type);
+
+ if (argc == 0 || !strcasecmp("all", Z_STRVAL_PP(type))) {
+ if (array_init(return_value) == FAILURE) {
+ RETURN_FALSE;
+ }
+ if ((name = (char *)mbfl_no_encoding2name(MBSTRG(current_internal_encoding)))
+ != NULL) {
+ add_assoc_string(return_value, "internal_encoding", name, 1);
+ }
+ if ((name = (char *)mbfl_no_encoding2name(MBSTRG(http_input_identify)))
+ != NULL) {
+ add_assoc_string(return_value, "http_input", name, 1);
+ }
+ if ((name = (char *)mbfl_no_encoding2name(MBSTRG(current_http_output_encoding)))
+ != NULL) {
+ add_assoc_string(return_value, "http_output", name, 1);
+ }
+ if ((name = (char *)mbfl_no_encoding2name(MBSTRG(func_overload)))
+ != NULL) {
+ add_assoc_string(return_value, "func_overload", name, 1);
+ }
+ } else if (!strcasecmp("internal_encoding", Z_STRVAL_PP(type))) {
+ if ((name = (char *)mbfl_no_encoding2name(MBSTRG(current_internal_encoding)))
+ != NULL) {
+ RETVAL_STRING(name, 1);
+ }
+ } else if (!strcasecmp("http_input", Z_STRVAL_PP(type))) {
+ if ((name = (char *)mbfl_no_encoding2name(MBSTRG(http_input_identify)))
+ != NULL) {
+ RETVAL_STRING(name, 1);
+ }
+ } else if (!strcasecmp("http_output", Z_STRVAL_PP(type))) {
+ if ((name = (char *)mbfl_no_encoding2name(MBSTRG(current_http_output_encoding)))
+ != NULL) {
+ RETVAL_STRING(name, 1);
+ }
+ } else if (!strcasecmp("func_overload", Z_STRVAL_PP(type))) {
+ if ((name = (char *)mbfl_no_encoding2name(MBSTRG(func_overload)))
+ != NULL) {
+ RETVAL_STRING(name, 1);
+ }
+ } else {
+ RETURN_FALSE;
+ }
+}
+/* }}} */
+
#endif /* HAVE_MBSTRING */
/*
diff --git a/ext/mbstring/mbstring.h b/ext/mbstring/mbstring.h
index bed70adadc..6a0000048c 100644
--- a/ext/mbstring/mbstring.h
+++ b/ext/mbstring/mbstring.h
@@ -90,6 +90,7 @@ PHP_FUNCTION(mb_convert_variables);
PHP_FUNCTION(mb_encode_numericentity);
PHP_FUNCTION(mb_decode_numericentity);
PHP_FUNCTION(mb_send_mail);
+PHP_FUNCTION(mb_get_info);
ZEND_BEGIN_MODULE_GLOBALS(mbstring)
int language;