thewoolleyman-webgen 0.5.8.20090419
Sign up to get free protection for your applications and to get access to all the features.
- data/AUTHORS +8 -0
- data/COPYING +10 -0
- data/GPL +340 -0
- data/Rakefile +334 -0
- data/THANKS +18 -0
- data/bin/webgen +12 -0
- data/data/webgen/resources.yaml +3 -0
- data/data/webgen/webgui/controller/main.rb +135 -0
- data/data/webgen/webgui/overrides/win32console.rb +0 -0
- data/data/webgen/webgui/public/css/jquery.autocomplete.css +50 -0
- data/data/webgen/webgui/public/css/ramaze_error.css +90 -0
- data/data/webgen/webgui/public/css/style.css +55 -0
- data/data/webgen/webgui/public/img/headerbg.jpg +0 -0
- data/data/webgen/webgui/public/img/webgen_logo.png +0 -0
- data/data/webgen/webgui/public/js/jquery.autocomplete.js +15 -0
- data/data/webgen/webgui/public/js/jquery.js +32 -0
- data/data/webgen/webgui/view/create_website.xhtml +22 -0
- data/data/webgen/webgui/view/error.xhtml +64 -0
- data/data/webgen/webgui/view/index.xhtml +22 -0
- data/data/webgen/webgui/view/manage_website.xhtml +18 -0
- data/data/webgen/webgui/view/page.xhtml +40 -0
- data/data/webgen/website_skeleton/README +10 -0
- data/data/webgen/website_skeleton/Rakefile +40 -0
- data/data/webgen/website_skeleton/config.yaml +17 -0
- data/data/webgen/website_skeleton/ext/init.rb +10 -0
- data/data/webgen/website_styles/1024px/README +13 -0
- data/data/webgen/website_styles/1024px/src/default.css +188 -0
- data/data/webgen/website_styles/1024px/src/default.template +60 -0
- data/data/webgen/website_styles/1024px/src/images/background.gif +0 -0
- data/data/webgen/website_styles/andreas00/README +13 -0
- data/data/webgen/website_styles/andreas00/src/default.css +290 -0
- data/data/webgen/website_styles/andreas00/src/default.template +60 -0
- data/data/webgen/website_styles/andreas00/src/images/bg.gif +0 -0
- data/data/webgen/website_styles/andreas00/src/images/front.jpg +0 -0
- data/data/webgen/website_styles/andreas00/src/images/menubg.gif +0 -0
- data/data/webgen/website_styles/andreas00/src/images/menubg2.gif +0 -0
- data/data/webgen/website_styles/andreas01/README +14 -0
- data/data/webgen/website_styles/andreas01/src/default.css +310 -0
- data/data/webgen/website_styles/andreas01/src/default.template +62 -0
- data/data/webgen/website_styles/andreas01/src/images/bg.gif +0 -0
- data/data/webgen/website_styles/andreas01/src/images/front.jpg +0 -0
- data/data/webgen/website_styles/andreas01/src/print.css +35 -0
- data/data/webgen/website_styles/andreas03/README +14 -0
- data/data/webgen/website_styles/andreas03/src/default.css +223 -0
- data/data/webgen/website_styles/andreas03/src/default.template +58 -0
- data/data/webgen/website_styles/andreas03/src/images/bodybg.png +0 -0
- data/data/webgen/website_styles/andreas03/src/images/contbg.png +0 -0
- data/data/webgen/website_styles/andreas03/src/images/footerbg.png +0 -0
- data/data/webgen/website_styles/andreas03/src/images/gradient1.png +0 -0
- data/data/webgen/website_styles/andreas03/src/images/gradient2.png +0 -0
- data/data/webgen/website_styles/andreas04/README +15 -0
- data/data/webgen/website_styles/andreas04/src/default.css +290 -0
- data/data/webgen/website_styles/andreas04/src/default.template +81 -0
- data/data/webgen/website_styles/andreas04/src/images/blinkarrow.gif +0 -0
- data/data/webgen/website_styles/andreas04/src/images/bodybg.png +0 -0
- data/data/webgen/website_styles/andreas04/src/images/contentbg.png +0 -0
- data/data/webgen/website_styles/andreas04/src/images/entrybg.png +0 -0
- data/data/webgen/website_styles/andreas04/src/images/flash.gif +0 -0
- data/data/webgen/website_styles/andreas04/src/images/flash2.gif +0 -0
- data/data/webgen/website_styles/andreas04/src/images/globe.gif +0 -0
- data/data/webgen/website_styles/andreas04/src/images/globebottom.gif +0 -0
- data/data/webgen/website_styles/andreas04/src/images/linkarrow.gif +0 -0
- data/data/webgen/website_styles/andreas04/src/images/menuhover.png +0 -0
- data/data/webgen/website_styles/andreas05/README +14 -0
- data/data/webgen/website_styles/andreas05/src/default.css +33 -0
- data/data/webgen/website_styles/andreas05/src/default.template +40 -0
- data/data/webgen/website_styles/andreas05/src/images/bodybg.gif +0 -0
- data/data/webgen/website_styles/andreas05/src/images/front.png +0 -0
- data/data/webgen/website_styles/andreas06/README +14 -0
- data/data/webgen/website_styles/andreas06/src/default.css +354 -0
- data/data/webgen/website_styles/andreas06/src/default.template +70 -0
- data/data/webgen/website_styles/andreas06/src/images/bodybg.gif +0 -0
- data/data/webgen/website_styles/andreas06/src/images/boxbg.gif +0 -0
- data/data/webgen/website_styles/andreas06/src/images/greypx.gif +0 -0
- data/data/webgen/website_styles/andreas06/src/images/header.jpg +0 -0
- data/data/webgen/website_styles/andreas06/src/images/innerbg.gif +0 -0
- data/data/webgen/website_styles/andreas06/src/images/leaves.jpg +0 -0
- data/data/webgen/website_styles/andreas06/src/images/tabs.gif +0 -0
- data/data/webgen/website_styles/andreas07/README +15 -0
- data/data/webgen/website_styles/andreas07/src/browserfix.css +7 -0
- data/data/webgen/website_styles/andreas07/src/default.css +92 -0
- data/data/webgen/website_styles/andreas07/src/default.template +42 -0
- data/data/webgen/website_styles/andreas07/src/images/bodybg.gif +0 -0
- data/data/webgen/website_styles/andreas07/src/images/sidebarbg.gif +0 -0
- data/data/webgen/website_styles/andreas08/README +14 -0
- data/data/webgen/website_styles/andreas08/src/default.css +224 -0
- data/data/webgen/website_styles/andreas08/src/default.template +51 -0
- data/data/webgen/website_styles/andreas09/README +14 -0
- data/data/webgen/website_styles/andreas09/src/default.css +308 -0
- data/data/webgen/website_styles/andreas09/src/default.template +68 -0
- data/data/webgen/website_styles/andreas09/src/images/bodybg-black.jpg +0 -0
- data/data/webgen/website_styles/andreas09/src/images/bodybg-green.jpg +0 -0
- data/data/webgen/website_styles/andreas09/src/images/bodybg-orange.jpg +0 -0
- data/data/webgen/website_styles/andreas09/src/images/bodybg-purple.jpg +0 -0
- data/data/webgen/website_styles/andreas09/src/images/bodybg-red.jpg +0 -0
- data/data/webgen/website_styles/andreas09/src/images/bodybg.jpg +0 -0
- data/data/webgen/website_styles/andreas09/src/images/footerbg.jpg +0 -0
- data/data/webgen/website_styles/andreas09/src/images/menuhover-black.jpg +0 -0
- data/data/webgen/website_styles/andreas09/src/images/menuhover-green.jpg +0 -0
- data/data/webgen/website_styles/andreas09/src/images/menuhover-orange.jpg +0 -0
- data/data/webgen/website_styles/andreas09/src/images/menuhover-purple.jpg +0 -0
- data/data/webgen/website_styles/andreas09/src/images/menuhover-red.jpg +0 -0
- data/data/webgen/website_styles/andreas09/src/images/menuhover.jpg +0 -0
- data/data/webgen/website_styles/simple/README +6 -0
- data/data/webgen/website_styles/simple/src/default.css +84 -0
- data/data/webgen/website_styles/simple/src/default.template +36 -0
- data/data/webgen/website_templates/default/README +6 -0
- data/data/webgen/website_templates/default/src/index.page +8 -0
- data/data/webgen/website_templates/project/README +5 -0
- data/data/webgen/website_templates/project/src/about.page +12 -0
- data/data/webgen/website_templates/project/src/download.page +15 -0
- data/data/webgen/website_templates/project/src/features.page +8 -0
- data/data/webgen/website_templates/project/src/index.page +9 -0
- data/data/webgen/website_templates/project/src/screenshots.page +18 -0
- data/doc/contentprocessor.template +11 -0
- data/doc/contentprocessor/blocks.page +129 -0
- data/doc/contentprocessor/builder.page +80 -0
- data/doc/contentprocessor/erb.page +59 -0
- data/doc/contentprocessor/erubis.page +46 -0
- data/doc/contentprocessor/fragments.page +25 -0
- data/doc/contentprocessor/haml.page +47 -0
- data/doc/contentprocessor/maruku.page +41 -0
- data/doc/contentprocessor/rdiscount.page +37 -0
- data/doc/contentprocessor/rdoc.page +36 -0
- data/doc/contentprocessor/redcloth.page +39 -0
- data/doc/contentprocessor/sass.page +31 -0
- data/doc/contentprocessor/tags.page +73 -0
- data/doc/extensions.metainfo +29 -0
- data/doc/extensions.page +16 -0
- data/doc/extensions.template +17 -0
- data/doc/faq.page +219 -0
- data/doc/getting_started.page +135 -0
- data/doc/index.page +65 -0
- data/doc/manual.page +589 -0
- data/doc/reference_configuration.page +959 -0
- data/doc/reference_metainfo.page +222 -0
- data/doc/source/filesystem.page +39 -0
- data/doc/source/tararchive.page +40 -0
- data/doc/sourcehandler.template +21 -0
- data/doc/sourcehandler/copy.page +19 -0
- data/doc/sourcehandler/directory.page +27 -0
- data/doc/sourcehandler/feed.page +105 -0
- data/doc/sourcehandler/metainfo.page +41 -0
- data/doc/sourcehandler/page.page +14 -0
- data/doc/sourcehandler/sitemap.page +46 -0
- data/doc/sourcehandler/template.page +45 -0
- data/doc/sourcehandler/virtual.page +49 -0
- data/doc/tag.template +25 -0
- data/doc/tag/breadcrumbtrail.page +40 -0
- data/doc/tag/coderay.page +49 -0
- data/doc/tag/date.page +31 -0
- data/doc/tag/executecommand.page +26 -0
- data/doc/tag/includefile.page +32 -0
- data/doc/tag/langbar.page +44 -0
- data/doc/tag/link.page +44 -0
- data/doc/tag/menu.page +106 -0
- data/doc/tag/metainfo.page +29 -0
- data/doc/tag/relocatable.page +38 -0
- data/doc/tag/sitemap.page +31 -0
- data/doc/tag/tikz.page +158 -0
- data/doc/upgrading.page +139 -0
- data/doc/webgen_page_format.page +129 -0
- data/lib/webgen/blackboard.rb +78 -0
- data/lib/webgen/cache.rb +87 -0
- data/lib/webgen/cli.rb +124 -0
- data/lib/webgen/cli/apply_command.rb +64 -0
- data/lib/webgen/cli/create_command.rb +66 -0
- data/lib/webgen/cli/run_command.rb +22 -0
- data/lib/webgen/cli/utils.rb +88 -0
- data/lib/webgen/cli/webgui_command.rb +72 -0
- data/lib/webgen/common.rb +21 -0
- data/lib/webgen/common/sitemap.rb +83 -0
- data/lib/webgen/configuration.rb +153 -0
- data/lib/webgen/contentprocessor.rb +99 -0
- data/lib/webgen/contentprocessor/blocks.rb +60 -0
- data/lib/webgen/contentprocessor/builder.rb +30 -0
- data/lib/webgen/contentprocessor/context.rb +89 -0
- data/lib/webgen/contentprocessor/erb.rb +28 -0
- data/lib/webgen/contentprocessor/erubis.rb +40 -0
- data/lib/webgen/contentprocessor/fragments.rb +25 -0
- data/lib/webgen/contentprocessor/haml.rb +30 -0
- data/lib/webgen/contentprocessor/maruku.rb +20 -0
- data/lib/webgen/contentprocessor/rdiscount.rb +17 -0
- data/lib/webgen/contentprocessor/rdoc.rb +19 -0
- data/lib/webgen/contentprocessor/redcloth.rb +17 -0
- data/lib/webgen/contentprocessor/sass.rb +20 -0
- data/lib/webgen/contentprocessor/tags.rb +136 -0
- data/lib/webgen/coreext.rb +13 -0
- data/lib/webgen/default_config.rb +215 -0
- data/lib/webgen/languages.rb +589 -0
- data/lib/webgen/loggable.rb +25 -0
- data/lib/webgen/logger.rb +97 -0
- data/lib/webgen/node.rb +391 -0
- data/lib/webgen/output.rb +82 -0
- data/lib/webgen/output/filesystem.rb +69 -0
- data/lib/webgen/page.rb +153 -0
- data/lib/webgen/path.rb +194 -0
- data/lib/webgen/source.rb +54 -0
- data/lib/webgen/source/filesystem.rb +61 -0
- data/lib/webgen/source/resource.rb +44 -0
- data/lib/webgen/source/stacked.rb +55 -0
- data/lib/webgen/source/tararchive.rb +73 -0
- data/lib/webgen/sourcehandler.rb +226 -0
- data/lib/webgen/sourcehandler/base.rb +248 -0
- data/lib/webgen/sourcehandler/copy.rb +43 -0
- data/lib/webgen/sourcehandler/directory.rb +36 -0
- data/lib/webgen/sourcehandler/feed.rb +117 -0
- data/lib/webgen/sourcehandler/fragment.rb +68 -0
- data/lib/webgen/sourcehandler/memory.rb +43 -0
- data/lib/webgen/sourcehandler/metainfo.rb +128 -0
- data/lib/webgen/sourcehandler/page.rb +59 -0
- data/lib/webgen/sourcehandler/sitemap.rb +60 -0
- data/lib/webgen/sourcehandler/template.rb +66 -0
- data/lib/webgen/sourcehandler/virtual.rb +110 -0
- data/lib/webgen/tag.rb +27 -0
- data/lib/webgen/tag/base.rb +170 -0
- data/lib/webgen/tag/breadcrumbtrail.rb +70 -0
- data/lib/webgen/tag/coderay.rb +31 -0
- data/lib/webgen/tag/date.rb +18 -0
- data/lib/webgen/tag/executecommand.rb +30 -0
- data/lib/webgen/tag/includefile.rb +42 -0
- data/lib/webgen/tag/langbar.rb +52 -0
- data/lib/webgen/tag/link.rb +26 -0
- data/lib/webgen/tag/menu.rb +207 -0
- data/lib/webgen/tag/metainfo.rb +25 -0
- data/lib/webgen/tag/relocatable.rb +54 -0
- data/lib/webgen/tag/sitemap.rb +41 -0
- data/lib/webgen/tag/tikz.rb +119 -0
- data/lib/webgen/tree.rb +90 -0
- data/lib/webgen/version.rb +8 -0
- data/lib/webgen/webgentask.rb +152 -0
- data/lib/webgen/website.rb +342 -0
- data/lib/webgen/websiteaccess.rb +31 -0
- data/lib/webgen/websitemanager.rb +127 -0
- data/man/man1/webgen.1 +73 -0
- data/misc/default.css +384 -0
- data/misc/default.template +75 -0
- data/misc/htmldoc.metainfo +25 -0
- data/misc/htmldoc.virtual +5 -0
- data/misc/images/arrow.gif +0 -0
- data/misc/images/error.png +0 -0
- data/misc/images/headerbg.jpg +0 -0
- data/misc/images/important.png +0 -0
- data/misc/images/information.png +0 -0
- data/misc/images/quote.gif +0 -0
- data/misc/images/warning.png +0 -0
- data/setup.rb +1585 -0
- data/test/helper.rb +45 -0
- data/test/test_blackboard.rb +60 -0
- data/test/test_cache.rb +59 -0
- data/test/test_cli.rb +21 -0
- data/test/test_common.rb +18 -0
- data/test/test_common_sitemap.rb +58 -0
- data/test/test_configuration.rb +68 -0
- data/test/test_contentprocessor.rb +33 -0
- data/test/test_contentprocessor_blocks.rb +68 -0
- data/test/test_contentprocessor_builder.rb +23 -0
- data/test/test_contentprocessor_context.rb +40 -0
- data/test/test_contentprocessor_erb.rb +23 -0
- data/test/test_contentprocessor_erubis.rb +49 -0
- data/test/test_contentprocessor_fragments.rb +42 -0
- data/test/test_contentprocessor_haml.rb +23 -0
- data/test/test_contentprocessor_maruku.rb +29 -0
- data/test/test_contentprocessor_rdiscount.rb +17 -0
- data/test/test_contentprocessor_rdoc.rb +18 -0
- data/test/test_contentprocessor_redcloth.rb +15 -0
- data/test/test_contentprocessor_sass.rb +22 -0
- data/test/test_contentprocessor_tags.rb +99 -0
- data/test/test_languages.rb +67 -0
- data/test/test_loggable.rb +32 -0
- data/test/test_logger.rb +94 -0
- data/test/test_node.rb +367 -0
- data/test/test_output_filesystem.rb +60 -0
- data/test/test_page.rb +214 -0
- data/test/test_path.rb +165 -0
- data/test/test_source_filesystem.rb +76 -0
- data/test/test_source_resource.rb +28 -0
- data/test/test_source_stacked.rb +36 -0
- data/test/test_source_tararchive.rb +65 -0
- data/test/test_sourcehandler_base.rb +123 -0
- data/test/test_sourcehandler_copy.rb +47 -0
- data/test/test_sourcehandler_directory.rb +42 -0
- data/test/test_sourcehandler_feed.rb +77 -0
- data/test/test_sourcehandler_fragment.rb +69 -0
- data/test/test_sourcehandler_memory.rb +44 -0
- data/test/test_sourcehandler_metainfo.rb +118 -0
- data/test/test_sourcehandler_page.rb +65 -0
- data/test/test_sourcehandler_sitemap.rb +49 -0
- data/test/test_sourcehandler_template.rb +65 -0
- data/test/test_sourcehandler_virtual.rb +87 -0
- data/test/test_tag_base.rb +85 -0
- data/test/test_tag_breadcrumbtrail.rb +91 -0
- data/test/test_tag_coderay.rb +32 -0
- data/test/test_tag_date.rb +18 -0
- data/test/test_tag_executecommand.rb +41 -0
- data/test/test_tag_includefile.rb +50 -0
- data/test/test_tag_langbar.rb +72 -0
- data/test/test_tag_link.rb +69 -0
- data/test/test_tag_menu.rb +207 -0
- data/test/test_tag_metainfo.rb +19 -0
- data/test/test_tag_relocatable.rb +59 -0
- data/test/test_tag_sitemap.rb +47 -0
- data/test/test_tag_tikz.rb +69 -0
- data/test/test_tree.rb +70 -0
- data/test/test_webgentask.rb +23 -0
- data/test/test_website.rb +98 -0
- data/test/test_websiteaccess.rb +25 -0
- data/test/test_websitemanager.rb +70 -0
- metadata +613 -0
@@ -0,0 +1,41 @@
|
|
1
|
+
---
|
2
|
+
title: Webgen::SourceHandler::Metainfo
|
3
|
+
---
|
4
|
+
## Description
|
5
|
+
|
6
|
+
This source handler provides the ability to set meta information for any path. It uses files in
|
7
|
+
[Webgen Page Format]({relocatable: ../webgen_page_format.html}) which can have two special blocks:
|
8
|
+
|
9
|
+
* `paths`: This block specifies meta information for paths and therefore this meta information is
|
10
|
+
applied before a node for a path is created. This can be used, for example, to change the output
|
11
|
+
path style. When specifying patterns, remember that the patterns are matched against paths!
|
12
|
+
|
13
|
+
* `alcn`: This block specifies meta information for nodes and this meta information is applied
|
14
|
+
directly after a node has been created. When specifying patterns, remember that the patterns are
|
15
|
+
matched against absolute localized canonical names! So you always need to take the language part
|
16
|
+
into account, ie. `/index.html` won't match but `/index.en.html`.
|
17
|
+
|
18
|
+
When no name is specified in the meta information file, the first block is assumed to be the `paths`
|
19
|
+
block and the second block is assumed to be the `alcn` block. The format of the two blocks is the
|
20
|
+
same: they need to be in YAML format and provide a hash with path patterns as keys and the
|
21
|
+
to-be-assigned meta information as values. This is best showed in an example:
|
22
|
+
|
23
|
+
--- name:paths
|
24
|
+
/**/index.page:
|
25
|
+
output_path_style: [:parent, :cnbase, :ext, [., :lang]]
|
26
|
+
|
27
|
+
mypic.jpg:
|
28
|
+
in_menu: true
|
29
|
+
--- name:alcn
|
30
|
+
**/index.en.html:
|
31
|
+
in_menu: true
|
32
|
+
|
33
|
+
All paths named `index.page` are assigned a new output path style. This has to be done in the
|
34
|
+
`paths` block because otherwise it would have no effect. And the file `mypic.jpg` will show up in
|
35
|
+
the menu. Notice, that the first form is specified as an absolute path pattern and the second
|
36
|
+
not. If this meta information file lies in the root directory there is no difference between those
|
37
|
+
two approaches. However, when it lies in a sub directory, the first form is still absolute but the
|
38
|
+
second form is taken relative to the directory in which the meta information file is in.
|
39
|
+
|
40
|
+
And last but not least, all nodes with a localized canonical name of `index.en.html` will show up in
|
41
|
+
the menu (again, notice that the pattern is relative).
|
@@ -0,0 +1,14 @@
|
|
1
|
+
---
|
2
|
+
title: Webgen::SourceHandler::Page
|
3
|
+
---
|
4
|
+
## Description
|
5
|
+
|
6
|
+
This source handler uses page files which are used to specify the actual content for the
|
7
|
+
website. These files are written using [Webgen Page Format]({relocatable:
|
8
|
+
../webgen_page_format.html}). Therefore they contain the content for the web page and, optionally,
|
9
|
+
meta information.
|
10
|
+
|
11
|
+
*In contrast* to other handled files, page files can never be unlocalized! If they have no language
|
12
|
+
set, the default language specified using the configuration option `website.lang` is used. This
|
13
|
+
means that for the default language set to English and a source path named `index.page`, the
|
14
|
+
language meta information is automatically set to English.
|
@@ -0,0 +1,46 @@
|
|
1
|
+
---
|
2
|
+
title: Webgen::SourceHandler::Sitemap
|
3
|
+
---
|
4
|
+
## Description
|
5
|
+
|
6
|
+
This source handler automatically generates a sitemap based on the specification of
|
7
|
+
[sitemaps.org](http://sitemaps.org) from a file in [Webgen Page Format]({relocatable:
|
8
|
+
../webgen_page_format.html}).
|
9
|
+
|
10
|
+
> This extension can only be used if you have installed the [builder](http://builder.rubyforge.org)
|
11
|
+
> library. The preferred way to do this is via Rubygems:
|
12
|
+
>
|
13
|
+
> gem install builder
|
14
|
+
{.warning}
|
15
|
+
|
16
|
+
The following meta information keys are supported:
|
17
|
+
|
18
|
+
* `site_url` (MANDATORY)
|
19
|
+
|
20
|
+
The base url of the website for which the sitemap is generated.
|
21
|
+
|
22
|
+
* `default_change_freq` (OPTIONAL)
|
23
|
+
|
24
|
+
The default change frequency of a file.
|
25
|
+
|
26
|
+
* `default_priority` (OPTIONAL)
|
27
|
+
|
28
|
+
The default priority of a file.
|
29
|
+
|
30
|
+
You can also specify all common sitemap configuration options to customize the output of the source
|
31
|
+
handler.
|
32
|
+
|
33
|
+
The following meta information keys of files are used if they are specified:
|
34
|
+
|
35
|
+
* `modified_at`
|
36
|
+
|
37
|
+
The time at which the file was last modified, used as the time at which this feed entry was
|
38
|
+
updated.
|
39
|
+
|
40
|
+
* `change_freq`
|
41
|
+
|
42
|
+
The change frequency of the the file.
|
43
|
+
|
44
|
+
* `priority`
|
45
|
+
|
46
|
+
The priority of the file in respect to the other files.
|
@@ -0,0 +1,45 @@
|
|
1
|
+
---
|
2
|
+
title: Webgen::SourceHandler::Template
|
3
|
+
---
|
4
|
+
## Description
|
5
|
+
|
6
|
+
The template handler processes the templates files. Templates, as the name already implies, normally
|
7
|
+
specify the layout and the overall "picture" of a web page that is defined using a page file. These
|
8
|
+
files are in [Webgen Page Format]({relocatable: ../webgen_page_format.html}) (the format which is
|
9
|
+
also used for page files).
|
10
|
+
|
11
|
+
The configuration option `sourcehandler.template.default_template` specifies the name of the default
|
12
|
+
template which is used when no explicit template is set via the meta information `template`. webgen
|
13
|
+
assumes that the default template is in the same directory as the page file. However, if it can not
|
14
|
+
be found there, the parent directory is searched for it and so on. If a default template isn't found
|
15
|
+
in the root directory, no template is used at all. This means that when you create a default
|
16
|
+
template in the root directory, it is used as template for all page files that have no explicit
|
17
|
+
template set.
|
18
|
+
|
19
|
+
webgen also uses the concept of a template chain to support multiple templates for one page
|
20
|
+
file. For example, assume that
|
21
|
+
|
22
|
+
* the page file `index.page` has set the `template` meta information to `special.template`,
|
23
|
+
* the template `special.template` has no `template` meta information set and
|
24
|
+
* the page file `other.page` also has no `template` meta information set.
|
25
|
+
|
26
|
+
The template chain for `index.page` would look like this
|
27
|
+
|
28
|
+
default.template <-- special.template <-- index.page
|
29
|
+
|
30
|
+
whereas the template chain for `other.page` would look like this
|
31
|
+
|
32
|
+
default.template <-- index.page
|
33
|
+
|
34
|
+
The first case also means that the `special.template` is nested in the `default.template`. This
|
35
|
+
makes it possible, for example, to create a general website layout and then to create a special
|
36
|
+
image gallery layout which uses the general one.
|
37
|
+
|
38
|
+
To stop the template handler from further searching for a template, you explicitly need to set a
|
39
|
+
null template for the page or template file:
|
40
|
+
|
41
|
+
template: ~
|
42
|
+
|
43
|
+
This is useful if you want to have a different `default.template` in a sub directory which should
|
44
|
+
provide a different look-and-feel for this subtree as the `default.template` in the root of the
|
45
|
+
website.
|
@@ -0,0 +1,49 @@
|
|
1
|
+
---
|
2
|
+
title: Webgen::SourceHandler::Virtual
|
3
|
+
---
|
4
|
+
## Description
|
5
|
+
|
6
|
+
This source handler uses files in [Webgen Page Format]({relocatable: ../webgen_page_format.html})
|
7
|
+
which are used to specify virtual paths. Virtual paths don't really exist as source paths but are
|
8
|
+
useful nonetheless. For example, they allow to include links to external content in automatically
|
9
|
+
generated menus. They are never written out since they define no real content!
|
10
|
+
|
11
|
+
The `content` block of the source path is used and its content needs to be a hash in YAML
|
12
|
+
format. The keys are relative or absolute source paths names and the values meta information for
|
13
|
+
them. Any meta information can be set on a virtual path but one meta information key is special:
|
14
|
+
`url`. This meta information specifies, relative to the directory in which the source file is in,
|
15
|
+
the output path for the virtual node. If no `url` meta information is specified, the source path
|
16
|
+
itself is used as output path.
|
17
|
+
|
18
|
+
Following is a sample virtual source files with explanations afterwards:
|
19
|
+
|
20
|
+
\--- !omap
|
21
|
+
- /documentation/:
|
22
|
+
|
23
|
+
- /documentation/index.html:
|
24
|
+
routed_title: Documentation
|
25
|
+
|
26
|
+
- download_and_installation.html:
|
27
|
+
in_menu: true
|
28
|
+
sort_info: 25
|
29
|
+
url: index.html#download__installation
|
30
|
+
|
31
|
+
- /documentation/api.html:
|
32
|
+
title: API Reference
|
33
|
+
url: http://myhost.com/api
|
34
|
+
|
35
|
+
> The example does not use a normal hash but an ordered YAML map. This ensures that the virtual
|
36
|
+
> nodes are created in the order they appear in the file.
|
37
|
+
{.information}
|
38
|
+
|
39
|
+
The first entry specifies that a directory `/documentation` should be created. The virtual file
|
40
|
+
handler recognizes this because the given path ends in a slash!. Then a virtual index file for the
|
41
|
+
virtual directory is created. This would be done, for example, when the documentation directory is
|
42
|
+
created by an external program.
|
43
|
+
|
44
|
+
The third entry specifies a virtual file that should in the menu and should have a certain sort
|
45
|
+
information. When this virtual file is referenced, the path given by the `url` key is returned. This
|
46
|
+
example shows how to make a single link to a fragment appear in automatically generated menus.
|
47
|
+
|
48
|
+
And the fourth entry specifies another virtual file whose output path is an URL pointing to
|
49
|
+
`http://myhost.com/api`.
|
data/doc/tag.template
ADDED
@@ -0,0 +1,25 @@
|
|
1
|
+
---
|
2
|
+
template: extensions.template
|
3
|
+
--- name:summary pipeline:erb,tags,maruku,blocks
|
4
|
+
|
5
|
+
The following tag names are registered for this tag class:
|
6
|
+
<%= context.website.config['contentprocessor.tags.map'].
|
7
|
+
select {|k,v| v == context.content_node['title']}.
|
8
|
+
map {|k,v| '`' + (k.kind_of?(Symbol) ? k.inspect : k.to_s) + '`'}.join(', ') %>
|
9
|
+
|
10
|
+
<% if context.content_node['used_options'] %>
|
11
|
+
This tag uses the following options:
|
12
|
+
|
13
|
+
<%
|
14
|
+
for option in context.content_node['used_options']
|
15
|
+
temp = 'mandatory' if !context.website.config.meta_info[option][:mandatory].nil?
|
16
|
+
temp += ' default' if context.website.config.meta_info[option][:mandatory] == 'default'
|
17
|
+
%>* [`<%= option %>`]({relocatable: reference_configuration.html#<%= option.tr('.', '') %>}) <%= temp ? '(' + temp + ')' : '' %>
|
18
|
+
<%
|
19
|
+
temp = nil
|
20
|
+
end
|
21
|
+
%>
|
22
|
+
|
23
|
+
<% end %>
|
24
|
+
--- name:content
|
25
|
+
<webgen:block name='content' />
|
@@ -0,0 +1,40 @@
|
|
1
|
+
---
|
2
|
+
title: Webgen::Tag::BreadcrumbTrail
|
3
|
+
used_options:
|
4
|
+
- tag.breadcrumbtrail.separator
|
5
|
+
- tag.breadcrumbtrail.omit_index_path
|
6
|
+
- tag.breadcrumbtrail.start_level
|
7
|
+
- tag.breadcrumbtrail.end_level
|
8
|
+
---
|
9
|
+
## Description
|
10
|
+
|
11
|
+
The breadcrumb trail tag is used for displaying the hierarchy of the current page. The behavior of
|
12
|
+
the `tag.breadcrumbtrail.omit_index_path` option can be overridden for individual index paths by
|
13
|
+
setting the meta information `omit_index_path` accordingly.
|
14
|
+
|
15
|
+
The amount of levels shown can be customized by using the options `tag.breadcrumbtrail.start_level`
|
16
|
+
and `tag.breadcrumbtrail.end_level`, see the examples below.
|
17
|
+
|
18
|
+
## Examples
|
19
|
+
|
20
|
+
<table class="examples">
|
21
|
+
<tr>
|
22
|
+
<th>Usage</th><th>Output</th>
|
23
|
+
</tr>
|
24
|
+
<tr>
|
25
|
+
<td>\{breadcrumb_trail:}</td>
|
26
|
+
<td>{breadcrumb_trail:}</td>
|
27
|
+
</tr>
|
28
|
+
<tr>
|
29
|
+
<td>\{breadcrumb_trail: {separator: " HELLO "}}</td>
|
30
|
+
<td>{breadcrumb_trail: {separator: " HELLO "}}</td>
|
31
|
+
</tr>
|
32
|
+
<tr>
|
33
|
+
<td>\{breadcrumb_trail: {end_level: -2}}</td>
|
34
|
+
<td>{breadcrumb_trail: {end_level: -2}}</td>
|
35
|
+
</tr>
|
36
|
+
<tr>
|
37
|
+
<td>\{breadcrumb_trail: {start_level: 1}}</td>
|
38
|
+
<td>{breadcrumb_trail: {start_level: 1}}</td>
|
39
|
+
</tr>
|
40
|
+
</table>
|
@@ -0,0 +1,49 @@
|
|
1
|
+
---
|
2
|
+
title: Webgen::Tag::Coderay
|
3
|
+
used_options:
|
4
|
+
- tag.coderay.lang
|
5
|
+
- tag.coderay.process_body
|
6
|
+
- tag.coderay.wrap
|
7
|
+
- tag.coderay.line_numbers
|
8
|
+
- tag.coderay.line_number_start
|
9
|
+
- tag.coderay.bold_every
|
10
|
+
- tag.coderay.tab_width
|
11
|
+
---
|
12
|
+
## Description
|
13
|
+
|
14
|
+
This tag applies syntax highlighting to its body by using the [coderay][1] library which can be used
|
15
|
+
to highlight many different languages (see `tag.coderay.lang` documentation). The body of the tag
|
16
|
+
specifies what should be highlighted.
|
17
|
+
|
18
|
+
> It is easy to include and highlight an entire file by combining this tag with the `include_file` tag:
|
19
|
+
>
|
20
|
+
> \{coderay:: ruby}{include_file: test.rb}{coderay}
|
21
|
+
{.information}
|
22
|
+
|
23
|
+
> This extension is only available if you have installed the [coderay][1] library. The preferred
|
24
|
+
> way to do this is via Rubygems:
|
25
|
+
>
|
26
|
+
> gem install coderay
|
27
|
+
{.warning}
|
28
|
+
|
29
|
+
[1]: http://coderay.rubychan.de/ "The Coderay homepage"
|
30
|
+
|
31
|
+
## Examples
|
32
|
+
|
33
|
+
<table class="examples">
|
34
|
+
<tr>
|
35
|
+
<th>Usage</th><th>Output</th>
|
36
|
+
</tr>
|
37
|
+
<tr>
|
38
|
+
<td>\{coderay:: {lang: ruby, bold_every: 2}}{include_file: lib/webgen/version.rb}{coderay}</td>
|
39
|
+
<% if File.exists?(File.join(context.website.directory, 'lib/webgen/version.rb')) %>
|
40
|
+
<td>{coderay:: {lang: ruby, bold_every: 2}}{include_file: lib/webgen/version.rb}{coderay}</td>
|
41
|
+
<% else %>
|
42
|
+
<td>{coderay:: {lang: ruby, bold_every: 2}}{include_file: ../lib/webgen/version.rb}{coderay}</td>
|
43
|
+
<% end %>
|
44
|
+
</tr>
|
45
|
+
<tr>
|
46
|
+
<td>\{coderay:: {lang: ruby, wrap: span}}puts 5+5{coderay}</td>
|
47
|
+
<td><code>{coderay:: {lang: ruby, wrap: span}}puts 5+5{coderay}</code></td>
|
48
|
+
</tr>
|
49
|
+
</table>
|
data/doc/tag/date.page
ADDED
@@ -0,0 +1,31 @@
|
|
1
|
+
---
|
2
|
+
title: Webgen::Tag::Date
|
3
|
+
used_options:
|
4
|
+
- tag.date.format
|
5
|
+
---
|
6
|
+
## Description
|
7
|
+
|
8
|
+
The date tag is used to display the current time in a specific format (the format of Ruby's inbuilt
|
9
|
+
method [Time#strftime][1]). Have a look a the examples below to see some possible outputs.
|
10
|
+
|
11
|
+
[1]: http://www.ruby-doc.org/core/classes/Time.html
|
12
|
+
|
13
|
+
## Examples
|
14
|
+
|
15
|
+
<table class="examples">
|
16
|
+
<tr>
|
17
|
+
<th>Usage</th><th>Output</th>
|
18
|
+
</tr>
|
19
|
+
<tr>
|
20
|
+
<td>\{date:}</td>
|
21
|
+
<td>{date:}</td>
|
22
|
+
</tr>
|
23
|
+
<tr>
|
24
|
+
<td>\{date: {format: '%A, %Y-%m-%d'}}</td>
|
25
|
+
<td>{date: {format: '%A, %Y-%m-%d'}}</td>
|
26
|
+
</tr>
|
27
|
+
<tr>
|
28
|
+
<td>\{date: {format: %x - %X}}</td>
|
29
|
+
<td>{date: {format: %x - %X}}</td>
|
30
|
+
</tr>
|
31
|
+
</table>
|
@@ -0,0 +1,26 @@
|
|
1
|
+
---
|
2
|
+
title: Webgen::Tag::ExecuteCommand
|
3
|
+
used_options:
|
4
|
+
- tag.executecommand.command
|
5
|
+
- tag.executecommand.process_output
|
6
|
+
- tag.executecommand.escape_html
|
7
|
+
---
|
8
|
+
## Description
|
9
|
+
|
10
|
+
The execute command tag is used to include the output from a shell command.
|
11
|
+
|
12
|
+
## Examples
|
13
|
+
|
14
|
+
<table class="examples">
|
15
|
+
<tr>
|
16
|
+
<th>Usage</th><th>Output</th>
|
17
|
+
</tr>
|
18
|
+
<tr>
|
19
|
+
<td>\{execute_cmd: uname -p}</td>
|
20
|
+
<td><pre>{execute_cmd: uname -p}</pre></td>
|
21
|
+
</tr>
|
22
|
+
<tr>
|
23
|
+
<td>\{execute_cmd: {command: 'ruby -v'}}</td>
|
24
|
+
<td><pre>{execute_cmd: {command: 'ruby -v'}}</pre></td>
|
25
|
+
</tr>
|
26
|
+
</table>
|
@@ -0,0 +1,32 @@
|
|
1
|
+
---
|
2
|
+
title: Webgen::Tag::IncludeFile
|
3
|
+
used_options:
|
4
|
+
- tag.includefile.filename
|
5
|
+
- tag.includefile.process_output
|
6
|
+
- tag.includefile.escape_html
|
7
|
+
---
|
8
|
+
## Description
|
9
|
+
|
10
|
+
The include file tag is used to include the content of a file. The filename needs to be specified
|
11
|
+
relative to the website directory or an absolute filename.
|
12
|
+
|
13
|
+
> By surrounding the include file tag with a syntax highlighting tag it is possible to highlight the
|
14
|
+
> contents of a file.
|
15
|
+
{.information}
|
16
|
+
|
17
|
+
|
18
|
+
## Examples
|
19
|
+
|
20
|
+
<table class="examples">
|
21
|
+
<tr>
|
22
|
+
<th>Usage</th><th>Output</th>
|
23
|
+
</tr>
|
24
|
+
<tr>
|
25
|
+
<td>\{include_file: {filename: AUTHORS, process_output: false}}</td>
|
26
|
+
<% if File.exists?(File.join(context.website.directory, 'AUTHORS')) %>
|
27
|
+
<td><pre>{include_file: {filename: AUTHORS, process_output: false}}</pre></td>
|
28
|
+
<% else %>
|
29
|
+
<td><pre>{include_file: {filename: ../AUTHORS, process_output: false}}</pre></td>
|
30
|
+
<% end %>
|
31
|
+
</tr>
|
32
|
+
</table>
|
@@ -0,0 +1,44 @@
|
|
1
|
+
---
|
2
|
+
title: Webgen::Tag::Langbar
|
3
|
+
used_options:
|
4
|
+
- tag.langbar.separator
|
5
|
+
- tag.langbar.show_own_lang
|
6
|
+
- tag.langbar.show_single_lang
|
7
|
+
- tag.langbar.lang_names
|
8
|
+
---
|
9
|
+
## Description
|
10
|
+
|
11
|
+
This tag is used to display a list of links to translations of the page. The text that is displayed
|
12
|
+
can be set via the configuration option `tag.langbar.lang_names` (if not set, the language code is
|
13
|
+
shown).
|
14
|
+
|
15
|
+
The option `tag.langbar.process_output` is useful in conjunction with `tag.langbar.lang_names` to
|
16
|
+
display language flags. For example, you can use the following entries in `config.yaml`:
|
17
|
+
|
18
|
+
tag.langbar.lang_names:
|
19
|
+
en: |
|
20
|
+
<img src="\{relocatable: img/flag_english.gif}" alt="English flag"/> English
|
21
|
+
de: |
|
22
|
+
<img src="\{relocatable: img/flag_german.gif}" alt="German flag"/> Deutsch
|
23
|
+
|
24
|
+
tag.langbar.process_output: true
|
25
|
+
|
26
|
+
This assumes that the `langbar` tag is *only* used in `src/default.template` and the flag images are
|
27
|
+
under `src/img/` (otherwise the `relocatable` tag can correctly find the paths). To work around
|
28
|
+
this, you could specify the `lang_names` directly in the `langbar` tag.
|
29
|
+
|
30
|
+
## Examples
|
31
|
+
|
32
|
+
<table class="examples">
|
33
|
+
<tr>
|
34
|
+
<th>Usage</th><th>Output</th>
|
35
|
+
</tr>
|
36
|
+
<tr>
|
37
|
+
<td>\{langbar:}</td>
|
38
|
+
<td>{langbar:}</td>
|
39
|
+
</tr>
|
40
|
+
<tr>
|
41
|
+
<td>\{langbar: {lang_names: {en: Englisch}}}</td>
|
42
|
+
<td>{langbar: {lang_names: {en: Englisch}}}</td>
|
43
|
+
</tr>
|
44
|
+
</table>
|