aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack/lib/action_controller/lock.rb
diff options
context:
space:
mode:
authorColin Curtin <colin@procore.com>2008-12-20 20:21:20 -0800
committerColin Curtin <colin@procore.com>2008-12-20 20:21:20 -0800
commit0e121f9ed93ebb417cc63307aaaf47f8adfd220d (patch)
tree39530f289b38a5dd1b2e6b170dab2631c983aaf3 /actionpack/lib/action_controller/lock.rb
parentb0187434bd7601a5b2e5f7afac99c964e566b9db (diff)
parenta0d091a41604d709cf2b99c85dcf4ae3ee275b9c (diff)
downloadrails-0e121f9ed93ebb417cc63307aaaf47f8adfd220d.tar.gz
rails-0e121f9ed93ebb417cc63307aaaf47f8adfd220d.tar.bz2
rails-0e121f9ed93ebb417cc63307aaaf47f8adfd220d.zip
Merge branch 'master' of git@github.com:lifo/docrails
Diffstat (limited to 'actionpack/lib/action_controller/lock.rb')
-rw-r--r--actionpack/lib/action_controller/lock.rb16
1 files changed, 16 insertions, 0 deletions
diff --git a/actionpack/lib/action_controller/lock.rb b/actionpack/lib/action_controller/lock.rb
new file mode 100644
index 0000000000..c50762216e
--- /dev/null
+++ b/actionpack/lib/action_controller/lock.rb
@@ -0,0 +1,16 @@
+module ActionController
+ class Lock
+ FLAG = 'rack.multithread'.freeze
+
+ def initialize(app, lock = Mutex.new)
+ @app, @lock = app, lock
+ end
+
+ def call(env)
+ old, env[FLAG] = env[FLAG], false
+ @lock.synchronize { @app.call(env) }
+ ensure
+ env[FLAG] = old
+ end
+ end
+end