about summary refs log tree commit homepage
path: root/lib/yahns/config.rb
diff options
context:
space:
mode:
Diffstat (limited to 'lib/yahns/config.rb')
-rw-r--r--lib/yahns/config.rb14
1 files changed, 12 insertions, 2 deletions
diff --git a/lib/yahns/config.rb b/lib/yahns/config.rb
index 29f5746..1862eee 100644
--- a/lib/yahns/config.rb
+++ b/lib/yahns/config.rb
@@ -76,7 +76,7 @@ class Yahns::Config # :nodoc:
 
   def shutdown_timeout(sec)
     var = _check_in_block(nil, :shutdown_timeout)
-    @set[var] = _check_int(var, sec, 0)
+    @set[var] = _check_num(var, sec, 0)
   end
 
   def worker_processes(nr, &blk)
@@ -283,6 +283,12 @@ class Yahns::Config # :nodoc:
     n
   end
 
+  def _check_num(var, n, min)
+    Numeric === n or raise ArgumentError, "not a number: #{var}=#{n.inspect}"
+    n >= min or raise ArgumentError, "too low (< #{min}): #{var}=#{n.inspect}"
+    n
+  end
+
   # global
   def client_expire_threshold(val)
     var = _check_in_block(nil, :client_expire_threshold)
@@ -345,7 +351,6 @@ class Yahns::Config # :nodoc:
     client_body_buffer_size: 1,
     client_header_buffer_size: 1,
     client_max_header_size: 1,
-    client_timeout: 0,
   }.each do |_v,minval|
     eval(
     %Q(def #{_v}(val);) <<
@@ -355,6 +360,11 @@ class Yahns::Config # :nodoc:
     )
   end
 
+  def client_timeout(val)
+    var = _check_in_block(:app, :client_timeout)
+    @block.ctx.__send__("#{var}=", _check_num(var, val, 0))
+  end
+
   def client_max_body_size(val)
     var = _check_in_block(:app, :client_max_body_size)
     val = _check_int(var, val, 0) if val != nil