PHP 8.2.31
Preview: singleton.rb Size: 3.94 KB
//proc/thread-self/root/opt/alt/ruby33/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.2.0"

  # 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:
      @singleton__instance__ || @singleton__mutex__.synchronize { @singleton__instance__ ||= new }
    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: 32 × Files: 63

Name Size Perms Modified Actions
- drwxr-xr-x 2026-04-30 07:09:18
Edit Download
cgi DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
csv DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
digest DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
drb DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
erb DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
fiddle DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
io DIR
- drwxr-xr-x 2026-04-07 13:52:06
Edit Download
json DIR
- drwxr-xr-x 2026-04-30 07:09:21
Edit Download
logger DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
net DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
objspace DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
open3 DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
openssl DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
optparse DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
prism DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
psych DIR
- drwxr-xr-x 2026-04-30 07:09:18
Edit Download
random DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
reline DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
rinda DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
ripper DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
ruby_vm DIR
- drwxr-xr-x 2024-06-14 07:28:26
Edit Download
set DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
syslog DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
uri DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
- drwxr-xr-x 2026-04-07 13:52:06
Edit Download
yaml DIR
- drwxr-xr-x 2026-04-30 07:09:17
Edit Download
3.47 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
13.22 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
18.42 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
130 B lrw-r--r-- 2026-04-07 13:52:15
Edit Download
6.86 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
9.83 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
368 B lrw-r--r-- 2026-04-07 13:52:15
Edit Download
92.46 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
1.17 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
11.68 KB lrw-r--r-- 2026-04-07 13:52:13
Edit Download
5.36 KB lrw-r--r-- 2026-04-07 13:52:14
Edit Download
3.30 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
50 B lrw-r--r-- 2026-04-07 13:52:15
Edit Download
5.54 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
14.53 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
84 B lrw-r--r-- 2026-04-07 13:52:15
Edit Download
2.19 KB lrw-r--r-- 2026-04-07 13:52:13
Edit Download
2.88 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
78.69 KB lrw-r--r-- 2026-04-07 13:52:13
Edit Download
2.52 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
9.03 KB lrw-r--r-- 2026-04-07 13:52:13
Edit Download
20.26 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
20.93 KB lrw-r--r-- 2026-04-07 13:52:13
Edit Download
19.62 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
5.72 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
22.03 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
88.69 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
6.75 KB lrw-r--r-- 2026-04-07 13:52:13
Edit Download
2.36 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
4.14 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
6.38 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
25.84 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
47.51 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
1.03 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
59 B lrw-r--r-- 2026-04-07 13:52:15
Edit Download
61.82 KB lrw-r--r-- 2026-04-07 13:52:13
Edit Download
14.22 KB lrw-r--r-- 2026-04-07 13:52:14
Edit Download
16.85 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
17.24 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
15.93 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
3.17 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
20.61 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
24.44 KB lrw-r--r-- 2026-04-07 13:52:13
Edit Download
215 B lrw-r--r-- 2026-04-07 13:52:15
Edit Download
14.70 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
1.76 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
85.19 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
2.44 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
2.06 KB lrw-r--r-- 2026-04-07 13:52:13
Edit Download
24.94 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
7.11 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
3.94 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
44.04 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
74 B lrw-r--r-- 2026-04-07 13:52:15
Edit Download
14.73 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
23.74 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
5.69 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
4.93 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
14.29 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
11.17 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
3.06 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
1.36 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download
2.13 KB lrw-r--r-- 2026-04-07 13:52:15
Edit Download

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