aboutsummaryrefslogtreecommitdiffhomepage
path: root/win32
diff options
context:
space:
mode:
authorNeil <nyamatongwe@gmail.com>2014-05-31 09:59:44 +1000
committerNeil <nyamatongwe@gmail.com>2014-05-31 09:59:44 +1000
commite8891bcd3711bcb93f049d8115c3ec56a35a7347 (patch)
treece9f5c2cadcbb15907b72cfdc7160fde4766f3c1 /win32
parent8eea3418fcb2e24f1e666b40b669029a4bcc4135 (diff)
parent5c4efef3606ad493f1e75a9a13dc3c360eee74d4 (diff)
downloadscintilla-mirror-e8891bcd3711bcb93f049d8115c3ec56a35a7347.tar.gz
Merge with 343-Win32-Fix.
Diffstat (limited to 'win32')
-rw-r--r--win32/PlatWin.cxx50
-rw-r--r--win32/PlatWin.h2
-rw-r--r--win32/ScintRes.rc4
-rw-r--r--win32/ScintillaWin.cxx16
4 files changed, 40 insertions, 32 deletions
diff --git a/win32/PlatWin.cxx b/win32/PlatWin.cxx
index 9eb45e804..fda07875a 100644
--- a/win32/PlatWin.cxx
+++ b/win32/PlatWin.cxx
@@ -3280,31 +3280,33 @@ void Platform_Initialise(void *hInstance) {
#pragma warning(default: 4996)
#endif
-void Platform_Finalise() {
+void Platform_Finalise(bool fromDllMain) {
#if defined(USE_D2D)
- if (defaultRenderingParams) {
- defaultRenderingParams->Release();
- defaultRenderingParams = 0;
- }
- if (customClearTypeRenderingParams) {
- customClearTypeRenderingParams->Release();
- customClearTypeRenderingParams = 0;
- }
- if (pIDWriteFactory) {
- pIDWriteFactory->Release();
- pIDWriteFactory = 0;
- }
- if (pD2DFactory) {
- pD2DFactory->Release();
- pD2DFactory = 0;
- }
- if (hDLLDWrite) {
- FreeLibrary(hDLLDWrite);
- hDLLDWrite = NULL;
- }
- if (hDLLD2D) {
- FreeLibrary(hDLLD2D);
- hDLLD2D = NULL;
+ if (!fromDllMain) {
+ if (defaultRenderingParams) {
+ defaultRenderingParams->Release();
+ defaultRenderingParams = 0;
+ }
+ if (customClearTypeRenderingParams) {
+ customClearTypeRenderingParams->Release();
+ customClearTypeRenderingParams = 0;
+ }
+ if (pIDWriteFactory) {
+ pIDWriteFactory->Release();
+ pIDWriteFactory = 0;
+ }
+ if (pD2DFactory) {
+ pD2DFactory->Release();
+ pD2DFactory = 0;
+ }
+ if (hDLLDWrite) {
+ FreeLibrary(hDLLDWrite);
+ hDLLDWrite = NULL;
+ }
+ if (hDLLD2D) {
+ FreeLibrary(hDLLD2D);
+ hDLLD2D = NULL;
+ }
}
#endif
if (reverseArrowCursor != NULL)
diff --git a/win32/PlatWin.h b/win32/PlatWin.h
index 93e1d7253..c284d42d3 100644
--- a/win32/PlatWin.h
+++ b/win32/PlatWin.h
@@ -14,7 +14,7 @@ namespace Scintilla {
extern bool IsNT();
extern void Platform_Initialise(void *hInstance);
-extern void Platform_Finalise();
+extern void Platform_Finalise(bool fromDllMain);
#if defined(USE_D2D)
extern bool LoadD2D();
diff --git a/win32/ScintRes.rc b/win32/ScintRes.rc
index dd1099196..c7ccba757 100644
--- a/win32/ScintRes.rc
+++ b/win32/ScintRes.rc
@@ -4,8 +4,8 @@
#include <windows.h>
-#define VERSION_SCINTILLA "3.4.2"
-#define VERSION_WORDS 3, 4, 2, 0
+#define VERSION_SCINTILLA "3.4.3"
+#define VERSION_WORDS 3, 4, 3, 0
VS_VERSION_INFO VERSIONINFO
FILEVERSION VERSION_WORDS
diff --git a/win32/ScintillaWin.cxx b/win32/ScintillaWin.cxx
index a83c92ef6..c3a6beefb 100644
--- a/win32/ScintillaWin.cxx
+++ b/win32/ScintillaWin.cxx
@@ -2909,25 +2909,31 @@ int Scintilla_RegisterClasses(void *hInstance) {
return result;
}
-// This function is externally visible so it can be called from container when building statically.
-int Scintilla_ReleaseResources() {
+static int ResourcesRelease(bool fromDllMain) {
bool result = ScintillaWin::Unregister();
if (commctrl32) {
FreeLibrary(commctrl32);
commctrl32 = NULL;
}
- Platform_Finalise();
+ Platform_Finalise(fromDllMain);
return result;
}
+// This function is externally visible so it can be called from container when building statically.
+int Scintilla_ReleaseResources() {
+ return ResourcesRelease(false);
+}
+
#ifndef STATIC_BUILD
-extern "C" int APIENTRY DllMain(HINSTANCE hInstance, DWORD dwReason, LPVOID) {
+extern "C" int APIENTRY DllMain(HINSTANCE hInstance, DWORD dwReason, LPVOID lpvReserved) {
//Platform::DebugPrintf("Scintilla::DllMain %d %d\n", hInstance, dwReason);
if (dwReason == DLL_PROCESS_ATTACH) {
if (!Scintilla_RegisterClasses(hInstance))
return FALSE;
} else if (dwReason == DLL_PROCESS_DETACH) {
- Scintilla_ReleaseResources();
+ if (lpvReserved == NULL) {
+ ResourcesRelease(true);
+ }
}
return TRUE;
}