OSDN Git Service

Plugins: Fix a crash on Window XP
[winmerge-jp/winmerge-jp.git] / Src / OptionsInit.cpp
index fce4023..18d31cd 100644 (file)
@@ -6,6 +6,7 @@
 
 #include "pch.h"
 #include <vector>
+#include <typeinfo>
 #include "OptionsDef.h"
 #include "OptionsMgr.h"
 #include "RegOptionsMgr.h"
@@ -13,6 +14,7 @@
 #include "OptionsDiffOptions.h"
 #include "OptionsDiffColors.h"
 #include "OptionsDirColors.h"
+#include "OptionsEditorSyntax.h"
 #include "OptionsFont.h"
 #include "DiffWrapper.h" // CMP_CONTENT
 #include "paths.h"
@@ -21,7 +23,6 @@
 #include "Constants.h"
 
 // Functions to copy values set by installer from HKLM to HKCU.
-static void CopyHKLMValues();
 static bool OpenHKLM(HKEY *key, LPCTSTR relpath = nullptr);
 static bool OpenHKCU(HKEY *key, LPCTSTR relpath = nullptr);
 static void CopyFromLMtoCU(HKEY lmKey, HKEY cuKey, LPCTSTR valname);
@@ -38,7 +39,10 @@ namespace Options
  */
 void Init(COptionsMgr *pOptions)
 {
-       static_cast<CRegOptionsMgr *>(pOptions)->SetRegRootKey(_T("Thingamahoochie\\WinMerge\\"));
+       if (typeid(*pOptions) == typeid(CRegOptionsMgr))
+       {
+               static_cast<CRegOptionsMgr*>(pOptions)->SetRegRootKey(_T("Thingamahoochie\\WinMerge\\"));
+       }
 
        LANGID LangId = GetUserDefaultLangID();
        pOptions->InitOption(OPT_SELECTED_LANGUAGE, static_cast<int>(LangId));
@@ -69,13 +73,13 @@ void Init(COptionsMgr *pOptions)
        pOptions->InitOption(OPT_VIEW_LINENUMBERS, false);
        pOptions->InitOption(OPT_VIEW_WHITESPACE, false);
        pOptions->InitOption(OPT_VIEW_EOL, false);
-       pOptions->InitOption(OPT_CONNECT_MOVED_BLOCKS, 0);
        pOptions->InitOption(OPT_SCROLL_TO_FIRST, false);
        pOptions->InitOption(OPT_SCROLL_TO_FIRST_INLINE_DIFF, false);
        pOptions->InitOption(OPT_VERIFY_OPEN_PATHS, true);
        pOptions->InitOption(OPT_AUTO_COMPLETE_SOURCE, (int)1);
        pOptions->InitOption(OPT_VIEW_FILEMARGIN, false);
        pOptions->InitOption(OPT_DIFF_CONTEXT, (int)-1);
+       pOptions->InitOption(OPT_INVERT_DIFF_CONTEXT, false);
        pOptions->InitOption(OPT_SPLIT_HORIZONTALLY, false);
        pOptions->InitOption(OPT_RENDERING_MODE, -1);
        pOptions->InitOption(OPT_FILE_SIZE_THRESHOLD, 64*1024*1024);
@@ -110,9 +114,9 @@ void Init(COptionsMgr *pOptions)
        pOptions->InitOption(OPT_TAB_SIZE, (int)4);
        pOptions->InitOption(OPT_TAB_TYPE, (int)0);     // 0 means tabs inserted
 
-       pOptions->InitOption(OPT_EXT_EDITOR_CMD, paths::ConcatPath(env::GetWindowsDirectory(), _T("NOTEPAD.EXE")));
+       pOptions->InitOption(OPT_EXT_EDITOR_CMD, _T("%windir%\\NOTEPAD.EXE"));
        pOptions->InitOption(OPT_USE_RECYCLE_BIN, true);
-       pOptions->InitOption(OPT_SINGLE_INSTANCE, false);
+       pOptions->InitOption(OPT_SINGLE_INSTANCE, 0);
        pOptions->InitOption(OPT_MERGE_MODE, false);
        // OPT_WORDDIFF_HIGHLIGHT is initialized above
        pOptions->InitOption(OPT_BREAK_ON_WORDS, false);
@@ -160,12 +164,15 @@ void Init(COptionsMgr *pOptions)
        pOptions->InitOption(OPT_CMP_IMG_THRESHOLD, 0);
        pOptions->InitOption(OPT_CMP_IMG_INSERTIONDELETIONDETECTION_MODE, 0);
        pOptions->InitOption(OPT_CMP_IMG_VECTOR_IMAGE_ZOOM_RATIO, 1000);
+       pOptions->InitOption(OPT_CMP_IMG_OCR_RESULT_TYPE, 0);
 
        pOptions->InitOption(OPT_PROJECTS_PATH, _T(""));
        pOptions->InitOption(OPT_USE_SYSTEM_TEMP_PATH, true);
        pOptions->InitOption(OPT_CUSTOM_TEMP_PATH, _T(""));
 
        pOptions->InitOption(OPT_LINEFILTER_ENABLED, false);
+       pOptions->InitOption(OPT_SUBSTITUTION_FILTERS_ENABLED, false);
+
        pOptions->InitOption(OPT_FILEFILTER_CURRENT, _T("*.*"));
        // CMainFrame initializes this when it is empty.
        pOptions->InitOption(OPT_FILTER_USERPATH, _T(""));
@@ -192,11 +199,11 @@ void Init(COptionsMgr *pOptions)
        pOptions->InitOption(OPT_ARCHIVE_FILTER_INDEX, 1);
 
        pOptions->InitOption(OPT_PLUGINS_ENABLED, true);
-       pOptions->InitOption(OPT_PLUGINS_DISABLED_LIST, _T(""));
-       pOptions->InitOption(OPT_PLUGINS_CUSTOM_FILTERS_LIST, _T(""));
-       pOptions->InitOption(OPT_PLUGINS_UNPACKER_MODE, PLUGIN_MANUAL);
-       pOptions->InitOption(OPT_PLUGINS_PREDIFFER_MODE, PLUGIN_MANUAL);
-       pOptions->InitOption(OPT_PLUGINS_UNPACK_DONT_CHECK_EXTENSION, false);
+       pOptions->InitOption(OPT_PLUGINS_CUSTOM_SETTINGS_LIST, _T(""));
+       pOptions->InitOption(OPT_PLUGINS_UNPACKER_MODE, false);
+       pOptions->InitOption(OPT_PLUGINS_PREDIFFER_MODE, false);
+       pOptions->InitOption(OPT_PLUGINS_UNPACK_DONT_CHECK_EXTENSION, true);
+       pOptions->InitOption(OPT_PLUGINS_OPEN_IN_SAME_FRAME_TYPE, false);
 
        pOptions->InitOption(OPT_PATCHCREATOR_PATCH_STYLE, 0);
        pOptions->InitOption(OPT_PATCHCREATOR_CONTEXT_LINES, 0);
@@ -219,6 +226,7 @@ void Init(COptionsMgr *pOptions)
        Options::DiffOptions::SetDefaults(pOptions);
        Options::DiffColors::SetDefaults(pOptions);
        Options::DirColors::SetDefaults(pOptions);
+       Options::EditorSyntax::SetDefaults(pOptions);
        Options::Font::SetDefaults(pOptions);
 }