giraffesoft-webby 0.9.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (233) hide show
  1. data/History.txt +218 -0
  2. data/README.rdoc +92 -0
  3. data/Rakefile +62 -0
  4. data/bin/webby +41 -0
  5. data/bin/webby-gen +41 -0
  6. data/examples/blog/Sitefile +7 -0
  7. data/examples/blog/tasks/blog.rake +72 -0
  8. data/examples/blog/templates/atom_feed.erb +40 -0
  9. data/examples/blog/templates/blog/month.erb +22 -0
  10. data/examples/blog/templates/blog/post.erb +16 -0
  11. data/examples/blog/templates/blog/year.erb +22 -0
  12. data/examples/presentation/Sitefile +10 -0
  13. data/examples/presentation/content/css/uv/twilight.css +137 -0
  14. data/examples/presentation/content/presentation/_sample_code.txt +10 -0
  15. data/examples/presentation/content/presentation/index.txt +63 -0
  16. data/examples/presentation/content/presentation/s5/blank.gif +0 -0
  17. data/examples/presentation/content/presentation/s5/bodybg.gif +0 -0
  18. data/examples/presentation/content/presentation/s5/framing.css +23 -0
  19. data/examples/presentation/content/presentation/s5/iepngfix.htc +42 -0
  20. data/examples/presentation/content/presentation/s5/opera.css +7 -0
  21. data/examples/presentation/content/presentation/s5/outline.css +15 -0
  22. data/examples/presentation/content/presentation/s5/pretty.css +86 -0
  23. data/examples/presentation/content/presentation/s5/print.css +25 -0
  24. data/examples/presentation/content/presentation/s5/s5-core.css +9 -0
  25. data/examples/presentation/content/presentation/s5/slides.css +3 -0
  26. data/examples/presentation/content/presentation/s5/slides.js +553 -0
  27. data/examples/presentation/layouts/presentation.txt +43 -0
  28. data/examples/presentation/templates/_code_partial.erb +13 -0
  29. data/examples/presentation/templates/presentation.erb +40 -0
  30. data/examples/tumblog/Sitefile +9 -0
  31. data/examples/tumblog/content/css/tumblog.css +308 -0
  32. data/examples/tumblog/content/images/tumblog/permalink.gif +0 -0
  33. data/examples/tumblog/content/images/tumblog/rss.gif +0 -0
  34. data/examples/tumblog/content/tumblog/200806/the-noble-chicken/index.txt +12 -0
  35. data/examples/tumblog/content/tumblog/200807/historical-perspectives-on-the-classic-chicken-joke/index.txt +12 -0
  36. data/examples/tumblog/content/tumblog/200807/mad-city-chickens/index.txt +10 -0
  37. data/examples/tumblog/content/tumblog/200807/the-wisdom-of-the-dutch/index.txt +11 -0
  38. data/examples/tumblog/content/tumblog/200807/up-a-tree/index.txt +13 -0
  39. data/examples/tumblog/content/tumblog/index.txt +37 -0
  40. data/examples/tumblog/content/tumblog/rss.txt +37 -0
  41. data/examples/tumblog/layouts/tumblog/default.txt +44 -0
  42. data/examples/tumblog/layouts/tumblog/post.txt +15 -0
  43. data/examples/tumblog/lib/tumblog_helper.rb +32 -0
  44. data/examples/tumblog/tasks/tumblog.rake +30 -0
  45. data/examples/tumblog/templates/atom_feed.erb +40 -0
  46. data/examples/tumblog/templates/tumblog/conversation.erb +12 -0
  47. data/examples/tumblog/templates/tumblog/link.erb +10 -0
  48. data/examples/tumblog/templates/tumblog/photo.erb +13 -0
  49. data/examples/tumblog/templates/tumblog/post.erb +12 -0
  50. data/examples/tumblog/templates/tumblog/quote.erb +11 -0
  51. data/examples/webby/Sitefile +19 -0
  52. data/examples/webby/content/communicate/index.txt +28 -0
  53. data/examples/webby/content/css/background.gif +0 -0
  54. data/examples/webby/content/css/blueprint/print.css +76 -0
  55. data/examples/webby/content/css/blueprint/screen.css +696 -0
  56. data/examples/webby/content/css/coderay.css +96 -0
  57. data/examples/webby/content/css/site.css +196 -0
  58. data/examples/webby/content/css/uv/twilight.css +137 -0
  59. data/examples/webby/content/index.txt +37 -0
  60. data/examples/webby/content/learn/index.txt +28 -0
  61. data/examples/webby/content/reference/index.txt +204 -0
  62. data/examples/webby/content/release-notes/index.txt +21 -0
  63. data/examples/webby/content/release-notes/rel-0-9-0/index.txt +74 -0
  64. data/examples/webby/content/release-notes/rel-0-9-1/index.txt +93 -0
  65. data/examples/webby/content/release-notes/rel-0-9-2/index.txt +14 -0
  66. data/examples/webby/content/release-notes/rel-0-9-3/index.txt +47 -0
  67. data/examples/webby/content/robots.txt +6 -0
  68. data/examples/webby/content/script/jquery.corner.js +152 -0
  69. data/examples/webby/content/script/jquery.js +31 -0
  70. data/examples/webby/content/sitemap.txt +31 -0
  71. data/examples/webby/content/tips_and_tricks/index.txt +97 -0
  72. data/examples/webby/content/tutorial/index.txt +135 -0
  73. data/examples/webby/content/user-manual/index.txt +419 -0
  74. data/examples/webby/layouts/default.txt +49 -0
  75. data/examples/webby/templates/page.erb +10 -0
  76. data/examples/website/Sitefile +7 -0
  77. data/examples/website/content/css/blueprint/ie.css +26 -0
  78. data/examples/website/content/css/blueprint/plugins/buttons/icons/cross.png +0 -0
  79. data/examples/website/content/css/blueprint/plugins/buttons/icons/key.png +0 -0
  80. data/examples/website/content/css/blueprint/plugins/buttons/icons/tick.png +0 -0
  81. data/examples/website/content/css/blueprint/plugins/buttons/readme.txt +32 -0
  82. data/examples/website/content/css/blueprint/plugins/buttons/screen.css +97 -0
  83. data/examples/website/content/css/blueprint/plugins/fancy-type/readme.txt +14 -0
  84. data/examples/website/content/css/blueprint/plugins/fancy-type/screen.css +71 -0
  85. data/examples/website/content/css/blueprint/plugins/link-icons/icons/doc.png +0 -0
  86. data/examples/website/content/css/blueprint/plugins/link-icons/icons/email.png +0 -0
  87. data/examples/website/content/css/blueprint/plugins/link-icons/icons/external.png +0 -0
  88. data/examples/website/content/css/blueprint/plugins/link-icons/icons/feed.png +0 -0
  89. data/examples/website/content/css/blueprint/plugins/link-icons/icons/im.png +0 -0
  90. data/examples/website/content/css/blueprint/plugins/link-icons/icons/pdf.png +0 -0
  91. data/examples/website/content/css/blueprint/plugins/link-icons/icons/visited.png +0 -0
  92. data/examples/website/content/css/blueprint/plugins/link-icons/icons/xls.png +0 -0
  93. data/examples/website/content/css/blueprint/plugins/link-icons/readme.txt +18 -0
  94. data/examples/website/content/css/blueprint/plugins/link-icons/screen.css +40 -0
  95. data/examples/website/content/css/blueprint/plugins/rtl/readme.txt +10 -0
  96. data/examples/website/content/css/blueprint/plugins/rtl/screen.css +109 -0
  97. data/examples/website/content/css/blueprint/print.css +30 -0
  98. data/examples/website/content/css/blueprint/screen.css +251 -0
  99. data/examples/website/content/css/blueprint/src/forms.css +49 -0
  100. data/examples/website/content/css/blueprint/src/grid.css +212 -0
  101. data/examples/website/content/css/blueprint/src/grid.png +0 -0
  102. data/examples/website/content/css/blueprint/src/ie.css +59 -0
  103. data/examples/website/content/css/blueprint/src/print.css +85 -0
  104. data/examples/website/content/css/blueprint/src/reset.css +38 -0
  105. data/examples/website/content/css/blueprint/src/typography.css +105 -0
  106. data/examples/website/content/css/coderay.css +111 -0
  107. data/examples/website/content/css/site.css +67 -0
  108. data/examples/website/content/index.txt +19 -0
  109. data/examples/website/layouts/default.txt +61 -0
  110. data/examples/website/lib/breadcrumbs.rb +28 -0
  111. data/examples/website/templates/_partial.erb +10 -0
  112. data/examples/website/templates/page.erb +18 -0
  113. data/lib/webby.rb +233 -0
  114. data/lib/webby/apps.rb +12 -0
  115. data/lib/webby/apps/generator.rb +276 -0
  116. data/lib/webby/apps/main.rb +258 -0
  117. data/lib/webby/auto_builder.rb +157 -0
  118. data/lib/webby/builder.rb +172 -0
  119. data/lib/webby/core_ext/enumerable.rb +11 -0
  120. data/lib/webby/core_ext/hash.rb +28 -0
  121. data/lib/webby/core_ext/kernel.rb +26 -0
  122. data/lib/webby/core_ext/string.rb +163 -0
  123. data/lib/webby/core_ext/time.rb +9 -0
  124. data/lib/webby/filters.rb +85 -0
  125. data/lib/webby/filters/basepath.rb +97 -0
  126. data/lib/webby/filters/erb.rb +9 -0
  127. data/lib/webby/filters/haml.rb +18 -0
  128. data/lib/webby/filters/markdown.rb +16 -0
  129. data/lib/webby/filters/maruku.rb +16 -0
  130. data/lib/webby/filters/outline.rb +309 -0
  131. data/lib/webby/filters/sass.rb +17 -0
  132. data/lib/webby/filters/slides.rb +56 -0
  133. data/lib/webby/filters/textile.rb +16 -0
  134. data/lib/webby/filters/tidy.rb +76 -0
  135. data/lib/webby/filters/wiki_words.rb +14 -0
  136. data/lib/webby/helpers.rb +30 -0
  137. data/lib/webby/helpers/capture_helper.rb +141 -0
  138. data/lib/webby/helpers/coderay_helper.rb +69 -0
  139. data/lib/webby/helpers/graphviz_helper.rb +136 -0
  140. data/lib/webby/helpers/tag_helper.rb +65 -0
  141. data/lib/webby/helpers/tex_img_helper.rb +133 -0
  142. data/lib/webby/helpers/ultraviolet_helper.rb +63 -0
  143. data/lib/webby/helpers/url_helper.rb +241 -0
  144. data/lib/webby/journal.rb +126 -0
  145. data/lib/webby/link_validator.rb +160 -0
  146. data/lib/webby/renderer.rb +389 -0
  147. data/lib/webby/resources.rb +137 -0
  148. data/lib/webby/resources/db.rb +251 -0
  149. data/lib/webby/resources/layout.rb +54 -0
  150. data/lib/webby/resources/meta_file.rb +211 -0
  151. data/lib/webby/resources/page.rb +81 -0
  152. data/lib/webby/resources/partial.rb +85 -0
  153. data/lib/webby/resources/resource.rb +201 -0
  154. data/lib/webby/resources/static.rb +36 -0
  155. data/lib/webby/stelan/mktemp.rb +135 -0
  156. data/lib/webby/stelan/paginator.rb +165 -0
  157. data/lib/webby/tasks/build.rake +27 -0
  158. data/lib/webby/tasks/create.rake +25 -0
  159. data/lib/webby/tasks/deploy.rake +22 -0
  160. data/lib/webby/tasks/growl.rake +16 -0
  161. data/lib/webby/tasks/validate.rake +19 -0
  162. data/spec/core_ext/hash_spec.rb +47 -0
  163. data/spec/core_ext/string_spec.rb +110 -0
  164. data/spec/core_ext/time_spec.rb +19 -0
  165. data/spec/data/hooligans/bad_meta_data_1.txt +34 -0
  166. data/spec/data/hooligans/bad_meta_data_2.txt +34 -0
  167. data/spec/data/html/anchor.html +11 -0
  168. data/spec/data/html/external.html +10 -0
  169. data/spec/data/html/invalid-relative.html +10 -0
  170. data/spec/data/html/relative-anchor.html +10 -0
  171. data/spec/data/html/relative-invalid-anchor.html +10 -0
  172. data/spec/data/html/relative.html +10 -0
  173. data/spec/data/outline/basic.out +81 -0
  174. data/spec/data/outline/basic.txt +25 -0
  175. data/spec/data/outline/no_clobber.out +86 -0
  176. data/spec/data/outline/numbering.out +81 -0
  177. data/spec/data/outline/numbering_only.out +21 -0
  178. data/spec/data/outline/toc_range_1.out +66 -0
  179. data/spec/data/outline/toc_range_2.out +55 -0
  180. data/spec/data/outline/toc_style.out +81 -0
  181. data/spec/data/site/Sitefile +9 -0
  182. data/spec/data/site/content/_partial.txt +10 -0
  183. data/spec/data/site/content/css/coderay.css +111 -0
  184. data/spec/data/site/content/css/site.css +67 -0
  185. data/spec/data/site/content/css/tumblog.css +308 -0
  186. data/spec/data/site/content/images/tumblog/permalink.gif +0 -0
  187. data/spec/data/site/content/images/tumblog/rss.gif +0 -0
  188. data/spec/data/site/content/index.txt +19 -0
  189. data/spec/data/site/content/photos.txt +21 -0
  190. data/spec/data/site/content/tumblog/200806/the-noble-chicken/index.txt +12 -0
  191. data/spec/data/site/content/tumblog/200807/historical-perspectives-on-the-classic-chicken-joke/index.txt +12 -0
  192. data/spec/data/site/content/tumblog/200807/mad-city-chickens/index.txt +10 -0
  193. data/spec/data/site/content/tumblog/200807/the-wisdom-of-the-dutch/index.txt +11 -0
  194. data/spec/data/site/content/tumblog/200807/up-a-tree/index.txt +13 -0
  195. data/spec/data/site/content/tumblog/index.txt +37 -0
  196. data/spec/data/site/content/tumblog/rss.txt +37 -0
  197. data/spec/data/site/layouts/default.txt +58 -0
  198. data/spec/data/site/layouts/tumblog/default.txt +44 -0
  199. data/spec/data/site/layouts/tumblog/post.txt +15 -0
  200. data/spec/data/site/lib/breadcrumbs.rb +28 -0
  201. data/spec/data/site/lib/tumblog_helper.rb +32 -0
  202. data/spec/data/site/tasks/tumblog.rake +30 -0
  203. data/spec/data/site/templates/_partial.erb +10 -0
  204. data/spec/data/site/templates/atom_feed.erb +40 -0
  205. data/spec/data/site/templates/page.erb +18 -0
  206. data/spec/data/site/templates/presentation.erb +40 -0
  207. data/spec/data/site/templates/tumblog/conversation.erb +12 -0
  208. data/spec/data/site/templates/tumblog/link.erb +10 -0
  209. data/spec/data/site/templates/tumblog/photo.erb +13 -0
  210. data/spec/data/site/templates/tumblog/post.erb +12 -0
  211. data/spec/data/site/templates/tumblog/quote.erb +11 -0
  212. data/spec/spec.opts +1 -0
  213. data/spec/spec_helper.rb +58 -0
  214. data/spec/webby/apps/generator_spec.rb +117 -0
  215. data/spec/webby/apps/main_spec.rb +88 -0
  216. data/spec/webby/filters/basepath_spec.rb +167 -0
  217. data/spec/webby/filters/maruku_spec.rb +31 -0
  218. data/spec/webby/filters/outline_spec.rb +92 -0
  219. data/spec/webby/filters/textile_spec.rb +31 -0
  220. data/spec/webby/helpers/capture_helper_spec.rb +56 -0
  221. data/spec/webby/link_validator_spec.rb +154 -0
  222. data/spec/webby/renderer_spec.rb +139 -0
  223. data/spec/webby/resources/db_spec.rb +250 -0
  224. data/spec/webby/resources/layout_spec.rb +83 -0
  225. data/spec/webby/resources/meta_file_spec.rb +171 -0
  226. data/spec/webby/resources/page_spec.rb +111 -0
  227. data/spec/webby/resources/partial_spec.rb +58 -0
  228. data/spec/webby/resources/resource_spec.rb +219 -0
  229. data/spec/webby/resources/static_spec.rb +49 -0
  230. data/spec/webby/resources_spec.rb +69 -0
  231. data/tasks/mswin32.rake +38 -0
  232. data/tasks/website.rake +37 -0
  233. 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&amp;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