PHP 8.2.31
Preview: singleton.rb Size: 4.08 KB
//proc/thread-self/root/opt/alt/ruby31/share/ruby/singleton.rb

# frozen_string_literal: false

# The Singleton module implements the Singleton pattern.
#
# == Usage
#
# To use Singleton, include the module in your class.
#
#    class Klass
#       include Singleton
#       # ...
#    end
#
# This ensures that only one instance of Klass can be created.
#
#      a,b = Klass.instance, Klass.instance
#
#      a == b
#      # => true
#
#      Klass.new
#      # => NoMethodError - new is private ...
#
# The instance is created at upon the first call of Klass.instance().
#
#      class OtherKlass
#        include Singleton
#        # ...
#      end
#
#      ObjectSpace.each_object(OtherKlass){}
#      # => 0
#
#      OtherKlass.instance
#      ObjectSpace.each_object(OtherKlass){}
#      # => 1
#
#
# This behavior is preserved under inheritance and cloning.
#
# == Implementation
#
# This above is achieved by:
#
# *  Making Klass.new and Klass.allocate private.
#
# *  Overriding Klass.inherited(sub_klass) and Klass.clone() to ensure that the
#    Singleton properties are kept when inherited and cloned.
#
# *  Providing the Klass.instance() method that returns the same object each
#    time it is called.
#
# *  Overriding Klass._load(str) to call Klass.instance().
#
# *  Overriding Klass#clone and Klass#dup to raise TypeErrors to prevent
#    cloning or duping.
#
# == Singleton and Marshal
#
# By default Singleton's #_dump(depth) returns the empty string. Marshalling by
# default will strip state information, e.g. instance variables from the instance.
# Classes using Singleton can provide custom _load(str) and _dump(depth) methods
# to retain some of the previous state of the instance.
#
#    require 'singleton'
#
#    class Example
#      include Singleton
#      attr_accessor :keep, :strip
#      def _dump(depth)
#        # this strips the @strip information from the instance
#        Marshal.dump(@keep, depth)
#      end
#
#      def self._load(str)
#        instance.keep = Marshal.load(str)
#        instance
#      end
#    end
#
#    a = Example.instance
#    a.keep = "keep this"
#    a.strip = "get rid of this"
#
#    stored_state = Marshal.dump(a)
#
#    a.keep = nil
#    a.strip = nil
#    b = Marshal.load(stored_state)
#    p a == b  #  => true
#    p a.keep  #  => "keep this"
#    p a.strip #  => nil
#
module Singleton
  VERSION = "0.1.1"

  # Raises a TypeError to prevent cloning.
  def clone
    raise TypeError, "can't clone instance of singleton #{self.class}"
  end

  # Raises a TypeError to prevent duping.
  def dup
    raise TypeError, "can't dup instance of singleton #{self.class}"
  end

  # By default, do not retain any state when marshalling.
  def _dump(depth = -1)
    ''
  end

  module SingletonClassMethods # :nodoc:

    def clone # :nodoc:
      Singleton.__init__(super)
    end

    # By default calls instance(). Override to retain singleton state.
    def _load(str)
      instance
    end

    def instance # :nodoc:
      return @singleton__instance__ if @singleton__instance__
      @singleton__mutex__.synchronize {
        return @singleton__instance__ if @singleton__instance__
        @singleton__instance__ = new()
      }
      @singleton__instance__
    end

    private

    def inherited(sub_klass)
      super
      Singleton.__init__(sub_klass)
    end
  end

  class << Singleton # :nodoc:
    def __init__(klass) # :nodoc:
      klass.instance_eval {
        @singleton__instance__ = nil
        @singleton__mutex__ = Thread::Mutex.new
      }
      klass
    end

    private

    # extending an object with Singleton is a bad idea
    undef_method :extend_object

    def append_features(mod)
      #  help out people counting on transitive mixins
      unless mod.instance_of?(Class)
        raise TypeError, "Inclusion of the OO-Singleton module in module #{mod}"
      end
      super
    end

    def included(klass)
      super
      klass.private_class_method :new, :allocate
      klass.extend SingletonClassMethods
      Singleton.__init__(klass)
    end
  end

  ##
  # :singleton-method: _load
  #  By default calls instance(). Override to retain singleton state.

  ##
  # :singleton-method: instance
  #  Returns the singleton instance.
end

Directory Contents

Dirs: 31 × Files: 61

Name Size Perms Modified Actions
benchmark DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
- drwxr-xr-x 2025-05-13 07:34:59
Edit Download
cgi DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
csv DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
digest DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
drb DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
erb DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
fiddle DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
io DIR
- drwxr-xr-x 2025-04-28 17:36:02
Edit Download
json DIR
- drwxr-xr-x 2025-05-13 07:35:40
Edit Download
logger DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
net DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
objspace DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
open3 DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
openssl DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
optparse DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
psych DIR
- drwxr-xr-x 2025-05-13 07:35:00
Edit Download
racc DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
random DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
reline DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
rinda DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
ripper DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
set DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
syslog DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
uri DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
- drwxr-xr-x 2025-04-28 17:36:02
Edit Download
yaml DIR
- drwxr-xr-x 2025-05-13 07:34:34
Edit Download
3.45 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
3.35 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download
18.40 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
24 B lrw-r--r-- 2025-04-28 17:36:08
Edit Download
9.83 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
368 B lrw-r--r-- 2025-04-28 17:36:08
Edit Download
92.41 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
1.10 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download
11.68 KB lrw-r--r-- 2025-04-28 17:36:06
Edit Download
5.31 KB lrw-r--r-- 2025-04-28 17:36:06
Edit Download
3.30 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
50 B lrw-r--r-- 2025-04-28 17:36:07
Edit Download
6.11 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
28.74 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download
84 B lrw-r--r-- 2025-04-28 17:36:08
Edit Download
2.17 KB lrw-r--r-- 2025-04-28 17:36:06
Edit Download
2.11 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
47.74 KB lrw-r--r-- 2025-04-28 17:36:06
Edit Download
2.50 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
8.98 KB lrw-r--r-- 2025-04-28 17:36:06
Edit Download
15.46 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download
20.58 KB lrw-r--r-- 2025-04-28 17:36:06
Edit Download
19.29 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download
5.72 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
16.54 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
88.12 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
6.76 KB lrw-r--r-- 2025-04-28 17:36:06
Edit Download
2.33 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
2.66 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download
6.38 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
24.88 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
22.11 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download
1.03 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download
59 B lrw-r--r-- 2025-04-28 17:36:08
Edit Download
58.82 KB lrw-r--r-- 2025-04-28 17:36:06
Edit Download
13.78 KB lrw-r--r-- 2025-04-28 17:36:06
Edit Download
16.47 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download
16.69 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download
15.90 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download
14.73 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
24.61 KB lrw-r--r-- 2025-04-28 17:36:06
Edit Download
137 B lrw-r--r-- 2025-04-28 17:36:07
Edit Download
189 B lrw-r--r-- 2025-04-28 17:36:08
Edit Download
17.67 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download
1.76 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download
74.18 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download
2.44 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
2.06 KB lrw-r--r-- 2025-04-28 17:36:06
Edit Download
25.43 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
7.09 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
4.08 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download
43.65 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download
12.43 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
23.72 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download
4.07 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
4.44 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
14.30 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
11.06 KB lrw-r--r-- 2025-04-28 17:36:08
Edit Download
3.06 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download
1.46 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download
1.80 KB lrw-r--r-- 2025-04-28 17:36:07
Edit Download

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