-
Notifications
You must be signed in to change notification settings - Fork 49
/
bundle_indexing.rb
45 lines (41 loc) · 1.43 KB
/
bundle_indexing.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
module Picky
# A Bundle is a number of indexes
# per [index, category] combination.
#
# At most, there are three indexes:
# * *core* index (always used)
# * *weights* index (always used)
# * *similarity* index (used with similarity)
#
# In Picky, indexing is separated from the index
# handling itself through a parallel structure.
#
# Both use methods provided by this base class, but
# have very different goals:
#
# * *Indexing*::*Bundle* is just concerned with creating index files
# and providing helper functions to e.g. check the indexes.
#
# * *Index*::*Bundle* is concerned with loading these index files into
# memory and looking up search data as fast as possible.
#
# This is the indexing bundle.
#
# It does all menial tasks that have nothing to do
# with the actual index running etc.
# (Find these in Indexed::Bundle)
#
class Bundle
# Saves the indexes in a dump file.
#
def dump
@backend_inverted.dump @inverted
# THINK about this. Perhaps the strategies should implement the backend methods? Or only the internal index ones?
#
@backend_weights.dump @weights if @weight_strategy.respond_to?(:saved?) && @weight_strategy.saved?
@backend_similarity.dump @similarity if @similarity_strategy.respond_to?(:saved?) && @similarity_strategy.saved?
@backend_configuration.dump @configuration
@backend_realtime.dump @realtime
end
end
end