mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-28 15:06:15 +01:00
Mention G_WIN32_DLLMAIN_FOR_DLL_NAME() will be deprecated in the future.
2008-02-24 Tor Lillqvist <tml@novell.com> * glib/gutils.h: Mention G_WIN32_DLLMAIN_FOR_DLL_NAME() will be deprecated in the future. * glib/gutils.c: Drop use of G_WIN32_DLLMAIN_FOR_DLL_NAME(). Use a minimal DllMain() instead that just saves the DLL handle. (g_win32_get_system_data_dirs_for_module, _glib_get_locale_dir) (get_module_share_dir): Use g_win32_get_package_installation_directory_of_module(). svn path=/trunk/; revision=6570
This commit is contained in:
parent
3af00194ea
commit
811b86fa56
@ -30,6 +30,15 @@
|
|||||||
|
|
||||||
* glib/glib.symbols: Add it.
|
* glib/glib.symbols: Add it.
|
||||||
|
|
||||||
|
* glib/gutils.h: Mention G_WIN32_DLLMAIN_FOR_DLL_NAME() will be
|
||||||
|
deprecated in the future.
|
||||||
|
|
||||||
|
* glib/gutils.c: Drop use of G_WIN32_DLLMAIN_FOR_DLL_NAME(). Use a
|
||||||
|
minimal DllMain() instead that just saves the DLL handle.
|
||||||
|
(g_win32_get_system_data_dirs_for_module, _glib_get_locale_dir)
|
||||||
|
(get_module_share_dir): Use
|
||||||
|
g_win32_get_package_installation_directory_of_module().
|
||||||
|
|
||||||
2008-02-23 Matthias Clasen <mclasen@redhat.com>
|
2008-02-23 Matthias Clasen <mclasen@redhat.com>
|
||||||
|
|
||||||
* NEWS: Updates
|
* NEWS: Updates
|
||||||
|
@ -133,7 +133,18 @@ const guint glib_binary_age = GLIB_BINARY_AGE;
|
|||||||
|
|
||||||
#ifdef G_PLATFORM_WIN32
|
#ifdef G_PLATFORM_WIN32
|
||||||
|
|
||||||
G_WIN32_DLLMAIN_FOR_DLL_NAME (static, dll_name)
|
static HMODULE glib_dll = NULL;
|
||||||
|
|
||||||
|
BOOL WINAPI
|
||||||
|
DllMain (HINSTANCE hinstDLL,
|
||||||
|
DWORD fdwReason,
|
||||||
|
LPVOID lpvReserved)
|
||||||
|
{
|
||||||
|
if (fdwReason == DLL_PROCESS_ATTACH)
|
||||||
|
glib_dll = hinstDLL;
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -2428,7 +2439,7 @@ get_module_for_address (gconstpointer address)
|
|||||||
static gboolean beenhere = FALSE;
|
static gboolean beenhere = FALSE;
|
||||||
typedef BOOL (WINAPI *t_GetModuleHandleExA) (DWORD, LPCTSTR, HMODULE *);
|
typedef BOOL (WINAPI *t_GetModuleHandleExA) (DWORD, LPCTSTR, HMODULE *);
|
||||||
static t_GetModuleHandleExA p_GetModuleHandleExA = NULL;
|
static t_GetModuleHandleExA p_GetModuleHandleExA = NULL;
|
||||||
HMODULE hmodule;
|
HMODULE hmodule = NULL;
|
||||||
|
|
||||||
if (!address)
|
if (!address)
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -2458,27 +2469,14 @@ static gchar *
|
|||||||
get_module_share_dir (gconstpointer address)
|
get_module_share_dir (gconstpointer address)
|
||||||
{
|
{
|
||||||
HMODULE hmodule;
|
HMODULE hmodule;
|
||||||
gchar *filename = NULL;
|
gchar *filename;
|
||||||
gchar *p, *retval;
|
gchar *retval;
|
||||||
wchar_t wfilename[MAX_PATH];
|
|
||||||
|
|
||||||
hmodule = get_module_for_address (address);
|
hmodule = get_module_for_address (address);
|
||||||
if (hmodule == NULL)
|
if (hmodule == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if (GetModuleFileNameW (hmodule, wfilename, G_N_ELEMENTS (wfilename)))
|
filename = g_win32_get_package_installation_directory_of_module (hmodule);
|
||||||
filename = g_utf16_to_utf8 (wfilename, -1, NULL, NULL, NULL);
|
|
||||||
|
|
||||||
if (filename == NULL)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
if ((p = strrchr (filename, G_DIR_SEPARATOR)) != NULL)
|
|
||||||
*p = '\0';
|
|
||||||
|
|
||||||
p = strrchr (filename, G_DIR_SEPARATOR);
|
|
||||||
if (p && (g_ascii_strcasecmp (p + 1, "bin") == 0))
|
|
||||||
*p = '\0';
|
|
||||||
|
|
||||||
retval = g_build_filename (filename, "share", NULL);
|
retval = g_build_filename (filename, "share", NULL);
|
||||||
g_free (filename);
|
g_free (filename);
|
||||||
|
|
||||||
@ -2493,6 +2491,7 @@ g_win32_get_system_data_dirs_for_module (gconstpointer address)
|
|||||||
static GHashTable *per_module_data_dirs = NULL;
|
static GHashTable *per_module_data_dirs = NULL;
|
||||||
gchar **retval;
|
gchar **retval;
|
||||||
gchar *p;
|
gchar *p;
|
||||||
|
gchar *exe_root;
|
||||||
|
|
||||||
if (address)
|
if (address)
|
||||||
{
|
{
|
||||||
@ -2553,13 +2552,20 @@ g_win32_get_system_data_dirs_for_module (gconstpointer address)
|
|||||||
if (p)
|
if (p)
|
||||||
g_array_append_val (data_dirs, p);
|
g_array_append_val (data_dirs, p);
|
||||||
|
|
||||||
p = g_win32_get_package_installation_subdirectory (NULL, dll_name, "share");
|
if (glib_dll != NULL)
|
||||||
|
{
|
||||||
|
gchar *glib_root = g_win32_get_package_installation_directory_of_module (glib_dll);
|
||||||
|
p = g_build_filename (glib_root, "share", NULL);
|
||||||
if (p)
|
if (p)
|
||||||
g_array_append_val (data_dirs, p);
|
g_array_append_val (data_dirs, p);
|
||||||
|
g_free (glib_root);
|
||||||
|
}
|
||||||
|
|
||||||
p = g_win32_get_package_installation_subdirectory (NULL, NULL, "share");
|
exe_root = g_win32_get_package_installation_directory_of_module (NULL);
|
||||||
|
p = g_build_filename (exe_root, "share", NULL);
|
||||||
if (p)
|
if (p)
|
||||||
g_array_append_val (data_dirs, p);
|
g_array_append_val (data_dirs, p);
|
||||||
|
g_free (exe_root);
|
||||||
|
|
||||||
retval = (gchar **) g_array_free (data_dirs, FALSE);
|
retval = (gchar **) g_array_free (data_dirs, FALSE);
|
||||||
|
|
||||||
@ -3149,10 +3155,11 @@ _g_utils_thread_init (void)
|
|||||||
static gchar *
|
static gchar *
|
||||||
_glib_get_locale_dir (void)
|
_glib_get_locale_dir (void)
|
||||||
{
|
{
|
||||||
gchar *install_dir, *locale_dir;
|
gchar *install_dir = NULL, *locale_dir;
|
||||||
gchar *retval = NULL;
|
gchar *retval = NULL;
|
||||||
|
|
||||||
install_dir = g_win32_get_package_installation_directory (GETTEXT_PACKAGE, dll_name);
|
if (glib_dll != NULL)
|
||||||
|
install_dir = g_win32_get_package_installation_directory_of_module (glib_dll);
|
||||||
|
|
||||||
if (install_dir)
|
if (install_dir)
|
||||||
{
|
{
|
||||||
|
@ -427,6 +427,12 @@ const gchar * glib_check_version (guint required_major,
|
|||||||
G_END_DECLS
|
G_END_DECLS
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
* This macro will be deprecated in the future. This DllMain() is too
|
||||||
|
* complex. It is recommended to have a DLlMain() that just saves the
|
||||||
|
* handle to the DLL and then use that handle in normal code instead,
|
||||||
|
* for instance passing it to
|
||||||
|
* g_win32_get_package_installation_directory_of_module().
|
||||||
|
*
|
||||||
* On Windows, this macro defines a DllMain function that stores the
|
* On Windows, this macro defines a DllMain function that stores the
|
||||||
* actual DLL name that the code being compiled will be included in.
|
* actual DLL name that the code being compiled will be included in.
|
||||||
* STATIC should be empty or 'static'. DLL_NAME is the name of the
|
* STATIC should be empty or 'static'. DLL_NAME is the name of the
|
||||||
|
Loading…
Reference in New Issue
Block a user