From: Ilia Alshanetsky Date: Sat, 22 Feb 2003 20:33:11 +0000 (+0000) Subject: int/long change. X-Git-Tag: RELEASE_0_5~821 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=d2e2fbcc5bf18f941954b9c324ad7a3827819bf3;p=php int/long change. --- diff --git a/ext/standard/basic_functions.c b/ext/standard/basic_functions.c index 31c7f54e07..4ff5f555a7 100644 --- a/ext/standard/basic_functions.c +++ b/ext/standard/basic_functions.c @@ -670,6 +670,7 @@ function_entry basic_functions[] = { PHP_STATIC_FE("tmpfile", php_if_tmpfile, NULL) PHP_FE(file, NULL) PHP_FE(file_get_contents, NULL) + PHP_FE(file_write_content, NULL) PHP_FE(stream_select, first_through_third_args_force_ref) PHP_FE(stream_context_create, NULL) PHP_FE(stream_context_set_params, NULL) diff --git a/ext/standard/file.c b/ext/standard/file.c index fa7649b45c..3aad41ee19 100644 --- a/ext/standard/file.c +++ b/ext/standard/file.c @@ -408,6 +408,67 @@ PHP_FUNCTION(get_meta_tags) /* }}} */ +/* {{{ proto int file_write_content(string filename, mixed content [, char mode [, bool use_include_path]]) + Write a string to a file. */ +PHP_FUNCTION(file_write_content) +{ + zval *content; + char *filename, *mode; + int filename_len, mode_len = 0; + zend_bool use_include_path = 0; + size_t written; + php_stream *stream; + + if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "sz|sb", &filename, &filename_len, &content, &mode, &mode_len, &use_include_path) == FAILURE) { + RETURN_FALSE; + } + + if (!(stream = php_stream_open_wrapper(filename, (mode_len ? mode : "wb"), (use_include_path ? USE_PATH : 0) | ENFORCE_SAFE_MODE | REPORT_ERRORS, NULL))) { + RETURN_FALSE; + } + + /* try to set an exclusive lock on the file to prevent access to the file while the write operation + * is happening. + */ + php_stream_set_option(stream, PHP_STREAM_OPTION_LOCKING, F_SETLKW, (void *) F_WRLCK TSRMLS_CC); + + if (Z_TYPE_P(content) == IS_ARRAY) { + HashPosition pos; + zval **tmp; + size_t cur_write; + + written = 0; + zend_hash_internal_pointer_reset_ex(Z_ARRVAL_P(content), &pos); + + while (zend_hash_get_current_data_ex(Z_ARRVAL_P(content), (void **) &tmp, &pos) == SUCCESS) { + SEPARATE_ZVAL(tmp); + convert_to_string(*tmp); + + if ((cur_write = php_stream_write(stream, Z_STRVAL_PP(tmp), Z_STRLEN_PP(tmp))) < 0) { + RETVAL_FALSE; + goto done; + } + written += cur_write; + + zend_hash_move_forward_ex(Z_ARRVAL_P(content), &pos); + } + RETVAL_LONG(written); + } else { + SEPARATE_ZVAL(&content); + convert_to_string(content); + if ((written = php_stream_write(stream, Z_STRVAL_P(content), Z_STRLEN_P(content))) < 0) { + RETVAL_FALSE; + } else { + RETVAL_LONG(written); + } + zval_ptr_dtor(&content); + } + +done: + php_stream_close(stream); +} +/* }}} */ + /* {{{ proto string file_get_contents(string filename [, bool use_include_path]) Read the entire file into a string */ PHP_FUNCTION(file_get_contents) diff --git a/ext/standard/file.h b/ext/standard/file.h index ffd2669315..0771e731d6 100644 --- a/ext/standard/file.h +++ b/ext/standard/file.h @@ -54,6 +54,7 @@ PHP_FUNCTION(unlink); PHP_FUNCTION(copy); PHP_FUNCTION(file); PHP_FUNCTION(file_get_contents); +PHP_FUNCTION(file_write_content); PHP_FUNCTION(set_socket_blocking); /* deprecated */ PHP_FUNCTION(stream_set_blocking); PHP_FUNCTION(stream_select); diff --git a/ext/standard/html.c b/ext/standard/html.c index 2133ed8b71..be06b8dbef 100644 --- a/ext/standard/html.c +++ b/ext/standard/html.c @@ -831,11 +831,11 @@ static void php_html_entities(INTERNAL_FUNCTION_PARAMETERS, int all) { char *str, *hint_charset = NULL; int str_len, hint_charset_len = 0; - int len, quote_style = ENT_COMPAT; + int len; + long quote_style = ENT_COMPAT; char *replaced; - if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s|ls", &str, &str_len, - "e_style, &hint_charset, &hint_charset_len) == FAILURE) { + if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s|ls", &str, &str_len, "e_style, &hint_charset, &hint_charset_len) == FAILURE) { return; }