gojee-sunspot 2.0.2 → 2.0.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (178) hide show
  1. metadata +3 -261
  2. data/.gitignore +0 -12
  3. data/Gemfile +0 -5
  4. data/History.txt +0 -252
  5. data/LICENSE +0 -18
  6. data/Rakefile +0 -13
  7. data/TODO +0 -13
  8. data/lib/light_config.rb +0 -40
  9. data/lib/sunspot.rb +0 -579
  10. data/lib/sunspot/adapters.rb +0 -265
  11. data/lib/sunspot/batcher.rb +0 -62
  12. data/lib/sunspot/class_set.rb +0 -23
  13. data/lib/sunspot/composite_setup.rb +0 -202
  14. data/lib/sunspot/configuration.rb +0 -53
  15. data/lib/sunspot/data_extractor.rb +0 -50
  16. data/lib/sunspot/dsl.rb +0 -5
  17. data/lib/sunspot/dsl/adjustable.rb +0 -47
  18. data/lib/sunspot/dsl/field_group.rb +0 -57
  19. data/lib/sunspot/dsl/field_query.rb +0 -327
  20. data/lib/sunspot/dsl/fields.rb +0 -103
  21. data/lib/sunspot/dsl/fulltext.rb +0 -243
  22. data/lib/sunspot/dsl/function.rb +0 -27
  23. data/lib/sunspot/dsl/functional.rb +0 -44
  24. data/lib/sunspot/dsl/more_like_this_query.rb +0 -56
  25. data/lib/sunspot/dsl/paginatable.rb +0 -32
  26. data/lib/sunspot/dsl/query_facet.rb +0 -36
  27. data/lib/sunspot/dsl/restriction.rb +0 -25
  28. data/lib/sunspot/dsl/restriction_with_near.rb +0 -160
  29. data/lib/sunspot/dsl/scope.rb +0 -217
  30. data/lib/sunspot/dsl/search.rb +0 -30
  31. data/lib/sunspot/dsl/standard_query.rb +0 -123
  32. data/lib/sunspot/field.rb +0 -193
  33. data/lib/sunspot/field_factory.rb +0 -129
  34. data/lib/sunspot/indexer.rb +0 -136
  35. data/lib/sunspot/query.rb +0 -11
  36. data/lib/sunspot/query/abstract_field_facet.rb +0 -52
  37. data/lib/sunspot/query/bbox.rb +0 -15
  38. data/lib/sunspot/query/boost_query.rb +0 -24
  39. data/lib/sunspot/query/common_query.rb +0 -96
  40. data/lib/sunspot/query/composite_fulltext.rb +0 -36
  41. data/lib/sunspot/query/connective.rb +0 -206
  42. data/lib/sunspot/query/date_field_facet.rb +0 -14
  43. data/lib/sunspot/query/dismax.rb +0 -132
  44. data/lib/sunspot/query/field_facet.rb +0 -41
  45. data/lib/sunspot/query/field_group.rb +0 -36
  46. data/lib/sunspot/query/filter.rb +0 -38
  47. data/lib/sunspot/query/function_query.rb +0 -52
  48. data/lib/sunspot/query/geo.rb +0 -53
  49. data/lib/sunspot/query/geofilt.rb +0 -16
  50. data/lib/sunspot/query/highlighting.rb +0 -62
  51. data/lib/sunspot/query/more_like_this.rb +0 -61
  52. data/lib/sunspot/query/more_like_this_query.rb +0 -12
  53. data/lib/sunspot/query/pagination.rb +0 -42
  54. data/lib/sunspot/query/query_facet.rb +0 -16
  55. data/lib/sunspot/query/restriction.rb +0 -262
  56. data/lib/sunspot/query/scope.rb +0 -9
  57. data/lib/sunspot/query/sort.rb +0 -109
  58. data/lib/sunspot/query/sort_composite.rb +0 -34
  59. data/lib/sunspot/query/standard_query.rb +0 -16
  60. data/lib/sunspot/query/text_field_boost.rb +0 -17
  61. data/lib/sunspot/schema.rb +0 -151
  62. data/lib/sunspot/search.rb +0 -9
  63. data/lib/sunspot/search/abstract_search.rb +0 -281
  64. data/lib/sunspot/search/date_facet.rb +0 -35
  65. data/lib/sunspot/search/facet_row.rb +0 -27
  66. data/lib/sunspot/search/field_facet.rb +0 -88
  67. data/lib/sunspot/search/field_group.rb +0 -32
  68. data/lib/sunspot/search/group.rb +0 -50
  69. data/lib/sunspot/search/highlight.rb +0 -38
  70. data/lib/sunspot/search/hit.rb +0 -150
  71. data/lib/sunspot/search/hit_enumerable.rb +0 -72
  72. data/lib/sunspot/search/more_like_this_search.rb +0 -31
  73. data/lib/sunspot/search/paginated_collection.rb +0 -57
  74. data/lib/sunspot/search/query_facet.rb +0 -67
  75. data/lib/sunspot/search/standard_search.rb +0 -21
  76. data/lib/sunspot/session.rb +0 -262
  77. data/lib/sunspot/session_proxy.rb +0 -95
  78. data/lib/sunspot/session_proxy/abstract_session_proxy.rb +0 -29
  79. data/lib/sunspot/session_proxy/class_sharding_session_proxy.rb +0 -66
  80. data/lib/sunspot/session_proxy/id_sharding_session_proxy.rb +0 -89
  81. data/lib/sunspot/session_proxy/master_slave_session_proxy.rb +0 -43
  82. data/lib/sunspot/session_proxy/multicore_session_proxy.rb +0 -67
  83. data/lib/sunspot/session_proxy/sharding_session_proxy.rb +0 -222
  84. data/lib/sunspot/session_proxy/silent_fail_session_proxy.rb +0 -42
  85. data/lib/sunspot/session_proxy/thread_local_session_proxy.rb +0 -37
  86. data/lib/sunspot/setup.rb +0 -350
  87. data/lib/sunspot/text_field_setup.rb +0 -29
  88. data/lib/sunspot/type.rb +0 -393
  89. data/lib/sunspot/util.rb +0 -252
  90. data/lib/sunspot/version.rb +0 -3
  91. data/log/.gitignore +0 -1
  92. data/pkg/.gitignore +0 -1
  93. data/script/console +0 -10
  94. data/spec/api/adapters_spec.rb +0 -33
  95. data/spec/api/batcher_spec.rb +0 -112
  96. data/spec/api/binding_spec.rb +0 -50
  97. data/spec/api/class_set_spec.rb +0 -24
  98. data/spec/api/hit_enumerable_spec.rb +0 -47
  99. data/spec/api/indexer/attributes_spec.rb +0 -149
  100. data/spec/api/indexer/batch_spec.rb +0 -72
  101. data/spec/api/indexer/dynamic_fields_spec.rb +0 -42
  102. data/spec/api/indexer/fixed_fields_spec.rb +0 -57
  103. data/spec/api/indexer/fulltext_spec.rb +0 -43
  104. data/spec/api/indexer/removal_spec.rb +0 -53
  105. data/spec/api/indexer/spec_helper.rb +0 -1
  106. data/spec/api/indexer_spec.rb +0 -14
  107. data/spec/api/query/advanced_manipulation_examples.rb +0 -35
  108. data/spec/api/query/connectives_examples.rb +0 -189
  109. data/spec/api/query/dsl_spec.rb +0 -18
  110. data/spec/api/query/dynamic_fields_examples.rb +0 -165
  111. data/spec/api/query/faceting_examples.rb +0 -397
  112. data/spec/api/query/fulltext_examples.rb +0 -313
  113. data/spec/api/query/function_spec.rb +0 -79
  114. data/spec/api/query/geo_examples.rb +0 -68
  115. data/spec/api/query/group_spec.rb +0 -32
  116. data/spec/api/query/highlighting_examples.rb +0 -245
  117. data/spec/api/query/more_like_this_spec.rb +0 -140
  118. data/spec/api/query/ordering_pagination_examples.rb +0 -116
  119. data/spec/api/query/scope_examples.rb +0 -275
  120. data/spec/api/query/spatial_examples.rb +0 -27
  121. data/spec/api/query/spec_helper.rb +0 -1
  122. data/spec/api/query/standard_spec.rb +0 -29
  123. data/spec/api/query/text_field_scoping_examples.rb +0 -30
  124. data/spec/api/query/types_spec.rb +0 -20
  125. data/spec/api/search/dynamic_fields_spec.rb +0 -33
  126. data/spec/api/search/faceting_spec.rb +0 -360
  127. data/spec/api/search/highlighting_spec.rb +0 -69
  128. data/spec/api/search/hits_spec.rb +0 -131
  129. data/spec/api/search/paginated_collection_spec.rb +0 -36
  130. data/spec/api/search/results_spec.rb +0 -72
  131. data/spec/api/search/search_spec.rb +0 -23
  132. data/spec/api/search/spec_helper.rb +0 -1
  133. data/spec/api/session_proxy/class_sharding_session_proxy_spec.rb +0 -85
  134. data/spec/api/session_proxy/id_sharding_session_proxy_spec.rb +0 -30
  135. data/spec/api/session_proxy/master_slave_session_proxy_spec.rb +0 -41
  136. data/spec/api/session_proxy/sharding_session_proxy_spec.rb +0 -77
  137. data/spec/api/session_proxy/silent_fail_session_proxy_spec.rb +0 -24
  138. data/spec/api/session_proxy/spec_helper.rb +0 -9
  139. data/spec/api/session_proxy/thread_local_session_proxy_spec.rb +0 -39
  140. data/spec/api/session_spec.rb +0 -232
  141. data/spec/api/spec_helper.rb +0 -3
  142. data/spec/api/sunspot_spec.rb +0 -29
  143. data/spec/ext.rb +0 -11
  144. data/spec/helpers/indexer_helper.rb +0 -17
  145. data/spec/helpers/integration_helper.rb +0 -8
  146. data/spec/helpers/mock_session_helper.rb +0 -13
  147. data/spec/helpers/query_helper.rb +0 -26
  148. data/spec/helpers/search_helper.rb +0 -68
  149. data/spec/integration/dynamic_fields_spec.rb +0 -57
  150. data/spec/integration/faceting_spec.rb +0 -251
  151. data/spec/integration/field_grouping_spec.rb +0 -66
  152. data/spec/integration/geospatial_spec.rb +0 -85
  153. data/spec/integration/highlighting_spec.rb +0 -44
  154. data/spec/integration/indexing_spec.rb +0 -55
  155. data/spec/integration/keyword_search_spec.rb +0 -317
  156. data/spec/integration/local_search_spec.rb +0 -64
  157. data/spec/integration/more_like_this_spec.rb +0 -43
  158. data/spec/integration/scoped_search_spec.rb +0 -354
  159. data/spec/integration/stored_fields_spec.rb +0 -12
  160. data/spec/integration/test_pagination.rb +0 -43
  161. data/spec/integration/unicode_spec.rb +0 -15
  162. data/spec/mocks/adapters.rb +0 -32
  163. data/spec/mocks/blog.rb +0 -3
  164. data/spec/mocks/comment.rb +0 -21
  165. data/spec/mocks/connection.rb +0 -126
  166. data/spec/mocks/mock_adapter.rb +0 -30
  167. data/spec/mocks/mock_class_sharding_session_proxy.rb +0 -24
  168. data/spec/mocks/mock_record.rb +0 -52
  169. data/spec/mocks/mock_sharding_session_proxy.rb +0 -15
  170. data/spec/mocks/photo.rb +0 -11
  171. data/spec/mocks/post.rb +0 -86
  172. data/spec/mocks/super_class.rb +0 -2
  173. data/spec/mocks/user.rb +0 -13
  174. data/spec/spec_helper.rb +0 -40
  175. data/sunspot.gemspec +0 -42
  176. data/tasks/rdoc.rake +0 -27
  177. data/tasks/schema.rake +0 -19
  178. data/tasks/todo.rake +0 -4
@@ -1,34 +0,0 @@
1
- module Sunspot
2
- module Query
3
- #
4
- # The SortComposite class encapsulates an ordered collection of Sort
5
- # objects. It's necessary to keep this as a separate class as Solr takes
6
- # the sort as a single parameter, so adding sorts as regular components
7
- # would not merge correctly in the #to_params method.
8
- #
9
- class SortComposite #:nodoc:
10
- def initialize
11
- @sorts = []
12
- end
13
-
14
- #
15
- # Add a sort to the composite
16
- #
17
- def <<(sort)
18
- @sorts << sort
19
- end
20
-
21
- #
22
- # Combine the sorts into a single param by joining them
23
- #
24
- def to_params(prefix = "")
25
- unless @sorts.empty?
26
- key = "#{prefix}sort".to_sym
27
- { key => @sorts.map { |sort| sort.to_param } * ', ' }
28
- else
29
- {}
30
- end
31
- end
32
- end
33
- end
34
- end
@@ -1,16 +0,0 @@
1
- module Sunspot
2
- module Query
3
- class StandardQuery < CommonQuery
4
- attr_accessor :scope, :fulltext
5
-
6
- def initialize(types)
7
- super
8
- @components << @fulltext = CompositeFulltext.new
9
- end
10
-
11
- def add_fulltext(keywords)
12
- @fulltext.add(keywords)
13
- end
14
- end
15
- end
16
- end
@@ -1,17 +0,0 @@
1
- module Sunspot
2
- module Query
3
- class TextFieldBoost #:nodoc:
4
- attr_reader :boost
5
-
6
- def initialize(field, boost = nil)
7
- @field, @boost = field, boost
8
- end
9
-
10
- def to_boosted_field
11
- boosted_field = @field.indexed_name
12
- boosted_field.concat("^#{@boost}") if @boost
13
- boosted_field
14
- end
15
- end
16
- end
17
- end
@@ -1,151 +0,0 @@
1
- require 'erb'
2
-
3
- module Sunspot
4
- #
5
- # Object that encapsulates schema information for building a Solr schema.xml
6
- # file. This class is used by the schema:compile task as well as the
7
- # sunspot-configure-solr executable.
8
- #
9
- class Schema #:nodoc:all
10
- FieldType = Struct.new(:name, :class_name, :suffix)
11
- FieldVariant = Struct.new(:attribute, :suffix)
12
-
13
- DEFAULT_TOKENIZER = 'solr.StandardTokenizerFactory'
14
- DEFAULT_FILTERS = %w(solr.StandardFilterFactory solr.LowerCaseFilterFactory)
15
-
16
- FIELD_TYPES = [
17
- FieldType.new('boolean', 'Bool', 'b'),
18
- FieldType.new('sfloat', 'SortableFloat', 'f'),
19
- FieldType.new('date', 'Date', 'd'),
20
- FieldType.new('sint', 'SortableInt', 'i'),
21
- FieldType.new('string', 'Str', 's'),
22
- FieldType.new('sdouble', 'SortableDouble', 'e'),
23
- FieldType.new('slong', 'SortableLong', 'l'),
24
- FieldType.new('tint', 'TrieInteger', 'it'),
25
- FieldType.new('tfloat', 'TrieFloat', 'ft'),
26
- FieldType.new('tdate', 'TrieInt', 'dt')
27
-
28
- ]
29
-
30
- FIELD_VARIANTS = [
31
- FieldVariant.new('multiValued', 'm'),
32
- FieldVariant.new('stored', 's')
33
- ]
34
-
35
- attr_reader :tokenizer, :filters
36
-
37
- def initialize
38
- @tokenizer = DEFAULT_TOKENIZER
39
- @filters = DEFAULT_FILTERS.dup
40
- end
41
-
42
- #
43
- # Attribute field types defined in the schema
44
- #
45
- def types
46
- FIELD_TYPES
47
- end
48
-
49
- #
50
- # DynamicField instances representing all the available types and variants
51
- #
52
- def dynamic_fields
53
- fields = []
54
- variant_combinations.each do |field_variants|
55
- FIELD_TYPES.each do |type|
56
- fields << DynamicField.new(type, field_variants)
57
- end
58
- end
59
- fields
60
- end
61
-
62
- #
63
- # Which tokenizer to use for text fields
64
- #
65
- def tokenizer=(tokenizer)
66
- @tokenizer =
67
- if tokenizer =~ /\./
68
- tokenizer
69
- else
70
- "solr.#{tokenizer}TokenizerFactory"
71
- end
72
- end
73
-
74
- #
75
- # Add a filter for text field tokenization
76
- #
77
- def add_filter(filter)
78
- @filters <<
79
- if filter =~ /\./
80
- filter
81
- else
82
- "solr.#{filter}FilterFactory"
83
- end
84
- end
85
-
86
- #
87
- # Return an XML representation of this schema using the ERB template
88
- #
89
- def to_xml
90
- template = File.join(File.dirname(__FILE__), '..', '..', 'templates', 'schema.xml.erb')
91
- ERB.new(File.read(template), nil, '-').result(binding)
92
- end
93
-
94
- private
95
-
96
- #
97
- # All of the possible combinations of variants
98
- #
99
- def variant_combinations
100
- combinations = []
101
- 0.upto(2 ** FIELD_VARIANTS.length - 1) do |b|
102
- combinations << combination = []
103
- FIELD_VARIANTS.each_with_index do |variant, i|
104
- combination << variant if b & 1<<i > 0
105
- end
106
- end
107
- combinations
108
- end
109
-
110
- #
111
- # Represents a dynamic field (in the Solr schema sense, not the Sunspot
112
- # sense).
113
- #
114
- class DynamicField
115
- def initialize(type, field_variants)
116
- @type, @field_variants = type, field_variants
117
- end
118
-
119
- #
120
- # Name of the field in the schema
121
- #
122
- def name
123
- variant_suffixes = @field_variants.map { |variant| variant.suffix }.join
124
- "*_#{@type.suffix}#{variant_suffixes}"
125
- end
126
-
127
- #
128
- # Name of the type as defined in the schema
129
- #
130
- def type
131
- @type.name
132
- end
133
-
134
- #
135
- # Implement magic methods to ask if a field is of a particular variant.
136
- # Returns "true" if the field is of that variant and "false" otherwise.
137
- #
138
- def method_missing(name, *args, &block)
139
- if name.to_s =~ /\?$/ && args.empty?
140
- if @field_variants.any? { |variant| "#{variant.attribute}?" == name.to_s }
141
- 'true'
142
- else
143
- 'false'
144
- end
145
- else
146
- super(name.to_sym, *args, &block)
147
- end
148
- end
149
- end
150
- end
151
- end
@@ -1,9 +0,0 @@
1
- %w(abstract_search standard_search more_like_this_search query_facet field_facet
2
- date_facet facet_row hit highlight field_group group hit_enumerable).each do |file|
3
- require File.join(File.dirname(__FILE__), 'search', file)
4
- end
5
-
6
- module Sunspot
7
- module Search
8
- end
9
- end
@@ -1,281 +0,0 @@
1
- require 'sunspot/search/paginated_collection'
2
- require 'sunspot/search/hit_enumerable'
3
-
4
- module Sunspot
5
- module Search #:nodoc:
6
-
7
- #
8
- # This class encapsulates the results of a Solr search. It provides access
9
- # to search results, total result count, facets, and pagination information.
10
- # Instances of Search are returned by the Sunspot.search and
11
- # Sunspot.new_search methods.
12
- #
13
- class AbstractSearch
14
- #
15
- # Retrieve all facet objects defined for this search, in order they were
16
- # defined. To retrieve an individual facet by name, use #facet()
17
- #
18
- attr_reader :facets, :groups
19
- attr_reader :query #:nodoc:
20
- attr_accessor :request_handler
21
-
22
- include HitEnumerable
23
-
24
- def initialize(connection, setup, query, configuration) #:nodoc:
25
- @connection, @setup, @query = connection, setup, query
26
- @query.paginate(1, configuration.pagination.default_per_page)
27
-
28
- @facets = []
29
- @facets_by_name = {}
30
-
31
- @groups_by_name = {}
32
- @groups = []
33
- end
34
-
35
- #
36
- # Execute the search on the Solr instance and store the results. If you
37
- # use Sunspot#search() to construct your searches, there is no need to call
38
- # this method as it has already been called. If you use
39
- # Sunspot#new_search(), you will need to call this method after building the
40
- # query.
41
- #
42
- def execute
43
- reset
44
- params = @query.to_params
45
- @solr_result = @connection.post "#{request_handler}", :data => params
46
- self
47
- end
48
-
49
- def execute! #:nodoc: deprecated
50
- execute
51
- end
52
-
53
- #
54
- # Get the collection of results as instantiated objects. If WillPaginate is
55
- # available, the results will be a WillPaginate::Collection instance; if
56
- # not, it will be a vanilla Array.
57
- #
58
- # If not all of the results referenced by the Solr hits actually exist in
59
- # the data store, Sunspot will only return the results that do exist.
60
- #
61
- # ==== Returns
62
- #
63
- # WillPaginate::Collection or Array:: Instantiated result objects
64
- #
65
- def results
66
- @results ||= paginate_collection(verified_hits.map { |hit| hit.instance })
67
- end
68
-
69
- #
70
- # Access raw Solr result information. Returns a collection of Hit objects
71
- # that contain the class name, primary key, keyword relevance score (if
72
- # applicable), and any stored fields.
73
- #
74
- # ==== Options (options)
75
- #
76
- # :verify::
77
- # Only return hits that reference objects that actually exist in the data
78
- # store. This causes results to be eager-loaded from the data store,
79
- # unlike the normal behavior of this method, which only loads the
80
- # referenced results when Hit#result is first called.
81
- #
82
- # ==== Returns
83
- #
84
- # Array:: Ordered collection of Hit objects
85
- #
86
- def hits(options = {})
87
- if options[:verify]
88
- super
89
- else
90
- @hits ||= paginate_collection(super)
91
- end
92
- end
93
- alias_method :raw_results, :hits
94
-
95
- #
96
- # The total number of documents matching the query parameters
97
- #
98
- # ==== Returns
99
- #
100
- # Integer:: Total matching documents
101
- #
102
- def total
103
- @total ||= solr_response['numFound'] || 0
104
- end
105
-
106
- #
107
- # The time elapsed to generate the Solr response
108
- #
109
- # ==== Returns
110
- #
111
- # Integer:: Query runtime in milliseconds
112
- #
113
- def query_time
114
- @query_time ||= solr_response_header['QTime']
115
- end
116
-
117
- #
118
- # Get the facet object for the given name. `name` can either be the name
119
- # given to a query facet, or the field name of a field facet. Returns a
120
- # Sunspot::Facet object.
121
- #
122
- # ==== Parameters
123
- #
124
- # name<Symbol>::
125
- # Name of the field to return the facet for, or the name given to the
126
- # query facet when the search was constructed.
127
- # dynamic_name<Symbol>::
128
- # If faceting on a dynamic field, this is the dynamic portion of the field
129
- # name.
130
- #
131
- # ==== Example:
132
- #
133
- # search = Sunspot.search(Post) do
134
- # facet :category_ids
135
- # dynamic :custom do
136
- # facet :cuisine
137
- # end
138
- # facet :age do
139
- # row 'Less than a month' do
140
- # with(:published_at).greater_than(1.month.ago)
141
- # end
142
- # row 'Less than a year' do
143
- # with(:published_at, 1.year.ago..1.month.ago)
144
- # end
145
- # row 'More than a year' do
146
- # with(:published_at).less_than(1.year.ago)
147
- # end
148
- # end
149
- # end
150
- # search.facet(:category_ids)
151
- # #=> Facet for :category_ids field
152
- # search.facet(:custom, :cuisine)
153
- # #=> Facet for the dynamic field :cuisine in the :custom field definition
154
- # search.facet(:age)
155
- # #=> Facet for the query facet named :age
156
- #
157
- def facet(name, dynamic_name = nil)
158
- if name
159
- if dynamic_name
160
- @facets_by_name[:"#{name}:#{dynamic_name}"]
161
- else
162
- @facets_by_name[name.to_sym]
163
- end
164
- end
165
- end
166
-
167
- def group(name)
168
- if name
169
- @groups_by_name[name.to_sym]
170
- end
171
- end
172
-
173
- #
174
- # Deprecated in favor of optional second argument to #facet
175
- #
176
- def dynamic_facet(base_name, dynamic_name) #:nodoc:
177
- facet(base_name, dynamic_name)
178
- end
179
-
180
- def facet_response #:nodoc:
181
- @solr_result['facet_counts']
182
- end
183
-
184
- def group_response #:nodoc:
185
- @solr_result['grouped']
186
- end
187
-
188
- #
189
- # Build this search using a DSL block. This method can be called more than
190
- # once on an unexecuted search (e.g., Sunspot.new_search) in order to build
191
- # a search incrementally.
192
- #
193
- # === Example
194
- #
195
- # search = Sunspot.new_search(Post)
196
- # search.build do
197
- # with(:published_at).less_than Time.now
198
- # end
199
- # search.execute
200
- #
201
- def build(&block)
202
- Util.instance_eval_or_call(dsl, &block)
203
- self
204
- end
205
-
206
-
207
- def inspect #:nodoc:
208
- "<Sunspot::Search:#{query.to_params.inspect}>"
209
- end
210
-
211
- def add_field_group(field, options = {}) #:nodoc:
212
- add_group(field.name, FieldGroup.new(field, self, options))
213
- end
214
-
215
- def add_field_facet(field, options = {}) #:nodoc:
216
- name = (options[:name] || field.name)
217
- add_facet(name, FieldFacet.new(field, self, options))
218
- end
219
-
220
- def add_query_facet(name, options) #:nodoc:
221
- add_facet(name, QueryFacet.new(name, self, options))
222
- end
223
-
224
- def add_date_facet(field, options) #:nodoc:
225
- name = (options[:name] || field.name)
226
- add_facet(name, DateFacet.new(field, self, options))
227
- end
228
-
229
- def highlights_for(doc) #:nodoc:
230
- if @solr_result['highlighting']
231
- @solr_result['highlighting'][doc['id']]
232
- end
233
- end
234
-
235
- private
236
-
237
- def dsl
238
- raise NotImplementedError
239
- end
240
-
241
- def execute_request(params)
242
- raise NotImplementedError
243
- end
244
-
245
- def solr_response
246
- @solr_response ||= @solr_result['response'] || {}
247
- end
248
-
249
- def solr_response_header
250
- @solr_response_header ||= @solr_result['responseHeader'] || {}
251
- end
252
-
253
- def solr_docs
254
- solr_response['docs']
255
- end
256
-
257
- def verified_hits
258
- @verified_hits ||= paginate_collection(super)
259
- end
260
-
261
- def paginate_collection(collection)
262
- PaginatedCollection.new(collection, @query.page, @query.per_page, total)
263
- end
264
-
265
- def add_facet(name, facet)
266
- @facets << facet
267
- @facets_by_name[name.to_sym] = facet
268
- end
269
-
270
- def add_group(name, group)
271
- @groups << group
272
- @groups_by_name[name.to_sym] = group
273
- end
274
-
275
- # Clear out all the cached ivars so the search can be called again.
276
- def reset
277
- @results = @hits = @verified_hits = @total = @solr_response = @doc_ids = nil
278
- end
279
- end
280
- end
281
- end