Forums / Developer / Lots of 'sections' and html whitespace

Lots of 'sections' and html whitespace

Author Message

Paul Forsyth

Friday 20 February 2004 4:17:00 am

Im adding logic to my templates for some situations, and when i look at the html source im finding it to contain lots of extra whitespace, which i believe are due to the many section/section-else statements. I've removed any tabs i have and the only whitespace remaining are normal spaces and new lines.

After removing such whitespace (making a huge single line) the html produced is what i expect.

So, is there a way to eliminate the indentions caused by logic code through the changing of a template? From the cause/effect experiments i've tried this seems to a lib/kernel issue.

Paul

Alex Jones

Friday 20 February 2004 6:42:40 am

A new whitespace wash operator would be nice. I recall an old thread that discussed it, but apparently the idea went no further than that: http://ez.no/community/forum/suggestions/nowhitespace_template_operator

I would really like the ability to format my eZ code so it is easy to read, without sacrificing the resulting HTML source.

Alex

Alex
[ bald_technologist on the IRC channel (irc.freenode.net): #eZpublish ]

<i>When in doubt, clear the cache.</i>

Paul Forsyth

Friday 20 February 2004 7:09:06 am

Pasted here from:

http://ez.no/community/bug_reports/template_logic_code_shouldn_t_produce_whitespace

to use the code tag!

            {section var=menu loop=$mainMenu}
                {section show=eq($menu.item.id, $menu_home_node)}
                     {set menu_url_alias="/"}
                {section-else}
                     {set menu_url_alias=$menu.item.url_alias}
                {/section}
                {section show=$menu.item.is_selected}
                    {* Only show the selection image if the current node is the same as the menu item *}
                    {section show=eq($node_id,$menu.item.id)}
                        {* If the current node is the last selection show the border *}
                        {section show=eq($menu.item.id,$last_selected_node)}
<li class="menu_link_level_{$menu.item.level}_selected"><a href={$menu_url_alias|ezurl}>{$menu.item.menu_name}</a></li>

Marko Pohl

Friday 20 February 2004 7:13:40 am

I would appreciate this opperator too.
I use this kind often when coding with the smarty template engine.
They use the tags {strip}{/strip} to eleminate whitespaces between the tags.

Area51 Mcb

Saturday 08 September 2007 5:25:55 am

Hi, I'm having the same problem, has anyone found a solution to this issue?
Unless I don't indent the code in the templates, the html source contains empty lines and spaces.

Thanks in advance.

Stéphane Bullier

Sunday 09 September 2007 12:18:07 am

Hello,

You have this setting for site.ini : UseFormatting

http://ez.no/doc/ez_publish/technical_manual/3_9/reference/configuration_files/site_ini/templatesettings/useformatting

Stéphane

Area51 Mcb

Monday 10 September 2007 12:43:41 am

Thank you for your reply.
I tried to enable / disable the UseFormatting setting, but it doesn't seem to do the trick. Well, I should say, I don't see any difference in the html source.
(The setting TemplateCompile is enabled though.)

When I first changed the UseFormatting setting, ezP generated bad code in the compiled templates. (I'm using ezP 3.9.2)

I got an unexpected T_String error, so I had to look into the compiled templates.

The content of $variableNameText in line 2698 of /lib/eztemplate/classes/eztemplatecompiler.php contains double quotes, resulting in something like this:

$tpl->warning("Variable "testvar" is already define.");

The original code of eztemplatecompiler.php

$php->addCodePiece( "    \$tpl->warning( '" . EZ_TEMPLATE_DEF_FUNCTION_NAME . "', \"Variable $variableNameText is already defined.\" );\n" );

I used a quick fix to replace double quotes by single quotes, to prevent this

$php->addCodePiece( "    \$tpl->warning( '" . EZ_TEMPLATE_DEF_FUNCTION_NAME . "', \"Variable ".str_replace("\"", "'", $variableNameText)." is already defined.\" );\n" );

Now the generated code should look like this:

$tpl->warning("Variable 'testvar' is already define.");

Not sure why this bug suddenly appeared when changing the UseFormatting setting, but anyway, with this fixed, I'm still having empty lines and whitespace in the html source.
Is there something else other than TemplateCompile that could have effect on UseFormatting?

eZ debug

Timing: Jan 18 2025 22:17:16
Script start
Timing: Jan 18 2025 22:17:16
Module start 'content'
Timing: Jan 18 2025 22:17:17
Module end 'content'
Timing: Jan 18 2025 22:17:17
Script end

Main resources:

Total runtime0.9156 sec
Peak memory usage4,096.0000 KB
Database Queries212

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0072 587.7344180.8281
Module start 'content' 0.00720.7345 768.5625700.3750
Module end 'content' 0.74160.1739 1,468.9375340.4609
Script end 0.9155  1,809.3984 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00450.4911210.0002
Check MTime0.00150.1662210.0001
Mysql Total
Database connection0.00070.078610.0007
Mysqli_queries0.809888.44132120.0038
Looping result0.00300.32622100.0000
Template Total0.886496.820.4432
Template load0.00180.201620.0009
Template processing0.884596.602220.4423
Template load and register function0.00030.028710.0003
states
state_id_array0.00070.075610.0007
state_identifier_array0.00200.223420.0010
Override
Cache load0.00160.1708460.0000
Sytem overhead
Fetch class attribute can translate value0.00110.123460.0002
Fetch class attribute name0.00100.110190.0001
XML
Image XML parsing0.00640.700260.0011
class_abstraction
Instantiating content class attribute0.00000.001890.0000
General
dbfile0.01781.9484330.0005
String conversion0.00000.001030.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
7content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
11content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
2content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
5content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
4content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 31
 Number of unique templates used: 7

Time used to render debug report: 0.0001 secs