/[cvs]/nfo/php/libs/org.netfrag.glib/DesignPattern/Loader.php
ViewVC logotype

Annotation of /nfo/php/libs/org.netfrag.glib/DesignPattern/Loader.php

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.3 - (hide annotations)
Sun Feb 9 17:10:34 2003 UTC (21 years, 7 months ago) by joko
Branch: MAIN
Changes since 1.2: +11 -6 lines
+ minor update related to new log level constants

1 joko 1.1 <?
2     // -------------------------------------------------------------------------
3 joko 1.3 // $Id: Loader.php,v 1.2 2003/02/04 08:20:34 joko Exp $
4 joko 1.1 // -------------------------------------------------------------------------
5     // $Log: Loader.php,v $
6 joko 1.3 // Revision 1.2 2003/02/04 08:20:34 joko
7     // + should now be independent from former encapsulation inside the 'Site'-object
8     //
9 joko 1.2 // Revision 1.1 2003/02/03 14:44:35 joko
10     // + initial commit
11     // + refactored from flib/Site/Loader.php
12     // + now inherits from DesignPattern::Logger
13     //
14 joko 1.1 // Revision 1.4 2002/12/23 11:33:32 jonen
15     // + minor changes
16     //
17     // Revision 1.3 2002/12/19 06:21:37 joko
18     // + loadTemplate
19     // + case 'template' for 'function loadComponent'
20     //
21     // Revision 1.2 2002/12/12 21:37:46 joko
22     // + fixes: now returning success-/error-status
23     //
24     // Revision 1.1 2002/11/12 05:42:31 joko
25     // + initial checkin
26     //
27     // -------------------------------------------------------------------------
28    
29    
30     class DesignPattern_Loader extends DesignPattern_Logger {
31    
32 joko 1.2 var $parent;
33    
34 joko 1.1 function includeFile($filename, $args = array()) {
35 joko 1.3 $this->log( get_class($this) . "->includeFile( filename $filename )", PEAR_LOG_DEBUG);
36 joko 1.2 // TODO: capture errors (e.g. via an eval) here?
37 joko 1.3 //global $site;
38     //print "parent: " . $this->parent . "<br>";
39 joko 1.1 if (include($filename)) {
40     return 1;
41     }
42     }
43    
44     function loadComponent($name, $type = "", $arguments = array()) {
45     $prefix = "";
46     $postfix = "";
47 joko 1.3 $this->log( get_class($this) . "->loadComponent( name $name, type $type )", PEAR_LOG_DEBUG);
48 joko 1.1
49 joko 1.2 $parent = $this->parent;
50    
51 joko 1.1 // TODO: croak somewhere (STDOUT?, logger?) if unknown type gets used here
52     switch ($type) {
53    
54     case "handler":
55 joko 1.2 $prefix = $this->$parent->config[path][handler];
56 joko 1.1 //$postfix = ".handler.php";
57     $postfix = ".php";
58     $includefile = "$prefix$name$postfix";
59     return $this->includeFile($includefile);
60     break;
61    
62     case "page":
63 joko 1.2 $prefix = $this->$parent->config[path][pages];
64 joko 1.1 $postfix = ".page";
65     $includefile = "$prefix$name$postfix";
66     return $this->includeFile($includefile, $arguments );
67     break;
68    
69     case "template":
70     // TODO: re-activate this (unset smarty's default directory or handle differently (generic))
71 joko 1.2 //$prefix = $this->$parent->config[path][base] . 'core/templates/';
72 joko 1.1 $prefix = '';
73     $postfix = ".html";
74     $includefile = "$prefix$name$postfix";
75     //return $this->includeFile($includefile);
76 joko 1.2 return $this->$parent->template->display($includefile, array(
77 joko 1.1 'cache_key' => $arguments[cache_key],
78     'interpolate' => $arguments['vars'],
79     'return' => $arguments['return']
80     ));
81     break;
82     }
83     }
84    
85     function loadHandler($name) {
86 joko 1.3 $this->log( get_class($this) . "->loadHandler( name $name )", PEAR_LOG_DEBUG);
87 joko 1.1 return $this->loadComponent($name, "handler");
88     }
89    
90     function loadPage($name, $args = array()) {
91 joko 1.3 $this->log( get_class($this) . "->loadPage( name $name )", PEAR_LOG_DEBUG);
92 joko 1.1 return $this->loadComponent($name, "page", $args);
93     }
94    
95     function loadTemplate($name, $template_variables = array(), $cache_key = "") {
96 joko 1.3 $this->log( get_class($this) . "->loadTemplate( name $name cache_key $cache_key )", PEAR_LOG_DEBUG);
97 joko 1.1 return $this->loadComponent($name, "template", array( 'cache_key' => $cache_key, 'vars' => $template_variables) );
98     }
99    
100     function loadClass() {
101     }
102    
103     function loadBusinessClass() {
104     }
105    
106    
107    
108     }
109     ?>

MailToCvsAdmin">MailToCvsAdmin
ViewVC Help
Powered by ViewVC 1.1.26 RSS 2.0 feed