<?php require_once(dirname(__FILE__).'/TSqlMapper.php'); /** * A DataMapper client class that can load a cached SqlMapper. Give the configuration * file, it looks for a .cache file containing serialized TSqlMapClient instance to * load. Usage: * * <code> * $client = new TSqlMapClient; * $sqlmap = $client->configure($configFile, true); //load from cache. * $products = $sqlMap->queryForList('statementName'); * </code> * * To save the TSqlMapper instance to cache for later usage, call * cacheConfiguration(). * * @author Wei Zhuo <weizhuo[at]gmail[dot]com> * @version $Id$ * @package System.DataAccess.SQLMap * @since 3.0 */ class TSqlMapClient { private $_mapper; private $_cache; public function configure($configFile, $loadFromCache=false) { if(is_null($this->_mapper)) $this->initMapper($configFile, $loadFromCache); return $this->_mapper; } public function getInstance() { return $this->_mapper; } public function cacheConfiguration() { if(!is_null($this->_mapper) && $this->_cache !== false) { if(!is_file($this->_cache)) { file_put_contents($this->_cache,serialize($this->_mapper)); return true; } } return false; } protected function initMapper($file=null,$loadFromCache=false) { $this->_cache = $this->getCacheFile($file); if($loadFromCache && $this->_cache !== false && is_file($this->_cache)) { $this->_mapper = unserialize(file_get_contents($this->_cache)); } else { $builder = new TDomSqlMapBuilder(); $this->_mapper = $builder->configure($file); } } protected function getCacheFile($file) { $path = realpath($file); if($path !== false) return substr($path,0, strrpos($path,'.')).'.cache'; else return false; } } ?>