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,393 +0,0 @@
1
- require 'singleton'
2
- begin
3
- require 'geohash'
4
- rescue LoadError => e
5
- require 'pr_geohash'
6
- end
7
-
8
- module Sunspot
9
- #
10
- # This module contains singleton objects that represent the types that can be
11
- # indexed and searched using Sunspot. Plugin developers should be able to
12
- # add new constants to the Type module; as long as they implement the
13
- # appropriate methods, Sunspot should be able to integrate them (note that
14
- # this capability is untested at the moment). The required methods are:
15
- #
16
- # +indexed_name+::
17
- # Convert a given field name into its form as stored in Solr. This
18
- # generally means adding a suffix to match a Solr dynamicField definition.
19
- # +to_indexed+::
20
- # Convert a value of this type into the appropriate Solr string
21
- # representation.
22
- # +cast+::
23
- # Convert a Solr string representation of a value into the appropriate
24
- # Ruby type.
25
- #
26
- module Type
27
- class <<self
28
- def register(sunspot_type, *classes)
29
- classes.each do |clazz|
30
- ruby_type_map[clazz.name.to_sym] = sunspot_type.instance
31
- end
32
- end
33
-
34
- def for_class(clazz)
35
- if clazz
36
- ruby_type_map[clazz.name.to_sym] || for_class(clazz.superclass)
37
- end
38
- end
39
-
40
- def for(object)
41
- for_class(object.class)
42
- end
43
-
44
- def to_indexed(object)
45
- if type = self.for(object)
46
- type.to_indexed(object)
47
- else
48
- object.to_s
49
- end
50
- end
51
-
52
- def to_literal(object)
53
- if type = self.for(object)
54
- type.to_literal(object)
55
- else
56
- raise ArgumentError, "Can't use #{object.inspect} as Solr literal: #{object.class} has no registered Solr type"
57
- end
58
- end
59
-
60
- private
61
-
62
- def ruby_type_map
63
- @ruby_type_map ||= {}
64
- end
65
- end
66
-
67
- class AbstractType #:nodoc:
68
- include Singleton
69
-
70
- def accepts_dynamic?
71
- true
72
- end
73
-
74
- def accepts_more_like_this?
75
- false
76
- end
77
-
78
- def to_literal(object)
79
- raise(
80
- ArgumentError,
81
- "#{self.class.name} cannot be used as a Solr literal"
82
- )
83
- end
84
- end
85
-
86
- #
87
- # Text is a special type that stores data for fulltext search. Unlike other
88
- # types, Text fields are tokenized and are made available to the keyword
89
- # search phrase. Text fields cannot be faceted, ordered upon, or used in
90
- # restrictions. Similarly, text fields are the only fields that are made
91
- # available to keyword search.
92
- #
93
- class TextType < AbstractType
94
- def indexed_name(name) #:nodoc:
95
- "#{name}_text"
96
- end
97
-
98
- def to_indexed(value) #:nodoc:
99
- value.to_s if value
100
- end
101
-
102
- def cast(text)
103
- text
104
- end
105
-
106
- def accepts_dynamic?
107
- false
108
- end
109
-
110
- def accepts_more_like_this?
111
- true
112
- end
113
- end
114
-
115
- #
116
- # The String type represents string data.
117
- #
118
- class StringType < AbstractType
119
- def indexed_name(name) #:nodoc:
120
- "#{name}_s"
121
- end
122
-
123
- def to_indexed(value) #:nodoc:
124
- value.to_s if value
125
- end
126
-
127
- def cast(string) #:nodoc:
128
- string
129
- end
130
- end
131
- register(StringType, String)
132
-
133
- #
134
- # The Integer type represents integers.
135
- #
136
- class IntegerType < AbstractType
137
- def indexed_name(name) #:nodoc:
138
- "#{name}_i"
139
- end
140
-
141
- def to_indexed(value) #:nodoc:
142
- value.to_i.to_s if value
143
- end
144
-
145
- def to_literal(value)
146
- to_indexed(value)
147
- end
148
-
149
- def cast(string) #:nodoc:
150
- string.to_i
151
- end
152
- end
153
- register(IntegerType, Integer)
154
-
155
- #
156
- # The Long type indexes Ruby Fixnum and Bignum numbers into Java Longs
157
- #
158
- class LongType < IntegerType
159
- def indexed_name(name) #:nodoc:
160
- "#{name}_l"
161
- end
162
- end
163
-
164
- #
165
- # The Float type represents floating-point numbers.
166
- #
167
- class FloatType < AbstractType
168
- def indexed_name(name) #:nodoc:
169
- "#{name}_f"
170
- end
171
-
172
- def to_indexed(value) #:nodoc:
173
- value.to_f.to_s if value
174
- end
175
-
176
- def to_literal(value)
177
- to_indexed(value)
178
- end
179
-
180
- def cast(string) #:nodoc:
181
- string.to_f
182
- end
183
- end
184
- register(FloatType, Float)
185
-
186
- #
187
- # The Double type indexes Ruby Floats (which are in fact doubles) into Java
188
- # Double fields
189
- #
190
- class DoubleType < FloatType
191
- def indexed_name(name)
192
- "#{name}_e"
193
- end
194
- end
195
-
196
- #
197
- # The time type represents times. Note that times are always converted to
198
- # UTC before indexing, and facets of Time fields always return times in UTC.
199
- #
200
- class TimeType < AbstractType
201
- XMLSCHEMA = "%Y-%m-%dT%H:%M:%SZ"
202
-
203
- def indexed_name(name) #:nodoc:
204
- "#{name}_d"
205
- end
206
-
207
- def to_indexed(value) #:nodoc:
208
- if value
209
- value_to_utc_time(value).strftime(XMLSCHEMA)
210
- end
211
- end
212
-
213
- def to_literal(value)
214
- to_indexed(value)
215
- end
216
-
217
- def cast(string) #:nodoc:
218
- begin
219
- Time.xmlschema(string)
220
- rescue ArgumentError
221
- DateTime.strptime(string, XMLSCHEMA)
222
- end
223
- end
224
-
225
- private
226
-
227
- def value_to_utc_time(value)
228
- if value.respond_to?(:utc)
229
- value.utc
230
- elsif value.respond_to?(:new_offset)
231
- value.new_offset
232
- else
233
- begin
234
- Time.parse(value.to_s).utc
235
- rescue ArgumentError
236
- DateTime.parse(value.to_s).new_offset
237
- end
238
- end
239
- end
240
- end
241
- register TimeType, Time, DateTime
242
-
243
- #
244
- # The DateType encapsulates dates (without time information). Internally,
245
- # Solr does not have a date-only type, so this type indexes data using
246
- # Solr's DateField type (which is actually date/time), midnight UTC of the
247
- # indexed date.
248
- #
249
- class DateType < TimeType
250
- def to_indexed(value) #:nodoc:
251
- if value
252
- time =
253
- if %w(year mon mday).all? { |method| value.respond_to?(method) }
254
- Time.utc(value.year, value.mon, value.mday)
255
- else
256
- date = Date.parse(value.to_s)
257
- Time.utc(date.year, date.mon, date.mday)
258
- end
259
- super(time)
260
- end
261
- end
262
-
263
- def cast(string) #:nodoc:
264
- time = super
265
- Date.civil(time.year, time.mon, time.mday)
266
- end
267
- end
268
- register DateType, Date
269
-
270
- #
271
- # Store integers in a TrieField, which makes range queries much faster.
272
- #
273
- class TrieIntegerType < IntegerType
274
- def indexed_name(name)
275
- "#{super}t"
276
- end
277
- end
278
-
279
- #
280
- # Store floats in a TrieField, which makes range queries much faster.
281
- #
282
- class TrieFloatType < FloatType
283
- def indexed_name(name)
284
- "#{super}t"
285
- end
286
- end
287
-
288
- #
289
- # Index times using a TrieField. Internally, trie times are indexed as
290
- # Unix timestamps in a trie integer field, as TrieField does not support
291
- # datetime types natively. This distinction should have no effect from the
292
- # standpoint of the library's API.
293
- #
294
- class TrieTimeType < TimeType
295
- def indexed_name(name)
296
- "#{super}t"
297
- end
298
- end
299
-
300
-
301
- #
302
- # The boolean type represents true/false values. Note that +nil+ will not be
303
- # indexed at all; only +false+ will be indexed with a false value.
304
- #
305
- class BooleanType < AbstractType
306
- def indexed_name(name) #:nodoc:
307
- "#{name}_b"
308
- end
309
-
310
- def to_indexed(value) #:nodoc:
311
- unless value.nil?
312
- value ? 'true' : 'false'
313
- end
314
- end
315
-
316
- def cast(string) #:nodoc:
317
- case string
318
- when 'true'
319
- true
320
- when 'false'
321
- false
322
- when true, false
323
- string
324
- end
325
- end
326
- end
327
- register BooleanType, TrueClass, FalseClass
328
-
329
- #
330
- # The Location type encodes geographical coordinates as a GeoHash.
331
- # The data for this type must respond to the `lat` and `lng` methods; you
332
- # can use Sunspot::Util::Coordinates as a wrapper if your source data does
333
- # not follow this API.
334
- #
335
- # Location fields are most usefully searched using the
336
- # Sunspot::DSL::RestrictionWithType#near method; see that method for more
337
- # information on geographical search.
338
- #
339
- # ==== Example
340
- #
341
- # Sunspot.setup(Post) do
342
- # location :coordinates do
343
- # Sunspot::Util::Coordinates.new(coordinates[0], coordinates[1])
344
- # end
345
- # end
346
- #
347
- class LocationType < AbstractType
348
- def indexed_name(name)
349
- "#{name}_s"
350
- end
351
-
352
- def to_indexed(value)
353
- GeoHash.encode(value.lat.to_f, value.lng.to_f, 12)
354
- end
355
- end
356
-
357
- #
358
- # The Latlon type encodes geographical coordinates in the native
359
- # Solr LatLonType.
360
- #
361
- # The data for this type must respond to the `lat` and `lng` methods; you
362
- # can use Sunspot::Util::Coordinates as a wrapper if your source data does
363
- # not follow this API.
364
- #
365
- # Location fields can be used with the geospatial DSL. See the
366
- # Geospatial section of the README for examples.
367
- #
368
- class LatlonType < AbstractType
369
- def indexed_name(name)
370
- "#{name}_ll"
371
- end
372
-
373
- def to_indexed(value)
374
- "#{value.lat.to_f},#{value.lng.to_f}"
375
- end
376
- end
377
-
378
- class ClassType < AbstractType
379
- def indexed_name(name) #:nodoc:
380
- 'class_name'
381
- end
382
-
383
- def to_indexed(value) #:nodoc:
384
- value.name
385
- end
386
-
387
- def cast(string) #:nodoc:
388
- Sunspot::Util.full_const_get(string)
389
- end
390
- end
391
- register ClassType, Class
392
- end
393
- end
@@ -1,252 +0,0 @@
1
- module Sunspot
2
- #
3
- # The Sunspot::Util module provides utility methods used elsewhere in the
4
- # library.
5
- #
6
- module Util #:nodoc:
7
- class <<self
8
- #
9
- # Get all of the superclasses for a given class, including the class
10
- # itself.
11
- #
12
- # ==== Parameters
13
- #
14
- # clazz<Class>:: class for which to get superclasses
15
- #
16
- # ==== Returns
17
- #
18
- # Array:: Collection containing class and its superclasses
19
- #
20
- def superclasses_for(clazz)
21
- superclasses = [clazz]
22
- superclasses << (clazz = clazz.superclass) while clazz.superclass != Object
23
- superclasses
24
- end
25
-
26
- #
27
- # Convert a string to snake case
28
- #
29
- # ==== Parameters
30
- #
31
- # string<String>:: String to convert to snake case
32
- #
33
- # ==== Returns
34
- #
35
- # String:: String in snake case
36
- #
37
- def snake_case(string)
38
- string.scan(/(^|[A-Z])([^A-Z]+)/).map! { |word| word.join.downcase }.join('_')
39
- end
40
-
41
- #
42
- # Convert a string to camel case
43
- #
44
- # ==== Parameters
45
- #
46
- # string<String>:: String to convert to camel case
47
- #
48
- # ==== Returns
49
- #
50
- # String:: String in camel case
51
- #
52
- def camel_case(string)
53
- string.split('_').map! { |word| word.capitalize }.join
54
- end
55
-
56
- #
57
- # Get a constant from a fully qualified name
58
- #
59
- # ==== Parameters
60
- #
61
- # string<String>:: The fully qualified name of a constant
62
- #
63
- # ==== Returns
64
- #
65
- # Object:: Value of constant named
66
- #
67
- def full_const_get(string)
68
- string.split('::').inject(Object) do |context, const_name|
69
- context.const_defined?(const_name) ? context.const_get(const_name) : context.const_missing(const_name)
70
- end
71
- end
72
-
73
- #
74
- # Evaluate the given proc in the context of the given object if the
75
- # block's arity is non-positive, or by passing the given object as an
76
- # argument if it is negative.
77
- #
78
- # ==== Parameters
79
- #
80
- # object<Object>:: Object to pass to the proc
81
- #
82
- def instance_eval_or_call(object, &block)
83
- if block.arity > 0
84
- block.call(object)
85
- else
86
- ContextBoundDelegate.instance_eval_with_context(object, &block)
87
- end
88
- end
89
-
90
- def extract_options_from(args)
91
- if args.last.is_a?(Hash)
92
- args.pop
93
- else
94
- {}
95
- end
96
- end
97
-
98
- #
99
- # Ruby's treatment of Strings as Enumerables is heavily annoying. As far
100
- # as I know the behavior of Kernel.Array() is otherwise fine.
101
- #
102
- def Array(object)
103
- case object
104
- when String, Hash
105
- [object]
106
- else
107
- super
108
- end
109
- end
110
-
111
- #
112
- # When generating boosts, Solr requires that the values be in standard
113
- # (not scientific) notation. We would like to ensure a minimum number of
114
- # significant digits (i.e., digits that are not prefix zeros) for small
115
- # float values.
116
- #
117
- def format_float(f, digits)
118
- if f < 1
119
- sprintf('%.*f', digits - Math.log10(f), f)
120
- else
121
- f.to_s
122
- end
123
- end
124
-
125
- #
126
- # Perform a deep merge of hashes, returning the result as a new hash.
127
- # See #deep_merge_into for rules used to merge the hashes
128
- #
129
- # ==== Parameters
130
- #
131
- # left<Hash>:: Hash to merge
132
- # right<Hash>:: The other hash to merge
133
- #
134
- # ==== Returns
135
- #
136
- # Hash:: New hash containing the given hashes deep-merged.
137
- #
138
- def deep_merge(left, right)
139
- deep_merge_into({}, left, right)
140
- end
141
-
142
- #
143
- # Perform a deep merge of the right hash into the left hash
144
- #
145
- # ==== Parameters
146
- #
147
- # left:: Hash to receive merge
148
- # right:: Hash to merge into left
149
- #
150
- # ==== Returns
151
- #
152
- # Hash:: left
153
- #
154
- def deep_merge!(left, right)
155
- deep_merge_into(left, left, right)
156
- end
157
-
158
- private
159
-
160
- #
161
- # Deep merge two hashes into a third hash, using rules that produce nice
162
- # merged parameter hashes. The rules are as follows, for a given key:
163
- #
164
- # * If only one hash has a value, or if both hashes have the same value,
165
- # just use the value.
166
- # * If either of the values is not a hash, create arrays out of both
167
- # values and concatenate them.
168
- # * Otherwise, deep merge the two values (which are both hashes)
169
- #
170
- # ==== Parameters
171
- #
172
- # destination<Hash>:: Hash into which to perform the merge
173
- # left<Hash>:: One hash to merge
174
- # right<Hash>:: The other hash to merge
175
- #
176
- # ==== Returns
177
- #
178
- # Hash:: destination
179
- #
180
- def deep_merge_into(destination, left, right)
181
- left.each_pair do |name, left_value|
182
- right_value = right[name] if right
183
- destination[name] =
184
- if right_value.nil? || left_value == right_value
185
- left_value
186
- elsif !left_value.respond_to?(:each_pair) || !right_value.respond_to?(:each_pair)
187
- Array(left_value) + Array(right_value)
188
- else
189
- merged_value = {}
190
- deep_merge_into(merged_value, left_value, right_value)
191
- end
192
- end
193
- left_keys = Set.new(left.keys)
194
- destination.merge!(right.reject { |k, v| left_keys.include?(k) })
195
- destination
196
- end
197
- end
198
-
199
- Coordinates = Struct.new(:lat, :lng)
200
-
201
- class ContextBoundDelegate
202
- class <<self
203
- def instance_eval_with_context(receiver, &block)
204
- calling_context = eval('self', block.binding)
205
- if parent_calling_context = calling_context.instance_eval{@__calling_context__}
206
- calling_context = parent_calling_context
207
- end
208
- new(receiver, calling_context).instance_eval(&block)
209
- end
210
- private :new
211
- end
212
-
213
- BASIC_METHODS = Set[:==, :equal?, :"!", :"!=", :instance_eval,
214
- :object_id, :__send__, :__id__]
215
-
216
- instance_methods.each do |method|
217
- unless BASIC_METHODS.include?(method.to_sym)
218
- undef_method(method)
219
- end
220
- end
221
-
222
- def initialize(receiver, calling_context)
223
- @__receiver__, @__calling_context__ = receiver, calling_context
224
- end
225
-
226
- def id
227
- @__calling_context__.__send__(:id)
228
- end
229
-
230
- # Special case due to `Kernel#sub`'s existence
231
- def sub(*args, &block)
232
- __proxy_method__(:sub, *args, &block)
233
- end
234
-
235
- def method_missing(method, *args, &block)
236
- __proxy_method__(method, *args, &block)
237
- end
238
-
239
- def __proxy_method__(method, *args, &block)
240
- begin
241
- @__receiver__.__send__(method.to_sym, *args, &block)
242
- rescue ::NoMethodError => e
243
- begin
244
- @__calling_context__.__send__(method.to_sym, *args, &block)
245
- rescue ::NoMethodError
246
- raise(e)
247
- end
248
- end
249
- end
250
- end
251
- end
252
- end