Forums / Developer / Module only returns strings, no integers

Module only returns strings, no integers

Author Message

Pål J Didriksen

Tuesday 28 June 2005 2:38:42 pm

I have a problem with the array returned from an extension module, and can't find out why.

I made a simple module, fetching content from an external table, called 'points'. Somehow, all values are returned as strings, even though most of them should be integers.

This is the code in 'points.php':

<?php

include_once( 'kernel/classes/ezpersistentobject.php' );

class Points extends eZPersistentObject
{

    function Points( $row )
    {
        $this->eZPersistentObject( $row );
    }

    function &definition()
    {
        $defArray= array( "fields" =>
               array(
                    'id' => array(
                    'datatype' => 'integer',
                    'default' => 0,
                    'name' => 'id',
                    'required' => true ),
              'contentobject_id' => array(
                    'name' => 'contentobject_id',
                    'datatype' => 'integer',
                    'default' => 0,
                    'required' => true ),
              'year' =>
              array('name' => 'year',
                    'datatype' => 'integer',
                    'default' => 0,
                    'required' => true ),
              'date' =>
              array('name' => 'date',
                    'datatype' => 'date',
                    'default' => 0,
                    'required' => false ),
              'category' =>
              array('name' => 'category',
                    'datatype' => 'integer',
                   'default' => 0,
                    'required' => false ),
              'title' =>
              array('name' => 'title',
                    'datatype' => 'string',
                    'default' => '',
                    'required' => false ),
              'points_int' =>
              array('name' => 'points_int',
                    'datatype' => 'integer',
                    'default' => 0,
                    'required' => false ) ),
           'keys' => array( 'id' ),
           'increment_key' => 'id',
           'class_name' => 'points',
           'sort'  => array( 'id' => 'asc'),
           'name' => 'points' );

        return $defArray;

    }

    function &fetchListFromDB( $parameters )
    {
        return Points::handleList( $parameters, false );
    }

    function &handleList( $parameters = array(), $asCount = false )
    {
        $parameters = array_merge( array( 'as_object' => true,
        'sort_by' => false,
        'offset' => false,
        'limit' => false,
        'contentobject_id' => true
         ),
        $parameters );

        $asObject = $parameters['as_object'];
        $offset = $parameters['offset'];
        $limit = $parameters['limit'];
        $sorts = $parameters['sort_by'];

        if (!$parameters['contentobject_id'] == "" )
            $conds = array('contentobject_id' => $parameters['contentobject_id']);
          $conds = "";

        $limitArray = null;
        if ( !$asCount and $offset !== false and $limit !== false )
        $limitArray = array( 'offset' => $offset,
                            'length' => $limit );

        $obj= eZPersistentObject::fetchObjectList( Points::definition(),
                                                    null, $conds, $sorts, $limitArray,
                                                    $asObject );

       return $obj;
    }

}

?>

Any tips, ideas or similar experiences?

eZ debug

Timing: Jan 20 2025 06:46:01
Script start
Timing: Jan 20 2025 06:46:01
Module start 'content'
Timing: Jan 20 2025 06:46:02
Module end 'content'
Timing: Jan 20 2025 06:46:02
Script end

Main resources:

Total runtime0.8531 sec
Peak memory usage4,096.0000 KB
Database Queries183

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0058 589.0703180.8281
Module start 'content' 0.00580.7023 769.8984457.6172
Module end 'content' 0.70810.1449 1,227.5156333.0547
Script end 0.8530  1,560.5703 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00400.4646210.0002
Check MTime0.00160.1847210.0001
Mysql Total
Database connection0.00070.079710.0007
Mysqli_queries0.780091.43651830.0043
Looping result0.00190.22721810.0000
Template Total0.827197.020.4135
Template load0.00180.216020.0009
Template processing0.825296.734920.4126
Template load and register function0.00020.022110.0002
states
state_id_array0.00110.128110.0011
state_identifier_array0.00150.176020.0008
Override
Cache load0.00150.176090.0002
Sytem overhead
Fetch class attribute can translate value0.00200.237120.0010
Fetch class attribute name0.00170.204120.0009
XML
Image XML parsing0.00830.967520.0041
class_abstraction
Instantiating content class attribute0.00000.000720.0000
General
dbfile0.00991.1660270.0004
String conversion0.00000.000730.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
1content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
1content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
2content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
1content/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: 7
 Number of unique templates used: 6

Time used to render debug report: 0.0002 secs