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
46
47
48
49
|
# File 'lib/glancer/indexer/model_indexer.rb', line 8
def index!
Glancer::Utils::Logger.info("Indexer::ModelIndexer", "Starting model indexing...")
model_files = Dir[Rails.root.join("app/models/**/*.rb")]
if model_files.empty?
Glancer::Utils::Logger.warn("Indexer::ModelIndexer", "No model files found for indexing.")
return []
end
Glancer::Utils::Logger.info("Indexer::ModelIndexer", "Found #{model_files.size} model file(s)")
all_chunks = []
model_files.each do |file|
Glancer::Utils::Logger.debug("Indexer::ModelIndexer", "Reading model file: #{file}")
content = File.read(file)
Glancer::Utils::Logger.debug("Indexer::ModelIndexer", "Read #{content.bytesize} bytes from #{file}")
chunks = split_into_chunks(content)
Glancer::Utils::Logger.debug("Indexer::ModelIndexer", "Split into #{chunks.size} chunk(s)")
all_chunks.concat(
chunks.map do |chunk|
{
content: chunk,
source_type: "models",
source_path: file
}
end
)
end
Glancer::Utils::Logger.info("Indexer::ModelIndexer", "Completed indexing. Total chunks: #{all_chunks.size}")
all_chunks
rescue StandardError => e
Glancer::Utils::Logger.error("Indexer::ModelIndexer", "Model indexing failed: #{e.class} - #{e.message}")
Glancer::Utils::Logger.debug("Indexer::ModelIndexer", "Backtrace:\n#{e.backtrace.join("\n")}")
raise Glancer::Error, "Model indexing failed: #{e.message}"
end
|