waves-stable 0.7.7

Sign up to get free protection for your applications and to get access to all the features.
Files changed (185) hide show
  1. data/app/Rakefile +72 -0
  2. data/app/bin/waves-console +4 -0
  3. data/app/bin/waves-server +4 -0
  4. data/app/configurations/development.rb.erb +31 -0
  5. data/app/configurations/mapping.rb.erb +14 -0
  6. data/app/configurations/production.rb.erb +31 -0
  7. data/app/controllers/.gitignore +0 -0
  8. data/app/doc/.gitignore +0 -0
  9. data/app/helpers/.gitignore +0 -0
  10. data/app/lib/application.rb.erb +5 -0
  11. data/app/lib/tasks/.gitignore +0 -0
  12. data/app/log/.gitignore +0 -0
  13. data/app/models/.gitignore +0 -0
  14. data/app/public/css/.gitignore +0 -0
  15. data/app/public/flash/.gitignore +0 -0
  16. data/app/public/images/.gitignore +0 -0
  17. data/app/public/javascript/.gitignore +0 -0
  18. data/app/schema/migrations/.gitignore +0 -0
  19. data/app/startup.rb +5 -0
  20. data/app/templates/errors/not_found_404.mab +2 -0
  21. data/app/templates/errors/server_error_500.mab +2 -0
  22. data/app/templates/layouts/default.mab +14 -0
  23. data/app/tmp/sessions/.gitignore +0 -0
  24. data/app/views/.gitignore +0 -0
  25. data/bin/waves +84 -0
  26. data/bin/waves-console +4 -0
  27. data/bin/waves-server +4 -0
  28. data/doc/HISTORY +44 -0
  29. data/doc/LICENSE +22 -0
  30. data/lib/commands/waves-console.rb +21 -0
  31. data/lib/commands/waves-server.rb +55 -0
  32. data/lib/controllers/base.rb +11 -0
  33. data/lib/controllers/mixin.rb +165 -0
  34. data/lib/dispatchers/base.rb +67 -0
  35. data/lib/dispatchers/default.rb +81 -0
  36. data/lib/foundations/default.rb +27 -0
  37. data/lib/foundations/simple.rb +30 -0
  38. data/lib/helpers/asset_helper.rb +67 -0
  39. data/lib/helpers/common.rb +66 -0
  40. data/lib/helpers/default.rb +13 -0
  41. data/lib/helpers/form.rb +40 -0
  42. data/lib/helpers/formatting.rb +30 -0
  43. data/lib/helpers/model.rb +33 -0
  44. data/lib/helpers/number_helper.rb +25 -0
  45. data/lib/helpers/tag_helper.rb +58 -0
  46. data/lib/helpers/url_helper.rb +77 -0
  47. data/lib/helpers/view.rb +24 -0
  48. data/lib/layers/default_errors.rb +26 -0
  49. data/lib/layers/inflect/english.rb +24 -0
  50. data/lib/layers/inflect/english/rules.rb +88 -0
  51. data/lib/layers/inflect/english/string.rb +24 -0
  52. data/lib/layers/mvc.rb +54 -0
  53. data/lib/layers/orm/active_record.rb +92 -0
  54. data/lib/layers/orm/active_record/migrations/empty.rb.erb +9 -0
  55. data/lib/layers/orm/active_record/tasks/generate.rb +28 -0
  56. data/lib/layers/orm/active_record/tasks/schema.rb +22 -0
  57. data/lib/layers/orm/data_mapper.rb +38 -0
  58. data/lib/layers/orm/filebase.rb +22 -0
  59. data/lib/layers/orm/migration.rb +79 -0
  60. data/lib/layers/orm/sequel.rb +86 -0
  61. data/lib/layers/orm/sequel/migrations/empty.rb.erb +9 -0
  62. data/lib/layers/orm/sequel/tasks/generate.rb +28 -0
  63. data/lib/layers/orm/sequel/tasks/schema.rb +16 -0
  64. data/lib/layers/simple.rb +32 -0
  65. data/lib/layers/simple_errors.rb +23 -0
  66. data/lib/mapping/mapping.rb +289 -0
  67. data/lib/mapping/pretty_urls.rb +96 -0
  68. data/lib/renderers/erubis.rb +63 -0
  69. data/lib/renderers/haml.rb +45 -0
  70. data/lib/renderers/markaby.rb +33 -0
  71. data/lib/renderers/mixin.rb +50 -0
  72. data/lib/runtime/application.rb +69 -0
  73. data/lib/runtime/blackboard.rb +57 -0
  74. data/lib/runtime/configuration.rb +185 -0
  75. data/lib/runtime/console.rb +20 -0
  76. data/lib/runtime/debugger.rb +9 -0
  77. data/lib/runtime/logger.rb +59 -0
  78. data/lib/runtime/mime_types.rb +22 -0
  79. data/lib/runtime/request.rb +78 -0
  80. data/lib/runtime/response.rb +40 -0
  81. data/lib/runtime/response_mixin.rb +38 -0
  82. data/lib/runtime/response_proxy.rb +30 -0
  83. data/lib/runtime/server.rb +107 -0
  84. data/lib/runtime/session.rb +66 -0
  85. data/lib/tasks/cluster.rb +26 -0
  86. data/lib/tasks/gem.rb +31 -0
  87. data/lib/tasks/generate.rb +80 -0
  88. data/lib/utilities/hash.rb +31 -0
  89. data/lib/utilities/inflect.rb +110 -0
  90. data/lib/utilities/integer.rb +24 -0
  91. data/lib/utilities/module.rb +21 -0
  92. data/lib/utilities/object.rb +25 -0
  93. data/lib/utilities/proc.rb +16 -0
  94. data/lib/utilities/string.rb +49 -0
  95. data/lib/utilities/symbol.rb +10 -0
  96. data/lib/utilities/tempfile.rb +9 -0
  97. data/lib/views/base.rb +9 -0
  98. data/lib/views/mixin.rb +110 -0
  99. data/lib/waves.rb +84 -0
  100. data/samples/blog/Rakefile +14 -0
  101. data/samples/blog/bin/waves-console +3 -0
  102. data/samples/blog/bin/waves-server +3 -0
  103. data/samples/blog/configurations/development.rb +31 -0
  104. data/samples/blog/configurations/mapping.rb +23 -0
  105. data/samples/blog/configurations/production.rb +30 -0
  106. data/samples/blog/doc/EMTPY +0 -0
  107. data/samples/blog/lib/application.rb +5 -0
  108. data/samples/blog/models/comment.rb +14 -0
  109. data/samples/blog/models/entry.rb +14 -0
  110. data/samples/blog/public/css/site.css +2 -0
  111. data/samples/blog/public/javascript/site.js +13 -0
  112. data/samples/blog/schema/migrations/001_initial_schema.rb +17 -0
  113. data/samples/blog/schema/migrations/002_add_comments.rb +18 -0
  114. data/samples/blog/schema/migrations/templates/empty.rb.erb +9 -0
  115. data/samples/blog/startup.rb +6 -0
  116. data/samples/blog/templates/comment/add.mab +10 -0
  117. data/samples/blog/templates/comment/list.mab +6 -0
  118. data/samples/blog/templates/entry/editor.mab +13 -0
  119. data/samples/blog/templates/entry/list.mab +11 -0
  120. data/samples/blog/templates/entry/show.mab +9 -0
  121. data/samples/blog/templates/entry/summary.mab +5 -0
  122. data/samples/blog/templates/errors/not_found_404.mab +2 -0
  123. data/samples/blog/templates/errors/server_error_500.mab +2 -0
  124. data/samples/blog/templates/layouts/default.mab +17 -0
  125. data/verify/app_generation/helpers.rb +24 -0
  126. data/verify/app_generation/startup.rb +39 -0
  127. data/verify/blackboard/blackboard_verify.rb +92 -0
  128. data/verify/blackboard/helpers.rb +5 -0
  129. data/verify/configurations/attributes.rb +37 -0
  130. data/verify/configurations/helpers.rb +1 -0
  131. data/verify/configurations/rack_integration.rb +29 -0
  132. data/verify/controllers/base.rb +37 -0
  133. data/verify/controllers/helpers.rb +13 -0
  134. data/verify/controllers/interface.rb +51 -0
  135. data/verify/core/helpers.rb +3 -0
  136. data/verify/core/utilities.rb +177 -0
  137. data/verify/foundations/default.rb +86 -0
  138. data/verify/foundations/default_application/Rakefile +14 -0
  139. data/verify/foundations/default_application/bin/waves-console +3 -0
  140. data/verify/foundations/default_application/bin/waves-server +3 -0
  141. data/verify/foundations/default_application/configurations/development.rb +26 -0
  142. data/verify/foundations/default_application/configurations/mapping.rb +14 -0
  143. data/verify/foundations/default_application/configurations/production.rb +30 -0
  144. data/verify/foundations/default_application/controllers/default.rb +15 -0
  145. data/verify/foundations/default_application/controllers/loaded.rb +15 -0
  146. data/verify/foundations/default_application/defaultapplication.db +0 -0
  147. data/verify/foundations/default_application/helpers/loaded.rb +10 -0
  148. data/verify/foundations/default_application/lib/application.rb +5 -0
  149. data/verify/foundations/default_application/models/default.rb +13 -0
  150. data/verify/foundations/default_application/models/loaded.rb +13 -0
  151. data/verify/foundations/default_application/schema/migrations/templates/empty.rb.erb +9 -0
  152. data/verify/foundations/default_application/startup.rb +7 -0
  153. data/verify/foundations/default_application/templates/errors/not_found_404.mab +2 -0
  154. data/verify/foundations/default_application/templates/errors/server_error_500.mab +2 -0
  155. data/verify/foundations/default_application/templates/layouts/default.mab +14 -0
  156. data/verify/foundations/default_application/views/default.rb +7 -0
  157. data/verify/foundations/default_application/views/loaded.rb +15 -0
  158. data/verify/foundations/helpers.rb +1 -0
  159. data/verify/foundations/simple.rb +25 -0
  160. data/verify/helpers.rb +76 -0
  161. data/verify/layers/data_mapper/association_verify.rb +87 -0
  162. data/verify/layers/default_errors.rb +29 -0
  163. data/verify/layers/helpers.rb +1 -0
  164. data/verify/layers/migration.rb +33 -0
  165. data/verify/layers/sequel/model.rb +41 -0
  166. data/verify/mapping/always.rb +19 -0
  167. data/verify/mapping/filters.rb +65 -0
  168. data/verify/mapping/handle.rb +24 -0
  169. data/verify/mapping/helpers.rb +7 -0
  170. data/verify/mapping/matches.rb +27 -0
  171. data/verify/mapping/named.rb +29 -0
  172. data/verify/mapping/options.rb +17 -0
  173. data/verify/mapping/path.rb +40 -0
  174. data/verify/mapping/response_proxy.rb +50 -0
  175. data/verify/mapping/threaded.rb +25 -0
  176. data/verify/requests/helpers.rb +16 -0
  177. data/verify/requests/request.rb +73 -0
  178. data/verify/requests/response.rb +59 -0
  179. data/verify/requests/session.rb +54 -0
  180. data/verify/views/helpers.rb +1 -0
  181. data/verify/views/rendering.rb +34 -0
  182. data/verify/views/templates/foo.erb +0 -0
  183. data/verify/views/templates/moo.erb +0 -0
  184. data/verify/views/templates/moo.mab +0 -0
  185. metadata +439 -0
@@ -0,0 +1,63 @@
1
+ require 'erubis'
2
+
3
+ module Erubis # :nodoc:
4
+
5
+ # This is added to the Erubis Content class to allow the same helper methods
6
+ # to be used with both Markaby and Erubis.
7
+ class Context
8
+ include Waves::Helpers::UrlHelper
9
+ include Waves::Helpers::TagHelper
10
+ include Waves::Helpers::AssetHelper
11
+ include Waves::Helpers::NumberHelper
12
+
13
+ def <<(s)
14
+ eval("_buf", @binding).concat s # add to rendered output
15
+ end
16
+
17
+ def capture
18
+ eval("_context.push(_buf); _buf = ''", @binding) #ignore output from that eval, will be added via "<<"
19
+ result = Erubis::Eruby.new(yield).result @binding
20
+ eval("_buf = _context.pop", @binding)
21
+ result
22
+ end
23
+
24
+ def render(eruby)
25
+ unless @binding
26
+ @binding = binding
27
+ eval("_buf = ''; _context = []", @binding)
28
+ end
29
+ eruby.result @binding
30
+ end
31
+
32
+ end
33
+
34
+ end
35
+
36
+ module Waves
37
+
38
+ module Renderers
39
+
40
+ class Erubis
41
+
42
+ include Renderers::Mixin
43
+
44
+ extension :erb
45
+
46
+ def self.render( path, assigns )
47
+ eruby = ::Erubis::Eruby.new( template( path ) )
48
+ helper = helper( path )
49
+ context = ::Erubis::Context.new
50
+ context.meta_eval { include( helper ) ; }
51
+ context.instance_eval do
52
+ assigns.each do |key,val|
53
+ instance_variable_set("@#{key}",val)
54
+ end
55
+ end
56
+ context.render(eruby)
57
+ end
58
+
59
+ end
60
+
61
+ end
62
+
63
+ end
@@ -0,0 +1,45 @@
1
+ require 'haml'
2
+
3
+ module Waves
4
+
5
+ module Renderers
6
+
7
+ class Scope
8
+ include Waves::Helpers::Common
9
+ include Waves::Helpers::Model
10
+ include Waves::Helpers::TagHelper
11
+ include Waves::Helpers::UrlHelper
12
+ include Waves::Helpers::View
13
+
14
+ def <<(s)
15
+ eval("@haml_buffer", @binding).push_text s # add to rendered output
16
+ end
17
+
18
+ def capture(&block)
19
+ capture_haml(nil, &block)
20
+ end
21
+
22
+ end
23
+
24
+ class Haml
25
+
26
+ include Renderers::Mixin
27
+
28
+ extension :haml
29
+
30
+ def self.render( path, assigns )
31
+ engine = ::Haml::Engine.new( template( path ) )
32
+ scope = Scope.new
33
+ helper = helper( path )
34
+ scope.meta_eval { include( helper ) }
35
+ scope.instance_eval do
36
+ assigns.each { |key,val| instance_variable_set("@#{key}",val) unless key == :request }
37
+ end
38
+ engine.render(scope, assigns)
39
+ end
40
+
41
+ end
42
+
43
+ end
44
+
45
+ end
@@ -0,0 +1,33 @@
1
+ require 'markaby'
2
+
3
+ ::Markaby::Builder.set( :indent, 2 )
4
+
5
+ module Waves
6
+
7
+ module Renderers
8
+
9
+ class Markaby
10
+
11
+ include Renderers::Mixin
12
+
13
+ extension :mab
14
+
15
+ # capture needed here for content fragments, otherwise
16
+ # you'll just get the last tag's output ...
17
+ # def self.capture( template )
18
+ # "capture { #{template} }"
19
+ # end
20
+
21
+ def self.render( path, assigns )
22
+ builder = ::Markaby::Builder.new( assigns )
23
+ helper = helper( path )
24
+ builder.meta_eval { include( helper ) }
25
+ builder.instance_eval( template( path ) )
26
+ builder.to_s
27
+ end
28
+
29
+ end
30
+
31
+ end
32
+
33
+ end
@@ -0,0 +1,50 @@
1
+ module Waves
2
+
3
+ module Renderers # :nodoc:
4
+
5
+ # The renderers mixin provides a number of methods to simplify writing new renderers.
6
+ # Just include this in your Renderer class and write your render method.
7
+ module Mixin
8
+
9
+ # Adds the following methods to the target class:
10
+ #
11
+ # - extension: allows you to set or get the extension used by this renderer.
12
+ #
13
+ # Renderers::Markaby.extension 'foo' # tell Waves to use .foo as Markaby extension
14
+ #
15
+ # - filename: generate a filename for the template based on a logical path.
16
+ # - template: read the template from the file corresponding to the given logical path.
17
+ # - helper: return a helper module that corresponds to the given logical path.
18
+ #
19
+ def self.included(target)
20
+ class << target
21
+
22
+ def extension(*args)
23
+ return @extension if args.length == 0
24
+ @extension = args.first
25
+ end
26
+
27
+ def filename(path)
28
+ :templates / "#{path}.#{self.extension}"
29
+ end
30
+
31
+ def render(path,args=nil)
32
+ end
33
+
34
+ def template( path )
35
+ File.read( filename( path ) )
36
+ end
37
+
38
+ def helper( path )
39
+ Waves.application.helpers[
40
+ File.basename( File.dirname( path ) ).camel_case ]
41
+ end
42
+ end
43
+ end
44
+
45
+
46
+ end
47
+
48
+ end
49
+
50
+ end
@@ -0,0 +1,69 @@
1
+ # See the README for an overview.
2
+ module Waves
3
+
4
+ class << self
5
+
6
+ # Access the principal Waves application.
7
+ attr_reader :application
8
+
9
+ # Register a module as a Waves application.
10
+ def << ( app )
11
+ @application = app if Module === app
12
+ end
13
+
14
+ def instance ; Waves::Application.instance ; end
15
+
16
+ def method_missing(name,*args,&block)
17
+ instance.send(name,*args,&block)
18
+ end
19
+
20
+ end
21
+
22
+ # An application in Waves is anything that provides access to the Waves
23
+ # runtime and the registered Waves applications. This includes both
24
+ # Waves::Server and Waves::Console. Waves::Application is *not* the actual
25
+ # application module(s) registered as Waves applications. To access the
26
+ # main Waves application, you can use +Waves+.+application+.
27
+ class Application
28
+
29
+ class << self; attr_accessor :instance; end
30
+
31
+ # Accessor for options passed to the application.
32
+ attr_reader :options
33
+
34
+ # Create a new Waves application instance.
35
+ def initialize( options={} )
36
+ @options = options
37
+ Dir.chdir options[:directory] if options[:directory]
38
+ Application.instance = self
39
+ Kernel.load( :lib / 'application.rb' ) if Waves.application.nil?
40
+ end
41
+
42
+ def synchronize( &block )
43
+ ( @mutex ||= Mutex.new ).synchronize( &block )
44
+ end
45
+
46
+ # The 'mode' of the application determines which configuration it will run under.
47
+ def mode
48
+ @mode ||= @options[:mode]||:development
49
+ end
50
+
51
+ # Debug is true if debug is set to true in the current configuration.
52
+ def debug? ; config.debug ; end
53
+
54
+ # Access the current configuration. *Example:* +Waves::Server.config+
55
+ def config
56
+ Waves.application.configurations[ mode ]
57
+ end
58
+
59
+ # Access the mappings for the application.
60
+ def mapping ; Waves.application.configurations[ :mapping ] ; end
61
+
62
+ # Reload the modules specified in the current configuration.
63
+ def reload ; config.reloadable.each { |mod| mod.reload } ; end
64
+
65
+ # Returns the cache set for the current configuration
66
+ def cache ; config.cache ; end
67
+ end
68
+
69
+ end
@@ -0,0 +1,57 @@
1
+ module Waves
2
+
3
+ # Encapsulates the blackboard associated with a given request. The scope of the blackboard is
4
+ # the same as the request object it gets attached to.
5
+ #
6
+ # The Waves blackboard is a very simple shared storaged usable during the request processing.
7
+ # It is available within:
8
+ # - mappings
9
+ # - controllers
10
+ # - helpers
11
+ #
12
+ # Adding a value:
13
+ # blackboard.value1 = 1
14
+ # blackboard[:value2] = 2
15
+ #
16
+ # Retrieving values
17
+ # blackboard.value1
18
+ # blackboard[:value2]
19
+ #
20
+ # see also blackboard_verify.rb
21
+
22
+ class Blackboard
23
+
24
+ # Create a new blackboard object using the given request.
25
+ def initialize( request )
26
+ @request = request
27
+ @data = {}
28
+ end
29
+
30
+ # Access a given data element of the blackboard using the given key.
31
+ def [](key)
32
+ @data[key]
33
+ end
34
+
35
+ # Set the given data element of the blackboard using the given key and value.
36
+ def []=(key,val)
37
+ @data[key] = val
38
+ end
39
+
40
+ def each(&block)
41
+ @data.each(&block)
42
+ end
43
+
44
+ # also allow things like
45
+ # blackboard.test1 instead of blackboard[:test1]
46
+ # blackboard.test1 = 2 instead of blackboard[:test1] = 2
47
+ def method_missing(name,*args)
48
+ if (name.to_s =~ /=$/)
49
+ self[name.to_s.gsub('=', '')] = args[0]
50
+ else
51
+ self[name.to_s]
52
+ end
53
+ end
54
+
55
+ end
56
+
57
+ end
@@ -0,0 +1,185 @@
1
+ module Waves
2
+
3
+ # Waves configurations are Ruby code. This means you can use a Ruby expression as
4
+ # the value of a configuration attribute, extend and inherit your configurations, and
5
+ # add your own attributes. You can even use it as a repository
6
+ # for your application configuration.
7
+ #
8
+ # You can access configuration attributes using the attribute name as a method, with the value as the argument.
9
+ #
10
+ # == Example
11
+ #
12
+ # module Blog
13
+ # module Configurations
14
+ # class Development < Default
15
+ # host '127.0.0.1'
16
+ # port 2000
17
+ # reloadable [ Blog ]
18
+ # log :level => :debug
19
+ # application do
20
+ # use Rack::ShowExceptions
21
+ # run Waves::Dispatchers::Default.new
22
+ # end
23
+ # end
24
+ # end
25
+ # end
26
+ #
27
+ # There are three forms for accessing attributes:
28
+ #
29
+ # Waves.config.port # generic form - gets the value for current config
30
+ # Blog.configurations[:development].port # gets the value for a specified config
31
+ # Blog::Configurations::Development.port # Access a specific config constant directly
32
+ #
33
+ # Configuration data is inheritable, as shown in the example above. Typically, you
34
+ # would set data common to all configurations in the Default class, from which
35
+ # your variations inherit.
36
+ #
37
+ # You may define your own heritable attributes using the +attribute+ class method:
38
+ #
39
+ # class Default < Waves::Configurations::Default
40
+ # attribute 'theme' # define an attribute named "theme"
41
+ # theme 'ultra' # set an inheritable default
42
+ # end
43
+ #
44
+ # Certain attributes are reserved for internal use by Waves:
45
+ #
46
+ # - application: configure the application for use with Rack
47
+ # - database: initialization parameters needed by the ORM layer
48
+ # - reloadable: an array of module names to reload; see below for more
49
+ # - log: takes a hash of parameters; see below for more
50
+ # - host: the host to bind the server to (string)
51
+ # - port: the port for the server to listen on (number)
52
+ # - ports: used by the cluster:start task for clustering servers (array of numbers)
53
+ # - debug: true if running in "debug" mode, which automatically reloads code
54
+ #
55
+ # == Configuring The Rack Application
56
+ #
57
+ # One of the really nice features of Rack is the ability to install "middleware"
58
+ # components to optimize the way you handle requests. Waves exposes this ability
59
+ # directly to the application developer via the +application+ configuration method.
60
+ #
61
+ # *Example*
62
+ #
63
+ # # Typical debugging configuration
64
+ # application do
65
+ # use Rack::ShowExceptions
66
+ # run Waves::Dispatchers::Default.new
67
+ # end
68
+ #
69
+ # == Configuring Database Access
70
+ #
71
+ # The ORM layers provided with Waves use the +database+ attribute for connection initialization.
72
+ # Most ORMs take a hash for this purpose, with keys that may vary depending on the ORM and backend.
73
+ #
74
+ # # Sequel with a MySQL db
75
+ # database :host => 'localhost', :adapter => 'mysql', :database => 'blog',
76
+ # :user => 'root', :password => 'guess'
77
+ #
78
+ # # Sequel with an SQLite db
79
+ # database :adapter => 'sqlite', :database => 'blog'
80
+ #
81
+ # See the documentation for each ORM layer for details.
82
+ #
83
+ # == Configuring Code Reloading
84
+ #
85
+ # The +reloadable+ attribute takes an array of modules. Before every request, the default Waves
86
+ # dispatcher calls +reload+ on each listed module. The module should remove any reloadable constants
87
+ # currently defined in its namespace.
88
+ #
89
+ # In a Waves application built on the Default foundation, +reload+ functionality is provided
90
+ # by AutoCode for the Configurations, Controllers, Helpers, Models, and Views modules.
91
+ #
92
+ # Listing only your application module will work in most cases:
93
+ #
94
+ # reloadable [ Blog ]
95
+ #
96
+ # As an alternative, you could reload only some of the modules within your application:
97
+ #
98
+ # reloadable [ Blog::Models, Blog::Controllers ]
99
+ #
100
+ # == Configuring Logging
101
+ #
102
+ # The +log+ configuration attribute takes hash with these keys:
103
+ # - :level - The log filter level. Uses Ruby's built in Logger class.
104
+ # - :output - A filename or IO object. Should be a filename if running as a daemon.
105
+ #
106
+ # *Examples*
107
+ #
108
+ # log :level => :info, :output => $stderr
109
+ # log :level => :error, :output => 'log/blog.log'
110
+ #
111
+
112
+ module Configurations
113
+
114
+ class Base
115
+ # Set the given attribute with the given value. Typically, you wouldn't
116
+ # use this directly.
117
+ def self.[]=( name, val )
118
+ meta_def("_#{name}") { val }
119
+ end
120
+
121
+ # Get the value of the given attribute. Typically, you wouldn't
122
+ # use this directly.
123
+ def self.[]( name ) ; send "_#{name}" ; end
124
+
125
+ # Define a new attribute. After calling this, you can get and set the value
126
+ # using the attribute name as the method
127
+ def self.attribute( name )
128
+ meta_def(name) do |*args|
129
+ raise ArgumentError.new('Too many arguments.') if args.length > 1
130
+ args.length == 1 ? self[ name ] = args.first : self[ name ]
131
+ end
132
+ self[ name ] = nil
133
+ end
134
+
135
+ end
136
+
137
+ # The Default configuration defines sensible defaults for attributes required by Waves.
138
+ # debug true
139
+ # synchronize? true
140
+ # session :duration => 30.minutes, :path => '/tmp/sessions'
141
+ # log :level => :info, :output => $stderr
142
+ # reloadable []
143
+ class Default < Base
144
+
145
+ %w( host port ports log reloadable database session debug root synchronize? ).
146
+ each { |name| attribute(name) }
147
+
148
+ # Set the Rack handler, along with any specific options
149
+ # that need to be passed to the handler's #run method.
150
+ #
151
+ # When accessing the value
152
+ # (calling with no arguments), returns an array of the handler and options.
153
+ def self.handler(*args)
154
+ if args.length > 0
155
+ @rack_handler, @rack_handler_options = args
156
+ else
157
+ [ @rack_handler, @rack_handler_options ]
158
+ end
159
+ end
160
+
161
+ # Provides access to the Waves::MimeTypes class via the configuration. You
162
+ # can override #mime_types to return your own MIME types repository class.
163
+ def self.mime_types
164
+ Waves::MimeTypes
165
+ end
166
+
167
+ # Defines the application for use with Rack. Treat this method like an
168
+ # instance of Rack::Builder
169
+ def self.application( &block )
170
+ if block_given?
171
+ self['application'] = Rack::Builder.new( &block )
172
+ else
173
+ self['application']
174
+ end
175
+ end
176
+
177
+ debug true ; synchronize? true
178
+ session :duration => 30.minutes, :path => '/tmp/sessions'
179
+ log :level => :info, :output => $stderr
180
+ reloadable []
181
+ end
182
+ end
183
+ end
184
+
185
+