Forums / General / Array append Problem

Array append Problem

Author Message

Michael Hoenig

Thursday 25 March 2004 3:08:43 pm

Hi, I'm new in ezPublish and I try to append a content of a variable to an existing array with the following code:

{let ort_array=array()}
...
{section loop=$node.object.related_contentobject_array}
...
{$ort_array|append($:item)}
{/section}
...
{/let}

Thanks for your help!!

Michael

Rinze Cats

Wednesday 09 June 2004 6:03:42 am

I am having troubles dymanically adding items in an array using a loop as well. Can anybody shine a light on the above problem?

Hugo Siles

Wednesday 09 June 2004 6:13:12 am

hi, you should try something like this

{let ort_array=array()}
...
{section loop=$node.object.related_contentobject_array}
...
{set ort_array=$ort_array|append($:item)}
{/section}
...
{/let}

Rinze Cats

Wednesday 09 June 2004 6:53:03 am

Hmm,

i was using the correct code, but it isn't working because I use a name for my section. Maybe you can help me with this code

{let my_array=array()}
{section loop=$current_node.object.related_contentobject_array}
{set my_array=$my_array|append($:item.data_map.positie.content.0)}
{/section}
{$my_array|count}
{/let}

this works, and count outputs 20. Adding the name (omitting it isn't an option right now)

{let my_array=array()}
{section name=Container loop=$current_node.object.related_contentobject_array}
{set my_array=$my_array|append($:item.data_map.positie.content.0)}
{/section}
{$my_array|count}
{/let}

This code, certainly is incorrect, but I can't get it to work (tried a godzillion syntatical variations ;-( )
greetz
rinze

Hugo Siles

Wednesday 09 June 2004 7:11:30 am

hi, again

{let my_array=array()}
{section name=Container loop=$current_node.object.related_contentobject_array}
{set my_array=$my_array|append(<b>$Container</b>:item.data_map.positie.content.0)}
{/section}
{$my_array|count}
{/let}

also it would be a good idea to look at this pages
http://ez.no/ez_publish/documentation/development/libraries/ez_template/functions/section
or
http://ez.no/ez_publish/documentation/toc

regards

hugo

Rinze Cats

Wednesday 09 June 2004 7:38:13 am

are you certain this code is correct? I have tried this, and tried it again just now (copy-paste), but it doesn't seem to work. Count results in 0. I am using 3.3.5.

the following error is produced by the debugger.

Warning: eZTemplate:set Jun 09 2004 16:34:30 
Variable 'Container:my_array' doesn't exist, cannot set

I have previously tried to solve this by adding the container prefix on an trial and error basis, resulting in some marvelous errors, but never the count of 20 ;-(

Hugo Siles

Wednesday 09 June 2004 7:48:14 am

hi, you are right, i forgot one important thing, as long as the my_array is in another namespace you cannot modify it in the Container namespace

in this page this problem is explained.. try it
http://ez.no/ez_publish/documentation/development/libraries/ez_template/basics/namespaces_

i guess the best solution it's ommit the name "Container" in the {section} tag

Regards

Hugo

Paul Forsyth

Wednesday 09 June 2004 7:57:13 am

You could omit the namespace altogether and use the new var= construct, eg:

{let my_array=array()}
{section var=Container loop=$current_node.object.related_contentobject_array}
{set my_array=$my_array|append($Container.data_map.positie.content.0)}
{/section}
{$my_array|count}
{/let}

Notice the new use of Container. The var parameter does away with namespaces...

paul

--
http://www.visionwt.com

Rinze Cats

Thursday 10 June 2004 1:18:18 am

Hi all, and thanx for the help. I replaced the namespace tag with the var tag and replaced all the references to the namespace from within my section (posted code is just a sniplet).

All is well now! I find it strange though, that a global variable cannot be adressed from within another namespace.

greetz
rinze

Rinze Cats

Thursday 10 June 2004 5:01:11 am

Mm, runnig into some weird behaviour again, do any of you have an explanation for this?

The code should first initialize an array, then it should dynamically at items to this array, if the item doesn't already exist. The general idea is to fetch an objects position value, or assign the first available position number randomly, if the position is missing from the current object.
The second part of this code snipplet is behaving really weird

{let my_array=array()}
{section var=Container loop=$current_node.object.related_contentobject_array}
{section show=and(ne($Container.data_map.positie.content.0,''), ne($Container.data_map.positie.content.0, '0'))}
	{set my_array=$my_array|append($Container.data_map.positie.content.0)}
{/section}
{/section}

{section var=counter loop=20}
	{section show=$my_array|contains($counter)}
		{* do nothing *}
	{section-else}
		{set my_array=$my_array|append($counter)}
	{/section}
{/section}
{/let}

When I omit the section-else part, the function works. With the {section-else} part, it doesn't. The else part is executed once, an item is added to array. So far so good. However, now the {section show=$my_array|contains($counter)} always evaluates to true, and the new element in the array is updated with the value of $counter (although the else part of the loop is isn't executed??).

I am at a loss here.

Paul Forsyth

Thursday 10 June 2004 5:07:05 am

Are you sure your array is populated correctly? What does {$my_array|attribute(show)} produce?

paul

--
http://www.visionwt.com

Rinze Cats

Thursday 10 June 2004 5:09:26 am

Mm, solved it myself, but am wondering if this is by design or if it is a bug.

Instead of using $counter, I assign it to a variable

{let my_count = $counter}

and use my_count in the function.

When using $counter, it adds $counter itself to array, and then startupdating it in the array. So {$counter} prints the number, with let you can assign it, but with append you append the variable instead of it's value.

Paul Forsyth

Thursday 10 June 2004 5:12:41 am

That is weird. Yes, file it as a bug. $counter should be the value of the current element of the loop. If its an integer it should act like one...

paul

--
http://www.visionwt.com

Rinze Cats

Thursday 10 June 2004 5:15:24 am

thanx for all the help paul, will report this is a bug

eZ debug

Timing: Jan 18 2025 11:35:36
Script start
Timing: Jan 18 2025 11:35:36
Module start 'content'
Timing: Jan 18 2025 11:35:37
Module end 'content'
Timing: Jan 18 2025 11:35:37
Script end

Main resources:

Total runtime0.7117 sec
Peak memory usage4,096.0000 KB
Database Queries231

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0078 588.7188180.8516
Module start 'content' 0.00780.5618 769.5703679.8828
Module end 'content' 0.56960.1420 1,449.4531350.0547
Script end 0.7116  1,799.5078 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00430.6067210.0002
Check MTime0.00160.2198210.0001
Mysql Total
Database connection0.00180.247010.0018
Mysqli_queries0.619687.06382310.0027
Looping result0.00300.42162290.0000
Template Total0.684896.220.3424
Template load0.00240.335820.0012
Template processing0.682495.884220.3412
Template load and register function0.00020.029910.0002
states
state_id_array0.00150.206010.0015
state_identifier_array0.00100.146720.0005
Override
Cache load0.00220.3122980.0000
Sytem overhead
Fetch class attribute can translate value0.00190.262250.0004
Fetch class attribute name0.00150.2051140.0001
XML
Image XML parsing0.00080.108550.0002
class_abstraction
Instantiating content class attribute0.00000.0031140.0000
General
dbfile0.00200.2754210.0001
String conversion0.00000.001130.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
14content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
30content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
11content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
6content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 63
 Number of unique templates used: 6

Time used to render debug report: 0.0002 secs