コード例 #1
0
 private void TestProjectButton_Click(object sender, RoutedEventArgs e)
 {
     try
     {
         CoreCode.RunTest(Settings.Default.SDKLocation, ProjectLocation.Text);
     }
     catch (Exception nwjsException)
     {
         MessageBox.Show(Properties.Resources.ErrorOccuredText, Properties.Resources.ErrorText, MessageBoxButton.OK, MessageBoxImage.Error);
         OutputArea.Text = OutputArea.Text + "\n" + DateTime.Now + nwjsException;
     }
 }
コード例 #2
0
        private void StartMapCompiler(object sender, DoWorkEventArgs e)
        {
            try
            {
                for (var i = 0; i < FolderList.Items.Count; i++)
                {
                    var i1 = i;
                    Dispatcher.Invoke(() =>
                                      OutputArea.Text = OutputArea.Text + "\n" + DateTime.Now + Properties.Resources.CompileText1 +
                                                        FolderList.Items[i1] + Properties.Resources.FolderText + "\n");

                    Dispatcher.Invoke(() =>
                                      MapStatusLabel.Content = Properties.Resources.CompileText1 + FolderList.Items[i1] + Properties.Resources.FolderText);
                    CoreCode.FileFinder(FolderList.Items[i1].ToString(), "*.js");
                    Dispatcher.Invoke(() =>
                                      OutputArea.Text += "\n" + DateTime.Now +
                                                         Properties.Resources.BinRemovalText);
                    Dispatcher.Invoke(() => CurrentWorkloadBar.Maximum = CoreCode.FileMap.Length);

                    Dispatcher.Invoke(() =>
                                      CurrentWorkloadLabel.Content = Properties.Resources.BinRemovalStatusText + FolderList.Items[i1] + "...");
                    CoreCode.CleanupBin();
                    foreach (var file in CoreCode.FileMap)
                    {
                        Dispatcher.Invoke(() => CurrentWorkloadLabel.Content = Properties.Resources.CompileText + file + "...");
                        Thread.Sleep(200);
                        Dispatcher.Invoke(() => CoreCode.CompilerWorkerTask(file, FileExtensionTextbox.Text,
                                                                            RemoveCompiledJsCheckbox.IsChecked == true));
                        Thread.Sleep(200);
                        Dispatcher.Invoke(() => CurrentWorkloadBar.Value += 1);
                    }

                    Array.Clear(CoreCode.FileMap, 0, CoreCode.FileMap.Length);
                    Dispatcher.Invoke(() => CurrentWorkloadBar.Value = 0);
                    Dispatcher.Invoke(() => MapProgress.Value       += 1);
                }

                Dispatcher.Invoke(() =>
                                  OutputArea.Text = OutputArea.Text + "\n" + DateTime.Now + "\n" + Properties.Resources.CompilationCompleteText + "\n");
                MessageBox.Show(Properties.Resources.CompilationCompleteText, Properties.Resources.DoneText, MessageBoxButton.OK, MessageBoxImage.Information);
                Dispatcher.Invoke(() => MapStatusLabel.Content       = Properties.Resources.DoneText);
                Dispatcher.Invoke(() => CurrentWorkloadLabel.Content = Properties.Resources.DoneText);
            }
            catch (Exception exceptionOutput)
            {
                Dispatcher.Invoke(() => MapProgress.Foreground = Brushes.DarkRed);
                Dispatcher.Invoke(() =>
                                  OutputArea.Text = OutputArea.Text + "\n" + DateTime.Now + "\n" + exceptionOutput + "\n");
                Dispatcher.Invoke(() => MapStatusLabel.Content        = Properties.Resources.FailedText);
                Dispatcher.Invoke(() => CurrentWorkloadBar.Foreground = Brushes.DarkRed);
                Dispatcher.Invoke(() => CurrentWorkloadLabel.Content  = Properties.Resources.FailedText);

                Dispatcher.Invoke(() =>
                                  OutputArea.Text = OutputArea.Text + "\n" + DateTime.Now + "\n" + exceptionOutput + "\n");
                MessageBox.Show(Properties.Resources.ErrorOccuredText, Properties.Resources.FailedText,
                                MessageBoxButton.OK, MessageBoxImage.Error);
                Dispatcher.Invoke(() => CurrentWorkloadBar.Value      = 0);
                Dispatcher.Invoke(() => MapProgress.Value             = 0);
                Dispatcher.Invoke(() => MapProgress.Foreground        = Brushes.ForestGreen);
                Dispatcher.Invoke(() => CurrentWorkloadBar.Foreground = Brushes.ForestGreen);
                Array.Clear(CoreCode.FileMap, 0, CoreCode.FileMap.Length);
            }

            Dispatcher.Invoke(() => MapCompileButton.IsEnabled    = true);
            Dispatcher.Invoke(() => AddToMapButton.IsEnabled      = true);
            Dispatcher.Invoke(() => RemoveFromMapButton.IsEnabled = true);
        }
コード例 #3
0
ファイル: Program.cs プロジェクト: UHPD-Games/RMMVCookTool
        private static void Main(string[] args)
        {
            string sdkLocation;
            string projectLocation;

            char charBuffer;

            Console.WriteLine("================================================");
            Console.WriteLine("= RPG Maker MV Cook Tool (.NET Core CLI Version)");
            Console.WriteLine("= Version D1.00 Update 1");
            Console.WriteLine("= Developed by AceOfAces.");
            Console.WriteLine("= Licensed under GNU General Public License v3.");
            Console.WriteLine("================================================");

            do
            {   //Ask the user where is the SDK. Check if the folder's there.
                Console.WriteLine("Where's the SDK location? ");
                sdkLocation = Console.ReadLine();
                if (sdkLocation == null)
                {
                    Console.WriteLine("Please insert the path for the SDK please.\n");
                }
                else if (!Directory.Exists(sdkLocation))
                {
                    Console.Write("The directory isn't there. Please select an existing folder.\n");
                }
            } while (sdkLocation == null || !Directory.Exists(sdkLocation));

            do
            {  //Ask the user what project to compile. Check if the folder is there and there's a js folder.
                Console.WriteLine("\nWhere's the project you want to compile? ");
                projectLocation = Console.ReadLine();

                if (projectLocation == null)
                {
                    Console.WriteLine("Please specify the location of the folder.\n");
                }
                else if (!Directory.Exists(projectLocation))
                {
                    Console.WriteLine("The folder you've selected isn't present.\n");
                }
                else if (!Directory.Exists(Path.Combine(projectLocation, "www", "js")))
                {
                    Console.WriteLine("There is no js folder.\n");
                }
            }while (projectLocation == null || !Directory.Exists(projectLocation) ||
                    !Directory.Exists(Path.Combine(projectLocation, "www", "js")));

            //Leave the commented code as is for now.
            //do
            //{
            //    Console.WriteLine(
            //        "\nWould you like to:\n1. Compile JavaScript?\n2. Compile and package to package.nw?\n");
            //    modeSelected = Convert.ToInt32(Console.Read());
            //    if (modeSelected < 1 && modeSelected > 2) Console.Write("You didn't pick any of the answers. Try again.\n");
            //}
            //while (modeSelected < 1 && modeSelected > 2);

            //if (modeSelected != 3)
            //{

            //Ask the user for the file extension.
            Console.Write("\nWhat Extension will your game use (leave empty for .bin)? ");
            var fileExtension = Console.ReadLine();

            if (string.IsNullOrEmpty(fileExtension))
            {
                fileExtension = "bin";
            }
            //This is the check if the tool should delete the JS files.
            Console.WriteLine("\nDo you want to:\n1. Test that the binary files are loaded properly?\n2. Prepare for publishing?\n(Default is 1) ");
            var checkBuffer = Console.ReadLine();

            int.TryParse(checkBuffer, out var checkDeletion);
            var removeJsFiles = (checkDeletion == 2);

            //}

            if (checkDeletion == 2)
            {
                Console.WriteLine(
                    "\nWould you like to compress the game's files to an archive?\n1.Yes (delete the files as well).\n2.Yes (but leave the files intact).\n3. No.\n(Default is 3)");
                charBuffer = Console.ReadKey().KeyChar;
                if (!char.IsLetterOrDigit(charBuffer))
                {
                    _compressProject = Convert.ToInt32(charBuffer);
                }
                else
                {
                    _compressProject = 3;
                }
            }
            else
            {
                //Ask if the user would like to test with nwjs.
                Console.WriteLine("\nWould you like to test the project after compiling? (Y/N, Default is N)\n");
                charBuffer = Console.ReadKey().KeyChar;
                if (char.IsLetterOrDigit(charBuffer))
                {
                    switch (charBuffer)
                    {
                    case 'Y':
                    case 'y':
                    case 'Ν':
                    case 'ν':
                        _testProject = true;
                        break;

                    default:
                        _testProject = false;
                        break;
                    }
                }
                else
                {
                    _testProject = false;
                }
            }


            //The folder that the tool looks for.
            const string folderMap = "js";

            //Finding all the JS files.
            CoreCode.FileFinder(Path.Combine(projectLocation, "www", folderMap), "*.js");
            Console.WriteLine("\n" + DateTime.Now + "\nRemoving binary files (if present)...\n");
            CoreCode.CleanupBin();
            //Preparing the compiler task.
            CoreCode.CompilerInfo.FileName = Path.Combine(sdkLocation, RuntimeInformation.IsOSPlatform(OSPlatform.Windows) ? "nwjc.exe" : "nwjc");
            try
            {
                //Read from the FileMap (which is located in the CompilerCore library.
                //Compilation is done in parallel. Handy for multi-core systems.
                Parallel.ForEach(CoreCode.FileMap, fileName =>
                {
                    //Print the status of the compiler. Show which thread is compiling what as well.
                    Console.WriteLine("\n" + DateTime.Now + "\nThread #" + Thread.CurrentThread.ManagedThreadId + " is compiling " + fileName + "...\n");
                    //Call the compiler task.
                    CoreCode.CompilerWorkerTask(fileName, fileExtension, removeJsFiles);
                    Console.WriteLine("\n" + DateTime.Now + "\nThread #" + Thread.CurrentThread.ManagedThreadId + " finished compiling " + fileName + ".\n");
                });
                Console.WriteLine("\nFinished compiling.");
                if (_testProject)
                {
                    CoreCode.RunTest(sdkLocation, projectLocation);
                }
                else if (_compressProject < 3)
                {
                    Console.WriteLine("Copying the game files to a temporary location...");
                    CoreCode.PreparePack(projectLocation);
                    Console.WriteLine("Compressing files...");
                    CoreCode.CompressFiles(projectLocation);
                    if (_compressProject == 2)
                    {
                        Console.WriteLine("Deleting source files...");
                        CoreCode.DeleteFiles(projectLocation);
                    }
                }

                Console.WriteLine("\nThe task was completed.");
            }
            catch (Exception e)
            {
                //TODO Improve the handling of the errors.
                Console.WriteLine(e);
                throw;
            }
            //Ask the user to press Enter (or Return).
            Console.WriteLine("Push Enter/Return to exit.");
            Console.ReadLine();
        }
コード例 #4
0
        private void StartCompiler(object sender, DoWorkEventArgs e)
        {
            var compilerInput = Dispatcher.Invoke(() => ProjectLocation.Text);

            Dispatcher.Invoke(() => StatusLabel.Content = Properties.Resources.CompileJsFolderProgressText);
            try
            {
                var folderMap = "js";
                CoreCode.FileFinder(Path.Combine(compilerInput, "www", folderMap), "*.js");
                Dispatcher.Invoke(() =>
                                  OutputArea.Text += "\n" + DateTime.Now +
                                                     Properties.Resources.BinRemovalText);
                Dispatcher.Invoke(() => StatusLabel.Content = Properties.Resources.BinRemovalProgressText);
                CoreCode.CleanupBin();
                CoreCode.CompilerInfo.FileName = Dispatcher.Invoke(() => Path.Combine(NwjsLocation.Text, "nwjc.exe"));
                Dispatcher.Invoke(() => MainProgress.Maximum = CoreCode.FileMap.Length);
                if (Dispatcher.Invoke(() => PackageNwCheckbox.IsChecked == true))
                {
                    Dispatcher.Invoke(() => MainProgress.Maximum += 1);
                }
                if (Dispatcher.Invoke(() => RemoveFilesCheckBox.IsChecked == true))
                {
                    Dispatcher.Invoke(() => MainProgress.Maximum += 1);
                }
                foreach (var fileName in CoreCode.FileMap)
                {
                    Dispatcher.Invoke(
                        () => OutputArea.Text += "\n" + DateTime.Now + Properties.Resources.CompilingText + fileName + "...\n");
                    Thread.Sleep(200);
                    Dispatcher.Invoke(() =>
                                      StatusLabel.Content = StatusLabel.Content = Properties.Resources.CompileText + fileName + "...");
                    Thread.Sleep(200);
                    Dispatcher.Invoke(() => CoreCode.CompilerWorkerTask(fileName, FileExtensionTextbox.Text,
                                                                        RemoveCompiledJsCheckbox.IsChecked == true));
                    Dispatcher.Invoke(() => OutputArea.Text    += Properties.Resources.CompiledOutputText + DateTime.Now + "\n");
                    Dispatcher.Invoke(() => MainProgress.Value += 1);
                }

                Array.Clear(CoreCode.FileMap, 0, CoreCode.FileMap.Length);


                if (Dispatcher.Invoke(() => PackageNwCheckbox.IsChecked == true))
                {
                    Dispatcher.Invoke(() => StatusLabel.Content = Properties.Resources.PackaginStatusText);
                    Thread.Sleep(200);
                    Dispatcher.Invoke(() => OutputArea.Text = OutputArea.Text + "\n" + DateTime.Now +
                                                              Properties.Resources.FileCopyText);
                    Dispatcher.Invoke(() => CoreCode.PreparePack(compilerInput));
                    Thread.Sleep(200);
                    Dispatcher.Invoke(() =>
                                      OutputArea.Text = OutputArea.Text + "\n" + DateTime.Now + Properties.Resources.PackageCreationText);
                    CoreCode.CompressFiles(compilerInput);
                    Dispatcher.Invoke(() => MainProgress.Value += 1);
                    if (Dispatcher.Invoke(() => RemoveFilesCheckBox.IsChecked == true))
                    {
                        Dispatcher.Invoke(() => MainProgress.Value += 1);
                        Dispatcher.Invoke(() => OutputArea.Text     = OutputArea.Text + "\n" + DateTime.Now + "\nRemoving files...\n");
                        CoreCode.DeleteFiles(compilerInput);
                    }
                }

                Dispatcher.Invoke(() =>
                                  OutputArea.Text = OutputArea.Text + "\n" + DateTime.Now + "\n " + Properties.Resources.CompilationCompleteText + "\n");
                MessageBox.Show(Properties.Resources.CompilationCompleteText, Properties.Resources.DoneText, MessageBoxButton.OK, MessageBoxImage.Information);
                Dispatcher.Invoke(() => StatusLabel.Content = Properties.Resources.DoneText);
            }

            catch (Exception exceptionOutput)
            {
                Dispatcher.Invoke(() =>
                                  OutputArea.Text           = OutputArea.Text + "\n" + DateTime.Now + "\n" + exceptionOutput + "\n");
                Dispatcher.Invoke(() => StatusLabel.Content = Properties.Resources.FailedText);
                MessageBox.Show(Properties.Resources.ErrorOccuredText, Properties.Resources.FailedText,
                                MessageBoxButton.OK, MessageBoxImage.Error);
                Dispatcher.Invoke(() => MainProgress.Value      = 0);
                Dispatcher.Invoke(() => MainProgress.Foreground = Brushes.ForestGreen);
                Array.Clear(CoreCode.FileMap, 0, CoreCode.FileMap.Length);
            }

            Dispatcher.Invoke(() => CompileButton.IsEnabled     = true);
            Dispatcher.Invoke(() => TestProjectButton.IsEnabled = true);
            Dispatcher.Invoke(() => ProjectLocation.IsEnabled   = true);
            Dispatcher.Invoke(() => FindProjectButton.IsEnabled = true);
            Dispatcher.Invoke(() => LockSettings(true));
        }
コード例 #5
0
        private void StartCompiler(object sender, DoWorkEventArgs e)
        {
            var compilerInput = Dispatcher.Invoke(() => ProjectLocation.Text);
            var packageOutput = Path.Combine(compilerInput, "package.nw");

            Dispatcher.Invoke(() => StatusLabel.Content = Properties.Resources.CompileJsFolderProgressText);
            try
            {
                var folderMap = "js";
                CoreCode.FileFinder(Path.Combine(compilerInput, "www", folderMap), "*.js");
                Dispatcher.Invoke(() =>
                                  OutputArea.Text += "\n" + DateTime.Now +
                                                     "\nRemoving binary files from the project (if there are)...\n");
                Dispatcher.Invoke(() => StatusLabel.Content = Properties.Resources.BinRemovalProgressText);
                CoreCode.CleanupBin();
                CoreCode.CompilerInfo.FileName = Dispatcher.Invoke(() => NwjsLocation.Text);
                Dispatcher.Invoke(() => MainProgress.Maximum = CoreCode.FileMap.Length);
                if (Dispatcher.Invoke(() => PackageNwCheckbox.IsChecked == true))
                {
                    Dispatcher.Invoke(() => MainProgress.Maximum += 1);
                }
                foreach (var fileName in CoreCode.FileMap)
                {
                    Dispatcher.Invoke(
                        () => OutputArea.Text += "\n" + DateTime.Now + "\nCompiling " + fileName + "...\n");
                    Thread.Sleep(200);
                    Dispatcher.Invoke(() =>
                                      StatusLabel.Content = StatusLabel.Content = Properties.Resources.CompileText + fileName + "...");
                    Thread.Sleep(200);
                    Dispatcher.Invoke(() => CoreCode.CompilerWorkerTask(fileName, FileExtensionTextbox.Text,
                                                                        RemoveCompiledJsCheckbox.IsChecked == true));
                    Dispatcher.Invoke(() => OutputArea.Text    += "\nCompiled on " + DateTime.Now + "\n");
                    Dispatcher.Invoke(() => MainProgress.Value += 1);
                }

                Array.Clear(CoreCode.FileMap, 0, CoreCode.FileMap.Length);


                if (Dispatcher.Invoke(() => PackageNwCheckbox.IsChecked == true))
                {
                    Dispatcher.Invoke(() => StatusLabel.Content = "Packaging...");
                    Thread.Sleep(200);
                    Dispatcher.Invoke(() => OutputArea.Text = OutputArea.Text + "\n" + DateTime.Now +
                                                              "\n Copying files to a temporary area...\n");
                    Thread.Sleep(200);
                    if (Directory.Exists(_tempFolderLocation))
                    {
                        Directory.Delete(_tempFolderLocation, true);
                    }
                    Dispatcher.Invoke(() => CoreCode.DirectoryCopy(Path.Combine(compilerInput, "www"),
                                                                   Path.Combine(_tempFolderLocation, "www"), true));
                    File.Copy(Path.Combine(compilerInput, "package.json"),
                              Path.Combine(_tempFolderLocation, "package.json"), true);
                    Dispatcher.Invoke(() =>
                                      OutputArea.Text = OutputArea.Text + "\n" + DateTime.Now + "\n Creating package...\n");
                    if (File.Exists(packageOutput))
                    {
                        File.Delete(packageOutput);
                    }
                    ZipFile.CreateFromDirectory(_tempFolderLocation,
                                                packageOutput);
                    Directory.Delete(_tempFolderLocation, true);
                    Dispatcher.Invoke(() => MainProgress.Value += 1);
                }

                Dispatcher.Invoke(() =>
                                  OutputArea.Text = OutputArea.Text + "\n" + DateTime.Now + "\n Compilation complete!\n");
                MessageBox.Show(Properties.Resources.CompilationCompleteText, Properties.Resources.DoneText, MessageBoxButton.OK, MessageBoxImage.Information);
                Dispatcher.Invoke(() => StatusLabel.Content = Properties.Resources.DoneText);
            }

            catch (Exception exceptionOutput)
            {
                Dispatcher.Invoke(() =>
                                  OutputArea.Text           = OutputArea.Text + "\n" + DateTime.Now + "\n" + exceptionOutput + "\n");
                Dispatcher.Invoke(() => StatusLabel.Content = Properties.Resources.FailedText);
                MessageBox.Show(Properties.Resources.ErrorOccuredText, Properties.Resources.FailedText,
                                MessageBoxButton.OK, MessageBoxImage.Error);
                Dispatcher.Invoke(() => MainProgress.Value      = 0);
                Dispatcher.Invoke(() => MainProgress.Foreground = Brushes.ForestGreen);
                Array.Clear(CoreCode.FileMap, 0, CoreCode.FileMap.Length);
            }

            Dispatcher.Invoke(() => CompileButton.IsEnabled = true);
        }