Bonjour,
Je suis actuellement entrain de créer un site web sous joomla et je rencontre un code erreur lorsque j'essaye d'implémenter un module.
voici le message d'erreur en question:
Parse error: syntax error, unexpected T_STRING, expecting T_OLD_FUNCTION or T_FUNCTION or T_VAR or '}' in /homez.145/cemtrans/www/administrator/components/com_joomfish/classes/JCacheStorageJFDB.php on line 52
voici le fichier JCacheStorageJFDB.php
<?php
/**
* Joom!Fish - Multi Lingual extention and translation manager for Joomla!
* Copyright (C) 2003-2009 Think Network GmbH, Munich
*
* All rights reserved. The Joom!Fish project is a set of extentions for
* the content management system Joomla!. It enables Joomla!
* to manage multi lingual sites especially in all dynamic information
* which are stored in the database.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,USA.
*
* The "GNU General Public License" (GPL) is available at
*
http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
* -----------------------------------------------------------------------------
* $Id: JCacheStorageJFDB.php 1251 2009-01-07 06:29:53Z apostolov $
* @package joomfish
* @subpackage cache
*
*/
// Check to ensure this file is within the rest of the framework
defined('JPATH_BASE') or die();
//Register class that don't follow one file per class naming conventions
JLoader::register('JCacheStorage' , JPATH_LIBRARIES .DS. 'joomla'.DS.'cache' .DS.'storage.php');
/**
* Joomfish Cache Class
*
* @author Geraint Edwards (
http://www.gwesystems.com)
* @package Joomfish
* @subpackage Cache
* @since 2.0
*/
class JCacheStorageJfdb extends JCacheStorage
{
private $db;
private $profile_db;
/* Constructor
*
* @access protected
* @param array $options optional parameters
*/
function __construct( $options = array() )
{
static $expiredCacheCleaned;
$this->profile_db = & JFactory::getDBO();
$this->db = clone ($this->profile_db);
$this->_language = (isset($options['language'])) ? $options['language'] : 'en-GB';
$this->_lifetime = (isset($options['lifetime'])) ? $options['lifetime'] : 60;
$this->_now = (isset($options['now'])) ? $options['now'] : time();
$config =& JFactory::getConfig();
$this->_hash = $config->getValue('config.secret');
// if its not the first instance of the joomfish db cache then check if it should be cleaned and otherwise garbage collect
if (!isset($expiredCacheCleaned)) {
// check a file in the 'file' cache to check if we should remove all our db cache entries since cache manage doesn't handle anything other than file caches
$conf =& JFactory::getConfig();
$cachebase = $conf->getValue('config.cache_path',JPATH_ROOT.DS.'cache');
$cachepath = $cachebase.DS."joomfish-cache";
if (!JFolder::exists($cachepath)){
JFolder::create($cachepath);
}
$cachefile = $cachepath.DS."cachetest.txt";
jimport("joomla.filesystem.file");
if (!JFile::exists($cachefile) || JFile::read($cachefile)!="valid"){
// clean out the whole cache
$this->cleanCache();
JFile::write($cachefile,"valid");
}
$this->gc();
}
$expiredCacheCleaned = true;
}
/**
* One time only DB setup function
*
*/
function setupDB() {
$db = & JFactory::getDBO();
$charset = ($db->hasUTF()) ? 'CHARACTER SET utf8 COLLATE utf8_general_ci' : '';
$sql = "CREATE TABLE IF NOT EXISTS `#__dbcache` ("
. "\n `id` varchar ( 32 ) NOT NULL default '',"
. "\n `groupname` varchar ( 32 ) NOT NULL default '',"
. "\n `expire` datetime NOT NULL default '0000-00-00 00:00:00',"
//. "\n `value` MEDIUMTEXT NOT NULL default '',"
. "\n `value` MEDIUMBLOB NOT NULL default '',"
. "\n PRIMARY KEY ( `id`,`groupname` ),"
. "\n KEY ( `expire`,`groupname` )"
. "\n ) $charset";
$db->setQuery( $sql );
if (!$db->query()){
echo $db->getErrorMsg()."<br/>";
echo $db->_sql;
}
}
/**
* Get cached data from a db by id and group
*
* @access public
* @param string $id The cache data id
* @param string $group The cache data group
* @param boolean $checkTime True to verify cache time expiration threshold
* @return mixed Boolean false on failure or a cached data string
* @since 1.5
*/
function get($id, $group, $checkTime)
{
if (method_exists($this->profile_db,"_profile")) $pfunc = $this->profile_db->_profile();
$hashedid = md5($id.'-'.$this->_hash.'-'.$this->_language);
$data = false;
$sql = "SELECT UNCOMPRESS(value) FROM `#__dbcache` WHERE id=".$this->db->quote($hashedid)." AND groupname=".$this->db->quote($group)." AND expire>FROM_UNIXTIME(".$this->db->quote($this->_now).")";
$keepSQL = $this->db->_sql;
$this->db->setQuery($sql);
// Must set false to ensure that Joomfish doesn't get involved
$data = $this->db->loadResult(false);
$this->db->_sql = $keepSQL ;
if (is_null($data)){
$data = false;
}
else {
//$data = base64_decode($data);
}
if (method_exists($this->profile_db,"_profile")) $pfunc = $this->profile_db->_profile($pfunc);
return $data;
}
/**
* Store the data to a file by id and group
*
* @access public
* @param string $id The cache data id
* @param string $group The cache data group
* @param string $data The data to store in cache
* @return boolean True on success, false otherwise
* @since 1.5
*/
function store($id, $group, $data)
{
//$this->db =& JFactory::getDBO();
if (method_exists($this->profile_db,"_profile")) $pfunc = $this->profile_db->_profile();
$hashedid = md5($id.'-'.$this->_hash.'-'.$this->_language);
//$data = base64_encode($data);
$sql = "REPLACE INTO `#__dbcache` (id, groupname,expire,value) VALUES (".$this->db->quote($hashedid).",".$this->db->quote($group).",FROM_UNIXTIME(".$this->db->quote($this->_now + $this->_lifetime)."),COMPRESS(".$this->db->quote($data)."))";
$this->db->setQuery($sql);
$res = $this->db->query();
if (method_exists($this->profile_db,"_profile")) $pfunc = $this->profile_db->_profile($pfunc);
return $res;
}
/**
* Remove a cached data file by id and group
*
* @access public
* @param string $id The cache data id
* @param string $group The cache data group
* @return boolean True on success, false otherwise
* @since 1.5
*/
function remove($id, $group)
{
//$this->db =& JFactory::getDBO();
if (method_exists($this->profile_db,"_profile")) $pfunc = $this->profile_db->_profile();
$sql = "DELETE FROM `#__dbcache` WHERE id=".$this->db->quote($id)." AND groupname=".$this->db->quote($group);
$this->db->_skipSetRefTables=true;
$this->db->setQuery($sql);
$this->db->_skipSetRefTables=false;
if (method_exists($this->profile_db,"_profile")) $pfunc = $this->profile_db->_profile($pfunc);
return $this->db->query();
}
/**
* Clean cache for a group given a mode.
*
* group mode : cleans all cache in the group
* notgroup mode : cleans all cache not in the group
*
* @access public
* @param string $group The cache data group
* @param string $mode The mode for cleaning cache [group|notgroup]
* @return boolean True on success, false otherwise
* @since 1.5
*/
function clean($group, $mode)
{
//$this->db =& JFactory::getDBO();
if (method_exists($this->profile_db,"_profile")) $pfunc = $this->profile_db->_profile();
$result = false;
switch (trim($mode))
{
case 'group':
$sql = "DELETE FROM `#__dbcache` ";
$this->db->setQuery($sql);
break;
default:
$sql = "DELETE FROM `#__dbcache` WHERE groupname=".$this->db->quote($group);
$this->db->setQuery($sql);
break;
}
$this->db->_skipSetRefTables=true;
$result = $this->db->query();
$this->db->_skipSetRefTables=false;
if (method_exists($this->profile_db,"_profile")) $pfunc = $this->profile_db->_profile($pfunc);
return $result;
}
/**
* Clean the whole cache
*
* @return boolean True on success, false otherwise
*/
function cleanCache()
{
//$this->db =& JFactory::getDBO();
if (method_exists($this->profile_db,"_profile")) $pfunc = $this->profile_db->_profile();
$result = false;
$sql = "DELETE FROM `#__dbcache` ";
$this->db->setQuery($sql);
$this->db->_skipSetRefTables=true;
$result = $this->db->query();
$this->db->_skipSetRefTables=false;
if (method_exists($this->profile_db,"_profile")) $pfunc = $this->profile_db->_profile($pfunc);
return $result;
}
/**
* Garbage collect expired cache data
*
* @access public
* @return boolean True on success, false otherwise.
*/
function gc()
{
//$this->db =& JFactory::getDBO();
if (method_exists($this->profile_db,"_profile")) $pfunc = $this->profile_db->_profile();
$sql = "DELETE FROM `#__dbcache` WHERE expire< FROM_UNIXTIME(".$this->db->quote($this->_now).")";
$this->db->setQuery($sql);
$this->db->_skipSetRefTables=true;
$result = $this->db->query();
$this->db->_skipSetRefTables=false;
// if we can't delete then the database table probably doesn't exist so create it
if (!$result && $this->db->getErrorNum()==1146){
$this->setupDB();
}
if (method_exists($this->profile_db,"_profile")) $pfunc = $this->profile_db->_profile($pfunc);
}
/**
* Test to see if the cache storage is available.
*
* @static
* @access public
* @return boolean True on success, false otherwise.
*/
function test()
{
return true;
}
}
Merci pour d'avance pour votre aide car je ne vois vraiment pas d'ou vient le soucis
Configuration: Windows XP Internet Explorer 6.0