From b2f5f80cca754f80e18a0b1e33ac78e39b8b2f73 Mon Sep 17 00:00:00 2001 From: Haseeb Date: Sun, 1 Sep 2024 02:46:53 +0400 Subject: [PATCH] Fixing BUG: Appdata directory is invalid --- QVMEditor/QUtils.cs | 36 ++++++++++++++++++++++++++++++------ 1 file changed, 30 insertions(+), 6 deletions(-) diff --git a/QVMEditor/QUtils.cs b/QVMEditor/QUtils.cs index 3cad9b4..5848688 100644 --- a/QVMEditor/QUtils.cs +++ b/QVMEditor/QUtils.cs @@ -55,13 +55,36 @@ private static void MoveQEditorDir(string destPath) var qCompilerCurrPath = qEdCurrPath + "\\" + "QCompiler"; var keywordFilePath = qEdCurrPath + "\\" + keywordsFile; - if (Directory.Exists(qEdCurrPath) && Directory.Exists(qCompilerCurrPath) && !Directory.Exists(qvmEditorQEdPath)) + try { - DirectoryMove(qEdCurrPath, destPath + "\\" + "QEditor"); + if (Directory.Exists(qEdCurrPath) && Directory.Exists(qCompilerCurrPath) && !Directory.Exists(qvmEditorQEdPath)) + { + DirectoryMove(qEdCurrPath, destPath + "\\" + "QEditor"); + } + if (File.Exists(keywordFilePath)) + { + QUtils.FileIOMove(keywordFilePath, qvmEditorQEdPath + "\\" + keywordsFile); + } } - if (File.Exists(keywordFilePath)) + catch (Exception ex) { - QUtils.FileIOMove(keywordFilePath, qvmEditorQEdPath + "\\" + keywordsFile); + try + { + if (Directory.Exists(qEdCurrPath) && Directory.Exists(qCompilerCurrPath) && !Directory.Exists(qvmEditorQEdPath)) + { + DirectoryCopy(qEdCurrPath, destPath + "\\" + "QEditor", true); + Directory.Delete(qEdCurrPath, true); + } + if (File.Exists(keywordFilePath)) + { + QUtils.FileIOMove(keywordFilePath, qvmEditorQEdPath + "\\" + keywordsFile); + } + } + catch (Exception innerEx) + { + ShowLogException(MethodBase.GetCurrentMethod().Name, innerEx); + throw; + } } } @@ -122,6 +145,8 @@ internal static bool InitEditorAppData() objectsModelsFile = qvmEditorQEdPath + Path.DirectorySeparatorChar + "IGIModels.json"; tempPathFile = qvmEditorQEdPath + "\\" + tempPathFileName; + MoveQEditorDir(appdataPath); + if (!Directory.Exists(qvmEditorQEdPath)) { initErrReason = "QEditor"; initStatus = false; } else if (!Directory.Exists(qCompilerPath)) { initErrReason = @"QEditor\QCompiler"; initStatus = false; } @@ -130,10 +155,9 @@ internal static bool InitEditorAppData() //Show error if 'QEditor' path has invalid structure.. if (!initStatus) { - ShowSystemFatalError("QVVM Editor Appdata directory is invalid Error: (0x0000000F)\nReason: " + initErrReason + "\nPlease re-install new copy from Setup file."); + ShowSystemFatalError("QVM Editor Appdata directory is invalid Error: (0x0000000F)\nReason: " + initErrReason + "\nPlease re-install new copy from Setup file."); } - MoveQEditorDir(appdataPath); //Init Game objects and Keywords. InitGameObjectsInfo(); InitKeywords();