Server : Apache/2.4.43 (Win64) OpenSSL/1.1.1g PHP/7.4.6
System : Windows NT USER-PC 6.1 build 7601 (Windows 7 Professional Edition Service Pack 1) AMD64
User : User ( 0)
PHP Version : 7.4.6
Disable Function : NONE
Directory :  C:/xampp/php/docs/examples/
Upload File :
Current Directory [ Writeable ] Root Directory [ Writeable ]


Current File : C:/xampp/php/docs/examples/pci180_parsestring_toxml.php
<?php
/**
 * Get the Compatibility info for a chunk of code
 *
 * This example show the new options|features available with API 1.8.0
 * Especially, observer and xml renderer
 *
 * PHP versions 4 and 5
 *
 * @category PHP
 * @package  PHP_CompatInfo
 * @author   Laurent Laville <pear@laurent-laville.org>
 * @license  http://www.opensource.org/licenses/bsd-license.php  BSD
 * @version  CVS: $Id: pci180_parsestring_toxml.php,v 1.2 2008/07/22 20:26:45 farell Exp $
 * @link     http://pear.php.net/package/PHP_CompatInfo
 * @since    version 1.8.0b4 (2008-06-18)
 * @ignore
 */

require_once 'PHP/CompatInfo.php';

define('DEST_LOG_FILE', dirname(__FILE__) . DIRECTORY_SEPARATOR . 'notify.log');

/*
   Add an observer to listen all PCI events
 */
function pci180_debug(&$auditEvent)
{
    $notifyName = $auditEvent->getNotificationName();
    $notifyInfo = $auditEvent->getNotificationInfo();
    error_log('notifyName:'. $notifyName . PHP_EOL, 3, DEST_LOG_FILE);
    error_log('notifyInfo:'. PHP_EOL .
               var_export($notifyInfo, true) . PHP_EOL, 3, DEST_LOG_FILE);
}

/*
   With API 1.8.0 you may choose a custom render,
   between all default renderers (all customizable).

   Here we choose to display result as XML stream,
   beautified if PEAR::XML_Beautifier package is available (installed).
 */
$driverType = 'xml';

// use some options of XML_Beautifier to change default render
$driverOptions = array('beautifier' => array('indent' => ' ',
                                             'linebreak' => PHP_EOL),
//                     output all informations except tokens (output-level = 23)
                       'args' => array('output-level' => 23));
$compatInfo = new PHP_CompatInfo($driverType, $driverOptions);
$compatInfo->addListener('pci180_debug');

$str1 = '<?php
$nl = "\n";
echo "$nl Atom    = " . DATE_ATOM;
echo "$nl Cookie  = " . DATE_COOKIE;
echo "$nl Iso8601 = " . DATE_ISO8601;
echo "$nl Rfc822  = " . DATE_RFC822;
echo "$nl Rfc850  = " . DATE_RFC850;
echo "$nl Rfc1036 = " . DATE_RFC1036;
echo "$nl Rfc1123 = " . DATE_RFC1123;
echo "$nl Rfc2822 = " . DATE_RFC2822;
echo "$nl RSS     = " . DATE_RSS;
echo "$nl W3C     = " . DATE_W3C;
?>';

$str2 = '<?php
class Request6056
{
    function testMaxVersion()
    {
        // PHP 5 <= 5.0.4
        $res = php_check_syntax(\'bug6581.php\');

        $array1 = array(\'blue\'  => 1, \'red\'  => 2, \'green\'  => 3);
        $array2 = array(\'green\' => 5, \'blue\' => 6, \'yellow\' => 7);

        // PHP 5 >= 5.1.0RC1
        $diff = array_diff_key($array1, $array2);
    }
}
?>';

$source  = array($str1, $str2);
$options = array('is_string' => true, 'debug' => true);

//$r = $compatInfo->parseString($source, $options);
// You may also use the new unified method parseData(), parseString() became an alias
$r = $compatInfo->parseData($source, $options);

/*
   To keep backward compatibility, result is also return (here in $r)
   but you don't need to print it, it's the default behavior of API 1.8.0
 */
//var_export($r);
?>