diff options
author | Alexey Zakhlestin <indeyets@php.net> | 2008-06-22 14:13:01 +0000 |
---|---|---|
committer | Alexey Zakhlestin <indeyets@php.net> | 2008-06-22 14:13:01 +0000 |
commit | 247bf3eb4a8975cd891e64fb2c07b6bc7f5ffbf2 (patch) | |
tree | 526030e22a0c82972275ce842e5f5ff9184dc0b9 /ext/exif | |
parent | 521c5cf5fb3f427d8e364827ae75919ff6669218 (diff) | |
download | php-git-247bf3eb4a8975cd891e64fb2c07b6bc7f5ffbf2.tar.gz |
updated to the new parameter-parsing api
Diffstat (limited to 'ext/exif')
-rw-r--r-- | ext/exif/exif.c | 80 |
1 files changed, 31 insertions, 49 deletions
diff --git a/ext/exif/exif.c b/ext/exif/exif.c index da1f1d3f07..f9de7c3c19 100644 --- a/ext/exif/exif.c +++ b/ext/exif/exif.c @@ -2360,22 +2360,20 @@ static char * exif_get_markername(int marker) Get headername for index or false if not defined */ PHP_FUNCTION(exif_tagname) { - zval **p_num; - int tag, ac = ZEND_NUM_ARGS(); + long tag; char *szTemp; - if ((ac < 1 || ac > 1) || zend_get_parameters_ex(ac, &p_num) == FAILURE) { - WRONG_PARAM_COUNT; + if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "l", &tag) == FAILURE) { + return; } - convert_to_long_ex(p_num); - tag = Z_LVAL_PP(p_num); szTemp = exif_get_tagname(tag, NULL, 0, tag_table_IFD TSRMLS_CC); - if (tag<0 || !szTemp || !szTemp[0]) { - RETURN_BOOL(FALSE); - } else { - RETURN_STRING(szTemp, 1) + + if (tag < 0 || !szTemp || !szTemp[0]) { + RETURN_FALSE; } + + RETURN_STRING(szTemp, 1) } /* }}} */ @@ -3914,30 +3912,31 @@ static int exif_read_file(image_info_type *ImageInfo, char *FileName, int read_t Reads header data from the JPEG/TIFF image filename and optionally reads the internal thumbnails */ PHP_FUNCTION(exif_read_data) { - zval **p_name, **p_sections_needed, **p_sub_arrays, **p_read_thumbnail, **p_read_all; - int i, ac = ZEND_NUM_ARGS(), ret, sections_needed=0, sub_arrays=0, read_thumbnail=0, read_all=0; + char *p_name, *p_sections_needed; + long p_name_len, p_sections_needed_len; + zend_bool sub_arrays=0, read_thumbnail=0, read_all=0; + + int i, ac = ZEND_NUM_ARGS(), ret, sections_needed=0; image_info_type ImageInfo; char tmp[64], *sections_str, *s; - memset(&ImageInfo, 0, sizeof(ImageInfo)); - - if ((ac < 1 || ac > 4) || zend_get_parameters_ex(ac, &p_name, &p_sections_needed, &p_sub_arrays, &p_read_thumbnail, &p_read_all) == FAILURE) { - WRONG_PARAM_COUNT; + if (zend_parse_parameters(ac TSRMLS_CC, "s|sbb", &p_name, &p_name_len, &p_sections_needed, &p_sections_needed_len, &sub_arrays, &read_thumbnail) == FAILURE) { + return; } - convert_to_string_ex(p_name); + memset(&ImageInfo, 0, sizeof(ImageInfo)); - if(ac >= 2) { - convert_to_string_ex(p_sections_needed); - spprintf(§ions_str, 0, ",%s,", Z_STRVAL_PP(p_sections_needed)); + if (ac >= 2) { + spprintf(§ions_str, 0, ",%s,", p_sections_needed); /* sections_str DOES start with , and SPACES are NOT allowed in names */ s = sections_str; - while(*++s) { - if(*s==' ') { + while (*++s) { + if (*s == ' ') { *s = ','; } } - for (i=0; i<SECTION_COUNT; i++) { + + for (i = 0; i < SECTION_COUNT; i++) { snprintf(tmp, sizeof(tmp), ",%s,", exif_get_sectionname(i)); if (strstr(sections_str, tmp)) { sections_needed |= 1<<i; @@ -3954,24 +3953,9 @@ PHP_FUNCTION(exif_read_data) EFREE_IF(sections_str); #endif } - if(ac >= 3) { - convert_to_long_ex(p_sub_arrays); - sub_arrays = Z_LVAL_PP(p_sub_arrays); - } - if(ac >= 4) { - convert_to_long_ex(p_read_thumbnail); - read_thumbnail = Z_LVAL_PP(p_read_thumbnail); - } - if(ac >= 5) { - convert_to_long_ex(p_read_all); - read_all = Z_LVAL_PP(p_read_all); - } - /* parameters 3,4 will be working in later versions.... */ - read_all = 0; /* just to make function work for 4.2 tree */ - - ret = exif_read_file(&ImageInfo, Z_STRVAL_PP(p_name), read_thumbnail, read_all TSRMLS_CC); - sections_str = exif_get_sectionlist(ImageInfo.sections_found TSRMLS_CC); + ret = exif_read_file(&ImageInfo, p_name, read_thumbnail, read_all TSRMLS_CC); + sections_str = exif_get_sectionlist(ImageInfo.sections_found TSRMLS_CC); #ifdef EXIF_DEBUG if (sections_str) @@ -3980,7 +3964,7 @@ PHP_FUNCTION(exif_read_data) ImageInfo.sections_found |= FOUND_COMPUTED|FOUND_FILE;/* do not inform about in debug*/ - if (ret==FALSE || (sections_needed && !(sections_needed&ImageInfo.sections_found))) { + if (ret == FALSE || (sections_needed && !(sections_needed&ImageInfo.sections_found))) { /* array_init must be checked at last! otherwise the array must be freed if a later test fails. */ exif_discard_imageinfo(&ImageInfo); EFREE_IF(sections_str); @@ -4170,18 +4154,16 @@ PHP_FUNCTION(exif_thumbnail) Get the type of an image */ PHP_FUNCTION(exif_imagetype) { - zval **arg1; + char *imagefile; + long imagefile_len; php_stream * stream; int itype = 0; - if (ZEND_NUM_ARGS() != 1) - WRONG_PARAM_COUNT; - - if (zend_get_parameters_ex(1, &arg1) == FAILURE) - WRONG_PARAM_COUNT; + if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &imagefile, &imagefile_len) == FAILURE) { + return; + } - convert_to_string_ex(arg1); - stream = php_stream_open_wrapper(Z_STRVAL_PP(arg1), "rb", IGNORE_PATH|ENFORCE_SAFE_MODE|REPORT_ERRORS, NULL); + stream = php_stream_open_wrapper(imagefile, "rb", IGNORE_PATH|ENFORCE_SAFE_MODE|REPORT_ERRORS, NULL); if (stream == NULL) { RETURN_FALSE; |