summaryrefslogtreecommitdiff
path: root/lib/exe
diff options
context:
space:
mode:
authorAnika Henke <anika@selfthinker.org>2012-10-11 13:26:47 +0100
committerAnika Henke <anika@selfthinker.org>2012-10-11 13:26:47 +0100
commit0ac69508958a06e566a51fb6a74802401ebe5eb5 (patch)
tree5733102d426a768ab210064c879220fde678a576 /lib/exe
parent0e6f9f08b1c948f45d1867346a4502021afa55bc (diff)
downloadrpg-0ac69508958a06e566a51fb6a74802401ebe5eb5.tar.gz
rpg-0ac69508958a06e566a51fb6a74802401ebe5eb5.tar.bz2
changed local style.ini to be merged with standard one
Diffstat (limited to 'lib/exe')
-rw-r--r--lib/exe/css.php33
1 files changed, 21 insertions, 12 deletions
diff --git a/lib/exe/css.php b/lib/exe/css.php
index dd69c94cf..ae160558a 100644
--- a/lib/exe/css.php
+++ b/lib/exe/css.php
@@ -58,8 +58,7 @@ function css_out(){
// load template styles
$tplstyles = array();
if ($styleini) {
- $ini = parse_ini_file($styleini, true);
- foreach($ini['stylesheets'] as $file => $mode) {
+ foreach($styleini['stylesheets'] as $file => $mode) {
$tplstyles[$mode][$tplinc.$file] = $tpldir;
}
}
@@ -74,8 +73,8 @@ function css_out(){
$files = array();
$cache_files = getConfigFiles('main');
- if ($styleini)
- $cache_files[] = $styleini;
+ $cache_files[] = $tplinc.'style.ini';
+ $cache_files[] = $tplinc.'style.local.ini';
$cache_files[] = __FILE__;
foreach($mediatypes as $mediatype) {
@@ -180,21 +179,31 @@ function css_applystyle($css,$tplinc){
$styleini = css_styleini($tplinc);
if($styleini){
- $ini = parse_ini_file($styleini,true);
- $css = strtr($css,$ini['replacements']);
+ $css = strtr($css,$styleini['replacements']);
}
return $css;
}
/**
- * If either exist, get the template's style.local.ini or style.ini file.
+ * Get contents of merged style.ini and style.local.ini as an array.
+ *
+ * @author Anika Henke <anika@selfthinker.org>
*/
function css_styleini($tplinc) {
- if(@file_exists($tplinc.'style.local.ini'))
- return $tplinc.'style.local.ini';
- if(@file_exists($tplinc.'style.ini'))
- return $tplinc.'style.ini';
- return '';
+ $styleini = array();
+
+ foreach (array($tplinc.'style.ini', $tplinc.'style.local.ini') as $ini) {
+ $tmp = (@file_exists($ini)) ? parse_ini_file($ini, true) : array();
+
+ foreach($tmp as $key => $value) {
+ if(array_key_exists($key, $styleini) && is_array($value)) {
+ $styleini[$key] = array_merge($styleini[$key], $tmp[$key]);
+ } else {
+ $styleini[$key] = $value;
+ }
+ }
+ }
+ return $styleini;
}
/**