middleman 2.0.4 → 2.0.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (172) hide show
  1. data/CHANGELOG +8 -0
  2. data/lib/middleman.rb +7 -1
  3. data/lib/middleman/vendor/padrino-core-0.10.0/.document +5 -0
  4. data/lib/middleman/vendor/padrino-core-0.10.0/.gitignore +22 -0
  5. data/lib/middleman/vendor/padrino-core-0.10.0/LICENSE +20 -0
  6. data/lib/middleman/vendor/padrino-core-0.10.0/README.rdoc +294 -0
  7. data/lib/middleman/vendor/padrino-core-0.10.0/Rakefile +5 -0
  8. data/lib/middleman/vendor/padrino-core-0.10.0/bin/padrino +9 -0
  9. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core.rb +119 -0
  10. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/application.rb +259 -0
  11. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/application/rendering.rb +228 -0
  12. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/application/routing.rb +821 -0
  13. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/application/showexceptions.rb +18 -0
  14. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/caller.rb +45 -0
  15. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/cli/adapter.rb +24 -0
  16. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/cli/base.rb +152 -0
  17. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/cli/console.rb +20 -0
  18. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/cli/rake.rb +24 -0
  19. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/cli/rake_tasks.rb +59 -0
  20. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/command.rb +27 -0
  21. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/images/404.png +0 -0
  22. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/images/500.png +0 -0
  23. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/loader.rb +182 -0
  24. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/cz.yml +30 -0
  25. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/da.yml +30 -0
  26. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/de.yml +30 -0
  27. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/en.yml +30 -0
  28. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/es.yml +30 -0
  29. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/fr.yml +30 -0
  30. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/hu.yml +30 -0
  31. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/it.yml +37 -0
  32. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/ja.yml +30 -0
  33. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/nl.yml +30 -0
  34. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/no.yml +31 -0
  35. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/pl.yml +30 -0
  36. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/pt_br.yml +37 -0
  37. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/ru.yml +30 -0
  38. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/tr.yml +30 -0
  39. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/uk.yml +30 -0
  40. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/zh_cn.yml +30 -0
  41. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/locale/zh_tw.yml +30 -0
  42. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/logger.rb +344 -0
  43. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/mounter.rb +192 -0
  44. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/reloader.rb +247 -0
  45. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/router.rb +79 -0
  46. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/server.rb +70 -0
  47. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/support_lite.rb +135 -0
  48. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/tasks.rb +23 -0
  49. data/lib/middleman/vendor/padrino-core-0.10.0/lib/padrino-core/version.rb +15 -0
  50. data/lib/middleman/vendor/padrino-core-0.10.0/padrino-core.gemspec +38 -0
  51. data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/apps/.components +6 -0
  52. data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/apps/.gitignore +7 -0
  53. data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/apps/complex.rb +27 -0
  54. data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/apps/simple.rb +33 -0
  55. data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/dependencies/a.rb +9 -0
  56. data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/dependencies/b.rb +4 -0
  57. data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/dependencies/c.rb +1 -0
  58. data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/dependencies/circular/e.rb +13 -0
  59. data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/dependencies/circular/f.rb +2 -0
  60. data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/dependencies/circular/g.rb +2 -0
  61. data/lib/middleman/vendor/padrino-core-0.10.0/test/fixtures/dependencies/d.rb +4 -0
  62. data/lib/middleman/vendor/padrino-core-0.10.0/test/helper.rb +101 -0
  63. data/lib/middleman/vendor/padrino-core-0.10.0/test/test_application.rb +83 -0
  64. data/lib/middleman/vendor/padrino-core-0.10.0/test/test_core.rb +79 -0
  65. data/lib/middleman/vendor/padrino-core-0.10.0/test/test_dependencies.rb +44 -0
  66. data/lib/middleman/vendor/padrino-core-0.10.0/test/test_filters.rb +266 -0
  67. data/lib/middleman/vendor/padrino-core-0.10.0/test/test_logger.rb +91 -0
  68. data/lib/middleman/vendor/padrino-core-0.10.0/test/test_mounter.rb +176 -0
  69. data/lib/middleman/vendor/padrino-core-0.10.0/test/test_reloader_complex.rb +66 -0
  70. data/lib/middleman/vendor/padrino-core-0.10.0/test/test_reloader_simple.rb +97 -0
  71. data/lib/middleman/vendor/padrino-core-0.10.0/test/test_rendering.rb +437 -0
  72. data/lib/middleman/vendor/padrino-core-0.10.0/test/test_router.rb +146 -0
  73. data/lib/middleman/vendor/padrino-core-0.10.0/test/test_routing.rb +1491 -0
  74. data/lib/middleman/vendor/padrino-helpers-0.10.0/.document +5 -0
  75. data/lib/middleman/vendor/padrino-helpers-0.10.0/.gitignore +21 -0
  76. data/lib/middleman/vendor/padrino-helpers-0.10.0/LICENSE +20 -0
  77. data/lib/middleman/vendor/padrino-helpers-0.10.0/README.rdoc +239 -0
  78. data/lib/middleman/vendor/padrino-helpers-0.10.0/Rakefile +5 -0
  79. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers.rb +51 -0
  80. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/asset_tag_helpers.rb +288 -0
  81. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/form_builder/abstract_form_builder.rb +220 -0
  82. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/form_builder/standard_form_builder.rb +43 -0
  83. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/form_helpers.rb +446 -0
  84. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/format_helpers.rb +260 -0
  85. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/cz.yml +103 -0
  86. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/da.yml +91 -0
  87. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/de.yml +78 -0
  88. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/en.yml +103 -0
  89. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/es.yml +103 -0
  90. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/fr.yml +79 -0
  91. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/hu.yml +103 -0
  92. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/it.yml +85 -0
  93. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/ja.yml +103 -0
  94. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/nl.yml +78 -0
  95. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/no.yml +91 -0
  96. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/pl.yml +95 -0
  97. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/pt_br.yml +103 -0
  98. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/ru.yml +103 -0
  99. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/tr.yml +103 -0
  100. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/uk.yml +103 -0
  101. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/zh_cn.yml +103 -0
  102. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/locale/zh_tw.yml +103 -0
  103. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/number_helpers.rb +273 -0
  104. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/output_helpers.rb +128 -0
  105. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/output_helpers/abstract_handler.rb +103 -0
  106. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/output_helpers/erb_handler.rb +79 -0
  107. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/output_helpers/haml_handler.rb +64 -0
  108. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/output_helpers/slim_handler.rb +82 -0
  109. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/render_helpers.rb +40 -0
  110. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/tag_helpers.rb +59 -0
  111. data/lib/middleman/vendor/padrino-helpers-0.10.0/lib/padrino-helpers/translation_helpers.rb +21 -0
  112. data/lib/middleman/vendor/padrino-helpers-0.10.0/padrino-helpers.gemspec +27 -0
  113. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/app.rb +73 -0
  114. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/capture_concat.erb +14 -0
  115. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/capture_concat.haml +12 -0
  116. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/capture_concat.slim +13 -0
  117. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/content_for.erb +11 -0
  118. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/content_for.haml +9 -0
  119. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/content_for.slim +9 -0
  120. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/content_tag.erb +11 -0
  121. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/content_tag.haml +9 -0
  122. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/content_tag.slim +9 -0
  123. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/current_engine.erb +5 -0
  124. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/current_engine.haml +5 -0
  125. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/current_engine.slim +5 -0
  126. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/fields_for.erb +20 -0
  127. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/fields_for.haml +15 -0
  128. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/fields_for.slim +15 -0
  129. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/form_for.erb +56 -0
  130. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/form_for.haml +47 -0
  131. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/form_for.slim +47 -0
  132. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/form_tag.erb +56 -0
  133. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/form_tag.haml +45 -0
  134. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/form_tag.slim +45 -0
  135. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/link_to.erb +5 -0
  136. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/link_to.haml +4 -0
  137. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/link_to.slim +4 -0
  138. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/mail_to.erb +3 -0
  139. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/mail_to.haml +3 -0
  140. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/mail_to.slim +3 -0
  141. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/meta_tag.erb +3 -0
  142. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/meta_tag.haml +3 -0
  143. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/meta_tag.slim +3 -0
  144. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/partials/_erb.erb +1 -0
  145. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/partials/_haml.haml +1 -0
  146. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/partials/_slim.slim +1 -0
  147. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/simple_partial.erb +1 -0
  148. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/simple_partial.haml +1 -0
  149. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/markup_app/views/simple_partial.slim +1 -0
  150. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/app.rb +45 -0
  151. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/current_engine.haml +5 -0
  152. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/current_engines/_erb.erb +1 -0
  153. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/current_engines/_haml.haml +1 -0
  154. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/current_engines/_slim.slim +1 -0
  155. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/erb/test.erb +1 -0
  156. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/explicit_engine.haml +5 -0
  157. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/haml/test.haml +1 -0
  158. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/template/_user.haml +7 -0
  159. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/template/haml_template.haml +1 -0
  160. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/fixtures/render_app/views/template/some_template.haml +2 -0
  161. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/helper.rb +78 -0
  162. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/test_asset_tag_helpers.rb +320 -0
  163. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/test_form_builder.rb +998 -0
  164. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/test_form_helpers.rb +645 -0
  165. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/test_format_helpers.rb +227 -0
  166. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/test_number_helpers.rb +136 -0
  167. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/test_output_helpers.rb +133 -0
  168. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/test_render_helpers.rb +69 -0
  169. data/lib/middleman/vendor/padrino-helpers-0.10.0/test/test_tag_helpers.rb +100 -0
  170. data/lib/middleman/version.rb +1 -1
  171. data/middleman.gemspec +6 -2
  172. metadata +218 -67
data/CHANGELOG CHANGED
@@ -1,3 +1,11 @@
1
+ 2.0.5
2
+ =====
3
+ - Vendored Padrino 0.10.0
4
+
5
+ 2.0.4
6
+ =====
7
+ - Pulled out undocumented remote data feature into its own extension
8
+
1
9
  2.0.3
2
10
  =====
3
11
  - Pulled out undocumented Blog feature into its own extension
data/lib/middleman.rb CHANGED
@@ -55,6 +55,12 @@
55
55
  libdir = File.dirname(__FILE__)
56
56
  $LOAD_PATH.unshift(libdir) unless $LOAD_PATH.include?(libdir)
57
57
 
58
+ padrino_core_path = File.join(libdir, "middleman", "vendor", "padrino-core-0.10.0", "lib")
59
+ $LOAD_PATH.unshift(padrino_core_path) unless $LOAD_PATH.include?(padrino_core_path)
60
+
61
+ padrino_helpers_path = File.join(libdir, "middleman", "vendor", "padrino-helpers-0.10.0", "lib")
62
+ $LOAD_PATH.unshift(padrino_helpers_path) unless $LOAD_PATH.include?(padrino_helpers_path)
63
+
58
64
  # We're riding on Sinatra, so let's include it.
59
65
  require "sinatra/base"
60
66
 
@@ -164,7 +170,7 @@ module Middleman
164
170
 
165
171
  extensions.each do |spec|
166
172
  require spec.name
167
- $stderr.puts "require: #{spec.name}"
173
+ # $stderr.puts "require: #{spec.name}"
168
174
  end
169
175
  end
170
176
 
@@ -0,0 +1,5 @@
1
+ README.rdoc
2
+ lib/**/*.rb
3
+ bin/*
4
+ features/**/*.feature
5
+ LICENSE
@@ -0,0 +1,22 @@
1
+ ## MAC OS
2
+ .DS_Store
3
+
4
+ ## TEXTMATE
5
+ *.tmproj
6
+ tmtags
7
+
8
+ ## EMACS
9
+ *~
10
+ \#*
11
+ .\#*
12
+
13
+ ## VIM
14
+ *.swp
15
+
16
+ ## PROJECT::GENERAL
17
+ coverage
18
+ rdoc
19
+ pkg
20
+
21
+ ## PROJECT::SPECIFIC
22
+ test/tmp/*
@@ -0,0 +1,20 @@
1
+ Copyright (c) 2011 Padrino
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining
4
+ a copy of this software and associated documentation files (the
5
+ "Software"), to deal in the Software without restriction, including
6
+ without limitation the rights to use, copy, modify, merge, publish,
7
+ distribute, sublicense, and/or sell copies of the Software, and to
8
+ permit persons to whom the Software is furnished to do so, subject to
9
+ the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be
12
+ included in all copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
@@ -0,0 +1,294 @@
1
+ = Padrino (padrino-core)
2
+
3
+ Padrino is the godfather of Sinatra.
4
+
5
+ == Preface
6
+
7
+ Padrino is a ruby framework built upon the excellent {Sinatra Microframework}[http://www.sinatrarb.com].
8
+ Sinatra is a DSL for creating simple web applications in Ruby with speed and minimal effort.
9
+ This framework tries hard to make it as fun and easy as possible to code much more advanced web applications by
10
+ building upon the Sinatra philosophies and foundation.
11
+
12
+ == Introduction
13
+
14
+ Many people love Sinatra's simplicity and lightweight but often quickly come to miss a great deal
15
+ of functionality provided by other web frameworks such as Rails when building non-trivial applications.
16
+
17
+ Our goal with this framework is to match the essence of Sinatra and at the same time create a standard library
18
+ of tools, helpers and components that will make Sinatra suitable for more complex applications.
19
+
20
+ Here is a brief overview of functionality provided by the Padrino framework:
21
+
22
+ Agnostic:: Full support for many popular testing, templating, mocking, and data storage choices.
23
+ Generators:: Create Padrino applications, models, controllers i.e: padrino-gen project.
24
+ Mountable:: Unlike other ruby frameworks, principally designed for mounting multiple apps.
25
+ Routing:: Full url named routes, named params, respond_to support, before/after filter support.
26
+ Tag Helpers:: View helpers such as: tag, content_tag, input_tag.
27
+ Asset Helpers:: View helpers such as: link_to, image_tag, javascript_include_tag.
28
+ Form Helpers:: Builder support such as: form_tag, form_for, field_set_tag, text_field.
29
+ Text Helpers:: Useful formatting like: relative_time_ago, js_escape_html, sanitize_html.
30
+ Mailer:: Fast and simple delivery support for sending emails (akin to ActionMailer).
31
+ Admin:: Builtin Admin interface (like Django)
32
+ Logging:: Provide a unified logger that can interact with your ORM or any library.
33
+ Reloading:: Automatically reloads server code during development.
34
+ Localization:: Full support of I18n language localization and can auto-set user’s locale.
35
+
36
+ Keep in mind, the user will be able to pull in these components
37
+ {seperately into existing Sinatra applications}[http://www.padrinorb.com/guides/standalone-usage-in-sinatra]
38
+ or use them altogether for a comprehensive upgrade to Sinatra (a full-stack Padrino application).
39
+
40
+ == Installation
41
+
42
+ To install the padrino framework, simply grab the latest version from gemcutter:
43
+
44
+ $ sudo gem install padrino
45
+
46
+ This will install the necessary padrino gems to get you started.
47
+ Now you are ready to use this gem to enhance your sinatra projects or to create new Padrino applications.
48
+
49
+ For a more detailed look at Padrino installation,
50
+ check out the {Installation Guide}[http://www.padrinorb.com/guides/installation].
51
+
52
+ == Usage
53
+
54
+ Padrino is a framework which builds on the existing functionality and Sinatra and provides a variety of
55
+ additional tools and helpers to build upon that foundation. This README and Padrino documentation in general will focus
56
+ on the enhancements to the core Sinatra functionality. To use Padrino, one should be familiar with the basic
57
+ usage of Sinatra itself.
58
+
59
+ Please check out the
60
+ {Understanding Sinatra}[http://www.padrinorb.com/guides/underlying-sinatra-overview] guide
61
+ to learn more about these fundamentals.
62
+
63
+ For information on how to use a specific gem in isolation within an existing Sinatra project, checkout the guide for
64
+ {Using Padrino in Sinatra}[http://www.padrinorb.com/guides/standalone-usage-in-sinatra].
65
+
66
+ == Getting Started
67
+
68
+ Once a developer understands Sinatra, Padrino is quite easy to get comfortable with since Padrino is simply a superset
69
+ of existing Sinatra Functionality! Best way to get started with building Padrino applications is to read following resources:
70
+
71
+ * {Blog Tutorial}[http://www.padrinorb.com/guides/blog-tutorial] - Step-by-step guide to building a blog application with Padrino.
72
+ * {Quick Overview}[http://www.padrinorb.com/guides/basic-projects] - Outlines basic generation commands.
73
+ * {Padrino Examples}[http://www.padrinorb.com/guides/examples] - List of known Padrino applications which can serve as examples.
74
+
75
+ == Enhanced Base Application (padrino-core)
76
+
77
+ Sinatra has support for classes which can be extended to create an application: <tt>Sinatra::Base</tt> and <tt>Sinatra::Application</tt>
78
+ These classes can be extended in order to create a Sinatra web application. These classes provide support for all the basic
79
+ functionality afforded by Sinatra.
80
+
81
+ Padrino has support for an enhanced base application class <tt>Padrino::Application</tt>. <tt>Padrino::Application</tt>
82
+ expands the capabilities of Sinatra::Application and automatically provides the resulting application access to all of
83
+ the padrino framework's functionalities.
84
+
85
+ === Simple Application Definition
86
+
87
+ Let us first take a look at the simplest possible Padrino application:
88
+
89
+ # app.rb
90
+ PADRINO_ROOT = File.dirname(__FILE__) unless defined? PADRINO_ROOT
91
+ require 'padrino'
92
+ Padrino.load!
93
+
94
+ class SimpleApp < Padrino::Application
95
+ get '/' do
96
+ 'Hello world'
97
+ end
98
+
99
+ # and for read better we can divide with controllers
100
+ controller '/admin' do
101
+ get '/foo' do
102
+ 'Url is /admin/foo'
103
+ end
104
+ end
105
+ end
106
+
107
+ === Enhanced Route Definitions and Controllers
108
+
109
+ For a complete overview of the Padrino routing and controller system,
110
+ check out the {Routing and Controller guide}[http://www.padrinorb.com/guides/controllers].
111
+
112
+ Suppose we wanted to add additional routes to our Padrino application, and we want to organize the routes
113
+ within a more structured layout. Simply add a <tt>controllers</tt> or <tt>app/controllers</tt> folder and create a file as such:
114
+
115
+ # Simple Example
116
+ SimpleApp.controllers do
117
+ get "/test" do
118
+ "Text to return"
119
+ end
120
+ end
121
+
122
+ You can also do more complex route alias definitions:
123
+
124
+ # app/controllers/example.rb
125
+ SimpleApp.controllers :posts do
126
+ get :index do
127
+ ...
128
+ end
129
+
130
+ get :show, :with => :id do
131
+ # url generated is '/posts/show/:id'
132
+ # access params[:id]
133
+ end
134
+ end
135
+
136
+ as well as mapping the route aliases to an explicit url:
137
+
138
+ # app/controllers/example.rb
139
+ SimpleApp.controllers do
140
+ get :index, :map => '/index' do
141
+ ...
142
+ end
143
+
144
+ get :account, :map => '/the/accounts/:name/and/:id' do
145
+ # access params[:name] and params[:index]
146
+ end
147
+ end
148
+
149
+ and even configure the respond_to for each route:
150
+
151
+ # app/controllers/example.rb
152
+ SimpleApp.controllers :admin do
153
+ get :show, :with => :id, :provides => :js do
154
+ "Url is /admin/show/#{params[:id]}.#{params[:format]}"
155
+ end
156
+
157
+ get :other, with => [:id, :name], respond_to => [:html, :json] do
158
+ case content_type
159
+ when :js then ... end
160
+ when :json then ... end
161
+ end
162
+ end
163
+ end
164
+
165
+ or auto lookup for current locale or content_type
166
+
167
+ # app/controllers/example.rb
168
+ SimpleApp.controllers :admin do
169
+ get :show, :with => :id, :provides => [html, :js] do
170
+ render "admin/show"
171
+ end
172
+ end
173
+
174
+ When you visit :+show+ and your I18n.locale == :ru Padrino try to look for "admin/show.ru.js.*" if nothing match that path
175
+ they try "admin/show.ru.*" then "admin/show.js.*" if none match return "admin/show.erb" (or other engine i.e. haml)
176
+
177
+ For a complete overview of the routing and controller system, check out the
178
+ {Routing and Controller guide}[http://www.padrinorb.com/guides/controllers].
179
+
180
+ === Rendering
181
+
182
+ Unlike Sinatra, Padrino supports automatic template lookups such as:
183
+
184
+ # searches for 'account/index.{erb,haml,...}
185
+ render 'account/index'
186
+
187
+ This render does not require any template engine to be specified and will choose the first one that is discovered.
188
+ The existing render function works as well if an engine type should be specified:
189
+
190
+ # example.haml
191
+ render :haml, 'account/index'
192
+
193
+ For a complete overview of the Padrino rendering system, check out the
194
+ {Routing and Controller guide}[http://www.padrinorb.com/guides/controllers].
195
+
196
+ === Layout
197
+
198
+ With Padrino you can (like rails do) use for your custom layout, disable it
199
+
200
+ class SimpleApp < Padrino::Application
201
+
202
+ # Disable layouts
203
+ disable layout
204
+
205
+ # Use the layout located in views/layouts/custom.haml
206
+ layout :custom
207
+
208
+ For a complete overview of the layout functionality,
209
+ check out the {Routing and Controller guide}[http://www.padrinorb.com/guides/controllers].
210
+
211
+ === Mounting Applications
212
+
213
+ Padrino applications are all automatically mountable into other Padrino projects. This means that a given Padrino
214
+ project directory can easily mount multiple applications. This allows for better organization of complex applications,
215
+ re-usable applications that can be applied (i.e admin, auth, blog) and even more flexibility.
216
+
217
+ You can think of mountable applications as a 'full-featured' merb slice or rails engine. Instead of a separate construct,
218
+ any application can simply be packaged and mounted into another project.
219
+
220
+ Padrino stores application mounting information by default within <tt>config/apps.rb</tt>. This file is intended
221
+ to keep all information regarding what applications are mounted to which uri's.
222
+
223
+ For a complete look at mounting applications within a Padrino project,
224
+ check out the guide on {Mounting Applications}[http://www.padrinorb.com/guides/mounting-applications].
225
+
226
+ === Auto Load Paths
227
+
228
+ Padrino also intelligently supports requiring useful files within your application automatically and provides
229
+ functionality for easily splitting up your application into separate files. Padrino automatically requires <tt>config/database.rb</tt>
230
+ as a convention for establishing database connection. Also, any files within the <tt>lib</tt> folder will be required
231
+ automatically by Padrino.
232
+
233
+ For a complete overview of auto-loaded paths within Padrino,
234
+ check out the {Padrino Development Guide}[http://www.padrinorb.com/guides/development-and-terminal-commands].
235
+
236
+ === Application Logging
237
+
238
+ Padrino also supports robust logging capabilities. By default, logging information will
239
+ go to the STDOUT in development (for use in a console) and in an environment-specific log file <tt>log/development.log</tt>
240
+ in test and production environments.
241
+
242
+ To use the logger within a Padrino application, simply refer to the <tt>logger</tt> method accessible
243
+ within your app and any controller or views:
244
+
245
+ # controllers/example.rb
246
+ SimpleApp.controllers do
247
+ get("/test") { logger.info "This is a test" }
248
+ end
249
+
250
+ For a complete overview of Padrino logger functionality, check out the
251
+ {Padrino Development Guide}[http://www.padrinorb.com/guides/development-and-terminal-commands].
252
+
253
+ === Development Reloader
254
+
255
+ Padrino applications also have the enabled ability to automatically reload all changing application files without
256
+ the need to restart the server. Through the use of a customized Rack middleware, all files on the 'load path'
257
+ are monitored and reloaded whenever changes are applied.
258
+
259
+ This makes rapid development much easier and provides a better alternative to 'shotgun' or 'rerun'
260
+ which requires the application server to be restarted which makes requests take much longer to complete.
261
+
262
+ For a complete overview of code reloading in development,
263
+ check out the {Padrino Development Guide}[http://www.padrinorb.com/guides/development-and-terminal-commands].
264
+
265
+ === Terminal Commands
266
+
267
+ Padrino also comes equipped with multiple useful terminal commands which can be activated to perform
268
+ common tasks such as starting / stopping the application, executing the unit tests or activating an irb session.
269
+
270
+ The following commands are available:
271
+
272
+ # starts the app server (non-daemonized)
273
+ $ padrino start
274
+ # starts the app server (daemonized) with given port, environment and adapter
275
+ $ padrino start -d -p 3000 -e development -a thin
276
+
277
+ # Stops a daemonized app server
278
+ $ padrino stop
279
+
280
+ # Bootup the Padrino console (irb)
281
+ $ padrino console
282
+
283
+ # Run/List tasks
284
+ $ padrino rake
285
+
286
+ You can also create custom rake tasks as well. Using these commands can simplify common tasks
287
+ making development that much smoother.
288
+
289
+ For a complete overview of Padrino terminal commands, check out the
290
+ {Padrino Commands Guide}[http://www.padrinorb.com/guides/development-and-terminal-commands].
291
+
292
+ == Copyright
293
+
294
+ Copyright (c) 2011 Padrino. See LICENSE for details.
@@ -0,0 +1,5 @@
1
+ # coding:utf-8
2
+ RAKE_ROOT = __FILE__
3
+
4
+ require 'rubygems'
5
+ require File.expand_path(File.dirname(__FILE__) + '/../gem_rake_helper')
@@ -0,0 +1,9 @@
1
+ #!/usr/bin/env ruby
2
+ require 'rubygems' unless defined?(Gem)
3
+ require 'bundler/setup' if %w(Gemfile .components).all? { |f| File.exist?(f) }
4
+
5
+ padrino_core_path = File.expand_path('../../lib', __FILE__)
6
+ $:.unshift(padrino_core_path) if File.directory?(padrino_core_path) && !$:.include?(padrino_core_path)
7
+
8
+ require 'padrino-core/cli/base'
9
+ Padrino::Cli::Base.start(ARGV)
@@ -0,0 +1,119 @@
1
+ require 'sinatra/base'
2
+ require 'padrino-core/support_lite' unless defined?(SupportLite)
3
+
4
+ FileSet.glob_require('padrino-core/application/*.rb', __FILE__)
5
+ FileSet.glob_require('padrino-core/*.rb', __FILE__)
6
+
7
+ # Defines our Constants
8
+ PADRINO_ENV = ENV["PADRINO_ENV"] ||= ENV["RACK_ENV"] ||= "development" unless defined?(PADRINO_ENV)
9
+ PADRINO_ROOT = ENV["PADRINO_ROOT"] ||= File.dirname(Padrino.first_caller) unless defined?(PADRINO_ROOT)
10
+
11
+ module Padrino
12
+ class ApplicationLoadError < RuntimeError #:nodoc:
13
+ end
14
+
15
+ class << self
16
+ ##
17
+ # Helper method for file references.
18
+ #
19
+ # ==== Examples
20
+ #
21
+ # # Referencing a file in config called settings.yml
22
+ # Padrino.root("config", "settings.yml")
23
+ # # returns PADRINO_ROOT + "/config/setting.yml"
24
+ #
25
+ def root(*args)
26
+ File.expand_path(File.join(PADRINO_ROOT, *args))
27
+ end
28
+
29
+ ##
30
+ # Helper method that return PADRINO_ENV
31
+ #
32
+ def env
33
+ @_env ||= PADRINO_ENV.to_s.downcase.to_sym
34
+ end
35
+
36
+ ##
37
+ # Returns the resulting rack builder mapping each 'mounted' application
38
+ #
39
+ def application
40
+ raise ApplicationLoadError, "At least one app must be mounted!" unless Padrino.mounted_apps && Padrino.mounted_apps.any?
41
+ router = Padrino::Router.new
42
+ Padrino.mounted_apps.each { |app| app.map_onto(router) }
43
+
44
+ unless middleware.empty?
45
+ builder = Rack::Builder.new
46
+ middleware.each { |c,a,b| builder.use(c, *a, &b) }
47
+ builder.run(router)
48
+ builder.to_app
49
+ else
50
+ router
51
+ end
52
+ end
53
+
54
+ ##
55
+ # Configure Global Project Settings for mounted apps. These can be overloaded
56
+ # in each individual app's own personal configuration. This can be used like:
57
+ #
58
+ # Padrino.configure_apps do
59
+ # enable :sessions
60
+ # disable :raise_errors
61
+ # end
62
+ #
63
+ def configure_apps(&block)
64
+ @_global_configuration = block if block_given?
65
+ end
66
+
67
+ ###
68
+ # Returns project-wide configuration settings
69
+ # defined in 'configure_apps' block
70
+ #
71
+ def apps_configuration
72
+ @_global_configuration
73
+ end
74
+
75
+ ##
76
+ # Default encoding to UTF8.
77
+ #
78
+ def set_encoding
79
+ if RUBY_VERSION < '1.9'
80
+ $KCODE='u'
81
+ else
82
+ Encoding.default_external = Encoding::UTF_8
83
+ Encoding.default_internal = nil # Encoding::UTF_8
84
+ end
85
+ nil
86
+ end
87
+
88
+ ##
89
+ # Return bundle status :+:locked+ if .bundle/environment.rb exist :+:unlocked if Gemfile exist
90
+ # otherwise return nil
91
+ #
92
+ def bundle
93
+ return :locked if File.exist?(root('Gemfile.lock'))
94
+ return :unlocked if File.exist?(root("Gemfile"))
95
+ end
96
+
97
+ ##
98
+ # A Rack::Builder object that allows to add middlewares in front of all
99
+ # Padrino applications
100
+ #
101
+ def middleware
102
+ @middleware ||= []
103
+ end
104
+
105
+ ##
106
+ # Clears all previously configured middlewares
107
+ #
108
+ def clear_middleware!
109
+ @middleware = []
110
+ end
111
+
112
+ ##
113
+ # Convenience method for adding a Middleware to the whole padrino app.
114
+ #
115
+ def use(m, *args, &block)
116
+ middleware << [m, args, block]
117
+ end
118
+ end # self
119
+ end # Padrino