Forums / General / template includes and performance

template includes and performance

Author Message

*- pike

Tuesday 22 January 2008 5:06:41 am

Hi

Can't seem to find any info on this:

"Does including templates (using {include .. } ) decrease performance ?"

I would say, when template-compiling is on, the includes are actually included in the php code, If that is true, there is no difference at all (well, perhaps a msec while compiling). But I can't find the code that would do that ..

does anyone know?
*-pike

---------------
The class eZContentObjectTreeNode does.

*- pike

Tuesday 12 February 2008 11:54:59 am

Found my own answer

>I would say, when template-compiling is on, the includes are actually included
>in the php code, If that is true, there is no difference at all

But it isn't true.

Includes in templates, when compiled, become includes in PHP.

{include uri="SomeIncludedThing.tpl"}


becomes

<?include("SomeCompiledIncludedThing.php")?>

In other words - each EZP template is compiled into 1 PHP file.

And since SomeCompiledIncludedThing.php contains some wrapper php code (to prepare the actual compiled templatecode), including templates generates more php code, when compiled, then writing the template code all in one single template.

*-pike

---------------
The class eZContentObjectTreeNode does.

Abdelkader RHOUATI

Tuesday 12 February 2008 1:28:09 pm

hi,

perhaps there is no difference (or a small one). if we compare in way that ez compile the code {include ...}.

but for me, include templates in others, permit organize the code, then if i want to change a part of my site, i know exactely where i will do it. and this is a big differents.

some things are create for this reasons , just for improve the quality of devellopement...

tks

Abdelkader.

Abdelkader RHOUATI

Blog (french) : http://arhouati.com
----
Extension arh_jdebug : EzDebug using jquery

*- pike

Tuesday 12 February 2008 1:59:06 pm

absolutely. i love includes. i include everything.

but there is a downside, it decreases performance (a bit).

actually, i think it is a missed chance for ezpublish - one of the benefits for using a template language and compiling it into php is you could use includes while developing, and still have very efficient php after compiling (because the includes would be, well, included). but this is **not** the case as it is now (as far as i can see).

*-pike

---------------
The class eZContentObjectTreeNode does.

eZ debug

Timing: Jan 19 2025 00:14:08
Script start
Timing: Jan 19 2025 00:14:08
Module start 'content'
Timing: Jan 19 2025 00:14:09
Module end 'content'
Timing: Jan 19 2025 00:14:09
Script end

Main resources:

Total runtime1.3569 sec
Peak memory usage4,096.0000 KB
Database Queries197

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0073 587.7109180.8359
Module start 'content' 0.00731.1967 768.5469553.8984
Module end 'content' 1.20400.1528 1,322.4453336.7500
Script end 1.3568  1,659.1953 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00410.3045210.0002
Check MTime0.00160.1176210.0001
Mysql Total
Database connection0.00080.057310.0008
Mysqli_queries1.272393.76921970.0065
Looping result0.00250.18131950.0000
Template Total1.318697.220.6593
Template load0.00220.161520.0011
Template processing1.316397.012020.6582
Template load and register function0.00020.015810.0002
states
state_id_array0.00090.062710.0009
state_identifier_array0.00320.236620.0016
Override
Cache load0.00190.1390350.0001
Sytem overhead
Fetch class attribute can translate value0.00160.118530.0005
Fetch class attribute name0.00120.091050.0002
XML
Image XML parsing0.00210.157830.0007
class_abstraction
Instantiating content class attribute0.00000.000850.0000
General
dbfile0.00560.4100270.0002
String conversion0.00000.000430.0000
Note: percentages do not add up to 100% because some accumulators overlap

CSS/JS files loaded with "ezjscPacker" during request:

CacheTypePacklevelSourceFiles
CSS0extension/community/design/community/stylesheets/ext/jquery.autocomplete.css
extension/community_design/design/suncana/stylesheets/scrollbars.css
extension/community_design/design/suncana/stylesheets/tabs.css
extension/community_design/design/suncana/stylesheets/roadmap.css
extension/community_design/design/suncana/stylesheets/content.css
extension/community_design/design/suncana/stylesheets/star-rating.css
extension/community_design/design/suncana/stylesheets/syntax_and_custom_tags.css
extension/community_design/design/suncana/stylesheets/buttons.css
extension/community_design/design/suncana/stylesheets/tweetbox.css
extension/community_design/design/suncana/stylesheets/jquery.fancybox-1.3.4.css
extension/bcsmoothgallery/design/standard/stylesheets/magnific-popup.css
extension/sevenx/design/simple/stylesheets/star_rating.css
extension/sevenx/design/simple/stylesheets/libs/fontawesome/css/all.min.css
extension/sevenx/design/simple/stylesheets/main.v02.css
extension/sevenx/design/simple/stylesheets/main.v02.res.css
JS0extension/ezjscore/design/standard/lib/yui/3.17.2/build/yui/yui-min.js
extension/ezjscore/design/standard/javascript/jquery-3.7.0.min.js
extension/community_design/design/suncana/javascript/jquery.ui.core.min.js
extension/community_design/design/suncana/javascript/jquery.ui.widget.min.js
extension/community_design/design/suncana/javascript/jquery.easing.1.3.js
extension/community_design/design/suncana/javascript/jquery.ui.tabs.js
extension/community_design/design/suncana/javascript/jquery.hoverIntent.min.js
extension/community_design/design/suncana/javascript/jquery.popmenu.js
extension/community_design/design/suncana/javascript/jScrollPane.js
extension/community_design/design/suncana/javascript/jquery.mousewheel.js
extension/community_design/design/suncana/javascript/jquery.cycle.all.js
extension/sevenx/design/simple/javascript/jquery.scrollTo.js
extension/community_design/design/suncana/javascript/jquery.cookie.js
extension/community_design/design/suncana/javascript/ezstarrating_jquery.js
extension/community_design/design/suncana/javascript/jquery.initboxes.js
extension/community_design/design/suncana/javascript/app.js
extension/community_design/design/suncana/javascript/twitterwidget.js
extension/community_design/design/suncana/javascript/community.js
extension/community_design/design/suncana/javascript/roadmap.js
extension/community_design/design/suncana/javascript/ez.js
extension/community_design/design/suncana/javascript/ezshareevents.js
extension/sevenx/design/simple/javascript/main.js

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1node/view/full.tplfull/forum_topic.tplextension/sevenx/design/simple/override/templates/full/forum_topic.tplEdit templateOverride template
4content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
8content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
3content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
2content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
1content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 20
 Number of unique templates used: 7

Time used to render debug report: 0.0002 secs