sunspot_rails 2.0.0.pre.120924 → 2.0.0.pre.120925

Sign up to get free protection for your applications and to get access to all the features.
Files changed (293) hide show
  1. data/.gitignore +6 -10
  2. data/{sunspot_rails/.rspec → .rspec} +0 -0
  3. data/{sunspot_rails/History.txt → History.txt} +0 -0
  4. data/{sunspot/LICENSE → LICENSE} +0 -0
  5. data/{sunspot_rails/MIT-LICENSE → MIT-LICENSE} +0 -0
  6. data/{sunspot_rails/README.rdoc → README.rdoc} +0 -0
  7. data/Rakefile +12 -32
  8. data/{sunspot_rails/TODO → TODO} +0 -0
  9. data/{sunspot_rails/dev_tasks → dev_tasks}/rdoc.rake +0 -0
  10. data/{sunspot_rails/dev_tasks → dev_tasks}/release.rake +0 -0
  11. data/{sunspot_rails/dev_tasks → dev_tasks}/spec.rake +0 -0
  12. data/{sunspot/tasks → dev_tasks}/todo.rake +0 -0
  13. data/{sunspot_rails/gemfiles → gemfiles}/rails-2.3.14 +0 -0
  14. data/{sunspot_rails/gemfiles → gemfiles}/rails-3.0.15 +0 -0
  15. data/{sunspot_rails/gemfiles → gemfiles}/rails-3.1.6 +0 -0
  16. data/{sunspot_rails/gemfiles → gemfiles}/rails-3.2.6 +0 -0
  17. data/{sunspot_rails/generators → generators}/sunspot/sunspot_generator.rb +0 -0
  18. data/{sunspot_rails/generators → generators}/sunspot/templates/sunspot.yml +0 -0
  19. data/{sunspot_rails/install.rb → install.rb} +0 -0
  20. data/{sunspot_rails/lib → lib}/generators/sunspot_rails.rb +0 -0
  21. data/{sunspot_rails/lib → lib}/generators/sunspot_rails/install/install_generator.rb +0 -0
  22. data/{sunspot_rails/lib → lib}/generators/sunspot_rails/install/templates/config/sunspot.yml +0 -0
  23. data/{sunspot_rails/lib → lib}/sunspot/rails.rb +0 -0
  24. data/{sunspot_rails/lib → lib}/sunspot/rails/adapters.rb +0 -0
  25. data/{sunspot_rails/lib → lib}/sunspot/rails/configuration.rb +0 -0
  26. data/{sunspot_rails/lib → lib}/sunspot/rails/init.rb +0 -0
  27. data/{sunspot_rails/lib → lib}/sunspot/rails/log_subscriber.rb +0 -0
  28. data/{sunspot_rails/lib → lib}/sunspot/rails/railtie.rb +0 -0
  29. data/{sunspot_rails/lib → lib}/sunspot/rails/railties/controller_runtime.rb +0 -0
  30. data/{sunspot_rails/lib → lib}/sunspot/rails/request_lifecycle.rb +0 -0
  31. data/{sunspot_rails/lib → lib}/sunspot/rails/searchable.rb +0 -0
  32. data/{sunspot_rails/lib → lib}/sunspot/rails/server.rb +0 -0
  33. data/{sunspot_rails/lib → lib}/sunspot/rails/solr_instrumentation.rb +0 -0
  34. data/{sunspot_rails/lib → lib}/sunspot/rails/solr_logging.rb +0 -0
  35. data/{sunspot_rails/lib → lib}/sunspot/rails/spec_helper.rb +0 -0
  36. data/{sunspot_rails/lib → lib}/sunspot/rails/stub_session_proxy.rb +0 -0
  37. data/{sunspot_rails/lib → lib}/sunspot/rails/tasks.rb +0 -0
  38. data/{sunspot_rails/lib → lib}/sunspot_rails.rb +0 -0
  39. data/{sunspot_rails/spec → spec}/configuration_spec.rb +0 -0
  40. data/{sunspot_rails/spec → spec}/model_lifecycle_spec.rb +0 -0
  41. data/{sunspot_rails/spec → spec}/model_spec.rb +0 -0
  42. data/{sunspot_rails/spec → spec}/rails_template/app/controllers/application_controller.rb +0 -0
  43. data/{sunspot_rails/spec → spec}/rails_template/app/controllers/posts_controller.rb +0 -0
  44. data/{sunspot_rails/spec → spec}/rails_template/app/models/author.rb +0 -0
  45. data/{sunspot_rails/spec → spec}/rails_template/app/models/blog.rb +0 -0
  46. data/{sunspot_rails/spec → spec}/rails_template/app/models/location.rb +0 -0
  47. data/{sunspot_rails/spec → spec}/rails_template/app/models/photo_post.rb +0 -0
  48. data/{sunspot_rails/spec → spec}/rails_template/app/models/post.rb +0 -0
  49. data/{sunspot_rails/spec → spec}/rails_template/app/models/post_with_auto.rb +0 -0
  50. data/{sunspot_rails/spec → spec}/rails_template/app/models/post_with_default_scope.rb +0 -0
  51. data/{sunspot_rails/spec → spec}/rails_template/config/boot.rb +0 -0
  52. data/{sunspot_rails/spec → spec}/rails_template/config/preinitializer.rb +0 -0
  53. data/{sunspot_rails/spec → spec}/rails_template/config/routes.rb +0 -0
  54. data/{sunspot_rails/spec → spec}/rails_template/config/sunspot.yml +0 -0
  55. data/{sunspot_rails/spec → spec}/rails_template/db/schema.rb +0 -0
  56. data/{sunspot_rails/spec → spec}/request_lifecycle_spec.rb +0 -0
  57. data/{sunspot_rails/spec → spec}/schema.rb +0 -0
  58. data/{sunspot_rails/spec → spec}/searchable_spec.rb +0 -0
  59. data/{sunspot_rails/spec → spec}/server_spec.rb +0 -0
  60. data/{sunspot_rails/spec → spec}/session_spec.rb +0 -0
  61. data/{sunspot_rails/spec → spec}/shared_examples/indexed_after_save.rb +0 -0
  62. data/{sunspot_rails/spec → spec}/shared_examples/not_indexed_after_save.rb +0 -0
  63. data/{sunspot_rails/spec → spec}/spec_helper.rb +0 -0
  64. data/{sunspot_rails/spec → spec}/stub_session_proxy_spec.rb +0 -0
  65. data/{sunspot_rails/sunspot_rails.gemspec → sunspot_rails.gemspec} +0 -0
  66. metadata +102 -305
  67. data/.travis.yml +0 -35
  68. data/README.md +0 -863
  69. data/ci/travis.sh +0 -67
  70. data/sunspot/.gitignore +0 -13
  71. data/sunspot/Gemfile +0 -5
  72. data/sunspot/History.txt +0 -258
  73. data/sunspot/Rakefile +0 -13
  74. data/sunspot/TODO +0 -13
  75. data/sunspot/lib/light_config.rb +0 -40
  76. data/sunspot/lib/sunspot.rb +0 -579
  77. data/sunspot/lib/sunspot/adapters.rb +0 -349
  78. data/sunspot/lib/sunspot/batcher.rb +0 -62
  79. data/sunspot/lib/sunspot/class_set.rb +0 -23
  80. data/sunspot/lib/sunspot/composite_setup.rb +0 -202
  81. data/sunspot/lib/sunspot/configuration.rb +0 -53
  82. data/sunspot/lib/sunspot/data_extractor.rb +0 -50
  83. data/sunspot/lib/sunspot/dsl.rb +0 -5
  84. data/sunspot/lib/sunspot/dsl/adjustable.rb +0 -47
  85. data/sunspot/lib/sunspot/dsl/field_group.rb +0 -57
  86. data/sunspot/lib/sunspot/dsl/field_query.rb +0 -345
  87. data/sunspot/lib/sunspot/dsl/fields.rb +0 -103
  88. data/sunspot/lib/sunspot/dsl/fulltext.rb +0 -243
  89. data/sunspot/lib/sunspot/dsl/function.rb +0 -27
  90. data/sunspot/lib/sunspot/dsl/functional.rb +0 -44
  91. data/sunspot/lib/sunspot/dsl/more_like_this_query.rb +0 -56
  92. data/sunspot/lib/sunspot/dsl/paginatable.rb +0 -32
  93. data/sunspot/lib/sunspot/dsl/query_facet.rb +0 -36
  94. data/sunspot/lib/sunspot/dsl/restriction.rb +0 -25
  95. data/sunspot/lib/sunspot/dsl/restriction_with_near.rb +0 -160
  96. data/sunspot/lib/sunspot/dsl/scope.rb +0 -214
  97. data/sunspot/lib/sunspot/dsl/search.rb +0 -30
  98. data/sunspot/lib/sunspot/dsl/standard_query.rb +0 -122
  99. data/sunspot/lib/sunspot/field.rb +0 -193
  100. data/sunspot/lib/sunspot/field_factory.rb +0 -129
  101. data/sunspot/lib/sunspot/indexer.rb +0 -136
  102. data/sunspot/lib/sunspot/query.rb +0 -11
  103. data/sunspot/lib/sunspot/query/abstract_field_facet.rb +0 -55
  104. data/sunspot/lib/sunspot/query/bbox.rb +0 -15
  105. data/sunspot/lib/sunspot/query/boost_query.rb +0 -24
  106. data/sunspot/lib/sunspot/query/common_query.rb +0 -96
  107. data/sunspot/lib/sunspot/query/composite_fulltext.rb +0 -36
  108. data/sunspot/lib/sunspot/query/connective.rb +0 -206
  109. data/sunspot/lib/sunspot/query/date_field_facet.rb +0 -14
  110. data/sunspot/lib/sunspot/query/dismax.rb +0 -132
  111. data/sunspot/lib/sunspot/query/field_facet.rb +0 -41
  112. data/sunspot/lib/sunspot/query/field_group.rb +0 -37
  113. data/sunspot/lib/sunspot/query/filter.rb +0 -38
  114. data/sunspot/lib/sunspot/query/function_query.rb +0 -52
  115. data/sunspot/lib/sunspot/query/geo.rb +0 -53
  116. data/sunspot/lib/sunspot/query/geofilt.rb +0 -16
  117. data/sunspot/lib/sunspot/query/highlighting.rb +0 -62
  118. data/sunspot/lib/sunspot/query/more_like_this.rb +0 -61
  119. data/sunspot/lib/sunspot/query/more_like_this_query.rb +0 -12
  120. data/sunspot/lib/sunspot/query/pagination.rb +0 -42
  121. data/sunspot/lib/sunspot/query/query_facet.rb +0 -53
  122. data/sunspot/lib/sunspot/query/range_facet.rb +0 -15
  123. data/sunspot/lib/sunspot/query/restriction.rb +0 -308
  124. data/sunspot/lib/sunspot/query/scope.rb +0 -9
  125. data/sunspot/lib/sunspot/query/sort.rb +0 -109
  126. data/sunspot/lib/sunspot/query/sort_composite.rb +0 -34
  127. data/sunspot/lib/sunspot/query/standard_query.rb +0 -16
  128. data/sunspot/lib/sunspot/query/text_field_boost.rb +0 -17
  129. data/sunspot/lib/sunspot/schema.rb +0 -151
  130. data/sunspot/lib/sunspot/search.rb +0 -9
  131. data/sunspot/lib/sunspot/search/abstract_search.rb +0 -286
  132. data/sunspot/lib/sunspot/search/date_facet.rb +0 -35
  133. data/sunspot/lib/sunspot/search/facet_row.rb +0 -27
  134. data/sunspot/lib/sunspot/search/field_facet.rb +0 -88
  135. data/sunspot/lib/sunspot/search/field_group.rb +0 -70
  136. data/sunspot/lib/sunspot/search/group.rb +0 -54
  137. data/sunspot/lib/sunspot/search/highlight.rb +0 -38
  138. data/sunspot/lib/sunspot/search/hit.rb +0 -150
  139. data/sunspot/lib/sunspot/search/hit_enumerable.rb +0 -68
  140. data/sunspot/lib/sunspot/search/more_like_this_search.rb +0 -31
  141. data/sunspot/lib/sunspot/search/paginated_collection.rb +0 -57
  142. data/sunspot/lib/sunspot/search/query_facet.rb +0 -67
  143. data/sunspot/lib/sunspot/search/range_facet.rb +0 -37
  144. data/sunspot/lib/sunspot/search/standard_search.rb +0 -21
  145. data/sunspot/lib/sunspot/session.rb +0 -262
  146. data/sunspot/lib/sunspot/session_proxy.rb +0 -95
  147. data/sunspot/lib/sunspot/session_proxy/abstract_session_proxy.rb +0 -29
  148. data/sunspot/lib/sunspot/session_proxy/class_sharding_session_proxy.rb +0 -66
  149. data/sunspot/lib/sunspot/session_proxy/id_sharding_session_proxy.rb +0 -89
  150. data/sunspot/lib/sunspot/session_proxy/master_slave_session_proxy.rb +0 -43
  151. data/sunspot/lib/sunspot/session_proxy/retry_5xx_session_proxy.rb +0 -67
  152. data/sunspot/lib/sunspot/session_proxy/sharding_session_proxy.rb +0 -222
  153. data/sunspot/lib/sunspot/session_proxy/silent_fail_session_proxy.rb +0 -42
  154. data/sunspot/lib/sunspot/session_proxy/thread_local_session_proxy.rb +0 -37
  155. data/sunspot/lib/sunspot/setup.rb +0 -350
  156. data/sunspot/lib/sunspot/text_field_setup.rb +0 -29
  157. data/sunspot/lib/sunspot/type.rb +0 -393
  158. data/sunspot/lib/sunspot/util.rb +0 -252
  159. data/sunspot/lib/sunspot/version.rb +0 -3
  160. data/sunspot/script/console +0 -10
  161. data/sunspot/spec/api/adapters_spec.rb +0 -68
  162. data/sunspot/spec/api/batcher_spec.rb +0 -112
  163. data/sunspot/spec/api/binding_spec.rb +0 -50
  164. data/sunspot/spec/api/class_set_spec.rb +0 -24
  165. data/sunspot/spec/api/hit_enumerable_spec.rb +0 -47
  166. data/sunspot/spec/api/indexer/attributes_spec.rb +0 -149
  167. data/sunspot/spec/api/indexer/batch_spec.rb +0 -72
  168. data/sunspot/spec/api/indexer/dynamic_fields_spec.rb +0 -42
  169. data/sunspot/spec/api/indexer/fixed_fields_spec.rb +0 -57
  170. data/sunspot/spec/api/indexer/fulltext_spec.rb +0 -43
  171. data/sunspot/spec/api/indexer/removal_spec.rb +0 -53
  172. data/sunspot/spec/api/indexer/spec_helper.rb +0 -1
  173. data/sunspot/spec/api/indexer_spec.rb +0 -14
  174. data/sunspot/spec/api/query/advanced_manipulation_examples.rb +0 -35
  175. data/sunspot/spec/api/query/connectives_examples.rb +0 -201
  176. data/sunspot/spec/api/query/dsl_spec.rb +0 -18
  177. data/sunspot/spec/api/query/dynamic_fields_examples.rb +0 -165
  178. data/sunspot/spec/api/query/faceting_examples.rb +0 -497
  179. data/sunspot/spec/api/query/fulltext_examples.rb +0 -313
  180. data/sunspot/spec/api/query/function_spec.rb +0 -79
  181. data/sunspot/spec/api/query/geo_examples.rb +0 -68
  182. data/sunspot/spec/api/query/group_spec.rb +0 -32
  183. data/sunspot/spec/api/query/highlighting_examples.rb +0 -245
  184. data/sunspot/spec/api/query/more_like_this_spec.rb +0 -140
  185. data/sunspot/spec/api/query/ordering_pagination_examples.rb +0 -116
  186. data/sunspot/spec/api/query/scope_examples.rb +0 -275
  187. data/sunspot/spec/api/query/spatial_examples.rb +0 -27
  188. data/sunspot/spec/api/query/spec_helper.rb +0 -1
  189. data/sunspot/spec/api/query/standard_spec.rb +0 -29
  190. data/sunspot/spec/api/query/text_field_scoping_examples.rb +0 -30
  191. data/sunspot/spec/api/query/types_spec.rb +0 -20
  192. data/sunspot/spec/api/search/dynamic_fields_spec.rb +0 -33
  193. data/sunspot/spec/api/search/faceting_spec.rb +0 -360
  194. data/sunspot/spec/api/search/highlighting_spec.rb +0 -69
  195. data/sunspot/spec/api/search/hits_spec.rb +0 -147
  196. data/sunspot/spec/api/search/paginated_collection_spec.rb +0 -36
  197. data/sunspot/spec/api/search/results_spec.rb +0 -72
  198. data/sunspot/spec/api/search/search_spec.rb +0 -23
  199. data/sunspot/spec/api/search/spec_helper.rb +0 -1
  200. data/sunspot/spec/api/session_proxy/class_sharding_session_proxy_spec.rb +0 -85
  201. data/sunspot/spec/api/session_proxy/id_sharding_session_proxy_spec.rb +0 -30
  202. data/sunspot/spec/api/session_proxy/master_slave_session_proxy_spec.rb +0 -41
  203. data/sunspot/spec/api/session_proxy/retry_5xx_session_proxy_spec.rb +0 -78
  204. data/sunspot/spec/api/session_proxy/sharding_session_proxy_spec.rb +0 -77
  205. data/sunspot/spec/api/session_proxy/silent_fail_session_proxy_spec.rb +0 -24
  206. data/sunspot/spec/api/session_proxy/spec_helper.rb +0 -9
  207. data/sunspot/spec/api/session_proxy/thread_local_session_proxy_spec.rb +0 -39
  208. data/sunspot/spec/api/session_spec.rb +0 -232
  209. data/sunspot/spec/api/spec_helper.rb +0 -3
  210. data/sunspot/spec/api/sunspot_spec.rb +0 -29
  211. data/sunspot/spec/ext.rb +0 -11
  212. data/sunspot/spec/helpers/indexer_helper.rb +0 -17
  213. data/sunspot/spec/helpers/integration_helper.rb +0 -8
  214. data/sunspot/spec/helpers/mock_session_helper.rb +0 -13
  215. data/sunspot/spec/helpers/query_helper.rb +0 -26
  216. data/sunspot/spec/helpers/search_helper.rb +0 -68
  217. data/sunspot/spec/integration/dynamic_fields_spec.rb +0 -57
  218. data/sunspot/spec/integration/faceting_spec.rb +0 -330
  219. data/sunspot/spec/integration/field_grouping_spec.rb +0 -100
  220. data/sunspot/spec/integration/geospatial_spec.rb +0 -96
  221. data/sunspot/spec/integration/highlighting_spec.rb +0 -44
  222. data/sunspot/spec/integration/indexing_spec.rb +0 -55
  223. data/sunspot/spec/integration/keyword_search_spec.rb +0 -317
  224. data/sunspot/spec/integration/local_search_spec.rb +0 -64
  225. data/sunspot/spec/integration/more_like_this_spec.rb +0 -43
  226. data/sunspot/spec/integration/scoped_search_spec.rb +0 -386
  227. data/sunspot/spec/integration/stored_fields_spec.rb +0 -12
  228. data/sunspot/spec/integration/test_pagination.rb +0 -43
  229. data/sunspot/spec/integration/unicode_spec.rb +0 -15
  230. data/sunspot/spec/mocks/adapters.rb +0 -33
  231. data/sunspot/spec/mocks/blog.rb +0 -3
  232. data/sunspot/spec/mocks/comment.rb +0 -21
  233. data/sunspot/spec/mocks/connection.rb +0 -126
  234. data/sunspot/spec/mocks/mock_adapter.rb +0 -30
  235. data/sunspot/spec/mocks/mock_class_sharding_session_proxy.rb +0 -24
  236. data/sunspot/spec/mocks/mock_record.rb +0 -52
  237. data/sunspot/spec/mocks/mock_sharding_session_proxy.rb +0 -15
  238. data/sunspot/spec/mocks/photo.rb +0 -11
  239. data/sunspot/spec/mocks/post.rb +0 -86
  240. data/sunspot/spec/mocks/super_class.rb +0 -2
  241. data/sunspot/spec/mocks/user.rb +0 -13
  242. data/sunspot/spec/spec_helper.rb +0 -40
  243. data/sunspot/sunspot.gemspec +0 -37
  244. data/sunspot/tasks/rdoc.rake +0 -27
  245. data/sunspot/tasks/schema.rake +0 -19
  246. data/sunspot_rails/.gitignore +0 -7
  247. data/sunspot_rails/LICENSE +0 -18
  248. data/sunspot_rails/Rakefile +0 -17
  249. data/sunspot_rails/dev_tasks/todo.rake +0 -4
  250. data/sunspot_solr/Gemfile +0 -3
  251. data/sunspot_solr/README.rdoc +0 -24
  252. data/sunspot_solr/bin/sunspot-installer +0 -20
  253. data/sunspot_solr/bin/sunspot-solr +0 -80
  254. data/sunspot_solr/lib/sunspot/solr/installer.rb +0 -25
  255. data/sunspot_solr/lib/sunspot/solr/installer/config_installer.rb +0 -46
  256. data/sunspot_solr/lib/sunspot/solr/installer/task_helper.rb +0 -13
  257. data/sunspot_solr/lib/sunspot/solr/java.rb +0 -10
  258. data/sunspot_solr/lib/sunspot/solr/railtie.rb +0 -15
  259. data/sunspot_solr/lib/sunspot/solr/server.rb +0 -223
  260. data/sunspot_solr/lib/sunspot/solr/tasks.rb +0 -49
  261. data/sunspot_solr/lib/sunspot_solr.rb +0 -5
  262. data/sunspot_solr/solr/README.txt +0 -42
  263. data/sunspot_solr/solr/etc/jetty.xml +0 -219
  264. data/sunspot_solr/solr/etc/webdefault.xml +0 -379
  265. data/sunspot_solr/solr/lib/jetty-6.1.26-patched-JETTY-1340.jar +0 -0
  266. data/sunspot_solr/solr/lib/jetty-util-6.1.26-patched-JETTY-1340.jar +0 -0
  267. data/sunspot_solr/solr/lib/jsp-2.1/ant-1.6.5.jar +0 -0
  268. data/sunspot_solr/solr/lib/jsp-2.1/core-3.1.1.jar +0 -0
  269. data/sunspot_solr/solr/lib/jsp-2.1/jsp-2.1.jar +0 -0
  270. data/sunspot_solr/solr/lib/jsp-2.1/jsp-api-2.1.jar +0 -0
  271. data/sunspot_solr/solr/lib/servlet-api-2.5-20081211.jar +0 -0
  272. data/sunspot_solr/solr/solr/.gitignore +0 -1
  273. data/sunspot_solr/solr/solr/README.txt +0 -54
  274. data/sunspot_solr/solr/solr/conf/admin-extra.html +0 -31
  275. data/sunspot_solr/solr/solr/conf/elevate.xml +0 -36
  276. data/sunspot_solr/solr/solr/conf/mapping-ISOLatin1Accent.txt +0 -246
  277. data/sunspot_solr/solr/solr/conf/protwords.txt +0 -21
  278. data/sunspot_solr/solr/solr/conf/schema.xml +0 -250
  279. data/sunspot_solr/solr/solr/conf/scripts.conf +0 -24
  280. data/sunspot_solr/solr/solr/conf/solrconfig.xml +0 -934
  281. data/sunspot_solr/solr/solr/conf/spellings.txt +0 -2
  282. data/sunspot_solr/solr/solr/conf/stopwords.txt +0 -58
  283. data/sunspot_solr/solr/solr/conf/synonyms.txt +0 -31
  284. data/sunspot_solr/solr/solr/conf/xslt/example.xsl +0 -132
  285. data/sunspot_solr/solr/solr/conf/xslt/example_atom.xsl +0 -67
  286. data/sunspot_solr/solr/solr/conf/xslt/example_rss.xsl +0 -66
  287. data/sunspot_solr/solr/solr/conf/xslt/luke.xsl +0 -337
  288. data/sunspot_solr/solr/start.jar +0 -0
  289. data/sunspot_solr/solr/webapps/solr.war +0 -0
  290. data/sunspot_solr/spec/server_spec.rb +0 -98
  291. data/sunspot_solr/spec/spec_helper.rb +0 -18
  292. data/sunspot_solr/sunspot_solr.gemspec +0 -37
  293. data/tools/gem_tasks.rb +0 -69
@@ -1,32 +0,0 @@
1
- module Sunspot
2
- module DSL #:nodoc
3
- module Paginatable
4
- # Paginate your search. This works the same way as WillPaginate's
5
- # paginate().
6
- #
7
- # Note that Solr searches are _always_ paginated. Not calling #paginate is
8
- # the equivalent of calling:
9
- #
10
- # paginate(:page => 1, :per_page => Sunspot.config.pagination.default_per_page)
11
- #
12
- # ==== Options (options)
13
- #
14
- # :page<Integer,String>:: The requested page. The default is 1.
15
- #
16
- # :per_page<Integer,String>::
17
- # How many results to return per page. The default is the value in
18
- # +Sunspot.config.pagination.default_per_page+
19
- #
20
- # :offset<Integer,String>::
21
- # Applies a shift to paginated records. The default is 0.
22
- #
23
- def paginate(options = {})
24
- page = options.delete(:page)
25
- per_page = options.delete(:per_page)
26
- offset = options.delete(:offset)
27
- raise ArgumentError, "unknown argument #{options.keys.first.inspect} passed to paginate" unless options.empty?
28
- @query.paginate(page, per_page, offset)
29
- end
30
- end
31
- end
32
- end
@@ -1,36 +0,0 @@
1
- module Sunspot
2
- module DSL
3
- #
4
- # This tiny DSL class implements the DSL for the FieldQuery.facet
5
- # method.
6
- #
7
- class QueryFacet
8
- def initialize(query, setup, facet, options) #:nodoc:
9
- @query, @setup, @facet, @options = query, setup, facet, options
10
- end
11
-
12
- #
13
- # Add a row to this query facet. The label argument can be anything; it's
14
- # simply the value that's passed into the Sunspot::QueryFacetRow object
15
- # corresponding to the row that's created. Use whatever seems most
16
- # intuitive.
17
- #
18
- # The block is evaluated in the context of a Sunspot::DSL::Scope, meaning
19
- # any restrictions can be placed on the documents matching this facet row.
20
- #
21
- # ==== Parameters
22
- #
23
- # label<Object>::
24
- # An object used to identify this facet row in the results.
25
- #
26
- def row(label, &block)
27
- query_facet = Sunspot::Query::QueryFacet.new(@options)
28
- Sunspot::Util.instance_eval_or_call(
29
- Scope.new(@query.add_query_facet(query_facet), @setup),
30
- &block
31
- )
32
- @facet.add_row(label, query_facet.to_boolean_phrase)
33
- end
34
- end
35
- end
36
- end
@@ -1,25 +0,0 @@
1
- module Sunspot
2
- module DSL
3
- #
4
- # This class presents an API for building restrictions in the query DSL. The
5
- # methods exposed are the snake-cased names of the classes defined in the
6
- # Sunspot::Restriction module, with the exception of Base. All
7
- # methods take a single argument, which is the value to be applied to the
8
- # restriction.
9
- #
10
- class Restriction
11
- def initialize(field, scope, negative) #:nodoc:
12
- @field, @scope, @negative = field, scope, negative
13
- end
14
-
15
- Sunspot::Query::Restriction.names.each do |class_name|
16
- method_name = Util.snake_case(class_name.to_s)
17
- module_eval(<<-RUBY, __FILE__, __LINE__ + 1)
18
- def #{method_name}(*value)
19
- @scope.add_restriction(@negative, @field, Sunspot::Query::Restriction::#{class_name}, *value)
20
- end
21
- RUBY
22
- end
23
- end
24
- end
25
- end
@@ -1,160 +0,0 @@
1
- module Sunspot
2
- module DSL
3
- class RestrictionWithNear < Restriction
4
- def initialize(field, scope, query, negated)
5
- super(field, scope, negated)
6
- @query = query
7
- end
8
-
9
- #
10
- # Perform a Geohash-based location restriction for the given `location`
11
- # field. Though this uses the same API as other attribute-field
12
- # restrictions, there are several differences between this and other
13
- # scoping methods:
14
- #
15
- # * It can only be called from the top-level query; it cannot be nested
16
- # in a `dynamic`, `any_of`, or `all_of` block. This is because geohash
17
- # queries are not sent to Solr as filter queries like other scopes, but
18
- # rather are part of the fulltext query sent to Solr.
19
- # * Because it is included with the fulltext query (if any), location
20
- # restrictions can be given boost. By default, an "exact"
21
- # (maximum-precision) match will give the result a boost of 1.0; each
22
- # lower level of precision gives a boost of 1/2 the next highest
23
- # precision. See below for options to modify this behavior.
24
- #
25
- # ==== What is a Geohash?
26
- #
27
- # Geohash is a clever algorithm that creates a decodable digest of a
28
- # geographical point. It does this by dividing the globe into
29
- # quadrants, encoding the quadrant in which the point sits in the hash,
30
- # dividing the quadrant into smaller quadrants, and repeating an arbitrary
31
- # number of times (the "precision"). Because of the way Geohash are
32
- # built, the shared Geohash prefix length of two locations will
33
- # <em>usually</em> increase as the distance between the points decreases.
34
- # Put another way, the geohashes of two nearby points will
35
- # <em>usually</em> have a longer shared prefix than two points which are
36
- # distant from one another.
37
- #
38
- # Read more about Geohashes on
39
- # {Wikipedia}[http://en.wikipedia.org/wiki/Geohash] or play around with
40
- # generating your own at {geohash.org}[http://geohash.org/].
41
- #
42
- # In Sunspot, GeoHashes can have a precision between 3 and 12; this is the
43
- # number of characters in the hash. The precisions have the following
44
- # maximum bounding box sizes, in miles:
45
- #
46
- # <dt>3</dt>
47
- # <dd>389.07812</dd>
48
- # <dt>4</dt>
49
- # <dd>97.26953</dd>
50
- # <dt>5</dt>
51
- # <dd>24.31738</dd>
52
- # <dt>6</dt>
53
- # <dd>6.07935</dd>
54
- # <dt>7</dt>
55
- # <dd>1.51984
56
- # <dt>8</dt>
57
- # <dd>0.37996</dd>
58
- # <dt>9</dt>
59
- # <dd>0.09499</dd>
60
- # <dt>10</dt>
61
- # <dd>0.02375</dd>
62
- # <dt>11</dt>
63
- # <dd>0.00594</dd>
64
- # <dt>12</dt>
65
- # <dd>0.00148</dd>
66
- #
67
- # ==== Score, boost, and sorting with location search
68
- #
69
- # The concept of relevance scoring is a familiar one from fulltext search;
70
- # Solr (or Lucene, actually) gives each result document a score based on
71
- # how relevant the document's text is to the search phrase. Sunspot's
72
- # location search also uses scoring to determine geographical relevance;
73
- # using boosts, longer prefix matches (which are, in general,
74
- # geographically closer to the search origin) are assigned higher
75
- # relevance. This means that the results of a pure location search are
76
- # <em>roughly</em> in order of geographical distance, as long as no other
77
- # sort is specified explicitly.
78
- #
79
- # This geographical relevance plays on the same field as fulltext scoring;
80
- # if you use both fulltext and geographical components in a single search,
81
- # both types of relevance will be taken into account when scoring the
82
- # matches. Thus, a very close fulltext match that's further away from the
83
- # geographical origin will be scored similarly to a less precise fulltext
84
- # match that is very close to the geographical origin. That's likely to be
85
- # consistent with the way most users would expect a fulltext geographical
86
- # search to work.
87
- #
88
- # ==== Options
89
- #
90
- # <dt><code>:precision</code></dt>
91
- # <dd>The minimum precision at which locations should match. See the table
92
- # of precisions and bounding-box sizes above; the proximity value will
93
- # ensure that all matching documents share a bounding box of the
94
- # corresponding maximum size with your origin point. The default value
95
- # is 7, meaning all results will share a bounding box with edges of
96
- # about one and a half miles with the origin.</dd>
97
- # <dt><code>:boost</code></dt>
98
- # <dd>The boost to apply to maximum-precision matches. Default is 1.0. You
99
- # can use this option to adjust the weight given to geographic
100
- # proximity versus fulltext matching, if you are doing both in a
101
- # search.</dd>
102
- # <dt><code>:precision_factor</code></dt>
103
- # <dd>This option determines how much boost is applied to matches at lower
104
- # precisions. The default value, 16.0, means that a match at precision
105
- # N is 1/16 as relevant as a match at precision N+1 (this is consistent
106
- # with the fact that each precision's bounding box is about sixteen
107
- # times the size of the next highest precision.)</dd>
108
- #
109
- # ==== Example
110
- #
111
- # Sunspot.search(Post) do
112
- # fulltext('pizza')
113
- # with(:location).near(-40.0, -70.0, :boost => 2, :precision => 6)
114
- # end
115
- #
116
- def near(lat, lng, options = {})
117
- @query.fulltext.add_location(@field, lat, lng, options)
118
- end
119
-
120
- #
121
- # Performs a query that is filtered by a radius around a given
122
- # latitude and longitude.
123
- #
124
- # ==== Parameters
125
- #
126
- # :lat<Numeric>::
127
- # Latitude (in degrees)
128
- # :lon<Numeric>::
129
- # Longitude (in degrees)
130
- # :radius<Numeric>::
131
- # Radius (in kilometers)
132
- #
133
- # ==== Options
134
- #
135
- # <dt><code>:bbox</code></dt>
136
- # <dd>If `true`, performs the search using `bbox`. `bbox` is
137
- # more performant, but also more inexact (guaranteed to encompass
138
- # all of the points of interest, but may also include other points
139
- # that are slightly outside of the required distance).</dd>
140
- #
141
- def in_radius(lat, lon, radius, options = {})
142
- @query.add_geo(Sunspot::Query::Geofilt.new(@field, lat, lon, radius, options))
143
- end
144
-
145
- #
146
- # Performs a query that is filtered by a bounding box
147
- #
148
- # ==== Parameters
149
- #
150
- # :first_corner<Array>::
151
- # First corner (expressed as an array `[latitude, longitude]`)
152
- # :second_corner<Array>::
153
- # Second corner (expressed as an array `[latitude, longitude]`)
154
- #
155
- def in_bounding_box(first_corner, second_corner)
156
- @query.add_geo(Sunspot::Query::Bbox.new(@field, first_corner, second_corner))
157
- end
158
- end
159
- end
160
- end
@@ -1,214 +0,0 @@
1
- module Sunspot
2
- module DSL #:nodoc:
3
- #
4
- # This DSL presents methods for constructing restrictions and other query
5
- # elements that are specific to fields. As well as being a superclass of
6
- # Sunspot::DSL::StandardQuery, which presents the main query block, this
7
- # DSL class is also used directly inside the #dynamic() block, which only
8
- # allows operations on specific fields.
9
- #
10
- class Scope
11
- def initialize(scope, setup) #:nodoc:
12
- @scope, @setup = scope, setup
13
- end
14
-
15
- #
16
- # Build a positive restriction. This method can take three forms: equality
17
- # restriction, restriction by another restriction, or identity
18
- # restriction.
19
- # In the first two forms, the first argument is a field name. If only a
20
- # field name is specified, this method returns another DSL object which
21
- # presents methods for attaching various restriction types.
22
- # With two arguments, this creates a shorthand restriction: if the second
23
- # argument is a scalar, an equality restriction is created; if it is a
24
- # Range, a between restriction will be created; and if it is an Array, an
25
- # any_of restriction will be created.
26
- # The third from restricts the search results to a specific instance.
27
- #
28
- # ==== Parameters (restriction by field value)
29
- #
30
- # field_name<Symbol>:: Name of the field on which to place the restriction
31
- # value<Object,Range,Array>::
32
- # If passed, creates an equality, range, or any-of restriction based on
33
- # the type of value passed.
34
- #
35
- # ==== Parameters (restriction by identity)
36
- #
37
- # args<Object>...::
38
- # One or more instances that should be included in the results
39
- #
40
- # ==== Returns
41
- #
42
- # Sunspot::DSL::Restriction::
43
- # Restriction DSL object (if only one argument is passed which is a
44
- # field name)
45
- #
46
- # ==== Examples
47
- #
48
- # An equality restriction:
49
- #
50
- # Sunspot.search do
51
- # with(:blog_id, 1)
52
- # end
53
- #
54
- # Restrict by range:
55
- #
56
- # Sunspot.search do
57
- # with(:average_rating, 3.0..5.0)
58
- # end
59
- #
60
- # Restrict by a set of allowed values:
61
- #
62
- # Sunspot.search do
63
- # with(:category_ids, [1, 5, 9])
64
- # end
65
- #
66
- # Other restriction types:
67
- #
68
- # Sunspot.search(Post) do
69
- # with(:average_rating).greater_than(3.0)
70
- # end
71
- #
72
- # Restriction by identity:
73
- #
74
- # Sunspot.search(Post) do
75
- # with(some_post_instance)
76
- # end
77
- #
78
- def with(*args)
79
- add_restriction(false, *args)
80
- end
81
-
82
- #
83
- # Build a negative restriction (exclusion). This method works the same way
84
- # asthe #with method.
85
- #
86
- def without(*args)
87
- add_restriction(true, *args)
88
- end
89
-
90
- #
91
- # Create a disjunction, scoping the results to documents that match any
92
- # of the enclosed restrictions.
93
- #
94
- # ==== Example
95
- #
96
- # Sunspot.search(Post) do
97
- # any_of do
98
- # with(:expired_at).greater_than Time.now
99
- # with :expired_at, nil
100
- # end
101
- # end
102
- #
103
- # This will return all documents who either have an expiration time in the
104
- # future, or who do not have any expiration time at all.
105
- #
106
- def any_of(&block)
107
- disjunction = @scope.add_disjunction
108
- Util.instance_eval_or_call(Scope.new(disjunction, @setup), &block)
109
- disjunction
110
- end
111
-
112
- #
113
- # Create a conjunction, scoping the results to documents that match all of
114
- # the enclosed restrictions. When called from the top level of a search
115
- # block, this has no effect, but can be useful for grouping a conjunction
116
- # inside a disjunction.
117
- #
118
- # ==== Example
119
- #
120
- # Sunspot.search(Post) do
121
- # any_of do
122
- # with(:blog_id, 1)
123
- # all_of do
124
- # with(:blog_id, 2)
125
- # with(:category_ids, 3)
126
- # end
127
- # end
128
- # end
129
- #
130
- def all_of(&block)
131
- conjunction = @scope.add_conjunction
132
- Util.instance_eval_or_call(Scope.new(conjunction, @setup), &block)
133
- conjunction
134
- end
135
-
136
- #
137
- # Apply restrictions, facets, and ordering to dynamic field instances.
138
- # The block API is implemented by Sunspot::DSL::FieldQuery, which is a
139
- # superclass of the Query DSL (thus providing a subset of the API, in
140
- # particular only methods that refer to particular fields).
141
- #
142
- # ==== Parameters
143
- #
144
- # base_name<Symbol>:: The base name for the dynamic field definition
145
- #
146
- # ==== Example
147
- #
148
- # Sunspot.search Post do
149
- # dynamic :custom do
150
- # with :cuisine, 'Pizza'
151
- # facet :atmosphere
152
- # order_by :chef_name
153
- # end
154
- # end
155
- #
156
- def dynamic(base_name, &block)
157
- Sunspot::Util.instance_eval_or_call(
158
- Scope.new(@scope, @setup.dynamic_field_factory(base_name)),
159
- &block
160
- )
161
- end
162
-
163
- #
164
- # Apply scope-type restrictions on fulltext fields. In certain situations,
165
- # it may be desirable to place logical restrictions on text fields.
166
- # Remember that text fields are tokenized; your mileage may very.
167
- #
168
- # The block works exactly like a normal scope, except that the field names
169
- # refer to text fields instead of attribute fields.
170
- #
171
- # === Example
172
- #
173
- # Sunspot.search(Post) do
174
- # text_fields do
175
- # with :body, nil
176
- # end
177
- # end
178
- #
179
- # This will return all documents that do not have a body.
180
- #
181
- def text_fields(&block)
182
- Sunspot::Util.instance_eval_or_call(
183
- Scope.new(@scope, TextFieldSetup.new(@setup)),
184
- &block
185
- )
186
- end
187
-
188
- private
189
-
190
- def add_restriction(negated, *args)
191
- case args.first
192
- when String, Symbol
193
- raise ArgumentError if args.length > 2
194
- field = @setup.field(args[0].to_sym)
195
- if args.length > 1
196
- value = args[1]
197
- @scope.add_shorthand_restriction(negated, field, value)
198
- else # NONE
199
- DSL::Restriction.new(field, @scope, negated)
200
- end
201
- else # args are instances
202
- @scope.add_restriction(
203
- negated,
204
- IdField.instance,
205
- Sunspot::Query::Restriction::AnyOf,
206
- args.flatten.map { |instance|
207
- Sunspot::Adapters::InstanceAdapter.adapt(instance).index_id }
208
- )
209
- end
210
- end
211
-
212
- end
213
- end
214
- end