From: Operating system: Windows & Linux PHP version: 5.3.3 Package: Math related Bug Type: Bug Bug description:intval() returns incorrect int
Description: ------------ I was working on a way to calculate the LIMIT and OFFSET for a blog in reverse but still with ORDER BY date_create DESC and I kept running into flaws until i did a print on the mysql_query string,.. in order to keep the urls correct on the page,.. $postoffset = (((14 / 10) - 1) * 10); // 4 var_dump($postoffset); // returns float(4) var_dump(intval($postoffset)); // returns int(3) 14/10 = 1.4 1.4-1 = 0.4 0.4*10 = 4 (this is happening on many different php version, so i almost wanted to put the php version select on "Irrelavant") Test script: --------------- <?php header("Content-Type: text/plain"); $limit = (int) 10; $count = (int) 14; // mysql_query("select count(*)..."); $pages = (int) ceil($count/$limit); $page = (int) 1; $offset = ((($count / $limit) - $page) * $limit); var_dump($offset); var_dump(intval($offset)); $offset = (((14 / 10) - 1) * 10); // 4 var_dump($offset); var_dump(intval($offset)); var_dump(ceil(((14 / 10) - 1) * 10)); var_dump(floor(((14 / 10) - 1) * 10)); var_dump(round(((14 / 10) - 1) * 10)); print "- step by step -\n"; $pages = $count / $limit; var_dump($pages); // 1.4 var_dump(intval($pages)); // 1 $_page = $pages - $page; var_dump($_page); // 0.4 var_dump(intval($_page)); // 0 $offset = $_page * $limit; var_dump($offset); // 4 var_dump(intval($offset)); // 3 incorrect $offset = 0.4 * 10; var_dump($offset); // 4 var_dump(intval($offset)); // 4 correct ?> Expected result: ---------------- float(4) int(4) float(4) int(4) float(4) float(4) float(4) - step by step - float(1.4) int(1) float(0.4) int(0) float(4) int(4) float(4) int(4) Actual result: -------------- float(4) int(3) float(4) int(3) float(4) float(3) float(4) - step by step - float(1.4) int(1) float(0.4) int(0) float(4) int(3) float(4) int(4) -- Edit bug report at http://bugs.php.net/bug.php?id=52787&edit=1 -- Try a snapshot (PHP 5.2): http://bugs.php.net/fix.php?id=52787&r=trysnapshot52 Try a snapshot (PHP 5.3): http://bugs.php.net/fix.php?id=52787&r=trysnapshot53 Try a snapshot (trunk): http://bugs.php.net/fix.php?id=52787&r=trysnapshottrunk Fixed in SVN: http://bugs.php.net/fix.php?id=52787&r=fixed Fixed in SVN and need be documented: http://bugs.php.net/fix.php?id=52787&r=needdocs Fixed in release: http://bugs.php.net/fix.php?id=52787&r=alreadyfixed Need backtrace: http://bugs.php.net/fix.php?id=52787&r=needtrace Need Reproduce Script: http://bugs.php.net/fix.php?id=52787&r=needscript Try newer version: http://bugs.php.net/fix.php?id=52787&r=oldversion Not developer issue: http://bugs.php.net/fix.php?id=52787&r=support Expected behavior: http://bugs.php.net/fix.php?id=52787&r=notwrong Not enough info: http://bugs.php.net/fix.php?id=52787&r=notenoughinfo Submitted twice: http://bugs.php.net/fix.php?id=52787&r=submittedtwice register_globals: http://bugs.php.net/fix.php?id=52787&r=globals PHP 4 support discontinued: http://bugs.php.net/fix.php?id=52787&r=php4 Daylight Savings: http://bugs.php.net/fix.php?id=52787&r=dst IIS Stability: http://bugs.php.net/fix.php?id=52787&r=isapi Install GNU Sed: http://bugs.php.net/fix.php?id=52787&r=gnused Floating point limitations: http://bugs.php.net/fix.php?id=52787&r=float No Zend Extensions: http://bugs.php.net/fix.php?id=52787&r=nozend MySQL Configuration Error: http://bugs.php.net/fix.php?id=52787&r=mysqlcfg