php.net |  support |  documentation |  report a bug |  advanced search |  search howto |  statistics |  random bug |  login
Request #76763 Make libxml_set_external_entity_loader() return previous entity loader
Submitted: 2018-08-18 10:14 UTC Modified: -
From: clicky at erebot dot net Assigned:
Status: Open Package: XML related
PHP Version: 7.2.9 OS: Debian 9
Private report: No CVE-ID: None
Have you experienced this issue?
Rate the importance of this bug to you:

 [2018-08-18 10:14 UTC] clicky at erebot dot net
Description:
------------
There is no way at the moment to retrieve the callback currently in use by libxml2's entity loader.

Imagine an application uses XML and has defined an entity loader.
Now, that application relies on an external library which also uses XML and relies on its own entity loader.

When the library is called, it will overwrite the application's entity loader with no way to restore it afterward.

I suggest changing the return value of libxml_set_external_entity_loader() so that it returns the previous entity loader if one was registered or NULL if no entity loader has been registered yet. It would also return NULL for errors.
This would match the behavior of other PHP functions like set_error_handler() and set_exception_handler().

Alternatively, being able to define multiple (stacking) entity loaders or having a function to restore the previous entity loader would be fine too.


Patches

Add a Patch

Pull Requests

Add a Pull Request

 
PHP Copyright © 2001-2020 The PHP Group
All rights reserved.
Last updated: Thu Apr 02 20:01:23 2020 UTC