giraffesoft-webby 0.9.5
Sign up to get free protection for your applications and to get access to all the features.
- data/History.txt +218 -0
- data/README.rdoc +92 -0
- data/Rakefile +62 -0
- data/bin/webby +41 -0
- data/bin/webby-gen +41 -0
- data/examples/blog/Sitefile +7 -0
- data/examples/blog/tasks/blog.rake +72 -0
- data/examples/blog/templates/atom_feed.erb +40 -0
- data/examples/blog/templates/blog/month.erb +22 -0
- data/examples/blog/templates/blog/post.erb +16 -0
- data/examples/blog/templates/blog/year.erb +22 -0
- data/examples/presentation/Sitefile +10 -0
- data/examples/presentation/content/css/uv/twilight.css +137 -0
- data/examples/presentation/content/presentation/_sample_code.txt +10 -0
- data/examples/presentation/content/presentation/index.txt +63 -0
- data/examples/presentation/content/presentation/s5/blank.gif +0 -0
- data/examples/presentation/content/presentation/s5/bodybg.gif +0 -0
- data/examples/presentation/content/presentation/s5/framing.css +23 -0
- data/examples/presentation/content/presentation/s5/iepngfix.htc +42 -0
- data/examples/presentation/content/presentation/s5/opera.css +7 -0
- data/examples/presentation/content/presentation/s5/outline.css +15 -0
- data/examples/presentation/content/presentation/s5/pretty.css +86 -0
- data/examples/presentation/content/presentation/s5/print.css +25 -0
- data/examples/presentation/content/presentation/s5/s5-core.css +9 -0
- data/examples/presentation/content/presentation/s5/slides.css +3 -0
- data/examples/presentation/content/presentation/s5/slides.js +553 -0
- data/examples/presentation/layouts/presentation.txt +43 -0
- data/examples/presentation/templates/_code_partial.erb +13 -0
- data/examples/presentation/templates/presentation.erb +40 -0
- data/examples/tumblog/Sitefile +9 -0
- data/examples/tumblog/content/css/tumblog.css +308 -0
- data/examples/tumblog/content/images/tumblog/permalink.gif +0 -0
- data/examples/tumblog/content/images/tumblog/rss.gif +0 -0
- data/examples/tumblog/content/tumblog/200806/the-noble-chicken/index.txt +12 -0
- data/examples/tumblog/content/tumblog/200807/historical-perspectives-on-the-classic-chicken-joke/index.txt +12 -0
- data/examples/tumblog/content/tumblog/200807/mad-city-chickens/index.txt +10 -0
- data/examples/tumblog/content/tumblog/200807/the-wisdom-of-the-dutch/index.txt +11 -0
- data/examples/tumblog/content/tumblog/200807/up-a-tree/index.txt +13 -0
- data/examples/tumblog/content/tumblog/index.txt +37 -0
- data/examples/tumblog/content/tumblog/rss.txt +37 -0
- data/examples/tumblog/layouts/tumblog/default.txt +44 -0
- data/examples/tumblog/layouts/tumblog/post.txt +15 -0
- data/examples/tumblog/lib/tumblog_helper.rb +32 -0
- data/examples/tumblog/tasks/tumblog.rake +30 -0
- data/examples/tumblog/templates/atom_feed.erb +40 -0
- data/examples/tumblog/templates/tumblog/conversation.erb +12 -0
- data/examples/tumblog/templates/tumblog/link.erb +10 -0
- data/examples/tumblog/templates/tumblog/photo.erb +13 -0
- data/examples/tumblog/templates/tumblog/post.erb +12 -0
- data/examples/tumblog/templates/tumblog/quote.erb +11 -0
- data/examples/webby/Sitefile +19 -0
- data/examples/webby/content/communicate/index.txt +28 -0
- data/examples/webby/content/css/background.gif +0 -0
- data/examples/webby/content/css/blueprint/print.css +76 -0
- data/examples/webby/content/css/blueprint/screen.css +696 -0
- data/examples/webby/content/css/coderay.css +96 -0
- data/examples/webby/content/css/site.css +196 -0
- data/examples/webby/content/css/uv/twilight.css +137 -0
- data/examples/webby/content/index.txt +37 -0
- data/examples/webby/content/learn/index.txt +28 -0
- data/examples/webby/content/reference/index.txt +204 -0
- data/examples/webby/content/release-notes/index.txt +21 -0
- data/examples/webby/content/release-notes/rel-0-9-0/index.txt +74 -0
- data/examples/webby/content/release-notes/rel-0-9-1/index.txt +93 -0
- data/examples/webby/content/release-notes/rel-0-9-2/index.txt +14 -0
- data/examples/webby/content/release-notes/rel-0-9-3/index.txt +47 -0
- data/examples/webby/content/robots.txt +6 -0
- data/examples/webby/content/script/jquery.corner.js +152 -0
- data/examples/webby/content/script/jquery.js +31 -0
- data/examples/webby/content/sitemap.txt +31 -0
- data/examples/webby/content/tips_and_tricks/index.txt +97 -0
- data/examples/webby/content/tutorial/index.txt +135 -0
- data/examples/webby/content/user-manual/index.txt +419 -0
- data/examples/webby/layouts/default.txt +49 -0
- data/examples/webby/templates/page.erb +10 -0
- data/examples/website/Sitefile +7 -0
- data/examples/website/content/css/blueprint/ie.css +26 -0
- data/examples/website/content/css/blueprint/plugins/buttons/icons/cross.png +0 -0
- data/examples/website/content/css/blueprint/plugins/buttons/icons/key.png +0 -0
- data/examples/website/content/css/blueprint/plugins/buttons/icons/tick.png +0 -0
- data/examples/website/content/css/blueprint/plugins/buttons/readme.txt +32 -0
- data/examples/website/content/css/blueprint/plugins/buttons/screen.css +97 -0
- data/examples/website/content/css/blueprint/plugins/fancy-type/readme.txt +14 -0
- data/examples/website/content/css/blueprint/plugins/fancy-type/screen.css +71 -0
- data/examples/website/content/css/blueprint/plugins/link-icons/icons/doc.png +0 -0
- data/examples/website/content/css/blueprint/plugins/link-icons/icons/email.png +0 -0
- data/examples/website/content/css/blueprint/plugins/link-icons/icons/external.png +0 -0
- data/examples/website/content/css/blueprint/plugins/link-icons/icons/feed.png +0 -0
- data/examples/website/content/css/blueprint/plugins/link-icons/icons/im.png +0 -0
- data/examples/website/content/css/blueprint/plugins/link-icons/icons/pdf.png +0 -0
- data/examples/website/content/css/blueprint/plugins/link-icons/icons/visited.png +0 -0
- data/examples/website/content/css/blueprint/plugins/link-icons/icons/xls.png +0 -0
- data/examples/website/content/css/blueprint/plugins/link-icons/readme.txt +18 -0
- data/examples/website/content/css/blueprint/plugins/link-icons/screen.css +40 -0
- data/examples/website/content/css/blueprint/plugins/rtl/readme.txt +10 -0
- data/examples/website/content/css/blueprint/plugins/rtl/screen.css +109 -0
- data/examples/website/content/css/blueprint/print.css +30 -0
- data/examples/website/content/css/blueprint/screen.css +251 -0
- data/examples/website/content/css/blueprint/src/forms.css +49 -0
- data/examples/website/content/css/blueprint/src/grid.css +212 -0
- data/examples/website/content/css/blueprint/src/grid.png +0 -0
- data/examples/website/content/css/blueprint/src/ie.css +59 -0
- data/examples/website/content/css/blueprint/src/print.css +85 -0
- data/examples/website/content/css/blueprint/src/reset.css +38 -0
- data/examples/website/content/css/blueprint/src/typography.css +105 -0
- data/examples/website/content/css/coderay.css +111 -0
- data/examples/website/content/css/site.css +67 -0
- data/examples/website/content/index.txt +19 -0
- data/examples/website/layouts/default.txt +61 -0
- data/examples/website/lib/breadcrumbs.rb +28 -0
- data/examples/website/templates/_partial.erb +10 -0
- data/examples/website/templates/page.erb +18 -0
- data/lib/webby.rb +233 -0
- data/lib/webby/apps.rb +12 -0
- data/lib/webby/apps/generator.rb +276 -0
- data/lib/webby/apps/main.rb +258 -0
- data/lib/webby/auto_builder.rb +157 -0
- data/lib/webby/builder.rb +172 -0
- data/lib/webby/core_ext/enumerable.rb +11 -0
- data/lib/webby/core_ext/hash.rb +28 -0
- data/lib/webby/core_ext/kernel.rb +26 -0
- data/lib/webby/core_ext/string.rb +163 -0
- data/lib/webby/core_ext/time.rb +9 -0
- data/lib/webby/filters.rb +85 -0
- data/lib/webby/filters/basepath.rb +97 -0
- data/lib/webby/filters/erb.rb +9 -0
- data/lib/webby/filters/haml.rb +18 -0
- data/lib/webby/filters/markdown.rb +16 -0
- data/lib/webby/filters/maruku.rb +16 -0
- data/lib/webby/filters/outline.rb +309 -0
- data/lib/webby/filters/sass.rb +17 -0
- data/lib/webby/filters/slides.rb +56 -0
- data/lib/webby/filters/textile.rb +16 -0
- data/lib/webby/filters/tidy.rb +76 -0
- data/lib/webby/filters/wiki_words.rb +14 -0
- data/lib/webby/helpers.rb +30 -0
- data/lib/webby/helpers/capture_helper.rb +141 -0
- data/lib/webby/helpers/coderay_helper.rb +69 -0
- data/lib/webby/helpers/graphviz_helper.rb +136 -0
- data/lib/webby/helpers/tag_helper.rb +65 -0
- data/lib/webby/helpers/tex_img_helper.rb +133 -0
- data/lib/webby/helpers/ultraviolet_helper.rb +63 -0
- data/lib/webby/helpers/url_helper.rb +241 -0
- data/lib/webby/journal.rb +126 -0
- data/lib/webby/link_validator.rb +160 -0
- data/lib/webby/renderer.rb +389 -0
- data/lib/webby/resources.rb +137 -0
- data/lib/webby/resources/db.rb +251 -0
- data/lib/webby/resources/layout.rb +54 -0
- data/lib/webby/resources/meta_file.rb +211 -0
- data/lib/webby/resources/page.rb +81 -0
- data/lib/webby/resources/partial.rb +85 -0
- data/lib/webby/resources/resource.rb +201 -0
- data/lib/webby/resources/static.rb +36 -0
- data/lib/webby/stelan/mktemp.rb +135 -0
- data/lib/webby/stelan/paginator.rb +165 -0
- data/lib/webby/tasks/build.rake +27 -0
- data/lib/webby/tasks/create.rake +25 -0
- data/lib/webby/tasks/deploy.rake +22 -0
- data/lib/webby/tasks/growl.rake +16 -0
- data/lib/webby/tasks/validate.rake +19 -0
- data/spec/core_ext/hash_spec.rb +47 -0
- data/spec/core_ext/string_spec.rb +110 -0
- data/spec/core_ext/time_spec.rb +19 -0
- data/spec/data/hooligans/bad_meta_data_1.txt +34 -0
- data/spec/data/hooligans/bad_meta_data_2.txt +34 -0
- data/spec/data/html/anchor.html +11 -0
- data/spec/data/html/external.html +10 -0
- data/spec/data/html/invalid-relative.html +10 -0
- data/spec/data/html/relative-anchor.html +10 -0
- data/spec/data/html/relative-invalid-anchor.html +10 -0
- data/spec/data/html/relative.html +10 -0
- data/spec/data/outline/basic.out +81 -0
- data/spec/data/outline/basic.txt +25 -0
- data/spec/data/outline/no_clobber.out +86 -0
- data/spec/data/outline/numbering.out +81 -0
- data/spec/data/outline/numbering_only.out +21 -0
- data/spec/data/outline/toc_range_1.out +66 -0
- data/spec/data/outline/toc_range_2.out +55 -0
- data/spec/data/outline/toc_style.out +81 -0
- data/spec/data/site/Sitefile +9 -0
- data/spec/data/site/content/_partial.txt +10 -0
- data/spec/data/site/content/css/coderay.css +111 -0
- data/spec/data/site/content/css/site.css +67 -0
- data/spec/data/site/content/css/tumblog.css +308 -0
- data/spec/data/site/content/images/tumblog/permalink.gif +0 -0
- data/spec/data/site/content/images/tumblog/rss.gif +0 -0
- data/spec/data/site/content/index.txt +19 -0
- data/spec/data/site/content/photos.txt +21 -0
- data/spec/data/site/content/tumblog/200806/the-noble-chicken/index.txt +12 -0
- data/spec/data/site/content/tumblog/200807/historical-perspectives-on-the-classic-chicken-joke/index.txt +12 -0
- data/spec/data/site/content/tumblog/200807/mad-city-chickens/index.txt +10 -0
- data/spec/data/site/content/tumblog/200807/the-wisdom-of-the-dutch/index.txt +11 -0
- data/spec/data/site/content/tumblog/200807/up-a-tree/index.txt +13 -0
- data/spec/data/site/content/tumblog/index.txt +37 -0
- data/spec/data/site/content/tumblog/rss.txt +37 -0
- data/spec/data/site/layouts/default.txt +58 -0
- data/spec/data/site/layouts/tumblog/default.txt +44 -0
- data/spec/data/site/layouts/tumblog/post.txt +15 -0
- data/spec/data/site/lib/breadcrumbs.rb +28 -0
- data/spec/data/site/lib/tumblog_helper.rb +32 -0
- data/spec/data/site/tasks/tumblog.rake +30 -0
- data/spec/data/site/templates/_partial.erb +10 -0
- data/spec/data/site/templates/atom_feed.erb +40 -0
- data/spec/data/site/templates/page.erb +18 -0
- data/spec/data/site/templates/presentation.erb +40 -0
- data/spec/data/site/templates/tumblog/conversation.erb +12 -0
- data/spec/data/site/templates/tumblog/link.erb +10 -0
- data/spec/data/site/templates/tumblog/photo.erb +13 -0
- data/spec/data/site/templates/tumblog/post.erb +12 -0
- data/spec/data/site/templates/tumblog/quote.erb +11 -0
- data/spec/spec.opts +1 -0
- data/spec/spec_helper.rb +58 -0
- data/spec/webby/apps/generator_spec.rb +117 -0
- data/spec/webby/apps/main_spec.rb +88 -0
- data/spec/webby/filters/basepath_spec.rb +167 -0
- data/spec/webby/filters/maruku_spec.rb +31 -0
- data/spec/webby/filters/outline_spec.rb +92 -0
- data/spec/webby/filters/textile_spec.rb +31 -0
- data/spec/webby/helpers/capture_helper_spec.rb +56 -0
- data/spec/webby/link_validator_spec.rb +154 -0
- data/spec/webby/renderer_spec.rb +139 -0
- data/spec/webby/resources/db_spec.rb +250 -0
- data/spec/webby/resources/layout_spec.rb +83 -0
- data/spec/webby/resources/meta_file_spec.rb +171 -0
- data/spec/webby/resources/page_spec.rb +111 -0
- data/spec/webby/resources/partial_spec.rb +58 -0
- data/spec/webby/resources/resource_spec.rb +219 -0
- data/spec/webby/resources/static_spec.rb +49 -0
- data/spec/webby/resources_spec.rb +69 -0
- data/tasks/mswin32.rake +38 -0
- data/tasks/website.rake +37 -0
- metadata +372 -0
@@ -0,0 +1,133 @@
|
|
1
|
+
require Webby.libpath(*%w[webby stelan mktemp])
|
2
|
+
require 'fileutils'
|
3
|
+
|
4
|
+
module Webby::Helpers
|
5
|
+
module TexImgHelper
|
6
|
+
|
7
|
+
# The +tex2img+ method converts a a section of mathematical TeX script
|
8
|
+
# into an image and embeds the resulting image into the page. The TeX
|
9
|
+
# engine must be installed on your system along with the ImageMagick
|
10
|
+
# +convert+ program.
|
11
|
+
#
|
12
|
+
# Options can be passed to the TeX engine via attributes in the
|
13
|
+
# +tex2img+ method.
|
14
|
+
#
|
15
|
+
# <% tex2img( "wave_eq", :path => "images", :alt => "wave equation" ) do -%>
|
16
|
+
# $\psi_{tot}(x,-t_0,r) = \frac{1}{(2\pi)^2} \int\!\!\!\int
|
17
|
+
# \tilde\Psi_{tot}\left(k_x,\frac{c}{2}\sqrt{k_x^2 + k_r^2},r=0\right)$
|
18
|
+
# <% end -%>
|
19
|
+
#
|
20
|
+
# The supported TeX options are the following:
|
21
|
+
#
|
22
|
+
# :path : where generated images will be stored
|
23
|
+
# [default is "/"]
|
24
|
+
# :type : the type of image to generate (png, jpeg, gif)
|
25
|
+
# [default is png]
|
26
|
+
# :bg : the background color of the image (color name,
|
27
|
+
# TeX color spec, or #aabbcc) [default is white]
|
28
|
+
# :fg : the foreground color of the image (color name,
|
29
|
+
# TeX color spec, or #aabbcc) [default is black]
|
30
|
+
# :resolution : the desired resolution in dpi (HxV)
|
31
|
+
# [default is 150x150]
|
32
|
+
#
|
33
|
+
# the following options are passed as-is to the generated <img /> tag
|
34
|
+
# :style : CSS styles to apply to the <img />
|
35
|
+
# :class : CSS class to apply to the <img />
|
36
|
+
# :id : HTML identifier
|
37
|
+
# :alt : alternate text for the <img />
|
38
|
+
#
|
39
|
+
def tex2img( *args, &block )
|
40
|
+
opts = args.last.instance_of?(Hash) ? args.pop : {}
|
41
|
+
name = args.first
|
42
|
+
raise 'TeX graphics must have a name' if name.nil?
|
43
|
+
|
44
|
+
text = capture_erb(&block)
|
45
|
+
return if text.empty?
|
46
|
+
|
47
|
+
defaults = ::Webby.site.tex2img
|
48
|
+
path = opts.getopt(:path, defaults[:path])
|
49
|
+
type = opts.getopt(:type, defaults[:type])
|
50
|
+
bg = opts.getopt(:bg, defaults[:bg])
|
51
|
+
fg = opts.getopt(:fg, defaults[:fg])
|
52
|
+
res = opts.getopt(:resolution, defaults[:resolution])
|
53
|
+
|
54
|
+
# fix color escaping
|
55
|
+
fg = fg =~ %r/^[a-zA-Z]+$/ ? fg : "\"#{fg}\""
|
56
|
+
bg = bg =~ %r/^[a-zA-Z]+$/ ? bg : "\"#{bg}\""
|
57
|
+
|
58
|
+
# generate the image filename based on the path, graph name, and type
|
59
|
+
# of image to generate
|
60
|
+
image_fn = path.nil? ? name.dup : ::File.join(path, name)
|
61
|
+
image_fn = ::File.join('', image_fn) << '.' << type
|
62
|
+
|
63
|
+
# generate the image using convert -- but first ensure that the
|
64
|
+
# path exists
|
65
|
+
out_dir = ::Webby.site.output_dir
|
66
|
+
out_file = ::File.join('..', out_dir, image_fn)
|
67
|
+
FileUtils.mkpath(::File.join(out_dir, path)) unless path.nil?
|
68
|
+
|
69
|
+
tex = <<-TEX
|
70
|
+
\\nonstopmode
|
71
|
+
\\documentclass{article}
|
72
|
+
\\usepackage[T1]{fontenc}
|
73
|
+
\\usepackage{amsmath,amsfonts,amssymb,wasysym,latexsym,marvosym,txfonts}
|
74
|
+
\\usepackage[pdftex]{color}
|
75
|
+
\\pagestyle{empty}
|
76
|
+
\\begin{document}
|
77
|
+
\\fontsize{12}{24}
|
78
|
+
\\selectfont
|
79
|
+
\\color{white}
|
80
|
+
\\pagecolor{black}
|
81
|
+
\\[
|
82
|
+
#{text}
|
83
|
+
\\]
|
84
|
+
\\end{document}
|
85
|
+
TEX
|
86
|
+
tex.gsub!(%r/\n\s+/, "\n").strip!
|
87
|
+
|
88
|
+
# make a temporarty directory to store all the TeX files
|
89
|
+
pwd = Dir.pwd
|
90
|
+
tmpdir = ::Webby::MkTemp.mktempdir('tex2img_XXXXXX')
|
91
|
+
|
92
|
+
begin
|
93
|
+
Dir.chdir(tmpdir)
|
94
|
+
File.open('out.tex', 'w') {|fd| fd.puts tex}
|
95
|
+
dev_null = test(?e, "/dev/null") ? "/dev/null" : "NUL:"
|
96
|
+
|
97
|
+
%x[pdflatex -interaction=batchmode out.tex &> #{dev_null}]
|
98
|
+
|
99
|
+
convert = "\\( -density #{res} out.pdf -trim +repage \\) "
|
100
|
+
convert << "\\( -clone 0 -negate -background #{fg} -channel A -combine \\) "
|
101
|
+
convert << "\\( -clone 0 -background #{bg} -channel A -combine \\) "
|
102
|
+
convert << "-delete 0 -compose dst-over -composite #{out_file}"
|
103
|
+
%x[convert #{convert} &> #{dev_null}]
|
104
|
+
ensure
|
105
|
+
Dir.chdir(pwd)
|
106
|
+
FileUtils.rm_rf(tmpdir) if test(?e, tmpdir)
|
107
|
+
end
|
108
|
+
|
109
|
+
# generate the HTML img tag to insert back into the document
|
110
|
+
out = "<img src=\"#{image_fn}\""
|
111
|
+
%w[class style id alt].each do |atr|
|
112
|
+
val = opts.getopt(atr)
|
113
|
+
next if val.nil?
|
114
|
+
out << " %s=\"%s\"" % [atr, val]
|
115
|
+
end
|
116
|
+
out << " />\n"
|
117
|
+
|
118
|
+
# put some guards around the output (specifically for textile)
|
119
|
+
out = _guard(out)
|
120
|
+
|
121
|
+
concat_erb(out, block.binding)
|
122
|
+
return
|
123
|
+
end
|
124
|
+
end # module TexImgHelper
|
125
|
+
|
126
|
+
if cmd_available?(%w[pdflatex --version]) \
|
127
|
+
and cmd_available?(%w[convert --help])
|
128
|
+
register(TexImgHelper)
|
129
|
+
end
|
130
|
+
|
131
|
+
end # module Webby::Helpers
|
132
|
+
|
133
|
+
# EOF
|
@@ -0,0 +1,63 @@
|
|
1
|
+
# This code was provided by Guillaume Carbonneau -- http://radr.ca/
|
2
|
+
# Many thanks for his support of Webby!
|
3
|
+
|
4
|
+
if try_require 'uv'
|
5
|
+
|
6
|
+
module Webby::Helpers
|
7
|
+
module UltraVioletHelper
|
8
|
+
|
9
|
+
# The +uv+ method applies syntax highlighting to source code embedded
|
10
|
+
# in a webpage. The UltraViolet highlighting engine is used for the HTML
|
11
|
+
# markup of the source code. The page sections to be highlighted are given
|
12
|
+
# as blocks of text to the +uv+ method.
|
13
|
+
#
|
14
|
+
# Options can be passed to the UltraViolet engine via attributes in the
|
15
|
+
# +uv+ method.
|
16
|
+
#
|
17
|
+
# <% uv( :lang => "ruby", :line_numbers => true ) do -%>
|
18
|
+
# # Initializer for the class.
|
19
|
+
# def initialize( string )
|
20
|
+
# @str = string
|
21
|
+
# end
|
22
|
+
# <% end -%>
|
23
|
+
#
|
24
|
+
# The supported UltraViolet options are the following:
|
25
|
+
#
|
26
|
+
# :lang : the language to highlight (ruby, c, html, ...)
|
27
|
+
# [defaults to 'ruby']
|
28
|
+
# :line_numbers : true or false [defaults to false]
|
29
|
+
# :theme : see list of available themes in ultraviolet
|
30
|
+
# [defaults to 'mac_classic']
|
31
|
+
#
|
32
|
+
# The defaults can be overridden for an entire site by changing the SITE.uv
|
33
|
+
# options hash in the Rakefile.
|
34
|
+
#
|
35
|
+
def uv( *args, &block )
|
36
|
+
opts = args.last.instance_of?(Hash) ? args.pop : {}
|
37
|
+
|
38
|
+
text = capture_erb(&block)
|
39
|
+
return if text.empty?
|
40
|
+
|
41
|
+
defaults = ::Webby.site.uv
|
42
|
+
lang = opts.getopt(:lang, defaults[:lang])
|
43
|
+
line_numbers = opts.getopt(:line_numbers, defaults[:line_numbers])
|
44
|
+
theme = opts.getopt(:theme, defaults[:theme])
|
45
|
+
|
46
|
+
out = %Q{<div class="UltraViolet">\n}
|
47
|
+
out << Uv.parse(text, "xhtml", lang, line_numbers, theme)
|
48
|
+
out << %Q{\n</div>}
|
49
|
+
|
50
|
+
# put some guards around the output (specifically for textile)
|
51
|
+
out = _guard(out)
|
52
|
+
|
53
|
+
concat_erb(out, block.binding)
|
54
|
+
return
|
55
|
+
end
|
56
|
+
end # module UltraVioletHelper
|
57
|
+
|
58
|
+
register(UltraVioletHelper)
|
59
|
+
|
60
|
+
end # module Webby::Helpers
|
61
|
+
end # try_require
|
62
|
+
|
63
|
+
# EOF
|
@@ -0,0 +1,241 @@
|
|
1
|
+
module Webby::Helpers
|
2
|
+
|
3
|
+
#
|
4
|
+
#
|
5
|
+
module UrlHelper
|
6
|
+
|
7
|
+
# call-seq:
|
8
|
+
# url_for( name, opts = {} )
|
9
|
+
#
|
10
|
+
# Creates a URL for the given _name_ and _opts_. If _name_ is a string
|
11
|
+
# then it is used as the URL base. If _name_ is a Resource then it is
|
12
|
+
# converted to a URL by calling its +url+ method.
|
13
|
+
#
|
14
|
+
# ==== Options
|
15
|
+
#
|
16
|
+
# * <tt>:escape</tt> -- determines whether the returned URL will be HTML escaped or not (+true+ by default)
|
17
|
+
# * <tt>:anchor</tt> -- specifies the anchor name to be appended to the path
|
18
|
+
#
|
19
|
+
# ==== Examples
|
20
|
+
#
|
21
|
+
# <%= url_for('/some/page.html') %>
|
22
|
+
# # => /some/page
|
23
|
+
#
|
24
|
+
# <%= url_for('/some/page.html', :anchor => 'tidbit') %>
|
25
|
+
# # => /some/page#tidbit
|
26
|
+
#
|
27
|
+
# <%= url_for(@page) %>
|
28
|
+
# # => /current/page.html
|
29
|
+
#
|
30
|
+
# <%= url_for(@page, :anchor => 'this&that') %>
|
31
|
+
# # => /current/page.html#this&that
|
32
|
+
#
|
33
|
+
def url_for( *args )
|
34
|
+
opts = Hash === args.last ? args.pop : {}
|
35
|
+
obj = args.first
|
36
|
+
|
37
|
+
anchor = opts.delete(:anchor)
|
38
|
+
escape = opts.has_key?(:escape) ? opts.delete(:escape) : true
|
39
|
+
|
40
|
+
url = Webby::Resources::Resource === obj ? obj.url : obj.to_s
|
41
|
+
url = escape_once(url) if escape
|
42
|
+
url << "#" << anchor if anchor
|
43
|
+
|
44
|
+
return url
|
45
|
+
end
|
46
|
+
|
47
|
+
# call-seq:
|
48
|
+
# url_for_page( :key => value, :url => {} )
|
49
|
+
#
|
50
|
+
# Creates a URL for the page identified by the set of <em>:key /
|
51
|
+
# value</em> pairs. The <em>:url</em> options are passed to the url_for
|
52
|
+
# method for final URL creation; see the url_for method for
|
53
|
+
# documentation on those options.
|
54
|
+
#
|
55
|
+
# The Resources::DB#find method is used to locate the page; see the find
|
56
|
+
# method for the available options.
|
57
|
+
#
|
58
|
+
# ==== Examples
|
59
|
+
#
|
60
|
+
# <%= url_for_page(:title => 'Funny Story', :anchor => 'punchline') %>
|
61
|
+
# # => /humor/funny_story.html#punchline
|
62
|
+
#
|
63
|
+
def url_for_page( opts = {} )
|
64
|
+
opts = opts.symbolize_keys
|
65
|
+
url_opts = opts.delete(:url)
|
66
|
+
|
67
|
+
p = @pages.find(opts)
|
68
|
+
raise ::Webby::Error,
|
69
|
+
"could not find requested page: #{opts.inspect}" if p.nil?
|
70
|
+
|
71
|
+
self.url_for(p, url_opts)
|
72
|
+
end
|
73
|
+
|
74
|
+
# call-seq:
|
75
|
+
# link_to( name, url, :attrs => {} )
|
76
|
+
#
|
77
|
+
# Create an HTTP anchor tag with
|
78
|
+
#
|
79
|
+
# url can be a url string, a page, :back, or nothing
|
80
|
+
#
|
81
|
+
# :attrs are used to generate HTML anchor tag attributes
|
82
|
+
#
|
83
|
+
# ==== Examples
|
84
|
+
#
|
85
|
+
# <%= link_to('Google', 'http://www.google.com/', :attrs => {:name => 'google'}) %>
|
86
|
+
# # => <a href="http://www.google.com/" name="google">Google</a>
|
87
|
+
#
|
88
|
+
# <%= link_to('A Page', @page, :anchor => 'blah') %>
|
89
|
+
# # => <a href="/a/page.html#blah">A Page</a>
|
90
|
+
#
|
91
|
+
def link_to( name, *args )
|
92
|
+
opts = Hash === args.last ? args.pop : {}
|
93
|
+
obj = args.first
|
94
|
+
attrs = opts.delete(:attrs)
|
95
|
+
|
96
|
+
url = case obj
|
97
|
+
when String, Webby::Resources::Resource
|
98
|
+
self.url_for(obj, opts)
|
99
|
+
when ::Webby::Paginator::Page
|
100
|
+
self.url_for(obj.url, opts)
|
101
|
+
when :back
|
102
|
+
'javascript:history.back()'
|
103
|
+
else
|
104
|
+
self.url_for(name, opts)
|
105
|
+
end
|
106
|
+
|
107
|
+
if attrs
|
108
|
+
html_opts = attrs.stringify_keys
|
109
|
+
href = html_opts.has_key? 'href'
|
110
|
+
attrs = tag_options(html_opts)
|
111
|
+
else
|
112
|
+
href = false
|
113
|
+
attrs = nil
|
114
|
+
end
|
115
|
+
|
116
|
+
href_attr = href ? nil : %Q(href="#{url}")
|
117
|
+
"<a #{href_attr}#{attrs}>#{name || h(url)}</a>"
|
118
|
+
end
|
119
|
+
|
120
|
+
# call-seq:
|
121
|
+
# link_to_page( name )
|
122
|
+
# link_to_page( :key => value )
|
123
|
+
# link_to_page( name, :key => value )
|
124
|
+
# link_to_page( page )
|
125
|
+
#
|
126
|
+
# Creates a link tag of the given _name_ using a URL created by finding
|
127
|
+
# the associated page from the key/value pairs. If the key/value pairs are
|
128
|
+
# omitted, the _name_ is used in conjunction with the default site +find_by+
|
129
|
+
# attribute. Unless changed by the user, the default +find_by+ attribute
|
130
|
+
# is the page title.
|
131
|
+
#
|
132
|
+
# Pages are found using key/value pairs. The key is any of the page
|
133
|
+
# attributes, and the value is what that attribute should be. Any number
|
134
|
+
# of key/value pairs can be included, but all values must equal the
|
135
|
+
# corresponding page attributes for a match to be found -- i.e. the
|
136
|
+
# comparisons are joined by AND operations to determine a match.
|
137
|
+
#
|
138
|
+
# In the absence of any key/value pairs -- just a name was given -- then
|
139
|
+
# the default site +find_by+ attribute is used, and the name is compared
|
140
|
+
# against this attribute from the page. The default +find_by+ attribue is
|
141
|
+
# set in the Rakefile or in the <tt>Webby.site.find_by</tt> parameter.
|
142
|
+
#
|
143
|
+
# Several options can be passed to the method to determin how URLs are
|
144
|
+
# created and to specify any HTML attributes on the returned link tag. The
|
145
|
+
# URL options are given as a hash to the <tt>:url</tt> key. The HTML
|
146
|
+
# attributes are given as a hash to the <tt>:attrs</tt> key.
|
147
|
+
#
|
148
|
+
# See the +url_for+ method for a desciption of the <tt>:url</tt> options.
|
149
|
+
# See the +link_to+ method for a description of the <tt>:attrs</tt>
|
150
|
+
# options.
|
151
|
+
#
|
152
|
+
# ==== Examples
|
153
|
+
#
|
154
|
+
# <%= link_to_page('Funny Story', :url => {:anchor => 'punchline'}) %>
|
155
|
+
# # => <a href="/humor/funny_story.html#punchline">Funny Story</a>
|
156
|
+
#
|
157
|
+
# <%= link_to_page('Hilarious', :title => 'Funny Story') %>
|
158
|
+
# # => <a href="/humor/funn_story.html">Hilarious</a>
|
159
|
+
#
|
160
|
+
def link_to_page( *args )
|
161
|
+
self.link_to(*_find_page(args))
|
162
|
+
rescue ::Webby::Error => err
|
163
|
+
return yield if block_given?
|
164
|
+
raise err
|
165
|
+
end
|
166
|
+
|
167
|
+
# call-seq:
|
168
|
+
# link_to_page_unless_current( name )
|
169
|
+
# link_to_page_unless_current( :key => value )
|
170
|
+
# link_to_page_unless_current( name, :key => value )
|
171
|
+
# link_to_page_unless_current( page )
|
172
|
+
#
|
173
|
+
# This function operates in the same fashion as the +link_to_page+ fuction
|
174
|
+
# with the exception that if the page to be linked to is the current page,
|
175
|
+
# then only the _name_ is rendered without an HTML anchor tag.
|
176
|
+
#
|
177
|
+
# ==== Examples
|
178
|
+
#
|
179
|
+
# <%= link_to_page_unless_current('Funny Story') %>
|
180
|
+
# # => <a href="/humor/funny_story.html">Funny Story</a>
|
181
|
+
#
|
182
|
+
# <%= link_to_page_unless_current(@page) %>
|
183
|
+
# # => This Page
|
184
|
+
#
|
185
|
+
def link_to_page_unless_current( *args )
|
186
|
+
name, page, link_opts = _find_page(args)
|
187
|
+
return name if @page == page
|
188
|
+
|
189
|
+
self.link_to(name, page, link_opts)
|
190
|
+
rescue ::Webby::Error => err
|
191
|
+
return yield if block_given?
|
192
|
+
raise err
|
193
|
+
end
|
194
|
+
|
195
|
+
|
196
|
+
private
|
197
|
+
|
198
|
+
# call-seq:
|
199
|
+
# _find_page( name, opts = {} )
|
200
|
+
# _find_page( :key => value, [:key => value, ...], opts = {} )
|
201
|
+
# _find_page( name, :key => value, [:key => value, ...], opts = {} )
|
202
|
+
# _find_page( page, opts = {} )
|
203
|
+
#
|
204
|
+
# Returns an array of the [name, page, options].
|
205
|
+
#
|
206
|
+
# ==== Options
|
207
|
+
#
|
208
|
+
# * <tt>:url</tt> -- hash of options for the +url_for+ method
|
209
|
+
# * <tt>:attrs</tt> -- hash of options for the +link_to+ method
|
210
|
+
#
|
211
|
+
def _find_page( args )
|
212
|
+
raise ArgumentError, 'wrong number of arguments (0 for 1)' if args.empty?
|
213
|
+
|
214
|
+
opts = Hash === args.last ? args.pop : {}
|
215
|
+
name = args.first
|
216
|
+
link_opts = opts.delete(:url) || {}
|
217
|
+
link_opts[:attrs] = opts.delete(:attrs)
|
218
|
+
|
219
|
+
if Webby::Resources::Resource === name
|
220
|
+
p, name = name, nil
|
221
|
+
elsif opts.empty? && name
|
222
|
+
opts[Webby.site.find_by.to_sym] = name
|
223
|
+
p = @pages.find(opts)
|
224
|
+
else
|
225
|
+
p = @pages.find(opts)
|
226
|
+
end
|
227
|
+
|
228
|
+
raise ::Webby::Error,
|
229
|
+
"could not find requested page: #{opts.inspect}" if p.nil?
|
230
|
+
|
231
|
+
name = p.title || p.filename if name.nil?
|
232
|
+
return [h(name), p, link_opts]
|
233
|
+
end
|
234
|
+
|
235
|
+
end # module UrlHelper
|
236
|
+
|
237
|
+
register(UrlHelper)
|
238
|
+
|
239
|
+
end # module Webby::Helpers
|
240
|
+
|
241
|
+
# EOF
|
@@ -0,0 +1,126 @@
|
|
1
|
+
|
2
|
+
module Webby
|
3
|
+
|
4
|
+
# The Journal class is used to output simple messages regarding the creation
|
5
|
+
# and updating of files when webby applications are run. The output messages
|
6
|
+
# will be color coded if the terminal supports the ANSI codes.
|
7
|
+
#
|
8
|
+
class Journal
|
9
|
+
|
10
|
+
attr_accessor :colorize
|
11
|
+
attr_reader :logger
|
12
|
+
|
13
|
+
# Create a new journal
|
14
|
+
#
|
15
|
+
def initialize
|
16
|
+
@logger = ::Logging::Logger[self]
|
17
|
+
@colorize = ENV.has_key?('TERM')
|
18
|
+
end
|
19
|
+
|
20
|
+
# Output a message of the given _type_ using the option _color_ code. The
|
21
|
+
# available codes are as follows:
|
22
|
+
#
|
23
|
+
# * black
|
24
|
+
# * red
|
25
|
+
# * green
|
26
|
+
# * yellow
|
27
|
+
# * blue
|
28
|
+
# * magenta
|
29
|
+
# * cyan
|
30
|
+
# * white
|
31
|
+
#
|
32
|
+
# The color is specified as a string or a symbol.
|
33
|
+
#
|
34
|
+
def typed_message( type, msg, color = nil )
|
35
|
+
type = type.to_s.rjust(13)
|
36
|
+
type = self.send(color, type) unless color.nil?
|
37
|
+
logger.info "#{type} #{msg.to_s}"
|
38
|
+
end
|
39
|
+
|
40
|
+
# Output a "create" message or an "update" message depending on whether
|
41
|
+
# the given _page_ already has a generated output file or not.
|
42
|
+
#
|
43
|
+
def create_or_update( page )
|
44
|
+
if test(?e, page.destination)
|
45
|
+
update(page.destination)
|
46
|
+
else
|
47
|
+
create(page.destination)
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
51
|
+
# Output a create message.
|
52
|
+
#
|
53
|
+
def create( msg )
|
54
|
+
typed_message('create', msg, (colorize ? :green : nil))
|
55
|
+
end
|
56
|
+
|
57
|
+
# Output an update message.
|
58
|
+
#
|
59
|
+
def update( msg )
|
60
|
+
typed_message('update', msg, (colorize ? :yellow : nil))
|
61
|
+
end
|
62
|
+
|
63
|
+
# Output a force message.
|
64
|
+
#
|
65
|
+
def force( msg )
|
66
|
+
typed_message('force', msg, (colorize ? :red : nil))
|
67
|
+
end
|
68
|
+
|
69
|
+
# Output a skip message.
|
70
|
+
#
|
71
|
+
def skip( msg )
|
72
|
+
typed_message('skip', msg, (colorize ? :yellow : nil))
|
73
|
+
end
|
74
|
+
|
75
|
+
# Output an exists message.
|
76
|
+
#
|
77
|
+
def exists( msg )
|
78
|
+
typed_message('exists', msg, (colorize ? :cyan : nil))
|
79
|
+
end
|
80
|
+
|
81
|
+
# Output an identical message.
|
82
|
+
#
|
83
|
+
def identical( msg )
|
84
|
+
typed_message('identical', msg, (colorize ? :cyan : nil))
|
85
|
+
end
|
86
|
+
|
87
|
+
[ [ :clear , 0 ],
|
88
|
+
[ :reset , 0 ], # synonym for :clear
|
89
|
+
[ :bold , 1 ],
|
90
|
+
[ :dark , 2 ],
|
91
|
+
[ :italic , 3 ], # not widely implemented
|
92
|
+
[ :underline , 4 ],
|
93
|
+
[ :underscore , 4 ], # synonym for :underline
|
94
|
+
[ :blink , 5 ],
|
95
|
+
[ :rapid_blink , 6 ], # not widely implemented
|
96
|
+
[ :negative , 7 ], # no reverse because of String#reverse
|
97
|
+
[ :concealed , 8 ],
|
98
|
+
[ :strikethrough, 9 ], # not widely implemented
|
99
|
+
[ :black , 30 ],
|
100
|
+
[ :red , 31 ],
|
101
|
+
[ :green , 32 ],
|
102
|
+
[ :yellow , 33 ],
|
103
|
+
[ :blue , 34 ],
|
104
|
+
[ :magenta , 35 ],
|
105
|
+
[ :cyan , 36 ],
|
106
|
+
[ :white , 37 ],
|
107
|
+
[ :on_black , 40 ],
|
108
|
+
[ :on_red , 41 ],
|
109
|
+
[ :on_green , 42 ],
|
110
|
+
[ :on_yellow , 43 ],
|
111
|
+
[ :on_blue , 44 ],
|
112
|
+
[ :on_magenta , 45 ],
|
113
|
+
[ :on_cyan , 46 ],
|
114
|
+
[ :on_white , 47 ] ].each do |name,code|
|
115
|
+
|
116
|
+
class_eval <<-CODE
|
117
|
+
def #{name.to_s}( str )
|
118
|
+
"\e[#{code}m\#{str}\e[0m"
|
119
|
+
end
|
120
|
+
CODE
|
121
|
+
end
|
122
|
+
|
123
|
+
end # class Journal
|
124
|
+
end # module Webby
|
125
|
+
|
126
|
+
# EOF
|