Sha256: 0bdb7cf8a1f3b5f9bd4a1c50c69d5a3e8f039b7bd4395c6da259d73c62935566

Contents?: true

Size: 1.26 KB

Versions: 6

Compression:

Stored size: 1.26 KB

Contents

module Volt
  # A sub context takes in a hash of local variables that should be available
  # in front of the current context.  It basically proxies the local variables
  # first, then failing those proxies the context.
  #
  # SubContext is also used for the attrs in controllers.  You can pass return_nils
  # to have missing values return nil (as in attrs).
  class SubContext
    attr_reader :locals

    def initialize(locals, context = nil, return_nils = false)
      @locals  = locals.stringify_keys
      @context = context
      @return_nils = return_nils
    end

    def respond_to?(method_name)
      !!(@locals[method_name.to_s] || (@context && @context.respond_to?(method_name)))
    end

    def method_missing(method_name, *args, &block)
      method_name = method_name.to_s
      if @locals.key?(method_name)
        obj = @locals[method_name]

        # TODORW: Might get a normal proc, flag internal procs
        if obj.is_a?(Proc)
          obj = obj.call(*args)
        end
        return obj
      elsif @return_nils && method_name[-1] != '='
        return nil
      elsif @context
        return @context.send(method_name, *args, &block)
      end

      fail NoMethodError.new("undefined method `#{method_name}' for \"#{inspect}\":#{self.class}")
    end
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
volt-0.8.21 lib/volt/page/sub_context.rb
volt-0.8.20 lib/volt/page/sub_context.rb
volt-0.8.19 lib/volt/page/sub_context.rb
volt-0.8.18 lib/volt/page/sub_context.rb
volt-0.8.17 lib/volt/page/sub_context.rb
volt-0.8.16 lib/volt/page/sub_context.rb