PHP 8.2.31
Preview: observer.rb Size: 5.83 KB
/proc/thread-self/root/opt/alt/ruby26/lib64/ruby/2.6.0/observer.rb

# frozen_string_literal: true
#
# Implementation of the _Observer_ object-oriented design pattern.  The
# following documentation is copied, with modifications, from "Programming
# Ruby", by Hunt and Thomas; http://www.ruby-doc.org/docs/ProgrammingRuby/html/lib_patterns.html.
#
# See Observable for more info.

# The Observer pattern (also known as publish/subscribe) provides a simple
# mechanism for one object to inform a set of interested third-party objects
# when its state changes.
#
# == Mechanism
#
# The notifying class mixes in the +Observable+
# module, which provides the methods for managing the associated observer
# objects.
#
# The observable object must:
# * assert that it has +#changed+
# * call +#notify_observers+
#
# An observer subscribes to updates using Observable#add_observer, which also
# specifies the method called via #notify_observers. The default method for
# #notify_observers is #update.
#
# === Example
#
# The following example demonstrates this nicely.  A +Ticker+, when run,
# continually receives the stock +Price+ for its <tt>@symbol</tt>.  A +Warner+
# is a general observer of the price, and two warners are demonstrated, a
# +WarnLow+ and a +WarnHigh+, which print a warning if the price is below or
# above their set limits, respectively.
#
# The +update+ callback allows the warners to run without being explicitly
# called.  The system is set up with the +Ticker+ and several observers, and the
# observers do their duty without the top-level code having to interfere.
#
# Note that the contract between publisher and subscriber (observable and
# observer) is not declared or enforced.  The +Ticker+ publishes a time and a
# price, and the warners receive that.  But if you don't ensure that your
# contracts are correct, nothing else can warn you.
#
#   require "observer"
#
#   class Ticker          ### Periodically fetch a stock price.
#     include Observable
#
#     def initialize(symbol)
#       @symbol = symbol
#     end
#
#     def run
#       last_price = nil
#       loop do
#         price = Price.fetch(@symbol)
#         print "Current price: #{price}\n"
#         if price != last_price
#           changed                 # notify observers
#           last_price = price
#           notify_observers(Time.now, price)
#         end
#         sleep 1
#       end
#     end
#   end
#
#   class Price           ### A mock class to fetch a stock price (60 - 140).
#     def self.fetch(symbol)
#       60 + rand(80)
#     end
#   end
#
#   class Warner          ### An abstract observer of Ticker objects.
#     def initialize(ticker, limit)
#       @limit = limit
#       ticker.add_observer(self)
#     end
#   end
#
#   class WarnLow < Warner
#     def update(time, price)       # callback for observer
#       if price < @limit
#         print "--- #{time.to_s}: Price below #@limit: #{price}\n"
#       end
#     end
#   end
#
#   class WarnHigh < Warner
#     def update(time, price)       # callback for observer
#       if price > @limit
#         print "+++ #{time.to_s}: Price above #@limit: #{price}\n"
#       end
#     end
#   end
#
#   ticker = Ticker.new("MSFT")
#   WarnLow.new(ticker, 80)
#   WarnHigh.new(ticker, 120)
#   ticker.run
#
# Produces:
#
#   Current price: 83
#   Current price: 75
#   --- Sun Jun 09 00:10:25 CDT 2002: Price below 80: 75
#   Current price: 90
#   Current price: 134
#   +++ Sun Jun 09 00:10:25 CDT 2002: Price above 120: 134
#   Current price: 134
#   Current price: 112
#   Current price: 79
#   --- Sun Jun 09 00:10:25 CDT 2002: Price below 80: 79
module Observable

  #
  # Add +observer+ as an observer on this object. So that it will receive
  # notifications.
  #
  # +observer+:: the object that will be notified of changes.
  # +func+:: Symbol naming the method that will be called when this Observable
  #          has changes.
  #
  #          This method must return true for +observer.respond_to?+ and will
  #          receive <tt>*arg</tt> when #notify_observers is called, where
  #          <tt>*arg</tt> is the value passed to #notify_observers by this
  #          Observable
  def add_observer(observer, func=:update)
    @observer_peers = {} unless defined? @observer_peers
    unless observer.respond_to? func
      raise NoMethodError, "observer does not respond to `#{func}'"
    end
    @observer_peers[observer] = func
  end

  #
  # Remove +observer+ as an observer on this object so that it will no longer
  # receive notifications.
  #
  # +observer+:: An observer of this Observable
  def delete_observer(observer)
    @observer_peers.delete observer if defined? @observer_peers
  end

  #
  # Remove all observers associated with this object.
  #
  def delete_observers
    @observer_peers.clear if defined? @observer_peers
  end

  #
  # Return the number of observers associated with this object.
  #
  def count_observers
    if defined? @observer_peers
      @observer_peers.size
    else
      0
    end
  end

  #
  # Set the changed state of this object.  Notifications will be sent only if
  # the changed +state+ is +true+.
  #
  # +state+:: Boolean indicating the changed state of this Observable.
  #
  def changed(state=true)
    @observer_state = state
  end

  #
  # Returns true if this object's state has been changed since the last
  # #notify_observers call.
  #
  def changed?
    if defined? @observer_state and @observer_state
      true
    else
      false
    end
  end

  #
  # Notify observers of a change in state *if* this object's changed state is
  # +true+.
  #
  # This will invoke the method named in #add_observer, passing <tt>*arg</tt>.
  # The changed state is then set to +false+.
  #
  # <tt>*arg</tt>:: Any arguments to pass to the observers.
  def notify_observers(*arg)
    if defined? @observer_state and @observer_state
      if defined? @observer_peers
        @observer_peers.each do |k, v|
          k.send v, *arg
        end
      end
      @observer_state = false
    end
  end

end

Directory Contents

Dirs: 33 × Files: 73

Name Size Perms Modified Actions
bundler DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
cgi DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
csv DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
digest DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
drb DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
e2mmap DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
fiddle DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
fileutils DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
io DIR
- drwxr-xr-x 2024-03-03 22:47:34
Edit Download
irb DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
json DIR
- drwxr-xr-x 2024-03-03 22:47:36
Edit Download
matrix DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
net DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
openssl DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
optparse DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
psych DIR
- drwxr-xr-x 2024-03-03 22:47:37
Edit Download
racc DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
rdoc DIR
- drwxr-xr-x 2024-03-03 22:47:38
Edit Download
rexml DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
rinda DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
ripper DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
rss DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
rubygems DIR
- drwxr-xr-x 2024-03-03 22:47:39
Edit Download
shell DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
syslog DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
thwait DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
tracer DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
uri DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
webrick DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
- drwxr-xr-x 2024-03-03 22:47:37
Edit Download
yaml DIR
- drwxr-xr-x 2024-03-03 22:47:32
Edit Download
3.49 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
3.30 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
18.07 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
179 B lrw-r--r-- 2023-07-26 15:03:15
Edit Download
17.82 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
9.80 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
9.49 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
368 B lrw-r--r-- 2023-07-26 15:03:14
Edit Download
52.00 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
1.01 KB lrw-r--r-- 2023-07-26 15:03:15
Edit Download
29.97 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
10.44 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
2.83 KB lrw-r--r-- 2023-07-26 15:03:15
Edit Download
50 B lrw-r--r-- 2022-04-12 11:50:11
Edit Download
3.94 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
6.31 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
28.73 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
2.17 KB lrw-r--r-- 2023-07-26 15:03:15
Edit Download
1.68 KB lrw-r--r-- 2023-07-26 15:03:15
Edit Download
47.16 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
2.47 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
8.49 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
15.42 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
19.56 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
22.53 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
1.77 KB lrw-r--r-- 2023-07-26 15:03:14
Edit Download
5.77 KB lrw-r--r-- 2023-07-26 15:03:14
Edit Download
23.47 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
60.17 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
84.87 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
7.87 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
2.16 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
5.83 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
25.13 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
21.81 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
469 B lrw-r--r-- 2023-07-26 15:03:14
Edit Download
59 B lrw-r--r-- 2022-04-12 11:50:11
Edit Download
57.74 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
10.65 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
16.17 KB lrw-r--r-- 2023-07-26 15:03:15
Edit Download
15.08 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
15.89 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
12.37 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
235 B lrw-r--r-- 2022-04-12 11:50:11
Edit Download
4.54 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
14.70 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
21.11 KB lrw-r--r-- 2023-07-26 15:03:15
Edit Download
4.88 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
1.76 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
73.44 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
2.44 KB lrw-r--r-- 2023-07-26 15:03:15
Edit Download
2.87 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
36.11 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
23.55 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
8.98 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
24.07 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
11.39 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
6.66 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
4.04 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
43.51 KB lrw-r--r-- 2023-07-26 15:03:15
Edit Download
7.23 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
11.21 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
3.33 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
23.56 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
3.81 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
4.25 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
6.42 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
14.30 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
9.95 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
3.12 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
1.44 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
6.72 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download
1.81 KB lrw-r--r-- 2022-04-12 11:50:11
Edit Download

If ZipArchive is unavailable, a .tar will be created (no compression).