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

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

#idObject

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 "      alias \#{oldmeth} \#{meth}\n      def \#{meth}(*a, &b)\n        \#{mutex} = Mutex.new unless defined? \#{mutex}\n        \#{flag} = true unless defined? \#{flag}\n        run = \#{mutex}.synchronize do\n          if \#{flag}\n            \#{flag} = false\n            true\n          end\n        end\n        if run\n          ret = \#{oldmeth}(*a, &b)\n          \#{mutex}.synchronize { \#{flag} = true }\n          ret\n        end\n      end\n    EOF\n  end\nend\n"

#returning(x) {|x| ... } ⇒ Object

“k combinator”

Yields:

  • (x)


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 "      alias unsynchronized_\#{meth} \#{meth}\n      def \#{meth}(*a, &b)\n        @mutex.synchronize { unsynchronized_\#{meth}(*a, &b) }\n      end\n    EOF\n  end\nend\n"

#tap {|_self| ... } ⇒ Object

Yields:

  • (_self)

Yield Parameters:

  • _self (Object)

    the object that the method was called on



190
# File 'lib/sup/util.rb', line 190

def tap; yield self; self; end