shotgun 0.1 → 0.2
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.
- data/Rakefile +2 -2
- data/bin/shotgun +28 -8
- data/lib/shotgun.rb +2 -0
- data/shotgun.gemspec +4 -3
- metadata +15 -2
data/Rakefile
CHANGED
@@ -5,7 +5,7 @@ task :default => [:test]
|
|
5
5
|
task :spec => :test
|
6
6
|
|
7
7
|
Rake::TestTask.new(:test) do |t|
|
8
|
-
t.test_files = FileList['test
|
8
|
+
t.test_files = FileList['test/spec_*.rb']
|
9
9
|
t.ruby_opts = ['-rubygems'] if defined? Gem
|
10
10
|
end
|
11
11
|
|
@@ -48,7 +48,7 @@ file package('.tar.gz') => %w[pkg/] + $spec.files do |f|
|
|
48
48
|
end
|
49
49
|
|
50
50
|
desc 'Publish gem and tarball to rubyforge'
|
51
|
-
task '
|
51
|
+
task 'release' => [package('.gem'), package('.tar.gz')] do |t|
|
52
52
|
sh <<-end
|
53
53
|
rubyforge add_release wink #{$spec.name} #{$spec.version} #{package('.gem')} &&
|
54
54
|
rubyforge add_file wink #{$spec.name} #{$spec.version} #{package('.tar.gz')}
|
data/bin/shotgun
CHANGED
@@ -5,12 +5,10 @@ $LOAD_PATH.unshift libdir unless $LOAD_PATH.include?(libdir)
|
|
5
5
|
|
6
6
|
require 'optparse'
|
7
7
|
|
8
|
-
automatic = false
|
9
8
|
server = nil
|
10
9
|
env = ENV['RACK_ENV'] || 'development'
|
11
|
-
|
12
|
-
|
13
|
-
options = {:Port => 9393, :Host => "0.0.0.0", :AccessLog => []}
|
10
|
+
browse = false
|
11
|
+
options = {:Port => 9393, :Host => 'localhost', :AccessLog => []}
|
14
12
|
|
15
13
|
opts = OptionParser.new("", 24, ' ') { |opts|
|
16
14
|
opts.banner = "Usage: shotgun [ruby options] [rack options] [rackup config]"
|
@@ -60,14 +58,18 @@ opts = OptionParser.new("", 24, ' ') { |opts|
|
|
60
58
|
}
|
61
59
|
|
62
60
|
opts.separator ""
|
63
|
-
opts.separator "
|
61
|
+
opts.separator "Shotgun options:"
|
64
62
|
|
65
|
-
opts.
|
63
|
+
opts.on("-O", "--browse", "open browser immediately after starting") { |browse|
|
64
|
+
browse = true
|
65
|
+
}
|
66
|
+
|
67
|
+
opts.on_tail("-h", "--help", "show this message") do
|
66
68
|
puts opts
|
67
69
|
exit
|
68
70
|
end
|
69
71
|
|
70
|
-
opts.on_tail("--version", "
|
72
|
+
opts.on_tail("--version", "show version") do
|
71
73
|
require 'rack'
|
72
74
|
puts "Rack #{Rack.version}"
|
73
75
|
exit
|
@@ -84,6 +86,12 @@ if config =~ /\.ru$/ && File.read(config)[/^#\\(.*)/]
|
|
84
86
|
end
|
85
87
|
|
86
88
|
require 'rack'
|
89
|
+
require 'rack/utils'
|
90
|
+
require 'rack/request'
|
91
|
+
require 'rack/response'
|
92
|
+
require 'rack/lint'
|
93
|
+
require 'rack/commonlogger'
|
94
|
+
require 'rack/showexceptions'
|
87
95
|
|
88
96
|
unless server = Rack::Handler.get(server)
|
89
97
|
begin
|
@@ -95,12 +103,19 @@ end
|
|
95
103
|
|
96
104
|
app_wrapper =
|
97
105
|
lambda do |inner_app|
|
98
|
-
|
106
|
+
case env
|
107
|
+
when 'development'
|
99
108
|
Rack::Builder.new {
|
109
|
+
use Rack::CommonLogger, STDERR unless server.name =~ /CGI/
|
100
110
|
use Rack::ShowExceptions
|
101
111
|
use Rack::Lint
|
102
112
|
run inner_app
|
103
113
|
}.to_app
|
114
|
+
when 'deployment', 'production'
|
115
|
+
Rack::Builder.new {
|
116
|
+
use Rack::CommonLogger, STDERR unless server.name =~ /CGI/
|
117
|
+
run inner_app
|
118
|
+
}.to_app
|
104
119
|
else
|
105
120
|
inner_app
|
106
121
|
end
|
@@ -113,4 +128,9 @@ app = Shotgun.new(config, app_wrapper)
|
|
113
128
|
|
114
129
|
server.run app, options do |inst|
|
115
130
|
puts "== Shotgun starting #{server.to_s} on #{options[:Host]}:#{options[:Port]}"
|
131
|
+
|
132
|
+
if browse
|
133
|
+
require 'launchy'
|
134
|
+
Launchy.open("http://#{options[:Host]}:#{options[:Port]}/")
|
135
|
+
end
|
116
136
|
end
|
data/lib/shotgun.rb
CHANGED
@@ -64,6 +64,8 @@ class Shotgun
|
|
64
64
|
require rackup_file
|
65
65
|
if defined? Sinatra::Application
|
66
66
|
Sinatra::Application.set :reload, false
|
67
|
+
Sinatra::Application.set :logging, false
|
68
|
+
Sinatra::Application.set :raise_errors, true
|
67
69
|
Sinatra::Application
|
68
70
|
else
|
69
71
|
Object.const_get(File.basename(rackup_file, '.rb').capitalize)
|
data/shotgun.gemspec
CHANGED
@@ -3,8 +3,8 @@ Gem::Specification.new do |s|
|
|
3
3
|
s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
|
4
4
|
|
5
5
|
s.name = 'shotgun'
|
6
|
-
s.version = '0.
|
7
|
-
s.date = '2009-
|
6
|
+
s.version = '0.2'
|
7
|
+
s.date = '2009-03-22'
|
8
8
|
|
9
9
|
s.description = "Because reloading sucks."
|
10
10
|
s.summary = s.description
|
@@ -24,7 +24,8 @@ Gem::Specification.new do |s|
|
|
24
24
|
s.test_files = s.files.select {|path| path =~ /^test\/.*_test.rb/}
|
25
25
|
|
26
26
|
s.extra_rdoc_files = %w[README]
|
27
|
-
s.add_dependency 'rack',
|
27
|
+
s.add_dependency 'rack', '>= 0.9.1', '< 1.0'
|
28
|
+
s.add_dependency 'launchy', '>= 0.3.3', '< 1.0'
|
28
29
|
|
29
30
|
s.homepage = "http://github.com/rtomayko/shotgun/"
|
30
31
|
s.require_paths = %w[lib]
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: shotgun
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: "0.
|
4
|
+
version: "0.2"
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Ryan Tomayko
|
@@ -9,7 +9,7 @@ autorequire:
|
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
11
|
|
12
|
-
date: 2009-
|
12
|
+
date: 2009-03-22 00:00:00 -07:00
|
13
13
|
default_executable:
|
14
14
|
dependencies:
|
15
15
|
- !ruby/object:Gem::Dependency
|
@@ -25,6 +25,19 @@ dependencies:
|
|
25
25
|
- !ruby/object:Gem::Version
|
26
26
|
version: "1.0"
|
27
27
|
version:
|
28
|
+
- !ruby/object:Gem::Dependency
|
29
|
+
name: launchy
|
30
|
+
type: :runtime
|
31
|
+
version_requirement:
|
32
|
+
version_requirements: !ruby/object:Gem::Requirement
|
33
|
+
requirements:
|
34
|
+
- - ">="
|
35
|
+
- !ruby/object:Gem::Version
|
36
|
+
version: 0.3.3
|
37
|
+
- - <
|
38
|
+
- !ruby/object:Gem::Version
|
39
|
+
version: "1.0"
|
40
|
+
version:
|
28
41
|
description: Because reloading sucks.
|
29
42
|
email: r@tomayko.com
|
30
43
|
executables:
|