Skip to content

Commit

Permalink
Merge branch 'copy_on_write' into zero_copy_context_switch
Browse files Browse the repository at this point in the history
  • Loading branch information
FooBarWidget committed Jun 2, 2010
2 parents 7c20f17 + db73b4e commit 9f6078b
Show file tree
Hide file tree
Showing 6 changed files with 47 additions and 28 deletions.
10 changes: 10 additions & 0 deletions ChangeLog
@@ -1,3 +1,13 @@
Sun Jan 10 19:00:31 2010 Nobuyoshi Nakada <nobu@ruby-lang.org>

* lib/webrick/accesslog.rb : Escape needed.

* lib/webrick/httpstatus.rb : ditto.

* lib/webrick/httprequest.rb : ditto.

* lib/webrick/httputils.rb : ditto.

Thu Dec 24 18:04:27 2009 Nobuyoshi Nakada <nobu@ruby-lang.org>

* configure.in: default ac_cv_prog_CC to CC.
Expand Down
12 changes: 10 additions & 2 deletions lib/webrick/accesslog.rb
Expand Up @@ -53,15 +53,23 @@ def format(format_string, params)
when ?e, ?i, ?n, ?o
raise AccessLogError,
"parameter is required for \"#{spec}\"" unless param
params[spec][param] || "-"
param = params[spec][param] ? escape(param) : "-"
when ?t
params[spec].strftime(param || CLF_TIME_FORMAT)
when ?%
"%"
else
params[spec]
escape(params[spec].to_s)
end
}
end

def escape(data)
if data.tainted?
data.gsub(/[[:cntrl:]\\]+/) {$&.dump[1...-1]}.untaint
else
data
end
end
end
end
6 changes: 1 addition & 5 deletions lib/webrick/httprequest.rb
Expand Up @@ -242,11 +242,7 @@ def read_header(socket)
@raw_header << line
end
end
begin
@header = HTTPUtils::parse_header(@raw_header)
rescue => ex
raise HTTPStatus::BadRequest, ex.message
end
@header = HTTPUtils::parse_header(@raw_header.join)
end

def parse_uri(str, scheme="http")
Expand Down
31 changes: 18 additions & 13 deletions lib/webrick/httpstatus.rb
Expand Up @@ -12,7 +12,17 @@ module WEBrick

module HTTPStatus

class Status < StandardError; end
class Status < StandardError
def initialize(message=self.class, *rest)
super(AccessLog.escape(message), *rest)
end
class << self
attr_reader :code, :reason_phrase
end
def code() self::class::code end
def reason_phrase() self::class::reason_phrase end
alias to_i code
end
class Info < Status; end
class Success < Status; end
class Redirect < Status; end
Expand Down Expand Up @@ -68,6 +78,7 @@ class EOFError < StandardError; end
CodeToError = {}

StatusMessage.each{|code, message|
message.freeze
var_name = message.gsub(/[ \-]/,'_').upcase
err_name = message.gsub(/[ \-]/,'')

Expand All @@ -79,18 +90,12 @@ class EOFError < StandardError; end
when 500...600; parent = ServerError
end

eval %-
RC_#{var_name} = #{code}
class #{err_name} < #{parent}
def self.code() RC_#{var_name} end
def self.reason_phrase() StatusMessage[code] end
def code() self::class::code end
def reason_phrase() self::class::reason_phrase end
alias to_i code
end
-

CodeToError[code] = const_get(err_name)
const_set("RC_#{var_name}", code)
err_class = Class.new(parent)
err_class.instance_variable_set(:@code, code)
err_class.instance_variable_set(:@reason_phrase, message)
const_set(err_name, err_class)
CodeToError[code] = err_class
}

def reason_phrase(code)
Expand Down
4 changes: 2 additions & 2 deletions lib/webrick/httputils.rb
Expand Up @@ -128,11 +128,11 @@ def parse_header(raw)
when /^\s+(.*?)\s*\z/om
value = $1
unless field
raise "bad header '#{line.inspect}'."
raise HTTPStatus::BadRequest, "bad header '#{line}'."
end
header[field][-1] << " " << value
else
raise "bad header '#{line.inspect}'."
raise HTTPStatus::BadRequest, "bad header '#{line}'."
end
}
header.each{|key, values|
Expand Down
12 changes: 6 additions & 6 deletions version.h
@@ -1,15 +1,15 @@
#define RUBY_VERSION "1.8.7"
#define RUBY_RELEASE_DATE "2009-12-24"
#define RUBY_RELEASE_DATE "2010-01-10"
#define RUBY_VERSION_CODE 187
#define RUBY_RELEASE_CODE 20091224
#define RUBY_PATCHLEVEL 248
#define RUBY_RELEASE_CODE 20100110
#define RUBY_PATCHLEVEL 249

#define RUBY_VERSION_MAJOR 1
#define RUBY_VERSION_MINOR 8
#define RUBY_VERSION_TEENY 7
#define RUBY_RELEASE_YEAR 2009
#define RUBY_RELEASE_MONTH 12
#define RUBY_RELEASE_DAY 24
#define RUBY_RELEASE_YEAR 2010
#define RUBY_RELEASE_MONTH 1
#define RUBY_RELEASE_DAY 10

#ifdef RUBY_EXTERN
RUBY_EXTERN const char ruby_version[];
Expand Down

0 comments on commit 9f6078b

Please sign in to comment.