Phar::mount
(No version information available, might be only in CVS)
Phar::mount — Mount an external path or file to a virtual location within the phar archive
Description
void Phar::mount
( string $pharpath
, string $externalpath
)
Parameters
-
pharpath
-
The internal path within the phar archive to use as the mounted path location.
If executed within a phar archive, this may be a relative path, otherwise this must
be a full phar URL.
-
externalpath
-
A path or URL to an external file or directory to mount within the phar archive
Return Values
No return. PharException is thrown on failure.
Errors/Exceptions
Throws PharException if any problems occur mounting the path.
Examples
Example #1 A Phar::mount() example
The following example shows accessing an external configuration file as if it were
a path within a phar archive.
First, the code inside of a phar archive:
<?php
$configuration = simplexml_load_string(file_get_contents(
Phar::running(false) . '/config.xml'));
?>
Next the external code used to mount the configuration file:
<?php
Phar::mount('phar:///path/to/archive.phar/config.xml', '/home/example/config.xml');
include '/path/to/archive.phar';
?>
Another method is to put the mounting code inside the stub of the phar archive.
Here is an example of setting up a default
configuration file if no user configuration is specified:
<?php
if (defined('EXTERNAL_CONFIG')) {
Phar::mount('config.xml', EXTERNAL_CONFIG);
if (file_exists(__DIR__ . '/extra_config.xml')) {
Phar::mount('extra.xml', __DIR__ . '/extra_config.xml');
}
} else {
Phar::mount('config.xml', 'phar://' . __FILE__ . '/default_config.xml');
Phar::mount('extra.xml', 'phar://' . __FILE__ . '/default_extra.xml');
}
include 'phar://' . __FILE__ . '/index.php';
__HALT_COMPILER();
?>
...and the code externally to load this phar archive:
<?php
define('EXTERNAL_CONFIG', '/home/example/config.xml');
include '/path/to/archive.phar';
?>