]> granicus.if.org Git - php/log
php
4 years agoMerge branch 'PHP-8.0'
George Peter Banyard [Fri, 23 Oct 2020 19:48:52 +0000 (20:48 +0100)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Throw Value/TypeError for invalid $bodies in imap_mail_compose()

4 years agoThrow Value/TypeError for invalid $bodies in imap_mail_compose()
George Peter Banyard [Thu, 22 Oct 2020 14:23:35 +0000 (15:23 +0100)]
Throw Value/TypeError for invalid $bodies in imap_mail_compose()

Small drive by refactoring to use HashTables

Closes GH-6371

4 years agowaitpid in ftp server tests
Nikita Popov [Fri, 23 Oct 2020 09:10:21 +0000 (11:10 +0200)]
waitpid in ftp server tests

This is not relevant right now, but ensures consistent order if
the tests are repeated.

4 years agoAllow running session tests in parallel
Nikita Popov [Fri, 23 Oct 2020 14:17:13 +0000 (16:17 +0200)]
Allow running session tests in parallel

Use unique session IDs and/or save paths. Also removes the annoying
order-dependence of session tests.

4 years agoMerge branch 'PHP-8.0'
Máté Kocsis [Fri, 23 Oct 2020 14:34:40 +0000 (16:34 +0200)]
Merge branch 'PHP-8.0'

4 years agoRequire stubs to declare return types for magic methods when possible
Máté Kocsis [Fri, 23 Oct 2020 12:09:23 +0000 (14:09 +0200)]
Require stubs to declare return types for magic methods when possible

Closes GH-6376

4 years agoUse ephemeral port in more server tests
Nikita Popov [Fri, 23 Oct 2020 09:29:44 +0000 (11:29 +0200)]
Use ephemeral port in more server tests

Port the main php_cli_server.inc to use ephemeral ports, thus
allowing CLI server tests to be parallelized.

A complication here is that we also need to give each test a
separate doc root, to avoid index.php files writing over each
other.

Closes GH-6375.

4 years agoFix pasv_port determination
Nikita Popov [Fri, 23 Oct 2020 09:46:54 +0000 (11:46 +0200)]
Fix pasv_port determination

Apparently the ftp server is also used by ext/standard/tests/streams,
and only that part actually uses pasv.

4 years agoUse ephemeral port in ftp tests
Nikita Popov [Thu, 22 Oct 2020 10:53:57 +0000 (12:53 +0200)]
Use ephemeral port in ftp tests

And enable them to run in parallel.

4 years agoMerge branch 'PHP-8.0'
Nikita Popov [Fri, 23 Oct 2020 08:31:55 +0000 (10:31 +0200)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Make GC default threshold handling consistent

4 years agoMake GC default threshold handling consistent
Nikita Popov [Fri, 23 Oct 2020 08:30:07 +0000 (10:30 +0200)]
Make GC default threshold handling consistent

While the initial threshold is set to 10001 roots, the threshold
adjustment logic may then set it to 10000. The exact value really
doesn't matter, but we should make it consistent.

4 years agoMerge branch 'PHP-8.0'
Nikita Popov [Fri, 23 Oct 2020 07:47:36 +0000 (09:47 +0200)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Don't allow passing unknown named params to class without ctor

4 years agoDon't allow passing unknown named params to class without ctor
Nikita Popov [Wed, 21 Oct 2020 09:55:03 +0000 (11:55 +0200)]
Don't allow passing unknown named params to class without ctor

See also https://externals.io/message/112083.

Closes GH-6364.

4 years agoMerge branch 'PHP-8.0'
Nikita Popov [Fri, 23 Oct 2020 07:34:37 +0000 (09:34 +0200)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Fixed some typos

[ci skip]

4 years agoFixed some typos
Javier Eguiluz [Thu, 22 Oct 2020 17:46:24 +0000 (19:46 +0200)]
Fixed some typos

Closes GH-6373.

[ci skip]

4 years agoMerge branch 'PHP-8.0'
Dmitry Stogov [Thu, 22 Oct 2020 20:17:19 +0000 (23:17 +0300)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Fixed register allocation
  Fixed reference-counter inference
  Missed warning

4 years agoFixed register allocation
Dmitry Stogov [Thu, 22 Oct 2020 20:16:41 +0000 (23:16 +0300)]
Fixed register allocation

4 years agoFixed reference-counter inference
Dmitry Stogov [Thu, 22 Oct 2020 20:15:39 +0000 (23:15 +0300)]
Fixed reference-counter inference

4 years agoMissed warning
Dmitry Stogov [Thu, 22 Oct 2020 20:15:15 +0000 (23:15 +0300)]
Missed warning

4 years agoMerge branch 'PHP-8.0'
Máté Kocsis [Thu, 22 Oct 2020 17:03:04 +0000 (19:03 +0200)]
Merge branch 'PHP-8.0'

4 years agoRun arginfo/ZPP verification tests in strict mode as well
Máté Kocsis [Thu, 22 Oct 2020 10:48:12 +0000 (12:48 +0200)]
Run arginfo/ZPP verification tests in strict mode as well

Closes GH-6370

4 years agoMerge branch 'PHP-8.0'
George Peter Banyard [Thu, 22 Oct 2020 16:06:07 +0000 (17:06 +0100)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Fix bug 76618

4 years agoFix bug 76618
George Peter Banyard [Thu, 22 Oct 2020 16:01:48 +0000 (17:01 +0100)]
Fix bug 76618

Apply patch which was attached to the bug in July 2018

4 years agoMerge branch 'PHP-8.0'
Dmitry Stogov [Thu, 22 Oct 2020 15:24:22 +0000 (18:24 +0300)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Checj type guards before loading values into CPU registers
  Avoid register allocation for ASSIGN into aliased variable (it might be indirectly changed into IS_REFERENCE)

4 years agoChecj type guards before loading values into CPU registers
Dmitry Stogov [Thu, 22 Oct 2020 15:23:49 +0000 (18:23 +0300)]
Checj type guards before loading values into CPU registers

4 years agoAvoid register allocation for ASSIGN into aliased variable (it might be indirectly...
Dmitry Stogov [Thu, 22 Oct 2020 15:22:36 +0000 (18:22 +0300)]
Avoid register allocation for ASSIGN into aliased variable (it might be indirectly changed into IS_REFERENCE)

4 years agoMerge branch 'PHP-8.0'
George Peter Banyard [Thu, 22 Oct 2020 14:50:42 +0000 (15:50 +0100)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Fix segfaults after conversion from zval to zend_string params

4 years agoFix segfaults after conversion from zval to zend_string params
George Peter Banyard [Thu, 22 Oct 2020 14:21:57 +0000 (15:21 +0100)]
Fix segfaults after conversion from zval to zend_string params

4 years agoMerge branch 'PHP-8.0'
Nikita Popov [Thu, 22 Oct 2020 14:06:16 +0000 (16:06 +0200)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Don't crash on uninitialized tidy object

4 years agoMerge branch 'PHP-7.4' into PHP-8.0
Nikita Popov [Thu, 22 Oct 2020 14:05:57 +0000 (16:05 +0200)]
Merge branch 'PHP-7.4' into PHP-8.0

* PHP-7.4:
  Don't crash on uninitialized tidy object

4 years agoMerge branch 'PHP-7.3' into PHP-7.4
Nikita Popov [Thu, 22 Oct 2020 14:05:34 +0000 (16:05 +0200)]
Merge branch 'PHP-7.3' into PHP-7.4

* PHP-7.3:
  Don't crash on uninitialized tidy object

4 years agoDon't crash on uninitialized tidy object
Nikita Popov [Thu, 22 Oct 2020 14:04:22 +0000 (16:04 +0200)]
Don't crash on uninitialized tidy object

"Uninitialized" here means that the object was created ordinarily
-- no constructor skipping involved. Most tidy methods seem to
handle this fine, but these three need to be guarded.

4 years agoMerge branch 'PHP-8.0'
Nikita Popov [Thu, 22 Oct 2020 13:20:51 +0000 (15:20 +0200)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Properly validate ArrayObject::asort() argument

4 years agoProperly validate ArrayObject::asort() argument
Nikita Popov [Thu, 22 Oct 2020 13:19:47 +0000 (15:19 +0200)]
Properly validate ArrayObject::asort() argument

4 years agoFix zpp for GdFont|int
Nikita Popov [Thu, 22 Oct 2020 13:06:47 +0000 (15:06 +0200)]
Fix zpp for GdFont|int

Use Z_PARAM_OBJ_OF_TYPE_OR_LONG to get standard behavior.

4 years agoMerge branch 'PHP-8.0'
Nikita Popov [Thu, 22 Oct 2020 12:56:00 +0000 (14:56 +0200)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Fix parameter name of pspell_config_save_repl()

4 years agoFix parameter name of pspell_config_save_repl()
Máté Kocsis [Thu, 22 Oct 2020 09:44:19 +0000 (11:44 +0200)]
Fix parameter name of pspell_config_save_repl()

Closes GH-6369.

4 years agoMerge branch 'PHP-8.0'
Nikita Popov [Thu, 22 Oct 2020 12:52:03 +0000 (14:52 +0200)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Fix stub for dba_key_split()

4 years agoFix stub for dba_key_split()
Nikita Popov [Thu, 22 Oct 2020 12:49:48 +0000 (14:49 +0200)]
Fix stub for dba_key_split()

This is an extremely weird function, but the behavior seems to be
intentional, and is quite clearly documented.

So we adjust the stub to also accept false|null as arguments. I
believe the implementation already correctly matches union type
semantics.

4 years agoAccept zend_string in highlight_string API
Nikita Popov [Thu, 22 Oct 2020 12:35:40 +0000 (14:35 +0200)]
Accept zend_string in highlight_string API

4 years agoMerge branch 'PHP-8.0'
Nikita Popov [Thu, 22 Oct 2020 12:31:54 +0000 (14:31 +0200)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Make highlight_string() accept string in zpp

4 years agoMake highlight_string() accept string in zpp
Nikita Popov [Thu, 22 Oct 2020 12:31:23 +0000 (14:31 +0200)]
Make highlight_string() accept string in zpp

To satisfy the type declaration.

4 years agoRemove unused pasv_listen() function
Nikita Popov [Thu, 22 Oct 2020 12:23:07 +0000 (14:23 +0200)]
Remove unused pasv_listen() function

4 years agoMerge branch 'PHP-8.0'
Nikita Popov [Thu, 22 Oct 2020 12:22:16 +0000 (14:22 +0200)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Don't leak pcntl last_error across requests

4 years agoDon't leak pcntl last_error across requests
Nikita Popov [Thu, 22 Oct 2020 12:18:45 +0000 (14:18 +0200)]
Don't leak pcntl last_error across requests

4 years agoMerge branch 'PHP-8.0'
Nikita Popov [Thu, 22 Oct 2020 10:42:26 +0000 (12:42 +0200)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Don't leak json error_code across requests

4 years agoDon't leak json error_code across requests
Nikita Popov [Thu, 22 Oct 2020 10:41:52 +0000 (12:41 +0200)]
Don't leak json error_code across requests

4 years agoMerge branch 'PHP-8.0'
Nikita Popov [Thu, 22 Oct 2020 09:20:21 +0000 (11:20 +0200)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Don't leak pcre error_code across requests
  Updated to version 2020.4 (2020d)

4 years agoDon't leak pcre error_code across requests
Nikita Popov [Thu, 22 Oct 2020 09:01:59 +0000 (11:01 +0200)]
Don't leak pcre error_code across requests

4 years agoUpdated to version 2020.4 (2020d)
Derick Rethans [Thu, 22 Oct 2020 09:12:27 +0000 (10:12 +0100)]
Updated to version 2020.4 (2020d)

4 years agoUpdated to version 2020.4 (2020d)
Derick Rethans [Thu, 22 Oct 2020 09:12:27 +0000 (10:12 +0100)]
Updated to version 2020.4 (2020d)

4 years agoEmpty merge
Derick Rethans [Thu, 22 Oct 2020 09:12:27 +0000 (10:12 +0100)]
Empty merge

4 years agoEmpty merge
Derick Rethans [Thu, 22 Oct 2020 09:12:27 +0000 (10:12 +0100)]
Empty merge

4 years agoUpdated to version 2020.4 (2020d)
Derick Rethans [Thu, 22 Oct 2020 09:12:26 +0000 (10:12 +0100)]
Updated to version 2020.4 (2020d)

4 years agoEmpty merge
Derick Rethans [Thu, 22 Oct 2020 09:12:25 +0000 (10:12 +0100)]
Empty merge

4 years agoUpdated to version 2020.4 (2020d)
Derick Rethans [Thu, 22 Oct 2020 09:12:24 +0000 (10:12 +0100)]
Updated to version 2020.4 (2020d)

4 years agoRemove unused single.leaf member
Nikita Popov [Thu, 22 Oct 2020 08:42:26 +0000 (10:42 +0200)]
Remove unused single.leaf member

4 years agoDon't allow properties on former resource objects
Nikita Popov [Thu, 22 Oct 2020 08:35:03 +0000 (10:35 +0200)]
Don't allow properties on former resource objects

4 years agoMerge branch 'PHP-8.0'
Nikita Popov [Thu, 22 Oct 2020 08:34:44 +0000 (10:34 +0200)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Don't allow properties on GdImage

4 years agoDon't allow properties on GdImage
Nikita Popov [Thu, 22 Oct 2020 08:34:14 +0000 (10:34 +0200)]
Don't allow properties on GdImage

Just like all the other former resources... we missed this case.

4 years agoMerge branch 'PHP-8.0'
Nikita Popov [Thu, 22 Oct 2020 08:27:01 +0000 (10:27 +0200)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Simplify and fix generator tree management

4 years agoSimplify and fix generator tree management
Nikita Popov [Thu, 15 Oct 2020 14:42:59 +0000 (16:42 +0200)]
Simplify and fix generator tree management

This makes a number of related changes to the generator tree
management, that should hopefully make it easier to understand,
more robust and faster for the common linear-chain case. Fixes
https://bugs.php.net/bug.php?id=80240, which was the original
motivation here.

 * Generators now only add a ref to their direct parent.
 * Nodes only store their children, not their leafs, which avoids
   any need for leaf updating. This means it's no longer possible
   to fetch the child for a certain leaf, which is something we
   only needed in one place (update_current). If multi-children
   nodes are involved, this will require doing a walk in the other
   direction (from leaf to root). It does not affect the common
   case of single-child nodes.
 * The root/leaf pointers are now seen as a pair. One leaf generator
   can point to the current root. If a different leaf generator is
   used, we'll move the root pointer over to that one. Again, this
   is a cache to make the common linear chain case fast, trees may
   need to scan up the parent link.

Closes GH-6344.

4 years agoConvert pspell resources to objects
Sara Golemon [Thu, 22 Oct 2020 00:12:55 +0000 (00:12 +0000)]
Convert pspell resources to objects

4 years agoNEWS for gdFont conversion
Sara Golemon [Wed, 21 Oct 2020 23:43:28 +0000 (23:43 +0000)]
NEWS for gdFont conversion

4 years agoConvert gdFont from resource to object
Sara Golemon [Wed, 21 Oct 2020 23:21:25 +0000 (23:21 +0000)]
Convert gdFont from resource to object

4 years agoConvert FTP resource to object
Sara Golemon [Wed, 21 Oct 2020 22:09:08 +0000 (22:09 +0000)]
Convert FTP resource to object

4 years agoMerge branch 'PHP-8.0'
Nikita Popov [Wed, 21 Oct 2020 15:07:12 +0000 (17:07 +0200)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Update bcmath.scale when calling bcscale()

4 years agoUpdate bcmath.scale when calling bcscale()
Nikita Popov [Wed, 21 Oct 2020 15:03:54 +0000 (17:03 +0200)]
Update bcmath.scale when calling bcscale()

We should keep the value of bcmath.scale and the internal
bc_precision global synchronized.

Probably more important than the ability to retrieve bcmath.scale
via ini_get(), this also makes sure that the set scale does not
leak into the next request, as it currently does.

4 years agoMerge branch 'PHP-8.0'
Dmitry Stogov [Wed, 21 Oct 2020 13:05:34 +0000 (16:05 +0300)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  More accurate live range construction

4 years agoMore accurate live range construction
Dmitry Stogov [Wed, 21 Oct 2020 13:05:13 +0000 (16:05 +0300)]
More accurate live range construction

4 years agoMerge branch 'PHP-8.0'
Dmitry Stogov [Wed, 21 Oct 2020 13:03:54 +0000 (16:03 +0300)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Eliminate useless mov(s)

4 years agoEliminate useless mov(s)
Dmitry Stogov [Wed, 21 Oct 2020 13:03:28 +0000 (16:03 +0300)]
Eliminate useless mov(s)

4 years agoMerge branch 'PHP-8.0'
Nikita Popov [Wed, 21 Oct 2020 10:17:14 +0000 (12:17 +0200)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Add test for zend_extension loading

4 years agoAdd test for zend_extension loading
Nikita Popov [Wed, 21 Oct 2020 08:34:34 +0000 (10:34 +0200)]
Add test for zend_extension loading

Closes GH-6363.

4 years agoMerge branch 'PHP-8.0'
Nikita Popov [Wed, 21 Oct 2020 08:07:24 +0000 (10:07 +0200)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Fix invalid memory read on libpath

4 years agoFix invalid memory read on libpath
twosee [Wed, 21 Oct 2020 05:17:16 +0000 (13:17 +0800)]
Fix invalid memory read on libpath

Introduced in 3e33e1e86d15e262cd9e0224a9604e252f5d9284.

Closes GH-6362.

4 years agoMerge branch 'PHP-8.0'
Dmitry Stogov [Tue, 20 Oct 2020 20:37:39 +0000 (23:37 +0300)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Eliminate dead type store

4 years agoEliminate dead type store
Dmitry Stogov [Tue, 20 Oct 2020 20:37:19 +0000 (23:37 +0300)]
Eliminate dead type store

4 years agoMerge branch 'PHP-8.0'
Dmitry Stogov [Tue, 20 Oct 2020 17:31:09 +0000 (20:31 +0300)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Improve JIT for fetching character form string

4 years agoImprove JIT for fetching character form string
Dmitry Stogov [Tue, 20 Oct 2020 17:29:33 +0000 (20:29 +0300)]
Improve JIT for fetching character form string

4 years agoMerge branch 'PHP-8.0' into master
Christoph M. Becker [Tue, 20 Oct 2020 17:02:32 +0000 (19:02 +0200)]
Merge branch 'PHP-8.0' into master

* PHP-8.0:
  Fix #80242: imap_mail_compose() segfaults for multipart with rfc822

4 years agoMerge branch 'PHP-7.4' into PHP-8.0
Christoph M. Becker [Tue, 20 Oct 2020 17:01:56 +0000 (19:01 +0200)]
Merge branch 'PHP-7.4' into PHP-8.0

* PHP-7.4:
  Fix #80242: imap_mail_compose() segfaults for multipart with rfc822

4 years agoMerge branch 'PHP-7.3' into PHP-7.4
Christoph M. Becker [Tue, 20 Oct 2020 17:00:04 +0000 (19:00 +0200)]
Merge branch 'PHP-7.3' into PHP-7.4

* PHP-7.3:
  Fix #80242: imap_mail_compose() segfaults for multipart with rfc822

4 years agoFix #80242: imap_mail_compose() segfaults for multipart with rfc822
Christoph M. Becker [Tue, 20 Oct 2020 14:38:16 +0000 (16:38 +0200)]
Fix #80242: imap_mail_compose() segfaults for multipart with rfc822

libc-client expects `TYPEMESSAGE` with an explicit subtype of `RFC822`
to have a `nested.msg` (otherwise there will be a segfault during
free), but not to have any `contents.text.data` (this will leak
otherwise).

Closes GH-6345.

4 years agoMerge branch 'PHP-8.0'
Nikita Popov [Tue, 20 Oct 2020 14:48:28 +0000 (16:48 +0200)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Fix default value handling of mysqli_fetch_object()

4 years agoFix default value handling of mysqli_fetch_object()
Máté Kocsis [Tue, 13 Oct 2020 22:12:51 +0000 (00:12 +0200)]
Fix default value handling of mysqli_fetch_object()

Make [] acceptable both for classes without constructors and
classes with a constructor that takes no arguments.

Closes GH-6336.

4 years agoMerge branch 'PHP-8.0' into master
Christoph M. Becker [Tue, 20 Oct 2020 14:34:40 +0000 (16:34 +0200)]
Merge branch 'PHP-8.0' into master

* PHP-8.0:
  Add char* cast to avoid compiler warnings

4 years agoMerge branch 'PHP-7.4' into PHP-8.0
Christoph M. Becker [Tue, 20 Oct 2020 14:33:56 +0000 (16:33 +0200)]
Merge branch 'PHP-7.4' into PHP-8.0

* PHP-7.4:
  Add char* cast to avoid compiler warnings

4 years agoMerge branch 'PHP-7.3' into PHP-7.4
Christoph M. Becker [Tue, 20 Oct 2020 14:31:25 +0000 (16:31 +0200)]
Merge branch 'PHP-7.3' into PHP-7.4

* PHP-7.3:
  Add char* cast to avoid compiler warnings

4 years agoAdd char* cast to avoid compiler warnings
Christoph M. Becker [Tue, 20 Oct 2020 14:25:00 +0000 (16:25 +0200)]
Add char* cast to avoid compiler warnings

In libc-client 2007f `data` is declared as `unsigned char *`; there may
be variants which declare it as `void *`, but in any case picky
compilers may warn about a pointer type mismatch in the conditional
(and error with `-W-error`), so we're adding a `char *` cast for good
measure.

4 years agoMerge branch 'PHP-8.0'
Nikita Popov [Tue, 20 Oct 2020 13:36:02 +0000 (15:36 +0200)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Fixed bug #80256

4 years agoFixed bug #80256
Nikita Popov [Tue, 20 Oct 2020 13:32:01 +0000 (15:32 +0200)]
Fixed bug #80256

Remove the transfer_encoding stream filter immediately when we
destroy the old stream, to make sure it doesn't get attached to
the new stream.

4 years agoMerge branch 'PHP-8.0' into master
Christoph M. Becker [Tue, 20 Oct 2020 11:37:07 +0000 (13:37 +0200)]
Merge branch 'PHP-8.0' into master

* PHP-8.0:
  Properly fix #80220

4 years agoMerge branch 'PHP-7.4' into PHP-8.0
Christoph M. Becker [Tue, 20 Oct 2020 11:36:17 +0000 (13:36 +0200)]
Merge branch 'PHP-7.4' into PHP-8.0

* PHP-7.4:
  Properly fix #80220

4 years agoMerge branch 'PHP-7.3' into PHP-7.4
Christoph M. Becker [Tue, 20 Oct 2020 11:34:27 +0000 (13:34 +0200)]
Merge branch 'PHP-7.3' into PHP-7.4

* PHP-7.3:
  Properly fix #80220

4 years agoProperly fix #80220
Christoph M. Becker [Fri, 16 Oct 2020 09:58:50 +0000 (11:58 +0200)]
Properly fix #80220

The original fix for that bug[1] broke the formerly working composition
of message/rfc822 messages, which results in a segfault when freeing
the message body now.  While `imap_mail_compose()` does not really
support composition of meaningful message/rfc822 messages (although
libc-client appears to support that), some code may still use this to
compose partial messages, and using string manipulation to create the
final message.

The point is that libc-client expects `TYPEMESSAGE` with an explicit
subtype of `RFC822` to have a `nested.msg` (otherwise there will be a
segfault during free), but not to have any `contents.text.data` (this
will leak otherwise).

[1] <http://git.php.net/?p=php-src.git;a=commit;h=0d022ddf03c5fabaaa22e486d1e4a367ed9170a7>

Closes GH-6343.

4 years agoMerge branch 'PHP-8.0'
Nikita Popov [Tue, 20 Oct 2020 10:51:17 +0000 (12:51 +0200)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Fix bug #79643: Invalid memory read when opcache.interned_strings_buffer is 0

4 years agoMerge branch 'PHP-7.4' into PHP-8.0
Nikita Popov [Tue, 20 Oct 2020 10:51:08 +0000 (12:51 +0200)]
Merge branch 'PHP-7.4' into PHP-8.0

* PHP-7.4:
  Fix bug #79643: Invalid memory read when opcache.interned_strings_buffer is 0

4 years agoFix bug #79643: Invalid memory read when opcache.interned_strings_buffer is 0
twosee [Tue, 9 Jun 2020 06:55:36 +0000 (14:55 +0800)]
Fix bug #79643: Invalid memory read when opcache.interned_strings_buffer is 0

4 years agoMerge branch 'PHP-8.0'
Dmitry Stogov [Tue, 20 Oct 2020 10:46:47 +0000 (13:46 +0300)]
Merge branch 'PHP-8.0'

* PHP-8.0:
  Improve register allocator (register reuse)