Module: Elasticsearch::DSL::Search::BaseComponent::InstanceMethods

Defined in:
lib/elasticsearch/dsl/search/base_component.rb

Instance Method Summary collapse

Dynamic Method Handling

This class handles dynamic methods through the method_missing method

#method_missing(name, *args, &block) ⇒ Object (private)



185
186
187
188
189
190
191
# File 'lib/elasticsearch/dsl/search/base_component.rb', line 185

def method_missing(name, *args, &block)
  if @block
    @block.binding.eval('self').send(name, *args, &block)
  else
    super
  end
end

Instance Method Details

#callself

Evaluates any block passed to the query

Returns:

  • (self)


143
144
145
146
147
148
# File 'lib/elasticsearch/dsl/search/base_component.rb', line 143

def call
  if @block
    @block.arity < 1 ? self.instance_eval(&@block) : @block.call(self)
  end
  self
end

#empty?Boolean

Return true when the component definition is empty

Returns:

  • (Boolean)


152
153
154
# File 'lib/elasticsearch/dsl/search/base_component.rb', line 152

def empty?
  to_hash[name].respond_to?(:empty?) && to_hash[name].empty?
end

#nameString

Return the name for instance of the DSL class

Returns:

  • (String)


135
136
137
# File 'lib/elasticsearch/dsl/search/base_component.rb', line 135

def name
  self.class.name
end

#to_hash(options = {}) ⇒ Hash

Convert the query definition to a Hash

A default implementation, DSL classes can overload it.

Returns:

  • (Hash)


162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
# File 'lib/elasticsearch/dsl/search/base_component.rb', line 162

def to_hash(options={})
  case
    # 1. Create hash from the block
    when @block
      @hash = (@args && ! @args.empty?) ? { name => { @args => {} } } : { name => {} }
      call
      @hash[self.name.to_sym].update @options unless @options.empty?
      @hash
    # 2. Hash created with option methods
    when @hash[self.name.to_sym] && ! @args.is_a?(Hash) && @hash[self.name.to_sym][@args]
      @hash[self.name.to_sym].update @options unless @options.empty?
      @hash
    # 3. Hash passsed as @args
    when @hash[self.name.to_sym] && @args.respond_to?(:to_hash) && ! @args.empty?
      { name => @args.to_hash }
    # 4. Hash already built
    else
      @hash
  end
end