Skip to content

Commit

Permalink
Sinatra::Contrib dependency updates. Fixes sinatra#1207
Browse files Browse the repository at this point in the history
* Remove backports
* Work around Object#try and String#underscore
* Make Rack::Test a development dependency
  • Loading branch information
mwpastore committed Nov 25, 2016
1 parent 63e81bc commit da03260
Show file tree
Hide file tree
Showing 9 changed files with 24 additions and 33 deletions.
5 changes: 2 additions & 3 deletions sinatra-contrib/lib/sinatra/capture.rb
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
require 'sinatra/base'
require 'sinatra/engine_tracking'
require 'backports'

module Sinatra
#
Expand Down Expand Up @@ -106,12 +105,12 @@ def capture(*args, &block)
dummy = DUMMIES.fetch(current_engine)
options = { :layout => false, :locals => {:args => args, :block => block }}

buffer.try :clear
buffer.public_send(:clear) if buffer.respond_to?(:clear)
result = render(current_engine, dummy, options, &block)
end
result.strip.empty? && @capture ? @capture : result
ensure
buffer.try :replace, old_buffer
buffer.public_send(:replace, old_buffer) if buffer.respond_to?(:replace)
end

def capture_later(&block)
Expand Down
32 changes: 16 additions & 16 deletions sinatra-contrib/lib/sinatra/contrib.rb
Original file line number Diff line number Diff line change
Expand Up @@ -7,32 +7,32 @@ module Contrib
# or breaks if external dependencies are missing. Will extend
# Sinatra::Application by default.
module Common
register :ConfigFile
register :MultiRoute
register :Namespace
register :RespondWith
register :ConfigFile, 'sinatra/config_file'
register :MultiRoute, 'sinatra/multi_route'
register :Namespace, 'sinatra/namespace'
register :RespondWith, 'sinatra/respond_with'

helpers :Capture
helpers :ContentFor
helpers :Cookies
helpers :EngineTracking
helpers :JSON
helpers :LinkHeader
helpers :Streaming
helpers :RequiredParams
helpers :Capture, 'sinatra/capture'
helpers :ContentFor, 'sinatra/content_for'
helpers :Cookies, 'sinatra/cookies'
helpers :EngineTracking, 'sinatra/engine_tracking'
helpers :JSON, 'sinatra/json'
helpers :LinkHeader, 'sinatra/link_header'
helpers :Streaming, 'sinatra/streaming'
helpers :RequiredParams, 'sinatra/required_params'
end

##
# Other extensions you don't want to be loaded unless needed.
module Custom
# register :Compass
register :Reloader
# register :Compass, 'sinatra/compass'
register :Reloader, 'sinatra/reloader'
end

##
# Stuff that aren't Sinatra extensions, technically.
autoload :Extension
autoload :TestHelpers
autoload :Extension, 'sinatra/extension'
autoload :TestHelpers, 'sinatra/test_helpers'
end

register Sinatra::Contrib::Common
Expand Down
8 changes: 3 additions & 5 deletions sinatra-contrib/lib/sinatra/contrib/setup.rb
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
require 'sinatra/base'
require 'sinatra/contrib/version'
require 'backports'

module Sinatra
module Contrib
Expand All @@ -9,16 +8,15 @@ def extensions
@extensions ||= {:helpers => [], :register => []}
end

def register(name, path = nil)
def register(name, path)
autoload name, path, :register
end

def helpers(name, path = nil)
def helpers(name, path)
autoload name, path, :helpers
end

def autoload(name, path = nil, method = nil)
path ||= "sinatra/#{name.to_s.underscore}"
def autoload(name, path, method = nil)
extensions[method] << name if method
Sinatra.autoload(name, path)
end
Expand Down
1 change: 0 additions & 1 deletion sinatra-contrib/lib/sinatra/cookies.rb
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
require 'sinatra/base'
require 'backports'

module Sinatra
# = Sinatra::Cookies
Expand Down
1 change: 0 additions & 1 deletion sinatra-contrib/lib/sinatra/extension.rb
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
require 'sinatra/base'
require 'backports/basic_object' unless defined? BasicObject

module Sinatra

Expand Down
1 change: 0 additions & 1 deletion sinatra-contrib/lib/sinatra/namespace.rb
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
require 'backports'
require 'sinatra/base'
require 'mustermann'

Expand Down
1 change: 0 additions & 1 deletion sinatra-contrib/lib/sinatra/streaming.rb
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
require 'sinatra/base'
require 'backports'

module Sinatra

Expand Down
7 changes: 3 additions & 4 deletions sinatra-contrib/sinatra-contrib.gemspec
Original file line number Diff line number Diff line change
Expand Up @@ -217,10 +217,8 @@ Gem::Specification.new do |s|
s.required_ruby_version = '>= 2.2.0'

s.add_dependency "sinatra", Sinatra::VERSION
s.add_dependency "mustermann", "1.0.0.beta2"
s.add_dependency "backports", ">= 2.0"
s.add_dependency "tilt", ">= 1.3", "< 3"
s.add_dependency "rack-test"
s.add_dependency "mustermann", "1.0.0.beta2"
s.add_dependency "tilt", ">= 1.3", "< 3"
s.add_dependency "rack-protection", Sinatra::VERSION
s.add_dependency "multi_json"

Expand All @@ -242,4 +240,5 @@ Gem::Specification.new do |s|
s.add_development_dependency "wikicloth"
s.add_development_dependency "markaby"
s.add_development_dependency "rake", "< 11"
s.add_development_dependency "rack-test"
end
1 change: 0 additions & 1 deletion sinatra-contrib/spec/streaming_spec.rb
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
require 'backports'
require 'spec_helper'

describe Sinatra::Streaming do
Expand Down

0 comments on commit da03260

Please sign in to comment.