]> granicus.if.org Git - php/commitdiff
Fix invalid args bugs by Maksymilian Arciemowicz
authorStanislav Malyshev <stas@php.net>
Fri, 19 Nov 2010 23:22:55 +0000 (23:22 +0000)
committerStanislav Malyshev <stas@php.net>
Fri, 19 Nov 2010 23:22:55 +0000 (23:22 +0000)
ext/intl/dateformat/dateformat_attr.c
ext/intl/formatter/formatter_attr.c
ext/intl/tests/dateformat_get_locale.phpt
ext/intl/tests/formatter_get_set_symbol.phpt

index 51012896edc834942bc5c50af20af50a903b2fe7..7c6cef95360098ef24ebb54c4462620d6620dea8 100755 (executable)
@@ -309,6 +309,7 @@ PHP_FUNCTION( datefmt_get_locale )
        DATE_FORMAT_METHOD_FETCH_OBJECT;
 
        loc = (char *)udat_getLocaleByType(DATE_FORMAT_OBJECT(dfo), loc_type,&INTL_DATA_ERROR_CODE(dfo));
+       INTL_METHOD_CHECK_STATUS(dfo, "Error getting locale");
        RETURN_STRING(loc, 1);
 }
 /* }}} */
index d9b67dda3a689ac307ea3fd056f5b17ff8dbb14e..851b2b310ebc73c1d7ebd54b9377759770086bc1 100755 (executable)
@@ -250,7 +250,7 @@ PHP_FUNCTION( numfmt_get_symbol )
        long symbol;
        UChar value_buf[4];
        UChar *value = value_buf;
-       int length = USIZE(value);
+       int length = USIZE(value_buf);
        FORMATTER_METHOD_INIT_VARS;
 
        /* Parse parameters. */
@@ -262,12 +262,17 @@ PHP_FUNCTION( numfmt_get_symbol )
 
                RETURN_FALSE;
        }
+       
+       if(symbol >= UNUM_FORMAT_SYMBOL_COUNT || symbol < 0) {
+               intl_error_set( NULL, U_ILLEGAL_ARGUMENT_ERROR, "numfmt_get_symbol: invalid symbol value", 0 TSRMLS_CC );
+               RETURN_FALSE;
+       }
 
        /* Fetch the object. */
        FORMATTER_METHOD_FETCH_OBJECT;
 
        length = unum_getSymbol(FORMATTER_OBJECT(nfo), symbol, value_buf, length, &INTL_DATA_ERROR_CODE(nfo));
-       if(INTL_DATA_ERROR_CODE(nfo) == U_BUFFER_OVERFLOW_ERROR && length >= USIZE( value )) {
+       if(INTL_DATA_ERROR_CODE(nfo) == U_BUFFER_OVERFLOW_ERROR && length >= USIZE( value_buf )) {
                ++length; /* to avoid U_STRING_NOT_TERMINATED_WARNING */
                INTL_DATA_ERROR_CODE(nfo) = U_ZERO_ERROR;
                value = eumalloc(length);
index 262697261871baf6433195a5bf97d596e645643d..17fcca355132d91e3afd269dc01bd0af05d4a266 100755 (executable)
@@ -29,6 +29,12 @@ function ut_main()
                $res_str .= "\nAfter call to get_locale :  locale= $locale";
                $res_str .= "\n";
        }
+       $badvals = array(100, -1, 4294901761);
+       foreach($badvals as $badval) {
+               if(ut_datefmt_get_locale($fmt, $badval)) {
+                       $res_str .= "datefmt_get_locale should return false for bad argument $badval\n";
+               }
+       }
 
        return $res_str;
 
index a1a430244fe4d57fe3d03ff57626765c93a383e6..40bbd25aeff37ee1095147c5a6eb2ec8d090daef 100755 (executable)
@@ -73,7 +73,12 @@ function ut_main()
         // Restore attribute's symbol.
         ut_nfmt_set_symbol( $fmt, $symb, $orig_val );
     }
-
+    $badvals = array(2147483648, -2147483648, -1, 4294901761);
+    foreach($badvals as $badval) {
+           if(ut_nfmt_get_symbol( $fmt, 2147483648 ))  {
+               $res_str .= "Bad value $badval should return false!\n";
+           }
+    }
     return $res_str;
 }