php-src/NEWS

558 lines
22 KiB
Plaintext
Raw Normal View History

2015-07-21 22:36:36 +08:00
PHP NEWS
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
2016-08-03 07:40:07 +08:00
?? ??? 2016, PHP 7.1.0beta3
2016-08-04 03:31:15 +08:00
- EXIF:
. Fixed bug #72735 (Samsung picture thumb not read (zero size)). (Kalle, Remi)
2016-08-03 07:40:07 +08:00
04 Aug 2016, PHP 7.1.0beta2
2016-07-21 11:05:58 +08:00
2016-07-25 15:52:21 +08:00
- Core:
. Implemented FR #72614 (Support "nmake test" on building extensions by
phpize). (Yuji Uchiyama)
. Fixed bug #72641 (phpize (on Windows) ignores PHP_PREFIX).
(Yuji Uchiyama)
2016-07-28 02:49:46 +08:00
. Fixed bug #72683 (getmxrr broken). (Anatol)
2016-07-25 15:52:21 +08:00
- Calendar:
. Fixed bug #67976 (cal_days_month() fails for final month of the French
calendar). (cmb)
. Fixed bug #71894 (AddressSanitizer: global-buffer-overflow in
zif_cal_from_jd). (cmb)
2016-07-28 06:17:43 +08:00
- CURL:
. Fixed bug #71709 (curl_setopt segfault with empty CURLOPT_HTTPHEADER).
(Pierrick)
. Fixed bug #71929 (CURLINFO_CERTINFO data parsing error). (Pierrick)
2016-06-09 16:51:02 +08:00
2016-07-21 14:25:54 +08:00
- Intl:
. Fixed bug #72639 (Segfault when instantiating class that extends
IntlCalendar and adds a property). (Laruence)
2016-07-25 18:50:21 +08:00
. Fixed bug #72658 (Locale::lookup() / locale_lookup() hangs if no match
found). (Anatol)
2016-07-21 14:25:54 +08:00
2016-08-03 00:53:54 +08:00
- GD:
. Fixed bug #72709 (imagesetstyle() causes OOB read for empty $styles). (cmb)
- mbstring:
. Fixed bug #72691 (mb_ereg_search raises a warning if a match zero-width).
(cmb)
. Fixed bug #72693 (mb_ereg_search increments search position when a match
zero-width). (cmb)
. Fixed bug #72694 (mb_ereg_search_setpos does not accept a string's last
position). (cmb)
. Fixed bug #72710 (`mb_ereg` causes buffer overflow on regexp compile error).
(ju1ius)
- Mysqlnd:
. Fixed bug #71863 (Segfault when EXPLAIN with "Unknown column" error when
using MariaDB). (Andrey)
2016-07-29 23:33:40 +08:00
. Fixed bug #72701 (mysqli_get_host_info() wrong output). (Anatol)
2016-07-28 01:05:43 +08:00
- PCRE:
. Fixed bug #72688 (preg_match missing group names in matches). (cmb)
2016-07-31 21:01:45 +08:00
. Downgraded to PCRE 8.38. (Anatol)
- Reflection:
. Fixed bug #72661 (ReflectionType::__toString crashes with iterable).
(Laruence)
2016-07-22 21:28:42 +08:00
- SPL:
. Fixed bug #72646 (SplFileObject::getCsvControl does not return the escape
character). (cmb)
2016-07-28 05:52:05 +08:00
. Fixed bug #72684 (AppendIterator segfault with closed generator). (Pierrick)
2016-07-22 21:28:42 +08:00
2016-07-25 20:29:26 +08:00
- SQLite3:
. Fixed bug #72668 (Spurious warning when exception is thrown in user defined
function). (Laruence)
. Implemented FR #72653 (SQLite should allow opening with empty filename).
(cmb)
2016-07-25 20:29:26 +08:00
- Standard:
. Fixed bug #61967 (unset array item in array_walk_recursive cause
inconsistent array). (Nikita)
. Fixed bug #62607 (array_walk_recursive move internal pointer). (Nikita)
. Fixed bug #69068 (Exchanging array during array_walk -> memory errors).
(Nikita)
. Fixed bug #70713 (Use After Free Vulnerability in array_walk()/
array_walk_recursive()). (Nikita)
2016-07-21 17:20:06 +08:00
- Streams:
. Fixed bug #41021 (Problems with the ftps wrapper). (vhuk)
. Fixed bug #54431 (opendir() does not work with ftps:// wrapper). (vhuk)
. Fixed bug #72667 (opendir() with ftp:// attempts to open data stream for
non-existent directories). (vhuk)
2016-07-21 17:20:06 +08:00
2016-07-30 21:54:20 +08:00
- Wddx:
. Fixed bug #72142 (WDDX Packet Injection Vulnerability in
wddx_serialize_value()). (Taoguang Chen)
2016-07-22 23:14:51 +08:00
- XMLRPC:
. Fixed bug #72647 (xmlrpc_encode() unexpected output after referencing
array elements). (Laruence)
2016-07-24 23:59:05 +08:00
- Zip:
. Fixed bug #72660 (NULL Pointer dereference in zend_virtual_cwd).
(Laruence)
2016-07-21 11:05:58 +08:00
21 Jul 2016, PHP 7.1.0beta1
2016-07-06 03:33:22 +08:00
- Core:
2016-07-20 17:00:30 +08:00
. Fixed bug #72629 (Caught exception assignment to variables ignores
references). (Laruence)
2016-07-14 13:38:42 +08:00
. Fixed bug #72594 (Calling an earlier instance of an included anonymous
class fatals). (Laruence)
2016-07-12 11:52:49 +08:00
. Fixed bug #72581 (previous property undefined in Exception after
deserialization). (Laruence)
. Fixed bug #72543 (Different references behavior comparing to PHP 5)
(Laruence, Dmitry, Nikita)
. Fixed bug #72347 (VERIFY_RETURN type casts visible in finally). (Dmitry)
. Fixed bug #72216 (Return by reference with finally is not memory safe).
(Dmitry)
. Fixed bug #72215 (Wrong return value if var modified in finally). (Dmitry)
. Fixed bug #71818 (Memory leak when array altered in destructor). (Dmitry)
. Fixed bug #71539 (Memory error on $arr[$a] =& $arr[$b] if RHS rehashes)
(Dmitry, Nikita)
2016-07-08 21:25:28 +08:00
. Added new constant PHP_FD_SETSIZE. (cmb)
2016-07-08 22:58:26 +08:00
. Added optind parameter to getopt(). (as)
2016-07-13 16:51:03 +08:00
. Added PHP to SAPI error severity mapping for logs. (Martin Vobruba)
2016-07-12 19:04:04 +08:00
. Fixed bug #71911 (Unable to set --enable-debug on building extensions by
phpize on Windows). (Yuji Uchiyama)
. Fixed bug #29368 (The destructor is called when an exception is thrown from
the constructor). (Dmitry)
. Implemented RFC: RNG Fixes. (Leigh)
2016-07-19 05:04:22 +08:00
. Implemented email validation as per RFC 6531. (Leo Feyer, Anatol)
2016-07-21 16:49:15 +08:00
. Fixed bug #72513 (Stack-based buffer overflow vulnerability in
virtual_file_ex). (Stas)
. Fixed bug #72573 (HTTP_PROXY is improperly trusted by some PHP libraries
and applications). (Stas)
- bz2:
. Fixed bug #72613 (Inadequate error handling in bzread()). (Stas)
2016-07-12 23:02:39 +08:00
- COM:
2016-07-12 23:05:24 +08:00
. Fixed bug #72569 (DOTNET/COM array parameters broke in PHP7). (Anatol)
2016-07-12 23:02:39 +08:00
2016-07-21 16:49:15 +08:00
- Curl:
. Fixed bug #72541 (size_t overflow lead to heap corruption). (Stas)
2016-07-11 22:10:48 +08:00
- Date:
. Fixed bug #66836 (DateTime::createFromFormat 'U' with pre 1970 dates fails
parsing). (derick)
- DOM:
. Fixed bug #66502 (DOM document dangling reference). (Sean Heelan, cmb)
2016-07-21 16:49:15 +08:00
- Exif:
. Fixed bug #72603 (Out of bound read in exif_process_IFD_in_MAKERNOTE).
(Stas)
. Fixed bug #72618 (NULL Pointer Dereference in exif_process_user_comment).
(Stas)
- Filter:
2016-07-08 22:34:15 +08:00
. Fixed bug #71745 (FILTER_FLAG_NO_RES_RANGE does not cover whole 127.0.0.0/8
range). (bugs dot php dot net at majkl578 dot cz)
2016-07-12 17:26:59 +08:00
- FPM:
. Fixed bug #72575 (using --allow-to-run-as-root should ignore missing user).
(gooh)
- GD:
. Fixed bug #72596 (imagetypes function won't advertise WEBP support). (cmb)
. Fixed bug #72604 (imagearc() ignores thickness for full arcs). (cmb)
. Fixed bug #70315 (500 Server Error but page is fully rendered). (cmb)
2016-07-19 23:58:29 +08:00
. Fixed bug #43828 (broken transparency of imagearc for truecolor in
blendingmode). (cmb)
2016-07-21 16:49:15 +08:00
. Fixed bug #72512 (gdImageTrueColorToPaletteBody allows arbitrary write/read
access). (Pierre)
. Fixed bug #72519 (imagegif/output out-of-bounds access). (Pierre)
. Fixed bug #72558 (Integer overflow error within _gdContributionsAlloc()).
(Pierre)
. Fixed bug #72482 (Ilegal write/read access caused by gdImageAALine
overflow). (Pierre)
. Fixed bug #72494 (imagecropauto out-of-bounds access). (Pierre)
- Intl:
. Partially fixed #72506 (idn_to_ascii for UTS #46 incorrect for long domain
names). (cmb)
2016-07-21 16:49:15 +08:00
. Fixed bug #72533 (locale_accept_from_http out-of-bounds access). (Stas)
- Mbstring:
. Deprecated mb_ereg_replace() eval option. (Rouven Weßling, cmb)
2016-07-19 05:04:22 +08:00
. Fixed bug #69151 (mb_ereg should reject ill-formed byte sequence).
(Masaki Kagaya)
2016-07-11 19:30:46 +08:00
- MCrypt:
. Deprecated ext/mcrypt. (Scott Arciszewski, cmb)
2016-07-21 16:49:15 +08:00
. Fixed bug #72551, bug #72552 (In correct casting from size_t to int lead to
heap overflow in mdecrypt_generic). (Stas)
2016-07-11 19:30:46 +08:00
2016-07-13 11:03:26 +08:00
- Opcache:
. Fixed bug #72590 (Opcache restart with kill_all_lockers does not work).
(Keyur)
- OpenSSL:
. Fixed bug #72360 (ext/openssl build failure with OpenSSL 1.1.0).
(Jakub Zelenka)
. Bumped a minimal version to 1.0.1. (Jakub Zelenka)
. Dropped support for SSL2. (Remi)
- PDO_pgsql:
. Fixed bug #70313 (PDO statement fails to throw exception). (Matteo)
. Fixed bug #72570 (Segmentation fault when binding parameters on a query
without placeholders). (Matteo)
2016-07-28 05:32:20 +08:00
. Implemented FR #72633 (Postgres PDO lastInsertId() should work without
specifying a sequence). (Pablo Santiago Sánchez)
2016-07-13 10:51:11 +08:00
- Pcntl
. Implemented asynchronous signal handling without TICKS. (Dmitry)
2016-07-07 03:06:01 +08:00
. Added pcntl_signal_get_handler() that returns the current signal handler
for a particular signal. Addresses FR #72409. (David Walker)
. Add signinfo to pcntl_signal() handler args (Bishop Bettini, David Walker)
- Reflection:
. Fixed bug #72222 (ReflectionClass::export doesn't handle array constants).
(Nikita Nefedov)
2016-07-13 10:51:11 +08:00
- SimpleXML:
. Fixed bug #72588 (Using global var doesn't work while accessing SimpleXML
element). (Laruence)
2016-07-20 16:13:21 +08:00
- Standard:
. Fixed bug #72622 (array_walk + array_replace_recursive create references
from nothing). (Laruence)
. Fixed bug #72330 (CSV fields incorrectly split if escape char followed by
UTF chars). (cmb)
2016-07-20 16:13:21 +08:00
2016-07-11 20:36:39 +08:00
- Tidy:
. Implemented support for libtidy 5.0.0 and above. (Michael Orlitzky, Anatol)
2016-07-08 16:48:34 +08:00
- Wddx:
. Fixed bug #72564 (boolean always deserialized as "true") (Remi)
2016-07-21 16:49:15 +08:00
- XMLRPC:
. Fixed bug #72606 (heap-buffer-overflow (write) simplestring_addn
simplestring.c). (Stas)
- Zip:
. Fixed bug #72520 (Stack-based buffer overflow vulnerability in
php_stream_zip_opener). (Stas)
07 Jul 2016, PHP 7.1.0alpha3
2016-06-22 13:33:20 +08:00
2016-06-28 15:37:33 +08:00
- Core:
2016-07-04 12:35:40 +08:00
. Implemented RFC: Iterable. (Aaron Piotrowski)
. Fixed bug #72523 (dtrace issue with reflection (failed test)). (Laruence)
2016-06-28 15:37:33 +08:00
. Fixed bug #72508 (strange references after recursive function call and
"switch" statement). (Laruence)
2016-07-05 15:01:31 +08:00
. Implemented RFC: Closure::fromCallable (Danack)
2016-06-28 15:37:33 +08:00
2016-07-02 00:45:27 +08:00
- COM:
. Fixed bug #72498 (variant_date_from_timestamp null dereference). (Anatol)
2016-06-27 01:36:44 +08:00
- CURL:
. Add curl_multi_errno(), curl_share_errno() and curl_share_strerror()
functions. (Pierrick)
2016-06-28 05:23:00 +08:00
. Add support for HTTP/2 Server Push (davey)
2016-06-27 01:36:44 +08:00
2016-07-05 15:10:33 +08:00
- Date:
. Invalid serialization data for a DateTime or DatePeriod object will now
throw an instance of Error from __wakeup() or __set_state() instead of
resulting in a fatal error. (Aaron Piotrowski)
. Timezone initialization failure from serialized data will now throw an
instance of Error from __wakeup() or __set_state() instead of resulting in
a fatal error. (Aaron Piotrowski)
. Export date_get_interface_ce() for extension use. (Jeremy Mikola)
2016-07-05 15:10:33 +08:00
- DBA:
. Data modification functions (e.g.: dba_insert()) now throw an instance of
Error instead of triggering a catchable fatal error if the key is does not
contain exactly two elements. (Aaron Piotrowski)
2016-07-05 15:10:33 +08:00
- DOM:
. Invalid schema or RelaxNG validation contexts will throw an instance of
Error instead of resulting in a fatal error. (Aaron Piotrowski)
. Attempting to register a node class that does not extend the appropriate
base class will now throw an instance of Error instead of resulting in a
fatal error. (Aaron Piotrowski)
. Attempting to read an invalid or write to a readonly property will throw
an instance of Error instead of resulting in a fatal error. (Aaron
Piotrowski)
2016-07-03 18:43:30 +08:00
- GD:
. Fixed bug #72404 (imagecreatefromjpeg fails on selfie). (cmb)
2016-07-05 15:10:33 +08:00
- IMAP:
. An email address longer than 16385 bytes will throw an instance of Error
instead of resulting in a fatal error. (Aaron Piotrowski)
- Intl:
. Failure to call the parent constructor in a class extending Collator
before invoking the parent methods will throw an instance of Error
instead of resulting in a recoverable fatal error. (Aaron Piotrowski)
. Cloning a Transliterator object may will now throw an instance of Error
instead of resulting in a fatal error if cloning the internal
transliterator fails. (Aaron Piotrowski)
- LDAP:
. Providing an unknown modification type to ldap_batch_modify() will now
throw an instance of Error instead of resulting in a fatal error.
(Aaron Piotrowski)
- Mbstring:
. mb_ereg() and mb_eregi() will now throw an instance of ParseError if an
invalid PHP expression is provided and the 'e' option is used. (Aaron
Piotrowski)
- Mcrypt:
. mcrypt_encrypt() and mcrypt_decrypt() will throw an instance of Error
instead of resulting in a fatal error if mcrypt cannot be initialized.
(Aaron Piotrowski)
- Mysqli:
. Attempting to read an invalid or write to a readonly property will throw
an instance of Error instead of resulting in a fatal error. (Aaron
Piotrowski)
- OpenSSL:
. Implemented FR #61204 (Add elliptic curve support for OpenSSL).
(Dominic Luechinger)
2016-06-23 02:20:48 +08:00
- PCRE:
2016-06-23 14:07:31 +08:00
. Fixed bug #72476 (Memleak in jit_stack). (Laruence)
2016-06-23 02:20:48 +08:00
. Fixed bug #72463 (mail fails with invalid argument). (Anatol)
2016-06-22 13:33:20 +08:00
2016-07-03 23:57:23 +08:00
- Readline:
. Fixed bug #72538 (readline_redisplay crashes php). (Laruence)
2016-07-05 15:10:33 +08:00
- Reflection:
. Failure to retrieve a reflection object or retrieve an object property
will now throw an instance of Error instead of resulting in a fatal error.
(Aaron Piotrowski)
2016-06-27 23:25:06 +08:00
- SQLite3:
. Fixed bug #70628 (Clearing bindings on an SQLite3 statement doesn't work).
(cmb)
2016-07-03 09:31:06 +08:00
- Session:
. Fixed bug #72531 (ps_files_cleanup_dir Buffer overflow). (Laruence)
2016-07-05 15:10:33 +08:00
. Custom session handlers that do not return strings for session IDs will
now throw an instance of Error instead of resulting in a fatal error
when a function is called that must generate a session ID.
(Aaron Piotrowski)
. An invalid setting for session.hash_function will throw an instance of
Error instead of resulting in a fatal error when a session ID is created.
(Aaron Piotrowski)
2016-07-21 16:49:15 +08:00
. Fixed bug #72562 (Use After Free in unserialize() with Unexpected Session
Deserialization). (Stas)
2016-07-05 15:10:33 +08:00
- SimpleXML:
. Creating an unnamed or duplicate attribute will throw an instance of Error
instead of resulting in a fatal error. (Aaron Piotrowski)
2016-07-21 16:49:15 +08:00
- SNMP:
. Fixed bug #72479 (Use After Free Vulnerability in SNMP with GC and
unserialize()). (Stas)
2016-07-05 15:10:33 +08:00
- SPL:
. Attempting to clone an SplDirectory object will throw an instance of Error
instead of resulting in a fatal error. (Aaron Piotrowski)
. Calling ArrayIterator::append() when iterating over an object will throw an
instance of Error instead of resulting in a fatal error. (Aaron Piotrowski)
2016-07-05 22:51:25 +08:00
. Fixed bug #55701 (GlobIterator throws LogicException). (Valentin VĂLCIU)
2016-07-03 09:31:06 +08:00
2016-06-24 13:56:41 +08:00
- Standard:
2016-06-28 02:40:17 +08:00
. Implemented RFC: More precise float values. (Jakub Zelenka, Yasuo)
2016-06-24 13:56:41 +08:00
. array_multisort now uses zend_sort instead zend_qsort. (Laruence)
2016-06-28 11:12:22 +08:00
. Fixed bug #72505 (readfile() mangles files larger than 2G). (Cschneid)
2016-07-05 15:10:33 +08:00
. assert() will throw a ParseError when evaluating a string given as the first
argument if the PHP code is invalid instead of resulting in a catchable
fatal error. (Aaron Piotrowski)
. Calling forward_static_call() outside of a class scope will now throw an
instance of Error instead of resulting in a fatal error. (Aaron Piotrowski)
2016-06-24 13:56:41 +08:00
2016-07-03 23:16:53 +08:00
- Streams:
. Fixed bug #72534 (stream_socket_get_name crashes). (Anatol)
2016-07-05 15:10:33 +08:00
- Tidy:
. Creating a tidyNode manually will now throw an instance of Error instead of
resulting in a fatal error. (Aaron Piotrowski)
2016-07-03 23:16:53 +08:00
2016-07-05 15:10:33 +08:00
- WDDX:
. A circular reference when serializing will now throw an instance of Error
instead of resulting in a fatal error. (Aaron Piotrowski)
- XML-RPC:
. A circular reference when serializing will now throw an instance of Error
instead of resulting in a fatal error. (Aaron Piotrowski)
- Zip:
. ZipArchive::addGlob() will throw an instance of Error instead of resulting
in a fatal error if glob support is not available. (Aaron Piotrowski)
2016-06-22 13:30:30 +08:00
23 Jun 2016, PHP 7.1.0alpha2
2016-06-07 21:10:27 +08:00
2016-06-10 21:57:18 +08:00
- Core:
2016-06-18 00:40:12 +08:00
. Implemented RFC: Replace "Missing argument" warning with "Too few
2016-06-16 13:44:38 +08:00
arguments" exception. (Dmitry)
. Implemented RFC: Fix inconsistent behavior of $this variable. (Dmitry)
. Fixed bug #72441 (Segmentation fault: RFC list_keys). (Laruence)
2016-06-14 00:21:14 +08:00
. Fixed bug #72395 (list() regression). (Laruence)
2016-06-10 21:57:18 +08:00
. Fixed bug #72373 (TypeError after Generator function w/declared return type
finishes). (Nikita)
2016-06-17 23:16:36 +08:00
. Fixed bug #69489 (tempnam() should raise notice if falling back to temp dir).
(Laruence, Anatol)
2016-06-21 02:20:32 +08:00
. Fixed UTF-8 and long path support on Windows. (Anatol)
2016-06-07 21:10:27 +08:00
2016-07-04 17:07:34 +08:00
- Date:
. Fixed bug #63740 (strtotime seems to use both sunday and monday as start of
week). (Derick)
2016-06-16 20:34:34 +08:00
- GD:
. Fixed bug #43475 (Thick styled lines have scrambled patterns). (cmb)
2016-06-18 00:09:46 +08:00
. Fixed bug #53640 (XBM images require width to be multiple of 8). (cmb)
2016-06-20 21:39:34 +08:00
. Fixed bug #64641 (imagefilledpolygon doesn't draw horizontal line). (cmb)
2016-06-16 20:34:34 +08:00
- JSON
. Implemented FR #46600 ("_empty_" key in objects). (Jakub Zelenka)
2016-06-15 14:56:41 +08:00
- Mbstring:
. Fixed bug #72405 (mb_ereg_replace - mbc_to_code (oniguruma) -
oob read access). (Laruence)
. Fixed bug #72399 (Use-After-Free in MBString (search_re)). (Laruence)
- OpenSSL:
2016-06-20 00:59:09 +08:00
. Implemented FR #67304 (Added AEAD support [CCM and GCM modes] to
openssl_encrypt and openssl_decrypt). (Jakub Zelenka)
. Implemented error storing to the global queue and cleaning up the OpenSSL
error queue (resolves bugs #68276 and #69882). (Jakub Zelenka)
2016-06-20 02:40:45 +08:00
- PCRE:
. Upgraded to PCRE 8.39. (Anatol)
- Sqlite3:
. Implemented FR #72385 (Update SQLite bundle lib(3.13.0)). (Laruence)
2016-06-07 21:10:27 +08:00
2016-06-15 14:56:41 +08:00
- Standard:
2016-07-04 12:35:40 +08:00
. Added is_iterable() function. (Aaron Piotrowski)
2016-06-15 14:56:41 +08:00
. Fixed bug #72306 (Heap overflow through proc_open and $env parameter).
(Laruence)
- Streams:
. Fixed bug #72439 (Stream socket with remote address leads to a segmentation
fault). (Laruence)
2016-06-07 21:10:27 +08:00
09 Jun 2016, PHP 7.1.0alpha1
- Core:
. Added nullable types. (Levi, Dmitry)
. Added DFA optimization framework based on e-SSA form. (Dmitry, Nikita)
. Added specialized opcode handlers (e.g. ZEND_ADD_LONG_NO_OVERFLOW).
(Dmitry)
. Change statement and fcall extension handlers to accept frame. (Joe)
. Implemented safe execution timeout handling, that prevents random crashes
after "Maximum execution time exceeded" error. (Dmitry)
. Fixed bug #53432 (Assignment via string index access on an empty string
converts to array). (Nikita)
. Fixed bug #62210 (Exceptions can leak temporary variables). (Dmitry, Bob)
. Fixed bug #62814 (It is possible to stiffen child class members visibility).
(Nikita)
. Fixed bug #69989 (Generators don't participate in cycle GC). (Nikita)
. Fixed bug #70228 (Memleak if return in finally block). (Dmitry)
. Fixed bug #71266 (Missing separation of properties HT in foreach etc).
(Dmitry)
. Fixed bug #71604 (Aborted Generators continue after nested finally).
(Nikita)
. Fixed bug #71572 (String offset assignment from an empty string inserts
null byte). (Francois)
. Fixed bug #71897 (ASCII 0x7F Delete control character permitted in
identifiers). (Andrea)
. Fixed bug #72188 (Nested try/finally blocks losing return value). (Dmitry)
. Fixed bug #72213 (Finally leaks on nested exceptions). (Dmitry, Nikita)
. Implemented the RFC `Support Class Constant Visibility`. (Sean DuBois,
Reeze Xia, Dmitry)
. Added void return type. (Andrea)
. Added support for negative string offsets in string offset syntax and
various string functions. (Francois)
. Added a form of the list() construct where keys can be specified. (Andrea)
. Number operators taking numeric strings now emit E_NOTICEs or E_WARNINGs
when given malformed numeric strings. (Andrea)
. (int), intval() where $base is 10 or unspecified, settype(), decbin(),
decoct(), dechex(), integer operators and other conversions now always
respect scientific notation in numeric strings. (Andrea)
. Implemented the RFC `Catching multiple exception types`. (Bronislaw Bialek,
Pierrick)
. Raise a compile-time warning on octal escape sequence overflow. (Sara)
. Added [] = as alternative construct to list() =. (Bob)
. Implemented logging to syslog with dynamic error levels. (Jani Ollikainen)
. Fixed bug #47517 (php-cgi.exe missing UAC manifest).
(maxdax15801 at users noreply github com)
- Apache2handler:
. Enable per-module logging in Apache 2.4+. (Martin Vobruba)
- CLI Server:
. Fixed bug #71276 (Built-in webserver does not send Date header).
(see at seos fr)
- FTP:
. Implemented FR #55651 (Option to ignore the returned FTP PASV address).
(abrender at elitehosts dot com)
- Intl:
. Added IntlTimeZone::getWindowsID() and
IntlTimeZone::getIDForWindowsID(). (Sara)
. Fixed bug #69374 (IntlDateFormatter formatObject returns wrong utf8 value).
(lenhatanh86 at gmail com)
. Fixed bug #69398 (IntlDateFormatter formatObject returns wrong value when
time style is NONE). (lenhatanh86 at gmail com)
- Hash:
. Added SHA3 fixed mode algorithms (224, 256, 384, and 512 bit). (Sara)
. Added SHA512/256 and SHA512/224 algorithms. (Sara)
- JSON:
. Exported JSON parser API including json_parser_method that can be used
for implementing custom logic when parsing JSON. (Jakub Zelenka)
. Escaped U+2028 and U+2029 when JSON_UNESCAPED_UNICODE is supplied as
json_encode options and added JSON_UNESCAPED_LINE_TERMINATORS to restore
the previous behaviour. (Eddie Kohler)
- PDO_Firebird:
. Fixed bug #60052 (Integer returned as a 64bit integer on X86_64). (Mariuz)
- Pgsql:
. Implemented FR #31021 (pg_last_notice() is needed to get all notice
messages). (Yasuo)
. Implemented FR #48532 (Allow pg_fetch_all() to index numerically). (Yasuo)
- Reflection:
. Fix #72209 (ReflectionProperty::getValue() doesn't fail if object doesn't match type). (Joe)
- Session:
. Improved fix for bug #68063 (Empty session IDs do still start sessions).
(Yasuo)
. Fixed bug #71038 (session_start() returns TRUE on failure).
Session save handlers must return 'string' always for successful read.
i.e. Non-existing session read must return empty string. PHP 7.0 is made
not to tolerate buggy return value. (Yasuo)
. Fixed bug #71394 (session_regenerate_id() must close opened session on
errors). (Yasuo)
- SQLite3:
. Implemented FR #71159 (Upgraded bundled SQLite lib to 3.9.2). (Laruence)
- Standard:
. Fixed bug #71100 (long2ip() doesn't accept integers in strict mode).
(Laruence)
. Implemented FR #55716 (Add an option to pass a custom stream context to
get_headers()). (Ferenc)
. Additional validation for parse_url() for login/pass components).
(Ilia) (Julien)
. Implemented FR #69359 (Provide a way to fetch the current environment
variables). (Ferenc)
. unpack() function accepts an additional optional argument $offset. (Dmitry)
. Implemented #51879 stream context socket option tcp_nodelay (Joe)
2015-12-04 00:01:22 +08:00
<<< NOTE: Insert NEWS from last stable release here prior to actual release! >>>