File: Document.html

package info (click to toggle)
libtemplate-perl 2.24-1
  • links: PTS
  • area: main
  • in suites: wheezy
  • size: 8,660 kB
  • sloc: perl: 14,518; makefile: 15; sh: 5
file content (484 lines) | stat: -rwxr-xr-x 28,620 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484


<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Strict//EN">
<html>
  <head>
    <title>Template::Document</title>
    <link rel="stylesheet" type="text/css" href="../../css/blue.css" title="Clear Blue">
    <link rel="alternate stylesheet" type="text/css" href="../../css/orange.css" title="Clear Orange">
    <link rel="alternate stylesheet" type="text/css" href="../../css/green.css" title="Clear Green">
    <link rel="alternate stylesheet" type="text/css" href="../../css/purple.css" title="Clear Purple">
    <link rel="alternate stylesheet" type="text/css" href="../../css/grey.css" title="Clear Grey">
    <link rel="alternate stylesheet" type="text/css" href="../../css/print.css" title="Print">
    <!--[if IE 6]>
    <link rel="stylesheet" type="text/css" href="../../css/ie6.css" />
    <![endif]-->
    <!--[if IE 7]>
    <link rel="stylesheet" type="text/css" href="../../css/ie7.css" />
    <![endif]-->
    <link rel="stylesheet" type="text/css" href="../../css/print.css" media="print">
    <script type="text/javascript" src="../../js/tt2.js"></script>
    <meta http-equiv="Content-Type" content="text/html;charset=utf-8">
    <meta name="author" content="Andy Wardley">
  </head>
  <body id="body"> 
    <div id="layout">
        <div id="header">
          <a href="../../index.html" id="logo" alt="" title="Click for the Home Page"><span class="alt">TT2 Home Page</span></a>
          <ul id="trail">
            <li><a href="../../modules/index.html">Modules</a></li>
            <li><a href="../../modules/Template/index.html">Template::*</a></li>
            <li class="last"><a href="../../modules/Template/Document.html">Document.pm</a></li>
          </ul>
          <div class="controls">
            <a href="#" class="menu show" onclick="widescreen_off(); return false" title="Show Menu">
              <span class="about">Click to view the menu.  It's very nice.</span>
            </a>
            <a href="#" class="menu hide" onclick="widescreen_on();  return false" title="Hide Menu">
              <span class="about">Click to hide the menu and go all widescreen!</span>
            </a>
          
          <div class="pager">
            <a href="../../modules/Template/Directive.html" title="Template::Directive" class="go back">Back<span class="about"><h4>Template::Directive</h4>Perl code generator for template directives</span></a>
            <a href="../../modules/Template/index.html" title="Template::* Modules" class="go up">Up<span class="about"><h4>Template::* Modules</h4></span></a>
            <a href="../../modules/Template/Exception.html" title="Template::Exception" class="go next">Next<span class="about"><h4>Template::Exception</h4>Exception handling class module</span></a>
          </div>
          </div>
          <h1 class="headline">Template::Document</h1>
          <h2 class="subhead">Compiled template document object</h1>
        
        </div>
        
        <div id="page">
          <div id="sidebar">
            <a href="../../index.html" id="logo"></a>
            <div id="menu">
              <ul class="menu">
                <li class="l0 first"><a href="../../manual/index.html">Manual</a></li>
                <li class="l0"><a href="../../modules/index.html" class="warm">Modules</a></li>
                <li class="l1"><a href="../../modules/Template.html">Template.pm</a></li>
                <li class="l1"><a href="../../modules/Template/index.html" class="warm">Template::*</a></li>
                <li class="l2"><a href="../../modules/Template/Base.html">Base.pm</a></li>
                <li class="l2"><a href="../../modules/Template/Config.html">Config.pm</a></li>
                <li class="l2"><a href="../../modules/Template/Constants.html">Constants.pm</a></li>
                <li class="l2"><a href="../../modules/Template/Context.html">Context.pm</a></li>
                <li class="l2"><a href="../../modules/Template/Directive.html">Directive.pm</a></li>
                <li class="l2"><a href="../../modules/Template/Document.html" class="warm">Document.pm</a></li>
                <li class="l2"><a href="../../modules/Template/Exception.html">Exception.pm</a></li>
                <li class="l2"><a href="../../modules/Template/Filters.html">Filters.pm</a></li>
                <li class="l2"><a href="../../modules/Template/Grammar.html">Grammar.pm</a></li>
                <li class="l2"><a href="../../modules/Template/Iterator.html">Iterator.pm</a></li>
                <li class="l2"><a href="../../modules/Template/Namespace/index.html">Namespace::*</a></li>
                <li class="l2"><a href="../../modules/Template/Parser.html">Parser.pm</a></li>
                <li class="l2"><a href="../../modules/Template/Plugin.html">Plugin.pm</a></li>
                <li class="l2"><a href="../../modules/Template/Plugin/index.html">Plugin::*</a></li>
                <li class="l2"><a href="../../modules/Template/Plugins.html">Plugins.pm</a></li>
                <li class="l2"><a href="../../modules/Template/Provider.html">Provider.pm</a></li>
                <li class="l2"><a href="../../modules/Template/Service.html">Service.pm</a></li>
                <li class="l2"><a href="../../modules/Template/Stash.html">Stash.pm</a></li>
                <li class="l2"><a href="../../modules/Template/Stash/index.html">Stash::*</a></li>
                <li class="l2"><a href="../../modules/Template/Test.html">Test.pm</a></li>
                <li class="l2"><a href="../../modules/Template/VMethods.html">VMethods.pm</a></li>
                <li class="l2"><a href="../../modules/Template/View.html">View.pm</a></li>
                <li class="l0"><a href="../../tools/index.html">Tools</a></li>
                <li class="l0"><a href="../../tutorial/index.html">Tutorial</a></li>
                <li class="l0 last"><a href="../../faq/index.html">FAQ</a></li>
              </ul>
              <div class="foot"></div>
            </div>
          </div>
          <div id="content">
          <div class="section">
            <div class="head">
              <h1 id="contents" onclick="switch_section(this)" title="Click title to show/hide section content.">Contents</h1>
              <a href="#body" class="top" title="Back up to the top of the page" >Top</a>
            </div>
            <div class="body">
              <ul class="toc">
                  <li class=""><a href="#SYNOPSIS">SYNOPSIS</a></li>
                  <li class=""><a href="#DESCRIPTION">DESCRIPTION</a></li>
                  <li class=""><a href="#METHODS">METHODS</a></li>
                  <li class="sub"><a href="#method_new">new(\%config)</a></li>
                  <li class="sub"><a href="#method_process">process($context)</a></li>
                  <li class="sub"><a href="#method_block">block()</a></li>
                  <li class="sub"><a href="#method_blocks">blocks()</a></li>
                  <li class="sub"><a href="#method_variables">variables()</a></li>
                  <li class="sub"><a href="#section_AUTOLOAD">AUTOLOAD</a></li>
                  <li class=""><a href="#CLASS_METHODS">CLASS METHODS</a></li>
                  <li class="sub"><a href="#method_as_perl">as_perl($content)</a></li>
                  <li class="sub"><a href="#method_write_perl_file">write_perl_file(\%config)</a></li>
                  <li class=""><a href="#INTERNAL_FUNCTIONS">INTERNAL FUNCTIONS</a></li>
                  <li class="sub"><a href="#method_catch_warnings">catch_warnings()</a></li>
                  <li class="sub"><a href="#method_is_utf8">is_utf8()</a></li>
                  <li class=""><a href="#AUTHOR">AUTHOR</a></li>
                  <li class=""><a href="#COPYRIGHT">COPYRIGHT</a></li>
                  <li class=""><a href="#SEE_ALSO">SEE ALSO</a></li>
              
              </ul>
            </div>
          </div>
          
                <div class="pod">
            <div class="section">
              <div class="head">
                <h1 id="SYNOPSIS" onclick="switch_section(this)" title="Click title to show/hide section content.">SYNOPSIS</h1>
                <a href="#body" class="top" title="Back up to the top of the page" >Top</a>
              </div>
              <div class="body">
                <pre>use Template::Document;

$doc = Template::Document-&gt;new({
    BLOCK =&gt; sub { # some perl code; return $some_text },
    DEFBLOCKS =&gt; {
        header =&gt; sub { # more perl code; return $some_text },
        footer =&gt; sub { # blah blah blah; return $some_text },
    },
    METADATA =&gt; {
        author  =&gt; 'Andy Wardley',
        version =&gt; 3.14,
    }
}) || die $Template::Document::ERROR;

print $doc-&gt;process($context);</pre>
              </div>
            </div>
            <div class="section">
              <div class="head">
                <h1 id="DESCRIPTION" onclick="switch_section(this)" title="Click title to show/hide section content.">DESCRIPTION</h1>
                <a href="#body" class="top" title="Back up to the top of the page" >Top</a>
              </div>
              <div class="body">
                <p>
                      This module defines an object class whose instances represent compiled
                      template documents. The <a href="../../modules/Template/Parser.html">Template::Parser</a> module creates a
                      <code>Template::Document</code> instance to encapsulate a template as it
                      is compiled into Perl code.
                    </p>
                    <p>
                      The constructor method, <a href="#method_new">new()</a>, expects a
                      reference to a hash array containing the <code>BLOCK</code>,
                      <code>DEFBLOCKS</code> and <code>METADATA</code> items.
                    </p>
                    <p>
                      The <code>BLOCK</code> item should contain a reference to a Perl
                      subroutine or a textual representation of Perl code, as generated by the
                      <a href="../../modules/Template/Parser.html">Template::Parser</a>
                      module. This is then evaluated into a subroutine reference using
                      <code>eval()</code>.
                    </p>
                    <p>
                      The <code>DEFLOCKS</code> item should reference a hash array containing
                      further named <code>BLOCK</code>s which may be defined in the template.
                      The keys represent <code>BLOCK</code> names and the values should be
                      subroutine references or text strings of Perl code as per the main
                      <code>BLOCK</code> item.
                    </p>
                    <p>
                      The <code>METADATA</code> item should reference a hash array of metadata
                      items relevant to the document.
                    </p>
                    <p>
                      The <a href="#method_process">process()</a> method can then be called on
                      the instantiated <code>Template::Document</code> object, passing a
                      reference to a <a href="../../modules/Template/Context.html">Template::Context</a> object as the first parameter. This will
                      install any locally defined blocks (<code>DEFBLOCKS</code>) in the
                      <code>BLOCKS</code> cache in the context (via a call to <a href="../../modules/Template/Context.html#method_visit">visit()</a>) so that
                      they may be subsequently resolved by the context. The main
                      <code>BLOCK</code> subroutine is then executed, passing the context
                      reference on as a parameter. The text returned from the template
                      subroutine is then returned by the <a
                      href="#method_process">process()</a> method, after calling the context <a
                      href="../../modules/Template/Context.html#method_leave">leave()</a>
                      method to permit cleanup and de-registration of named <code>BLOCKS</code>
                      previously installed.
                    </p>
                    <p>
                      An <code>AUTOLOAD</code> method provides access to the
                      <code>METADATA</code> items for the document. The <a href="../../modules/Template/Service.html">Template::Service</a> module installs
                      a reference to the main <code>Template::Document</code> object in the
                      stash as the <code>template</code> variable. This allows metadata items
                      to be accessed from within templates, including <code>PRE_PROCESS</code>
                      templates.
                    </p>
                    <p>
                      header:
                    </p>
                    <pre>&lt;html&gt;
&lt;head&gt;
&lt;title&gt;<span class="tt">[% template.title %]</span>
&lt;/head&gt;
...</pre>
                    <p>
                      <code>Template::Document</code> objects are usually created by the <a
                      href="../../modules/Template/Parser.html">Template::Parser</a> but can
                      be manually instantiated or sub-classed to provide custom template
                      components.
                    </p>
              </div>
            </div>
            <div class="section">
              <div class="head">
                <h1 id="METHODS" onclick="switch_section(this)" title="Click title to show/hide section content.">METHODS</h1>
                <a href="#body" class="top" title="Back up to the top of the page" >Top</a>
              </div>
              <div class="body">
                <div class="subsection">
                  <div class="head">
                    <h2 id="method_new" class="method" onclick="switch_subsection(this)" title="Click title to show/hide sub-section content.">new(\%config)</h2>
                    <a href="#body" class="top" title="Back up to the top of the page" >Top</a>
                  </div>
                  <div class="body">
                    <p>
                          Constructor method which accept a reference to a hash array containing
                          the structure as shown in this example:
                        </p>
                        <pre>$doc = Template::Document-&gt;new({
    BLOCK =&gt; sub { # some perl code; return $some_text },
    DEFBLOCKS =&gt; {
        header =&gt; sub { # more perl code; return $some_text },
        footer =&gt; sub { # blah blah blah; return $some_text },
    },
    METADATA =&gt; {
        author  =&gt; 'Andy Wardley',
        version =&gt; 3.14,
    }
}) || die $Template::Document::ERROR;</pre>
                        <p>
                          <code>BLOCK</code> and <code>DEFBLOCKS</code> items may be expressed as
                          references to Perl subroutines or as text strings containing Perl
                          subroutine definitions, as is generated by the <a href="../../modules/Template/Parser.html">Template::Parser</a> module. These are
                          evaluated into subroutine references using <code>eval()</code>.
                        </p>
                        <p>
                          Returns a new <code>Template::Document</code> object or
                          <code>undef</code> on error. The <a href="../../modules/Template/Base.html#method_error">error()</a> class method can be called, or the
                          <code>$ERROR</code> package variable inspected to retrieve the relevant
                          error message.
                        </p>
                  </div>
                </div>    <div class="subsection">
                  <div class="head">
                    <h2 id="method_process" class="method" onclick="switch_subsection(this)" title="Click title to show/hide sub-section content.">process($context)</h2>
                    <a href="#body" class="top" title="Back up to the top of the page" >Top</a>
                  </div>
                  <div class="body">
                    <p>
                          Main processing routine for the compiled template document. A reference
                          to a <a href="../../modules/Template/Context.html">Template::Context</a> object should be passed as the first
                          parameter. The method installs any locally defined blocks via a call to
                          the context <a href="../../modules/Template/Context.html#method_visit">visit()</a> method, processes its own template,
                          (passing the context reference as a parameter) and then calls <a
                          href="../../modules/Template/Context.html#method_leave">leave()</a> in
                          the context to allow cleanup.
                        </p>
                        <pre>print $doc-&gt;process($context);</pre>
                        <p>
                          Returns a text string representing the generated output for the template.
                          Errors are thrown via <code>die()</code>.
                        </p>
                  </div>
                </div>    <div class="subsection">
                  <div class="head">
                    <h2 id="method_block" class="method" onclick="switch_subsection(this)" title="Click title to show/hide sub-section content.">block()</h2>
                    <a href="#body" class="top" title="Back up to the top of the page" >Top</a>
                  </div>
                  <div class="body">
                    <p>
                          Returns a reference to the main <code>BLOCK</code> subroutine.
                        </p>
                  </div>
                </div>    <div class="subsection">
                  <div class="head">
                    <h2 id="method_blocks" class="method" onclick="switch_subsection(this)" title="Click title to show/hide sub-section content.">blocks()</h2>
                    <a href="#body" class="top" title="Back up to the top of the page" >Top</a>
                  </div>
                  <div class="body">
                    <p>
                          Returns a reference to the hash array of named <code>DEFBLOCKS</code>
                          subroutines.
                        </p>
                  </div>
                </div>    <div class="subsection">
                  <div class="head">
                    <h2 id="method_variables" class="method" onclick="switch_subsection(this)" title="Click title to show/hide sub-section content.">variables()</h2>
                    <a href="#body" class="top" title="Back up to the top of the page" >Top</a>
                  </div>
                  <div class="body">
                    <p>
                          Returns a reference to a hash of variables used in the template. This
                          requires the <a href="../../manual/Config.html#section_TRACE_VARS">TRACE_VARS</a> option to be enabled.
                        </p>
                  </div>
                </div>    <div class="subsection">
                  <div class="head">
                    <h2 id="section_AUTOLOAD" onclick="switch_subsection(this)" title="Click title to show/hide sub-section content.">AUTOLOAD</h2>
                    <a href="#body" class="top" title="Back up to the top of the page" >Top</a>
                  </div>
                  <div class="body">
                    <p>
                          An autoload method returns <code>METADATA</code> items.
                        </p>
                        <pre>print $doc-&gt;author();</pre>
                  </div>
                </div>
              </div>
            </div>
            <div class="section">
              <div class="head">
                <h1 id="CLASS_METHODS" onclick="switch_section(this)" title="Click title to show/hide section content.">CLASS METHODS</h1>
                <a href="#body" class="top" title="Back up to the top of the page" >Top</a>
              </div>
              <div class="body">
                <p>
                      These methods are used internally.
                    </p>
                    <div class="subsection">
                  <div class="head">
                    <h2 id="method_as_perl" class="method" onclick="switch_subsection(this)" title="Click title to show/hide sub-section content.">as_perl($content)</h2>
                    <a href="#body" class="top" title="Back up to the top of the page" >Top</a>
                  </div>
                  <div class="body">
                    <p>
                          This method generate a Perl representation of the template.
                        </p>
                        <pre>my $perl = Template::Document-&gt;as_perl({
    BLOCK     =&gt; $main_block,
    DEFBLOCKS =&gt; {
        foo   =&gt; $foo_block,
        bar   =&gt; $bar_block,
    },
    METADATA  =&gt; {
        name  =&gt; 'my_template',
    }
});</pre>
                  </div>
                </div>    <div class="subsection">
                  <div class="head">
                    <h2 id="method_write_perl_file" class="method" onclick="switch_subsection(this)" title="Click title to show/hide sub-section content.">write_perl_file(\%config)</h2>
                    <a href="#body" class="top" title="Back up to the top of the page" >Top</a>
                  </div>
                  <div class="body">
                    <p>
                          This method is used to write compiled Perl templates to disk. If the
                          <code>COMPILE_EXT</code> option (to indicate a file extension for saving
                          compiled templates) then the <a href="../../modules/Template/Parser.html">Template::Parser</a> module calls this subroutine before calling the
                          <a href="#method_new">new()</a> constructor. At this stage, the parser
                          has a representation of the template as text strings containing Perl
                          code. We can write that to a file, enclosed in a small wrapper which will
                          allow us to susequently <code>require()</code> the file and have Perl
                          parse and compile it into a <code>Template::Document</code>. Thus we have
                          persistence of compiled templates.
                        </p>
                  </div>
                </div>
              </div>
            </div>
            <div class="section">
              <div class="head">
                <h1 id="INTERNAL_FUNCTIONS" onclick="switch_section(this)" title="Click title to show/hide section content.">INTERNAL FUNCTIONS</h1>
                <a href="#body" class="top" title="Back up to the top of the page" >Top</a>
              </div>
              <div class="body">
                <div class="subsection">
                  <div class="head">
                    <h2 id="method_catch_warnings" class="method" onclick="switch_subsection(this)" title="Click title to show/hide sub-section content.">catch_warnings()</h2>
                    <a href="#body" class="top" title="Back up to the top of the page" >Top</a>
                  </div>
                  <div class="body">
                    <p>
                          This is a simple handler used to catch any errors that arise when the
                          compiled Perl template is first evaluated (that is, evaluated by Perl to
                          create a template subroutine at compile, rather than the template being
                          processed at runtime).
                        </p>
                  </div>
                </div>    <div class="subsection">
                  <div class="head">
                    <h2 id="method_is_utf8" class="method" onclick="switch_subsection(this)" title="Click title to show/hide sub-section content.">is_utf8()</h2>
                    <a href="#body" class="top" title="Back up to the top of the page" >Top</a>
                  </div>
                  <div class="body">
                    <p>
                          This is mapped to <code>utf8::is_utf8</code> for versions of Perl that
                          have it (&gt; 5.008) or to <code>Encode::is_utf8</code> for Perl 5.008.
                          Earlier versions of Perl are not supported.
                        </p>
                  </div>
                </div>
              </div>
            </div>
            <div class="section">
              <div class="head">
                <h1 id="AUTHOR" onclick="switch_section(this)" title="Click title to show/hide section content.">AUTHOR</h1>
                <a href="#body" class="top" title="Back up to the top of the page" >Top</a>
              </div>
              <div class="body">
                <p>
                      Andy Wardley &lt;abw@wardley.org&gt; <a
                      href="http://wardley.org/">http://wardley.org/</a>
                    </p>
              </div>
            </div>
            <div class="section">
              <div class="head">
                <h1 id="COPYRIGHT" onclick="switch_section(this)" title="Click title to show/hide section content.">COPYRIGHT</h1>
                <a href="#body" class="top" title="Back up to the top of the page" >Top</a>
              </div>
              <div class="body">
                <p>
                      Copyright (C) 1996-2012 Andy Wardley. All Rights Reserved.
                    </p>
                    <p>
                      This module is free software; you can redistribute it and/or modify it
                      under the same terms as Perl itself.
                    </p>
              </div>
            </div>
            <div class="section">
              <div class="head">
                <h1 id="SEE_ALSO" onclick="switch_section(this)" title="Click title to show/hide section content.">SEE ALSO</h1>
                <a href="#body" class="top" title="Back up to the top of the page" >Top</a>
              </div>
              <div class="body">
                <p>
                      <a href="../../modules/Template.html">Template</a>, <a href="../../modules/Template/Parser.html">Template::Parser</a>
                    </p>
              </div>
            </div>
            
            </div></div>
          <br class="clear" />
          <div class="pageinfo">
            <a href="http://template-toolkit.org/docs/modules/Template/Document.html">http://template-toolkit.org/docs/modules/Template/Document.html</a>
          </div>
        </div>
        
        <div id="footer">
          <a href="http://opensource.org/" class="osi"></a>
          <div class="controls">
          <div class="pager">
            <a href="../../modules/Template/Directive.html" title="Template::Directive" class="go back">Back<span class="about"><h4>Template::Directive</h4></span></a>
            <a href="../../modules/Template/index.html" title="Template::* Modules" class="go up">Up<span class="about"><h4>Template::* Modules</h4></span></a>
            <a href="../../modules/Template/Exception.html" title="Template::Exception" class="go next">Next<span class="about"><h4>Template::Exception</h4></span></a>
          </div>
          </div>
          <div class="copyright">
            Copyright &copy; 1996-2012 <a href="http://wardley.org/">Andy Wardley</a>.  All Rights Reserved.
          </div>
          <div class="licence">
            The <a href="http://template-toolkit.org/">Template Toolkit</a> is <a href="http://opensource.org/">Open Source</a> software.
            You can redistribute and/or modify it under the terms of the <a href="http://www.opensource.org/licenses/gpl-license.php">GNU Public Licence</a>
            or the <a href="http://www.opensource.org/licenses/artistic-license.php">Perl Artistic Licence</a>.
          </div>
        </div>
        <div id="palette">
          <ul>
            <li class="first"><a href="#" class="blue" onclick="set_style('Clear Blue')"></a></li>
            <li><a href="#" class="orange" onclick="set_style('Clear Orange')"></a></li>
            <li><a href="#" class="green" onclick="set_style('Clear Green')"></a></li>
            <li><a href="#" class="purple" onclick="set_style('Clear Purple')"></a></li>
            <li><a href="#" class="grey" onclick="set_style('Clear Grey')"></a></li>
          </ul>
        </div>
    </div>  </body>
</html>