Program.cs 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. using System;
  2. using System.IO;
  3. namespace Rac
  4. {
  5. internal class Program
  6. {
  7. //TODO: Folder browser
  8. private static void Main(string[] args)
  9. {
  10. var db = "project.db3";
  11. void PrintUsage()
  12. {
  13. Console.WriteLine("args: [mode] [args]");
  14. Console.WriteLine(" crawler [project.db3] * default mode");
  15. Console.WriteLine(" offline [project.db3]");
  16. Console.WriteLine(" browser [project.db3] * not impl yet");
  17. Console.WriteLine(" extract [project.db3]");
  18. }
  19. if (args.Length == 0)
  20. {
  21. RunCrawler(db);
  22. }
  23. else
  24. {
  25. if (args.Length > 1) db = args[1];
  26. switch (args[0].ToLower())
  27. {
  28. default:
  29. PrintUsage();
  30. break;
  31. case "crawler":
  32. RunCrawler(db);
  33. break;
  34. case "offline":
  35. RunOffline(db);
  36. break;
  37. case "browser":
  38. RunBrowser(db);
  39. break;
  40. case "extract":
  41. RunExtract(db);
  42. break;
  43. }
  44. }
  45. Console.Write("Finished, Press ENTER to exit...");
  46. Console.ReadLine();
  47. }
  48. private static void RunExtract(string db)
  49. {
  50. var inst = new Extractor(db);
  51. inst.Log += (sender, ea) => Console.WriteLine($"Extract -- {ea.Level} -- {ea.Log}");
  52. inst.RunExtract();
  53. }
  54. private static void RunCrawler(string db)
  55. {
  56. var inst = new Crawler(Path.Combine(AppDomain.CurrentDomain.BaseDirectory, db));
  57. inst.Log += (sender, ea) => Console.WriteLine($"RAC -- {ea.Level} -- {ea.Log}");
  58. Console.WriteLine("Press ENTER to stop.");
  59. inst.Start();
  60. Console.ReadLine();
  61. if (inst.IsRunning)
  62. {
  63. Console.WriteLine("Stopping...");
  64. inst.Stop();
  65. Console.WriteLine();
  66. }
  67. }
  68. private static void RunOffline(string db)
  69. {
  70. var inst = new OfflineWebServer(db);
  71. inst.Log += (sender, ea) => Console.WriteLine($"OWS -- {ea.Level} -- {ea.Log}");
  72. Console.WriteLine("Press ENTER to stop.");
  73. inst.Start();
  74. Console.ReadLine();
  75. inst.Stop();
  76. }
  77. private static void RunBrowser(string db)
  78. {
  79. var inst = new FileBrowseServer(db);
  80. inst.Log += (sender, ea) => Console.WriteLine($"OWS -- {ea.Level} -- {ea.Log}");
  81. Console.WriteLine("Press ENTER to stop.");
  82. inst.Start();
  83. Console.ReadLine();
  84. inst.Stop();
  85. }
  86. }
  87. }