Class: Object
- Inherits:
- BasicObject
- Includes:
- Redwood::LogsStuff
- Defined in:
- lib/sup.rb,
lib/sup/util.rb,
lib/sup/logger/singleton.rb
Instance Method Summary collapse
- #benchmark(s, &b) ⇒ Object
-
#id ⇒ Object
this is for debugging purposes because i keep calling #id on the wrong object and i want it to throw an exception.
- #ignore_concurrent_calls(*methods) ⇒ Object
-
#returning(x) {|x| ... } ⇒ Object
“k combinator”.
-
#synchronized(*methods) ⇒ Object
clone of java-style whole-method synchronization assumes a @mutex variable TODO: clean up, try harder to avoid namespace collisions.
- #tap {|_self| ... } ⇒ Object
Instance Method Details
#benchmark(s, &b) ⇒ Object
233 234 235 236 237 238 |
# File 'lib/sup/util.rb', line 233 def benchmark s, &b ret = nil times = Benchmark.measure { ret = b.call } debug "benchmark #{s}: #{times}" ret end |
#id ⇒ Object
this is for debugging purposes because i keep calling #id on the wrong object and i want it to throw an exception
19 20 21 |
# File 'lib/sup.rb', line 19 def id raise "wrong id called on #{self.inspect}" end |
#ignore_concurrent_calls(*methods) ⇒ Object
207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 |
# File 'lib/sup/util.rb', line 207 def ignore_concurrent_calls *methods methods.each do |meth| mutex = "@__concurrent_protector_#{meth}" flag = "@__concurrent_flag_#{meth}" oldmeth = "__unprotected_#{meth}" class_eval <<-EOF alias #{oldmeth} #{meth} def #{meth}(*a, &b) #{mutex} = Mutex.new unless defined? #{mutex} #{flag} = true unless defined? #{flag} run = #{mutex}.synchronize do if #{flag} #{flag} = false true end end if run ret = #{oldmeth}(*a, &b) #{mutex}.synchronize { #{flag} = true } ret end end EOF end end |
#returning(x) {|x| ... } ⇒ Object
“k combinator”
187 |
# File 'lib/sup/util.rb', line 187 def returning x; yield x; x; end |
#synchronized(*methods) ⇒ Object
clone of java-style whole-method synchronization assumes a @mutex variable TODO: clean up, try harder to avoid namespace collisions
196 197 198 199 200 201 202 203 204 205 |
# File 'lib/sup/util.rb', line 196 def synchronized *methods methods.each do |meth| class_eval <<-EOF alias unsynchronized_#{meth} #{meth} def #{meth}(*a, &b) @mutex.synchronize { unsynchronized_#{meth}(*a, &b) } end EOF end end |