ramaze 0.0.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (174) hide show
  1. data/Rakefile +360 -0
  2. data/bin/ramaze +152 -0
  3. data/doc/CHANGELOG +2021 -0
  4. data/doc/COPYING +56 -0
  5. data/doc/COPYING.ja +51 -0
  6. data/doc/README +275 -0
  7. data/doc/TODO +33 -0
  8. data/doc/allison/LICENSE +184 -0
  9. data/doc/allison/README +37 -0
  10. data/doc/allison/allison.css +300 -0
  11. data/doc/allison/allison.gif +0 -0
  12. data/doc/allison/allison.js +307 -0
  13. data/doc/allison/allison.rb +287 -0
  14. data/doc/allison/cache/BODY +588 -0
  15. data/doc/allison/cache/CLASS_INDEX +4 -0
  16. data/doc/allison/cache/CLASS_PAGE +1 -0
  17. data/doc/allison/cache/FILE_INDEX +4 -0
  18. data/doc/allison/cache/FILE_PAGE +1 -0
  19. data/doc/allison/cache/FONTS +1 -0
  20. data/doc/allison/cache/FR_INDEX_BODY +1 -0
  21. data/doc/allison/cache/IMGPATH +1 -0
  22. data/doc/allison/cache/INDEX +1 -0
  23. data/doc/allison/cache/JAVASCRIPT +307 -0
  24. data/doc/allison/cache/METHOD_INDEX +4 -0
  25. data/doc/allison/cache/METHOD_LIST +1 -0
  26. data/doc/allison/cache/SRC_PAGE +1 -0
  27. data/doc/allison/cache/STYLE +322 -0
  28. data/doc/allison/cache/URL +1 -0
  29. data/examples/blog/main.rb +16 -0
  30. data/examples/blog/public/screen.css +106 -0
  31. data/examples/blog/src/controller.rb +50 -0
  32. data/examples/blog/src/element.rb +53 -0
  33. data/examples/blog/src/model.rb +29 -0
  34. data/examples/blog/template/edit.xhtml +6 -0
  35. data/examples/blog/template/index.xhtml +24 -0
  36. data/examples/blog/template/new.xhtml +5 -0
  37. data/examples/blog/template/view.xhtml +15 -0
  38. data/examples/blog/test/tc_entry.rb +18 -0
  39. data/examples/caching.rb +23 -0
  40. data/examples/element.rb +40 -0
  41. data/examples/hello.rb +23 -0
  42. data/examples/simple.rb +60 -0
  43. data/examples/templates/template/external.haml +21 -0
  44. data/examples/templates/template/external.liquid +28 -0
  45. data/examples/templates/template/external.mab +27 -0
  46. data/examples/templates/template/external.rhtml +29 -0
  47. data/examples/templates/template/external.rmze +24 -0
  48. data/examples/templates/template_erubis.rb +50 -0
  49. data/examples/templates/template_haml.rb +48 -0
  50. data/examples/templates/template_liquid.rb +64 -0
  51. data/examples/templates/template_markaby.rb +52 -0
  52. data/examples/templates/template_ramaze.rb +49 -0
  53. data/examples/whywiki/main.rb +56 -0
  54. data/examples/whywiki/template/edit.xhtml +14 -0
  55. data/examples/whywiki/template/show.xhtml +17 -0
  56. data/lib/proto/conf/benchmark.yaml +35 -0
  57. data/lib/proto/conf/debug.yaml +34 -0
  58. data/lib/proto/conf/live.yaml +33 -0
  59. data/lib/proto/conf/silent.yaml +31 -0
  60. data/lib/proto/conf/stage.yaml +33 -0
  61. data/lib/proto/main.rb +18 -0
  62. data/lib/proto/public/404.jpg +0 -0
  63. data/lib/proto/public/css/coderay.css +105 -0
  64. data/lib/proto/public/css/ramaze_error.css +42 -0
  65. data/lib/proto/public/error.xhtml +74 -0
  66. data/lib/proto/public/favicon.ico +0 -0
  67. data/lib/proto/public/js/jquery.js +1923 -0
  68. data/lib/proto/public/ramaze.png +0 -0
  69. data/lib/proto/src/controller/main.rb +7 -0
  70. data/lib/proto/src/element/page.rb +16 -0
  71. data/lib/proto/src/model.rb +5 -0
  72. data/lib/proto/template/index.xhtml +6 -0
  73. data/lib/ramaze.rb +317 -0
  74. data/lib/ramaze/adapter/mongrel.rb +111 -0
  75. data/lib/ramaze/adapter/webrick.rb +161 -0
  76. data/lib/ramaze/cache.rb +11 -0
  77. data/lib/ramaze/cache/memcached.rb +52 -0
  78. data/lib/ramaze/cache/memory.rb +6 -0
  79. data/lib/ramaze/cache/yaml_store.rb +37 -0
  80. data/lib/ramaze/controller.rb +10 -0
  81. data/lib/ramaze/dispatcher.rb +315 -0
  82. data/lib/ramaze/error.rb +11 -0
  83. data/lib/ramaze/gestalt.rb +108 -0
  84. data/lib/ramaze/global.rb +120 -0
  85. data/lib/ramaze/helper.rb +32 -0
  86. data/lib/ramaze/helper/aspect.rb +189 -0
  87. data/lib/ramaze/helper/auth.rb +120 -0
  88. data/lib/ramaze/helper/cache.rb +52 -0
  89. data/lib/ramaze/helper/feed.rb +135 -0
  90. data/lib/ramaze/helper/form.rb +204 -0
  91. data/lib/ramaze/helper/link.rb +80 -0
  92. data/lib/ramaze/helper/redirect.rb +48 -0
  93. data/lib/ramaze/helper/stack.rb +67 -0
  94. data/lib/ramaze/http_status.rb +66 -0
  95. data/lib/ramaze/inform.rb +166 -0
  96. data/lib/ramaze/snippets.rb +5 -0
  97. data/lib/ramaze/snippets/hash/keys_to_sym.rb +19 -0
  98. data/lib/ramaze/snippets/kernel/aquire.rb +22 -0
  99. data/lib/ramaze/snippets/kernel/autoreload.rb +79 -0
  100. data/lib/ramaze/snippets/kernel/caller_lines.rb +58 -0
  101. data/lib/ramaze/snippets/kernel/constant.rb +24 -0
  102. data/lib/ramaze/snippets/kernel/rescue_require.rb +12 -0
  103. data/lib/ramaze/snippets/kernel/self_method.rb +41 -0
  104. data/lib/ramaze/snippets/kernel/silently.rb +13 -0
  105. data/lib/ramaze/snippets/object/traits.rb +60 -0
  106. data/lib/ramaze/snippets/openstruct/temp.rb +10 -0
  107. data/lib/ramaze/snippets/string/DIVIDE.rb +16 -0
  108. data/lib/ramaze/snippets/string/camel_case.rb +14 -0
  109. data/lib/ramaze/snippets/string/snake_case.rb +12 -0
  110. data/lib/ramaze/snippets/symbol/to_proc.rb +14 -0
  111. data/lib/ramaze/snippets/thread/deadQUESTIONMARK.rb +11 -0
  112. data/lib/ramaze/store/default.rb +48 -0
  113. data/lib/ramaze/template.rb +102 -0
  114. data/lib/ramaze/template/amrita2.rb +40 -0
  115. data/lib/ramaze/template/erubis.rb +58 -0
  116. data/lib/ramaze/template/haml.rb +65 -0
  117. data/lib/ramaze/template/haml/actionview_stub.rb +20 -0
  118. data/lib/ramaze/template/liquid.rb +74 -0
  119. data/lib/ramaze/template/markaby.rb +68 -0
  120. data/lib/ramaze/template/ramaze.rb +177 -0
  121. data/lib/ramaze/template/ramaze/element.rb +166 -0
  122. data/lib/ramaze/template/ramaze/morpher.rb +156 -0
  123. data/lib/ramaze/tool/create.rb +70 -0
  124. data/lib/ramaze/tool/tidy.rb +71 -0
  125. data/lib/ramaze/trinity.rb +38 -0
  126. data/lib/ramaze/trinity/request.rb +244 -0
  127. data/lib/ramaze/trinity/response.rb +41 -0
  128. data/lib/ramaze/trinity/session.rb +129 -0
  129. data/lib/ramaze/version.rb +14 -0
  130. data/spec/spec_all.rb +73 -0
  131. data/spec/spec_helper.rb +215 -0
  132. data/spec/tc_adapter_mongrel.rb +24 -0
  133. data/spec/tc_adapter_webrick.rb +22 -0
  134. data/spec/tc_cache.rb +79 -0
  135. data/spec/tc_controller.rb +39 -0
  136. data/spec/tc_element.rb +100 -0
  137. data/spec/tc_error.rb +23 -0
  138. data/spec/tc_gestalt.rb +90 -0
  139. data/spec/tc_global.rb +46 -0
  140. data/spec/tc_helper_aspect.rb +65 -0
  141. data/spec/tc_helper_auth.rb +61 -0
  142. data/spec/tc_helper_cache.rb +81 -0
  143. data/spec/tc_helper_feed.rb +129 -0
  144. data/spec/tc_helper_form.rb +146 -0
  145. data/spec/tc_helper_link.rb +58 -0
  146. data/spec/tc_helper_redirect.rb +51 -0
  147. data/spec/tc_helper_stack.rb +55 -0
  148. data/spec/tc_morpher.rb +90 -0
  149. data/spec/tc_params.rb +84 -0
  150. data/spec/tc_request.rb +111 -0
  151. data/spec/tc_session.rb +56 -0
  152. data/spec/tc_store.rb +25 -0
  153. data/spec/tc_template_amrita2.rb +34 -0
  154. data/spec/tc_template_erubis.rb +41 -0
  155. data/spec/tc_template_haml.rb +44 -0
  156. data/spec/tc_template_liquid.rb +98 -0
  157. data/spec/tc_template_markaby.rb +74 -0
  158. data/spec/tc_template_ramaze.rb +54 -0
  159. data/spec/tc_tidy.rb +14 -0
  160. data/spec/template/amrita2/data.html +6 -0
  161. data/spec/template/amrita2/index.html +1 -0
  162. data/spec/template/amrita2/sum.html +1 -0
  163. data/spec/template/erubis/sum.rhtml +1 -0
  164. data/spec/template/haml/index.haml +5 -0
  165. data/spec/template/haml/with_vars.haml +4 -0
  166. data/spec/template/liquid/index.liquid +1 -0
  167. data/spec/template/liquid/products.liquid +45 -0
  168. data/spec/template/markaby/external.mab +8 -0
  169. data/spec/template/markaby/sum.mab +1 -0
  170. data/spec/template/ramaze/file_only.rmze +1 -0
  171. data/spec/template/ramaze/index.rmze +1 -0
  172. data/spec/template/ramaze/nested.rmze +1 -0
  173. data/spec/template/ramaze/sum.rmze +1 -0
  174. metadata +317 -0
@@ -0,0 +1,166 @@
1
+ # Copyright (c) 2006 Michael Fellinger m.fellinger@gmail.com
2
+ # All files in this distribution are subject to the terms of the Ruby license.
3
+
4
+ module Ramaze
5
+
6
+ # an Element is almost like an Controller, however, instead
7
+ # of connecting actions to templates it is only used in
8
+ # Ramaze::Template::Ramaze and can be used inside the
9
+ # templates of the Controller as a simple wrapper.
10
+ #
11
+ # Example:
12
+ #
13
+ # Your Element called Page:
14
+ #
15
+ # class Page < Element
16
+ # def render
17
+ # %{
18
+ # <html>
19
+ # <h1>
20
+ # #{@hash['title']}
21
+ # </h1>
22
+ # #{content}
23
+ # </html>
24
+ # }
25
+ # end
26
+ # end
27
+ #
28
+ # and one called SideBar
29
+ #
30
+ # class SideBar < Element
31
+ # def render
32
+ # %{
33
+ # <a href="http://something.com">something</a>
34
+ # }
35
+ # end
36
+ # end
37
+ #
38
+ # and your template (any template for any action):
39
+ #
40
+ # <Page title="Test">
41
+ # <SideBar />
42
+ # <p>
43
+ # Hello, World!
44
+ # </p>
45
+ # </Page>
46
+ #
47
+ # would result in:
48
+ #
49
+ # <html>
50
+ # <h1>
51
+ # Test
52
+ # </h1>
53
+ # <p>
54
+ # Hello, World!
55
+ # </p>
56
+ # </html>
57
+
58
+ class Element
59
+ extend Ramaze::Helper
60
+
61
+ helper :link, :redirect
62
+
63
+ attr_accessor :content
64
+
65
+ # this will be called by #transform, passes along the
66
+ # stuff inside the tags for the element
67
+
68
+ def initialize(content)
69
+ @content = content
70
+ end
71
+
72
+ # The method that will be called upon to render the things
73
+ # inside the element, you can access #content from here, which
74
+ # contains the contents between the tags.
75
+ #
76
+ # It should answer with a String.
77
+
78
+ def render *args
79
+ @content
80
+ end
81
+
82
+ class << self
83
+ # transforms all <Element> tags within the string, takes also
84
+ # a binding to be compatible to the transform-pipeline, won't have
85
+ # any use for it though.
86
+ #
87
+ # It also sets a instance-variable for you called @hash, which
88
+ # contains the parameters you gave the <Element> tag.
89
+ # See above for an example of writing and using them.
90
+
91
+ def transform string = '', binding = nil
92
+ string = string.to_s
93
+ matches = string.scan(/<([A-Z][a-zA-Z0-9]*)(.*?)?>/)
94
+
95
+ matches.each do |(klass, params)|
96
+ transformer = (params[-1,1] == '/' ? :without : :with)
97
+ string = send("transform_#{transformer}_content", string, klass)
98
+ end
99
+ string
100
+ end
101
+
102
+ # transforms elements like:
103
+ # <Page> some content </Page>
104
+
105
+ def transform_with_content(string, klass)
106
+ string.gsub(/<#{klass}( .*?)?>(.*?)<\/#{klass}>/m) do |m|
107
+ params, content = $1.to_s, $2.to_s
108
+ finish_transform(klass, params, content)
109
+ end
110
+ end
111
+
112
+ # transforms elements like:
113
+ # <Page />
114
+
115
+ def transform_without_content(string, klass)
116
+ string.gsub(/<#{klass}( .*?)?\/>/) do |m|
117
+ params = $1.to_s
118
+ finish_transform(klass, params, content = '')
119
+ end
120
+ end
121
+
122
+ # find the element, create an instance, pass it the content
123
+ # check if it responds to :render and set an instance-variable
124
+ # called @hash to hold the parameters passed to the element.
125
+ #
126
+ # Parameters look like:
127
+ # <Page foo="true"> bar </Page>
128
+ # <Page foo="true" />
129
+
130
+ def finish_transform(klass, params, content)
131
+ instance = constant(klass).new(content) rescue nil
132
+
133
+ return unless instance and instance.respond_to?(:render)
134
+
135
+ hash = demunge_passed_variables(params)
136
+ instance.instance_variable_set("@hash", hash)
137
+
138
+ instance.render
139
+ end
140
+
141
+ # basically processes stuff like
142
+ # 'foo="bar" foobar="baz"'
143
+ # do NOT pass actual objects that cannot be simply read as a string
144
+ # here, the information will be lost.
145
+ #
146
+ # Exceptions are true, false, Integers and Floats. They will appear
147
+ # in their real form (this again is also valid for strings that contain
148
+ # these values in a way that makes Integer/Float possible to parse them)
149
+ #
150
+ # Just remember, walk like a duck, talk like a duck.
151
+
152
+ def demunge_passed_variables(string)
153
+ string.scan(/\s?(.*?)="(.*?)"/).inject({}) do |hash, (key, value)|
154
+ value =
155
+ case value
156
+ when 'true' : true
157
+ when 'false' : false
158
+ else
159
+ Integer(value) rescue Float(value) rescue value
160
+ end
161
+ hash.merge key => value
162
+ end
163
+ end
164
+ end
165
+ end
166
+ end
@@ -0,0 +1,156 @@
1
+ # Copyright (c) 2006 Michael Fellinger m.fellinger@gmail.com
2
+ # All files in this distribution are subject to the terms of the Ruby license.
3
+
4
+ module Ramaze
5
+
6
+ # This applies a morphing-replace for the template.
7
+ #
8
+ # To use the functionality of Morpher you will need to have hpricot
9
+ # installed, you will get one error in case you don't and the method
10
+ # will be replaced by a stub that simply returns the template.
11
+ #
12
+ # The method first checks if you use any morphers and just skips
13
+ # the step if you don't, this should give quite some speedup for
14
+ # smaller templates that don't use this functionality at all.
15
+ # the check works by searching the morphs with appended '='
16
+ # in the template. There may be a few cases where this won't work
17
+ # since we cannot make any assumptions on the format.
18
+ #
19
+ # If you want to turn this functionality off, either remove Morpher
20
+ # from:
21
+ # Ramaze::Template::Ramaze.trait[:transform_pipeline]
22
+ # or do:
23
+ # Ramaze::Morpher.trait[:morphs] = {}
24
+ #
25
+ # The latter is a tad slower, but i mention the possibility in case you
26
+ # find good use for it.
27
+ #
28
+ # You can add your own morphers in Ramaze::Morpher.trait[:morphs]
29
+ #
30
+ # For Example:
31
+ #
32
+ # Morpher.trait[:morphs]['if'] = '<?r %morph %expression ?>%content<?r end ?>'
33
+ #
34
+ # Now, assuming that some tag in your template is '<a if="@foo">x</a>'
35
+ #
36
+ # %morph stands for the name of your morph: 'if'
37
+ # %expression is the stuff you write in the attribute: '@foo'
38
+ # %content is the tag without the attribute (and all inside): '<a>x</a>'
39
+
40
+ class Morpher
41
+
42
+ # Use this trait to define your custom morphs.
43
+ trait :morphs => {
44
+ 'if' => '<?r %morph %expression ?>%content<?r end ?>',
45
+ 'unless' => '<?r %morph %expression ?>%content<?r end ?>',
46
+ 'for' => '<?r %morph %expression ?>%content<?r end ?>',
47
+ 'each' => '<?r %expression.%morph do |_e| ?>%content<?r end ?>',
48
+ 'times' => '<?r %expression.%morph do |_t| ?>%content<?r end ?>',
49
+ }
50
+
51
+ # Since the functionality is best explained by examples, here they come.
52
+ #
53
+ # Example:
54
+ #
55
+ # if:
56
+ # <div if="@name">#@name</div>
57
+ # morphs to:
58
+ # <?r if @name ?>
59
+ # <div>#@name</div>
60
+ # <?r end ?>
61
+ #
62
+ # unless:
63
+ # <div unless="@name">No Name</div>
64
+ # morphs to:
65
+ # <?r unless @name ?>
66
+ # <div>No Name</div>
67
+ # <?r end ?>
68
+ #
69
+ # for:
70
+ # <div for="name in @names">#{name}</div>
71
+ # morphs to:
72
+ # <?r for name in @names ?>
73
+ # <div>#{name}</div>
74
+ # <?r end ?>
75
+ #
76
+ # times:
77
+ # <div times="3">#{_t}<div>
78
+ # morphs to:
79
+ # <?r 3.times do |_t| ?>
80
+ # <div>#{_t}</div>
81
+ # <?r end ?>
82
+ #
83
+ # each:
84
+ # <div each="[1,2,3]">#{_e}</div>
85
+ # morphs to:
86
+ # <?r [1,2,3].each do |_e| ?>
87
+ # <div>#{_e}</div>
88
+ # <?r end ?>
89
+ #
90
+ # The latter two examples show you also one standard introduced by a
91
+ # limitation of the replacement-system.
92
+ #
93
+ # When you yield a value, please name it by the first character(s) of
94
+ # the morphs name, with an underscore prefixed.
95
+ #
96
+ # for each an _e, for times a _t.
97
+ #
98
+ # This is by far not the best way to handle it and might lead to problems
99
+ # due to the lack of proper scoping in ruby (if you define an _e or _t
100
+ # before the block it will be overwritten).
101
+ #
102
+ # So please be careful, I tried to come up with something that is both easy
103
+ # to write and doesn't look outright awful while keeping an easy to remember
104
+ # mnemonic.
105
+ #
106
+ # TODO:
107
+ # - Add pure Ruby implementation as a fall-back.
108
+
109
+ def self.transform template, bound = nil
110
+ morphs =
111
+ trait[:morphs].map{|k,v| [k.to_s, v.to_s]}.select do |(k,v)|
112
+ template.to_s.include?("#{k}=")
113
+ end
114
+
115
+ morphs = Hash[*morphs.flatten]
116
+
117
+ return template if morphs.empty?
118
+
119
+ require 'hpricot'
120
+
121
+ hp = Hpricot(template)
122
+ hp.each_child do |child|
123
+ if child.elem?
124
+ morphs.each_pair do |morph, replacement|
125
+ if expression = child[morph]
126
+ old = child.to_html
127
+ child.remove_attribute(morph)
128
+
129
+ replacement = replacement.dup.
130
+ gsub('%morph', morph).
131
+ gsub('%expression', expression).
132
+ gsub('%content', child.to_html)
133
+
134
+ template.gsub!(old, replacement)
135
+ end
136
+ end
137
+ end
138
+ end
139
+
140
+ template
141
+
142
+ rescue LoadError => ex
143
+ error "Please install hpricot (for example via `gem install hpricot`) to get morphing"
144
+
145
+ # replace this method with a stub that only returns the template.
146
+
147
+ self.class_eval do
148
+ def self.transform(template, bound = nil)
149
+ template
150
+ end
151
+ end
152
+
153
+ template
154
+ end
155
+ end
156
+ end
@@ -0,0 +1,70 @@
1
+ # Copyright (c) 2006 Michael Fellinger m.fellinger@gmail.com
2
+ # All files in this distribution are subject to the terms of the Ruby license.
3
+
4
+ require 'fileutils'
5
+ require 'yaml'
6
+
7
+ module Ramaze
8
+ module Tool
9
+
10
+ # Create is a simple class used to create new projects based on the proto
11
+ # directory.
12
+ #
13
+ # It is primarly used for this command:
14
+ #
15
+ # ramaze --create project
16
+ #
17
+ # where project is the directory you want the content put into.
18
+
19
+ class Create
20
+ class << self
21
+
22
+ # a method to create a new project by copying the contents of lib/proto
23
+ # to the position you specify (project)
24
+ #
25
+ # It is just a nice wrapper showing you what files/directories are put
26
+ # in place.
27
+
28
+ def create project
29
+ @basedir = ::Ramaze::BASEDIR / 'proto'
30
+ @destdir = Dir.pwd / project
31
+
32
+ puts "creating project: #{project}"
33
+
34
+ FileUtils.mkdir_p(project)
35
+
36
+ puts "copy proto to new project (#@destdir)..."
37
+
38
+ directories, files =
39
+ Dir[@basedir / '**' / '*'].partition{|f| File.directory?(f) }
40
+
41
+ create_dirs(*directories)
42
+ copy_files(*files)
43
+
44
+ end
45
+
46
+ # create the directories recursivly
47
+
48
+ def create_dirs(*dirs)
49
+ dirs.each do |dir|
50
+ dest = dir.gsub(@basedir, @destdir)
51
+
52
+ puts "create directory: '#{dest}'"
53
+ FileUtils.mkdir_p(dest)
54
+ end
55
+ end
56
+
57
+ # copy the files over
58
+
59
+ def copy_files(*files)
60
+ files.each do |file|
61
+ dest = file.gsub(@basedir, @destdir)
62
+
63
+ puts "copy file: '#{dest}'"
64
+ FileUtils.cp(file, dest)
65
+ end
66
+ end
67
+ end
68
+ end
69
+ end
70
+ end
@@ -0,0 +1,71 @@
1
+ # Copyright (c) 2006 Michael Fellinger m.fellinger@gmail.com
2
+ # All files in this distribution are subject to the terms of the Ruby license.
3
+
4
+ module Ramaze
5
+ module Tool
6
+
7
+ # This is a simple tool to tidy up your html-output
8
+ # in general this is just used by setting Global.tidy = true
9
+
10
+ module Tidy
11
+
12
+ # set this to define a custom path to your tidy.so
13
+ trait[:path] ||= `locate libtidy.so`.strip
14
+
15
+ # dirty html in, tidy html out
16
+ # To activate Tidy for everything outgoing (given that it is of
17
+ # Content-Type text/html) set
18
+ # Global.tidy = true
19
+ # there is almost no speed-tradeoff but makes debugging a much
20
+ # nicer experience ;)
21
+ #
22
+ # Example:
23
+ #
24
+ # include Ramaze::Tool::Tidy
25
+ # puts tidy('<html></html>')
26
+ #
27
+ # # results in something like:
28
+ #
29
+ # <html>
30
+ # <head>
31
+ # <meta name="generator" content="HTML Tidy for Linux/x86 (vers 1 September 2005), see www.w3.org" />
32
+ # <title></title>
33
+ # </head>
34
+ # <body></body>
35
+ # </html>
36
+
37
+ def self.tidy html, options = {}
38
+ require 'tidy'
39
+
40
+ ::Tidy.path = trait[:path]
41
+
42
+ defaults = {
43
+ :output_xml => true,
44
+ :input_encoding => :utf8,
45
+ :output_encoding => :utf8,
46
+ :indent_spaces => 2,
47
+ :indent => :auto,
48
+ :markup => :yes,
49
+ :wrap => 500
50
+ }
51
+
52
+ ::Tidy.open(:show_warnings => true) do |tidy|
53
+ defaults.merge(options).each do |key, value|
54
+ tidy.options.send("#{key}=", value.to_s)
55
+ end
56
+ tidy.clean(html)
57
+ end
58
+ rescue LoadError => ex
59
+ puts ex
60
+ puts "cannot load 'tidy', please `gem install tidy`"
61
+ puts "you can find it at http://tidy.rubyforge.org/"
62
+ end
63
+
64
+ # calls self#tidy
65
+
66
+ def tidy html, options = {}
67
+ Ramaze::Tool::Tidy.tidy(html, options)
68
+ end
69
+ end
70
+ end
71
+ end