Skip to content

Commit

Permalink
Merge pull request sinatra#1527 from jkowens/cleanup_force_encoding
Browse files Browse the repository at this point in the history
Remove unnecessary code for force_encoding
  • Loading branch information
namusyaka authored Apr 12, 2019
2 parents 7b7043c + 6b96449 commit 5e2e41f
Showing 1 changed file with 13 additions and 20 deletions.
33 changes: 13 additions & 20 deletions lib/sinatra/base.rb
Original file line number Diff line number Diff line change
Expand Up @@ -1743,29 +1743,22 @@ def cleaned_caller(keep = 3)
end
end

# Fixes encoding issues by
# * defaulting to UTF-8
# * casting params to Encoding.default_external
#
# The latter might not be necessary if Rack handles it one day.
# Keep an eye on Rack's LH #100.
def force_encoding(*args) settings.force_encoding(*args) end
if defined? Encoding
def self.force_encoding(data, encoding = default_encoding)
return if data == settings || data.is_a?(Tempfile)
if data.respond_to? :force_encoding
data.force_encoding(encoding).encode!
elsif data.respond_to? :each_value
data.each_value { |v| force_encoding(v, encoding) }
elsif data.respond_to? :each
data.each { |v| force_encoding(v, encoding) }
end
data
# Force data to specified encoding. It defaults to settings.default_encoding
# which is UTF-8 by default
def self.force_encoding(data, encoding = default_encoding)
return if data == settings || data.is_a?(Tempfile)
if data.respond_to? :force_encoding
data.force_encoding(encoding).encode!
elsif data.respond_to? :each_value
data.each_value { |v| force_encoding(v, encoding) }
elsif data.respond_to? :each
data.each { |v| force_encoding(v, encoding) }
end
else
def self.force_encoding(data, *) data end
data
end

def force_encoding(*args) settings.force_encoding(*args) end

reset!

set :environment, (ENV['APP_ENV'] || ENV['RACK_ENV'] || :development).to_sym
Expand Down

0 comments on commit 5e2e41f

Please sign in to comment.