Thursday 18 August 2011 7:28:54 am

» Back to Roadmap

Description

eZ 4.4 has to be used with PHP 5.2 at least. With the major version 5.3, namespaces became available in PHP. Unfortunatly we can't use them in eZ Publish.

Whether eZ Core classes use namespaces or not, developpers can't also use them whereas there isn't much to do to make namespaces available.

We only need to add few lines in the file 'kernel/private/classes/ezautoloadgenerator.php'. Using the php function token_get_all provides an array with parsed elements of the file.

For a namespace, PHP use the constant T_NAMESPACE. To ensure that our code is compatible in PHP 5.2, we need to define the constant in that version. To do such thing, we only need to add line 436 the following code :


        $this->setStatArray( self::OUTPUT_PROGRESS_PHASE2, $statArray );
        $this->startProgressOutput( self::OUTPUT_PROGRESS_PHASE2 );

+        $aPhpVersion = explode('.', phpversion());
+        if ($aPhpVersion[1] < 3)
+        {
+            !defined('T_NAMESPACE') && define('T_NAMESPACE', 377);
+        }

        foreach( $fileList as $file )

For each file we set a namespace variable to an empty string :

+             $sNameSpace = '';
            $tokens = @token_get_all( file_get_contents( $file ) );

Then we get the namespace in the switch

                     switch( $token[0] )
                    {
+                        case T_NAMESPACE:
+                            $sNameSpace = '';
+                            for ($i = $key+2; $i < count($tokens)-1; $i++)
+                            {
+                                if (is_array($tokens[$i]) && T_STRING == $tokens[$i][0])
+                                {
+                                    $sNameSpace .= $tokens[$i][1].'\\';
+                                }
+                                else if (!is_array($tokens[$i]) && in_array($tokens[$i], array(';', '{')))
+                                {
+                                    break;
+                                }
+                            }
+                            break;

And finally we add the namespace before the class name, the autoload function will automaticly load the class

-                             $className = $tokens[$key+2][1];
+                            $className = $sNameSpace.$tokens[$key+2][1];

What do you think about it ?

No reply yet!

You must be logged in to post messages in this topic!

Powered by eZ Publish™ CMS Open Source Web Content Management. Copyright © 1999-2014 eZ Systems AS (except where otherwise noted). All rights reserved.

eZ debug

Timing: Jan 18 2025 02:05:07
Script start
Timing: Jan 18 2025 02:05:07
Module start 'layout'
Timing: Jan 18 2025 02:05:07
Module start 'content'
Timing: Jan 18 2025 02:05:07
Module end 'content'
Timing: Jan 18 2025 02:05:07
Script end

Main resources:

Total runtime0.0170 sec
Peak memory usage4,096.0000 KB
Database Queries3

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0069 587.9141152.6250
Module start 'layout' 0.00690.0036 740.539139.4531
Module start 'content' 0.01050.0046 779.992293.7500
Module end 'content' 0.01520.0018 873.742230.2891
Script end 0.0169  904.0313 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.002615.5309140.0002
Check MTime0.00116.7040140.0001
Mysql Total
Database connection0.00095.005910.0009
Mysqli_queries0.003017.809530.0010
Looping result0.00000.093910.0000
Template Total0.00148.410.0014
Template load0.00084.722610.0008
Template processing0.00063.669610.0006
Override
Cache load0.00053.181610.0005
General
dbfile0.00031.528480.0000
String conversion0.00000.068740.0000
Note: percentages do not add up to 100% because some accumulators overlap

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 1
 Number of unique templates used: 1

Time used to render debug report: 0.0001 secs