# File lib/thinking_sphinx/rake_interface.rb, line 2 def clear [ configuration.indices_location, configuration.searchd.binlog_path ].each do |path| FileUtils.rm_r(path) if File.exists?(path) end end
# File lib/thinking_sphinx/rake_interface.rb, line 11 def configure puts "Generating configuration to #{configuration.configuration_file}" configuration.render_to_file end
# File lib/thinking_sphinx/rake_interface.rb, line 16 def generate indices = configuration.indices.select { |index| index.type == 'rt' } indices.each do |index| ThinkingSphinx::RealTime::Populator.populate index end end
# File lib/thinking_sphinx/rake_interface.rb, line 23 def index(reconfigure = true, verbose = true) configure if reconfigure FileUtils.mkdir_p configuration.indices_location ThinkingSphinx.before_index_hooks.each { |hook| hook.call } controller.index :verbose => verbose end
# File lib/thinking_sphinx/rake_interface.rb, line 30 def prepare configuration.preload_indices configuration.render FileUtils.mkdir_p configuration.indices_location end
# File lib/thinking_sphinx/rake_interface.rb, line 37 def start raise RuntimeError, 'searchd is already running' if controller.running? FileUtils.mkdir_p configuration.indices_location controller.start if controller.running? puts "Started searchd successfully (pid: #{controller.pid})." else puts "Failed to start searchd. Check the log files for more information." end end
# File lib/thinking_sphinx/rake_interface.rb, line 50 def stop unless controller.running? puts 'searchd is not currently running.' and return end pid = controller.pid until controller.stop do sleep(0.5) end puts "Stopped searchd daemon (pid: #{pid})." end
# File lib/thinking_sphinx/rake_interface.rb, line 67 def configuration ThinkingSphinx::Configuration.instance end