Contrib : str_replace template operator

Author Message

Lex 007

Friday 22 April 2005 3:39:56 am

Hi everyone,

Since I didn't find any str_replace template operator (maybe I didn't look right??), I just programmed a small extension for it. Very easy and very usefull (it took me more time to write this topic than programm it lol)

1/ Go to your "extension" folder in your eZ Publish install

2/ Create file str_replace/autoloads/eztemplateautoload.php

<?php

// Operator autoloading

$eZTemplateOperatorArray = array();

$eZTemplateOperatorArray[] =
  array( 'script' => 'extension/str_replace/autoloads/str_replace_controloperator.php',
         'class' => 'MyStrReplaceOperator',
         'operator_names' => array( 'ezstr_replace' ) );

?>

3/ Create file str_replace/autoloads/str_replace_controloperator.php

<?php

class MyStrReplaceOperator
{
    /*!
     Constructor
    */
    function MyStrReplaceOperator()
    {
        $this->Operators = array( 'ezstr_replace');
    }

    /*!
     Returns the operators in this class.
    */
    function &operatorList()
    {
        return $this->Operators;
    }

    /*!
     \return true to tell the template engine that the parameter list
    exists per operator type, this is needed for operator classes
    that have multiple operators.
    */
    function namedParameterPerOperator()
    {
        return true;
    }

    /*!
     The first operator has two parameters, the other has none.
     See eZTemplateOperator::namedParameterList()
    */
    function namedParameterList()
    {
        return array(                      
                      'ezstr_replace' => array('search' => array( 'type' => 'string',
                                                                     'required' => true,
                                                                     'default' => '' ),
                                                'replace' => array( 'type' => 'string',
                                                                     'required' => true,
                                                                     'default' => '' ),
                                                'subject' => array( 'type' => 'string',
                                                                     'required' => true,
                                                                     'default' => '' )
                                            ) );
    }

    /*!
     Executes the needed operator(s).
     Checks operator names, and calls the appropriate functions.
    */
    function modify( &$tpl, &$operatorName, &$operatorParameters, &$rootNamespace,
                     &$currentNamespace, &$operatorValue, &$namedParameters )
    {
        switch ( $operatorName )
        {
            case 'ezstr_replace':
            {
                $operatorValue = $this->ezstr_replace( $namedParameters['search'], 
                                                        $namedParameters['replace'], 
                                                        $namedParameters['subject']);
            } break;
        }
    }

    function ezstr_replace( $search, $replace, $subject  )
    { 
        return str_replace( $search, $replace, $subject  );
    }

    /// \privatesection
    var $Operators;
}

?>

4/ Create file str_replace/settings/site.ini.append.php

<?php

[TemplateSettings]
ExtensionAutoloadPath[]=str_replace

?>

5/ Activate the extension in the admin interface

6/ To use it in a template :

{ezstr_replace($search,$replace,$subject)}

Enjoy !

Bruce Morrison

Friday 22 April 2005 8:40:30 pm

This would be good to include in the core distribution!

My Blog: http://www.stuffandcontent.com/
Follow me on twitter: http://twitter.com/brucemorrison
Consolidated eZ Publish Feed : http://friendfeed.com/rooms/ez-publish

kracker (the)

Friday 22 April 2005 10:49:30 pm

Lex,

Would you package up your operator as an eZ publish extension (packaged in an either zip or tar.gz) and upload it into the contributions section as a new project?

And if your interested in making your operator available for consideration into eZ publish you would want to be sure to clearly assign copyright to eZ systems.

More information on this subject is available on the "Contributing Code" Section (Towards the Bottom, <i>boy, I sure wish more ez.no's content had hidden anchors for direct linking to core information and subjects</i>)
http://ez.no/community/developer/contributing

cheers,
//kracker

sole : selling live water : Respect Pt. 3

Member since: 2001.07.13 || http://ezpedia.se7enx.com/

Lex 007

Monday 25 April 2005 6:36:37 am

OK, why not !
How to you make a *.ezpkg from an extension ?

kracker (the)

Monday 25 April 2005 6:46:29 am

right on,

sorry for the confusion, i don't think you can create an extension as an eZ package. I guess the next best alternative is a documented (zip/tar.gz package).

//kracker
what was I thinking?

<i>counting crows : hey monkey, where you been?</i>

Member since: 2001.07.13 || http://ezpedia.se7enx.com/

Lex 007

Tuesday 26 April 2005 1:52:30 am

That's right ! I'll try to published it soon then.

Lex 007

Wednesday 27 April 2005 8:17:53 am

I've uploaded the files to : http://ez.no/community/contribs/template_plugins/string_replace_operator

Please report any bug.

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 19:15:57
Script start
Timing: Jan 18 2025 19:15:57
Module start 'layout'
Timing: Jan 18 2025 19:15:57
Module start 'content'
Timing: Jan 18 2025 19:15:57
Module end 'content'
Timing: Jan 18 2025 19:15:57
Script end

Main resources:

Total runtime0.0157 sec
Peak memory usage2,048.0000 KB
Database Queries3

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0054 589.4453152.6250
Module start 'layout' 0.00540.0033 742.070339.4453
Module start 'content' 0.00880.0048 781.5156101.4609
Module end 'content' 0.01360.0020 882.976642.3047
Script end 0.0156  925.2813 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.002415.1263140.0002
Check MTime0.00116.7194140.0001
Mysql Total
Database connection0.00074.773310.0007
Mysqli_queries0.002918.781230.0010
Looping result0.00000.152210.0000
Template Total0.001710.710.0017
Template load0.00095.456510.0009
Template processing0.00085.226710.0008
Override
Cache load0.00063.840510.0006
General
dbfile0.00021.573380.0000
String conversion0.00000.051740.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