Add `arrived` attribute (file creation timestamp) to books table.
[quanlib.git] / main.rb
diff --git a/main.rb b/main.rb
index 98f5a3555656ba398afcc59efad7e7ffc2f0e2a2..e294b4a15e3391a0e4b84d41235b2eee1265ca31 100644 (file)
--- a/main.rb
+++ b/main.rb
@@ -1,10 +1,56 @@
-require './walkdir.rb'
+require_relative 'navigator'
+require_relative 'page'
+require_relative 'store'
+require_relative 'walk_dir'
 
-books = []
+@outputDir = 'output'
+
+@config_file = 'quanlib.ini'
+@skip_class = false
+
+def handleArg(arg)
+  if arg.start_with?("--config=")
+    @config_file = arg[9..-1]
+    puts 'Using config file "' + @config_file + '".'
+  elsif "--purge" == arg
+    puts 'Purging database...'
+    @store.dropSchema()
+    if File.exists?(@store.unclassified_csv)
+      File.delete(@store.unclassified_csv)
+    end
+  elsif "--skip-class" == arg
+    puts 'Skipping load of classification table.'
+    @skip_class = true
+  elsif arg.start_with?("--")
+    abort('ERROR:  Unrecognized option "' + arg + '".')
+  end
+end
+
+@store = Store.new(@config_file)
+@store.connect()
+
+for arg in ARGV
+  handleArg(arg)
+end
+
+@store.init_db(@skip_class)
 
 for arg in ARGV
-  w = WalkDir.new(arg)
-  books.push(w.books)
+  if ! arg.start_with?("--")
+    puts 'Scanning directory "' + arg + '"...'
+    w = WalkDir.new(@config_file, arg)
+    w.books
+  end
 end
 
-puts books
+@store.cross_reference_lists
+
+puts 'Creating output...'
+
+navigator = Navigator.new(@store)
+navigator.write_atoz_pages()
+navigator.write_series_listing()
+navigator.write_dewey()
+
+@store.disconnect()
+