Module: Elasticsearch::DSL::Search::BaseComponent::InstanceMethods
- Defined in:
- lib/elasticsearch/dsl/search/base_component.rb
Instance Method Summary collapse
-
#call ⇒ self
Evaluates any block passed to the query.
-
#empty? ⇒ Boolean
Return true when the component definition is empty.
-
#name ⇒ String
Return the name for instance of the DSL class.
-
#to_hash(options = {}) ⇒ Hash
Convert the query definition to a Hash.
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
#call ⇒ self
Evaluates any block passed to the query
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
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 |
#name ⇒ String
Return the name for instance of the DSL class
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.
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(={}) 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 |