JFactory sınıfını anlatmaya devam ediyorum. Hatırlarsanız Joomla! 1.0.x serisinde configuration.php dosyamızdaki verileri alabilmek için çeşitli işlemler yapıyor veya tek tek global olarak alıyorduk. Joomla! 1.5 te ise yine JFactory sınıfının bir metodu ile configuration.php dosyamızdaki değerleri alabiliyoruz.
function &getConfig($file = null, $type = 'PHP')
{
static $instance;
if (!is_object($instance))
{
if ($file === null) {
$file = dirname(__FILE__).DS.'config.php';
}
$instance = JFactory::_createConfig($file, $type);
}
return $instance;
}
Yukarıdaki fonksiyon da factory.php dosyasında JFactory sınıfının altındadır. Kullanımı şu şekilde;
$config = JFactory::getConfig();
Yukarıdaki fonksiyonda dikkatinizi çekmek istediğim nokta;
$instance = JFactory::_createConfig($file, $type);
_createConfig() metodunda gördüğünüz gibi eğer $file değerini girmezsek metod bize $file değeri olarak libraries/joomla içerisindeki config.php dosyasını veriyor. _createConfig() metodunun kodları da şöyle;
function &_createConfig($file, $type = 'PHP')
{
jimport('joomla.registry.registry');
require_once $file;
// Create the registry with a default namespace of config
$registry = new JRegistry('config');
// Create the JConfig object
$config = new JFrameworkConfig();
// Load the configuration values into the registry
$registry->loadObject($config);
return $registry;
}
Bu kodlarda gördüklerimizi kısaca anlatacak olursak; JRegistery sınıfıyla yeni bir config tanımlıyoruz. Daha sonra config.php içerisindeki JFrameworkConfig sınıfındaki değerleri alıp nesneleri yüklüyoruz. Kısaca kullanıma geçecek olursak;
$config = JFactory::getConfig();
koduyla aldığımız değerlerin başına ?config? ekliyoruz. Örneğin;
$sef = $config->getValue('config.sef');
bir başka örnek;
$list_limit = $config->getValue('config.list_limit');
$offset = $config->getValue('config.offset');
$tmp_dest = $config->getValue('config.tmp_path');
Umarım bu örneklerle demek istediğimi anlatabilmişimdir.
ALINTI
function &getConfig($file = null, $type = 'PHP')
{
static $instance;
if (!is_object($instance))
{
if ($file === null) {
$file = dirname(__FILE__).DS.'config.php';
}
$instance = JFactory::_createConfig($file, $type);
}
return $instance;
}
Yukarıdaki fonksiyon da factory.php dosyasında JFactory sınıfının altındadır. Kullanımı şu şekilde;
$config = JFactory::getConfig();
Yukarıdaki fonksiyonda dikkatinizi çekmek istediğim nokta;
$instance = JFactory::_createConfig($file, $type);
_createConfig() metodunda gördüğünüz gibi eğer $file değerini girmezsek metod bize $file değeri olarak libraries/joomla içerisindeki config.php dosyasını veriyor. _createConfig() metodunun kodları da şöyle;
function &_createConfig($file, $type = 'PHP')
{
jimport('joomla.registry.registry');
require_once $file;
// Create the registry with a default namespace of config
$registry = new JRegistry('config');
// Create the JConfig object
$config = new JFrameworkConfig();
// Load the configuration values into the registry
$registry->loadObject($config);
return $registry;
}
Bu kodlarda gördüklerimizi kısaca anlatacak olursak; JRegistery sınıfıyla yeni bir config tanımlıyoruz. Daha sonra config.php içerisindeki JFrameworkConfig sınıfındaki değerleri alıp nesneleri yüklüyoruz. Kısaca kullanıma geçecek olursak;
$config = JFactory::getConfig();
koduyla aldığımız değerlerin başına ?config? ekliyoruz. Örneğin;
$sef = $config->getValue('config.sef');
bir başka örnek;
$list_limit = $config->getValue('config.list_limit');
$offset = $config->getValue('config.offset');
$tmp_dest = $config->getValue('config.tmp_path');
Umarım bu örneklerle demek istediğimi anlatabilmişimdir.
ALINTI