Exemple #1
0
        static void Main(string[] args)
        {
            NumelonFunction nf      = new NumelonFunction();
            IAction         actMode = null;

            Console.WriteLine("実行モードを選んでください play : 1 , test : 2 , 終了 : 0");
            switch (nf.scanNum(0, 2))
            {
            case 0:
                Environment.Exit(0);
                break;

            case 1:
                actMode = new NumelonAction();
                break;

            case 2:
                actMode = new Test();
                break;
            }
            actMode.action();
        }
        public void action()
        {
            /*宣言*/
            int             mode;
            int             opponent;
            int             digit;
            string          log     = "";
            bool            logFlag = false;
            IPrayer         prayer1 = null;
            IPrayer         prayer2 = null;
            NumelonFunction nf      = new NumelonFunction();
            // Stopwatchクラス生成
            var sw = new System.Diagnostics.Stopwatch();

            Console.WriteLine("Numelon Game");

            /*桁数設定*/
            Console.WriteLine("ゲームの桁数を入力してください(2 ~ 9)");
            digit = nf.scanNum(2, 9);

            /*モード設定*/
            Console.WriteLine("モードを選んでください(Human : 1 , CPU : 2 , 終了 : 0)");
            mode = nf.scanNum(0, 2);
            switch (mode)
            {
            case 0:
                Environment.Exit(0);
                break;

            case 1:
                prayer1 = new Human(digit);
                break;

            case 2:
                prayer1 = new CPU1(digit, "CPU1");
                break;
            }

            /*対戦相手の設定*/
            Console.WriteLine("対戦相手を選んでください(Human : 1 , CPU : 2 , 人工無能 : 3 , 終了 : 0)");
            opponent = nf.scanNum(0, 3);
            switch (opponent)
            {
            case 0:
                Environment.Exit(0);
                break;

            case 1:
                prayer2 = new Human(digit);
                break;

            case 2:
                if (mode == 2)
                {
                    prayer2 = new CPU1(digit, "CPU2");
                }
                else
                {
                    prayer2 = new CPU1(digit, "CPU");
                }
                break;

            case 3:
                prayer2 = new ArtificialIncompetence(digit, "人工無能");
                break;
            }

            /*ゲーム開始*/
            // 計測開始
            sw.Start();
            try
            {
                log = nf.GameStart(digit, prayer1, prayer2);
            }
            //引数にnullがあったとき
            catch (ArgumentNullException)
            {
                Console.WriteLine("エラーが発生しました プログラムを終了します");
            }
            sw.Stop();

            /*ログファイルの処理*/
            Console.WriteLine("ログを出力しますか? yes : 1 no : 0");
            switch (nf.scanNum(0, 1))
            {
            case 0:
                logFlag = false;
                break;

            case 1:
                logFlag = true;
                break;
            }
            if (logFlag)
            {
                DateTime dt   = DateTime.Now;
                string   head = dt.ToString("yyyy年MM月dd日 HH時mm分ss秒") +
                                "  処理時間 " + $" {sw.ElapsedMilliseconds}ミリ秒\n";
                head += "+++++++++++++++++++++++++++++++++++++++++++++++++++++\n";
                log   = head + log;

                Console.WriteLine("ファイルに出力しますか? ");
                Console.WriteLine("ファイルに出力する : 1 , コンソール上に出力する : 2 , 出力しない : 0");
                switch (nf.scanNum(0, 2))
                {
                case 0:
                    logFlag = false;
                    break;

                case 1:
                    nf.logWriteToFile(log);
                    break;

                case 2:
                    Console.WriteLine(log);
                    break;
                }
            }
        }