File: base.rb

package info (click to toggle)
ruby-open-graph-reader 0.6.2%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 9,980 kB
  • ctags: 133
  • sloc: ruby: 1,505; xml: 22; makefile: 2
file content (70 lines) | stat: -rw-r--r-- 1,793 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
require "forwardable"

module OpenGraphReader
  # You get an instance of this class as result of your quest to obtain
  # an OpenGraph object. It simply contains and returns the root objects,
  # most commonly <tt>og</tt>.
  class Base
    extend Forwardable

    # @!method [](name)
    #   Get a root object by name.
    #
    #   @param [String] name The name of the root namespace.
    #   @return [Object, nil] The corresponding root object if available.
    #   @api private
    # @!method []=(name, object)
    #   Make a new root object available on this base.
    #
    #   @param [String] name The name of the root namespace.
    #   @param [Object] object The corresponding root object.
    #   @api private
    # @!method each
    #   Traverse the available objects
    #
    #   @yield [Object]
    #   @api private
    def_delegators :@bases, :[], :[]=, :each_value
    alias_method :each, :each_value

    # If available, contains the source location of the document the
    # available objects were parsed from.
    #
    # @return [String, nil]
    attr_reader :origin

    # Set origin.
    #
    # @api private
    # @see #origin
    attr_writer :origin

    # Return the stored root objects as a hash.
    #
    # @api private
    # @return [String => Object]
    attr_reader :bases
    alias_method :children, :bases

    # @api private
    def initialize
      @bases = {}
    end

    # @private
    def respond_to_missing?(method, _include_private=false)
      @bases.has_key? method.to_s
    end

    # Makes the found root objects available.
    # @return [Object]
    def method_missing(method, *args, &block)
      name = method.to_s
      if respond_to_missing? name
        @bases[name]
      else
        super(method, *args, &block)
      end
    end
  end
end