lib/sinatra/main.rb in sinatra-2.0.5 vs lib/sinatra/main.rb in sinatra-2.0.6
- old
+ new
@@ -1,29 +1,39 @@
-require 'sinatra/base'
-
module Sinatra
+ ParamsConfig = {}
+
+ if ARGV.any?
+ require 'optparse'
+ OptionParser.new { |op|
+ op.on('-p port', 'set the port (default is 4567)') { |val| ParamsConfig[:port] = Integer(val) }
+ op.on('-s server', 'specify rack server/handler (default is thin)') { |val| ParamsConfig[:server] = val }
+ op.on('-q', 'turn on quiet mode (default is off)') { ParamsConfig[:quiet] = true }
+ op.on('-x', 'turn on the mutex lock (default is off)') { ParamsConfig[:lock] = true }
+ op.on('-e env', 'set the environment (default is development)') do |val|
+ ENV['RACK_ENV'] = val
+ ParamsConfig[:environment] = val.to_sym
+ end
+ op.on('-o addr', "set the host (default is (env == 'development' ? 'localhost' : '0.0.0.0'))") do |val|
+ ParamsConfig[:bind] = val
+ end
+ }.parse!(ARGV.dup)
+ end
+
+ require 'sinatra/base'
+
class Application < Base
# we assume that the first file that requires 'sinatra' is the
# app_file. all other path related options are calculated based
# on this path by default.
set :app_file, caller_files.first || $0
set :run, Proc.new { File.expand_path($0) == File.expand_path(app_file) }
- if run? && ARGV.any?
- require 'optparse'
- OptionParser.new { |op|
- op.on('-p port', 'set the port (default is 4567)') { |val| set :port, Integer(val) }
- op.on('-o addr', "set the host (default is #{bind})") { |val| set :bind, val }
- op.on('-e env', 'set the environment (default is development)') { |val| set :environment, val.to_sym }
- op.on('-s server', 'specify rack server/handler (default is thin)') { |val| set :server, val }
- op.on('-q', 'turn on quiet mode (default is off)') { set :quiet, true }
- op.on('-x', 'turn on the mutex lock (default is off)') { set :lock, true }
- }.parse!(ARGV.dup)
- end
+ ParamsConfig.each { |k, v| set k, v } if run? && ARGV.any?
end
+ remove_const(:ParamsConfig)
at_exit { Application.run! if $!.nil? && Application.run? }
end
# include would include the module in Object
# extend only extends the `main` object