コード例 #1
0
ファイル: Program.cs プロジェクト: demidko888/TestTask
        public static void AddOrUpdateDB(DBWords database)
        {
            if (database == null)
            {
                Console.WriteLine("Database does not exist, entering input mode...");
                return;
            }
            while (true)
            {
                Console.Write("Enter file name: ");
                var fileName     = Console.ReadLine();
                var fullFileName = Directory.GetCurrentDirectory() + "\\" + fileName;
                if (!Directory.EnumerateFiles(Directory.GetCurrentDirectory()).Contains(fullFileName))
                {
                    Console.WriteLine("Invalid file name, try again...");
                    continue;
                }

                var EncodeChecker = new Utf8Checker();
                if (EncodeChecker.Check(fileName))
                {
                    var a      = FileController.ParseFile(File.ReadAllLines(fileName));
                    var e      = FileController.GenerateWordList(a);
                    var result = Requests.GenerateUpdateRequestWithGlobalOptions(e);
                    DBController.AddOrUpdateEntity(database, result);
                    return;
                }
                else
                {
                    Console.WriteLine("File is not in UTF-8 encoding");
                }
            }
        }
コード例 #2
0
        public void SetUp()
        {
            db = new DBWords(":memory:");

            // Test category
            testCategory         = db.LoadFromString("Food,Pizza,Ham,Eggs");
            testCategory.LastUse = DateTime.Now.Date;
            testCategory.Words.Select(w => w.LastUse = DateTime.Now.Date).ToList();
            testCategory.Words.Select(w => w.Views   = 1).ToList();
        }
コード例 #3
0
 public static List <Word> TakeRequest(DBWords db, string partOrValue)
 {
     if (db != null)
     {
         return(db.Words
                .Where(x => x.Name.StartsWith(partOrValue))
                .OrderByDescending(w => w.Frequency)
                .ThenBy(y => y.Name)
                .Take(GlobalSettings.MAX_WORDS_QUERY_COUNT)
                .ToList());
     }
     return(new List <Word>());
 }
コード例 #4
0
        public static void AddOrUpdateEntity(DBWords db, Word entity)
        {
            var dbEntity = db.Words.Where(w => w.Name == entity.Name).FirstOrDefault();

            if (dbEntity != null)
            {
                dbEntity.Frequency += entity.Frequency;
            }
            else
            {
                db.Add(entity);
            }
            db.SaveChanges();
        }
コード例 #5
0
 public static void AddOrUpdateEntity(DBWords db, List <Word> entities)
 {
     foreach (var entity in entities)
     {
         var dbEntity = db.Words.Where(w => w.Name == entity.Name).FirstOrDefault();
         if (dbEntity == null)
         {
             dbEntity = db.Words.Local.Where(w => w.Name == entity.Name).FirstOrDefault();
         }
         if (dbEntity != null)
         {
             dbEntity.Frequency += entity.Frequency;
         }
         else
         {
             db.Add(entity);
         }
     }
     db.SaveChanges();
 }
コード例 #6
0
 public static void DeleteDB(DBWords db)
 {
     //db.Words.RemoveRange(db.Words);
     db.Database.EnsureDeleted();
 }
コード例 #7
0
ファイル: Program.cs プロジェクト: demidko888/TestTask
        static void Main(string[] args)
        {
            Directory.SetCurrentDirectory(Directory.GetCurrentDirectory() + "\\Files");
            DBWords db = new DBWords(ConfigureConnectionToDB());

            if (args.Length > GlobalSettings.MAX_ARGS_COUNT)
            {
                Console.WriteLine("More than one argument has been entered to run");
                return;
            }

            if (args.Length != 0)
            {
                db = new DBWords(ConfigureConnectionToDB());
                switch (args[0])
                {
                case "-create":
                    db.CreateNewBD();
                    AddOrUpdateDB(db);
                    Console.WriteLine("New database was created");
                    break;

                case "-update":
                    if (!db.Database.CanConnect())
                    {
                        db = null;
                        Console.WriteLine("Database does not exist, entering input mode...");
                    }
                    else
                    {
                        AddOrUpdateDB(db);
                        Console.WriteLine("Database was updated");
                    }
                    break;

                case "-delete":
                    if (!db.DeleteDB())
                    {
                        Console.WriteLine("Database does not exist, entering input mode...");
                    }
                    else
                    {
                        Console.WriteLine("Database was deleted");
                    }
                    db = null;
                    break;

                default:
                    Console.WriteLine("Invalid input command, available start commands:");
                    Console.WriteLine("-create -> to create new database dictionary");
                    Console.WriteLine("-update -> to update database dictionary");
                    Console.WriteLine("-delete -> to delete database dictionary");
                    break;
                }
            }
            if (db != null)
            {
                if (!db.Database.CanConnect())
                {
                    db = null;
                }
            }
            var sb = new StringBuilder();

            Console.WriteLine("You are in input mode");
            while (true)
            {
                var symbol = Console.ReadKey(false);
                if (symbol.Key == ConsoleKey.Backspace && sb.Length != 0)
                {
                    sb.Remove(sb.Length - 1, 1);
                    Console.Write("\r");
                    Console.Write(sb.ToString() + " ");
                    Console.Write("\b");
                }
                else
                if (symbol.Key == ConsoleKey.Enter && sb.Length == 0 || symbol.Key == ConsoleKey.Escape)
                {
                    return;
                }
                else
                if (symbol.Key == ConsoleKey.Enter && sb.Length != 0)
                {
                    Console.WriteLine();
                    var resultString = sb.ToString();
                    sb = new StringBuilder();
                    var res = Requests.TakeRequest(db, resultString);
                    Requests.PrintRequest(res);
                    Console.WriteLine();
                }
                else if (symbol.Key != ConsoleKey.Backspace)
                {
                    sb.Append(symbol.KeyChar);
                }
            }
        }