Bug 658772: Directory paths for resource directories are hard coded.
Corrected formatting to match coding standards; introduced local statics to prevent leaking returned strings.
This commit is contained in:
@ -319,62 +319,81 @@ _gtk_quartz_set_selection_data_for_pasteboard (NSPasteboard *pasteboard,
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
static gchar *
|
static gchar *
|
||||||
get_bundle_path()
|
get_bundle_path ()
|
||||||
{
|
{
|
||||||
gchar *base, *path;
|
static gchar *path = NULL;
|
||||||
|
if (path == NULL)
|
||||||
|
{
|
||||||
|
gchar *base;
|
||||||
NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
|
NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
|
||||||
gchar *resource_path = g_strdup([[[NSBundle mainBundle] resourcePath] UTF8String]);
|
gchar *resource_path = g_strdup ([[[NSBundle mainBundle] resourcePath] UTF8String]);
|
||||||
[pool drain];
|
[pool drain];
|
||||||
base = g_path_get_basename(resource_path);
|
base = g_path_get_basename (resource_path);
|
||||||
if (strcmp(base, "bin") == 0)
|
if (strcmp (base, "bin") == 0)
|
||||||
path = g_path_get_dirname(resource_path);
|
path = g_path_get_dirname (resource_path);
|
||||||
else
|
else
|
||||||
path = strdup(resource_path);
|
path = strdup (resource_path);
|
||||||
g_free(resource_path);
|
g_free (resource_path);
|
||||||
g_free(base);
|
g_free (base);
|
||||||
|
}
|
||||||
return path;
|
return path;
|
||||||
}
|
}
|
||||||
|
|
||||||
const gchar *
|
const gchar *
|
||||||
_gtk_get_datadir (void)
|
_gtk_get_datadir (void)
|
||||||
{
|
{
|
||||||
gchar *resource_dir = get_bundle_path();
|
static gchar *path = NULL;
|
||||||
gchar *retval = g_build_filename(resource_dir, "share", NULL);
|
if (path == NULL)
|
||||||
g_free(resource_dir);
|
{
|
||||||
return retval;
|
gchar *resource_dir = get_bundle_path ();
|
||||||
|
path = g_build_filename (resource_dir, "share", NULL);
|
||||||
|
g_free (resource_dir);
|
||||||
|
}
|
||||||
|
return path;
|
||||||
}
|
}
|
||||||
|
|
||||||
const gchar *
|
const gchar *
|
||||||
_gtk_get_libdir (void)
|
_gtk_get_libdir (void)
|
||||||
{
|
{
|
||||||
gchar *resource_dir = get_bundle_path();
|
static gchar *path = NULL;
|
||||||
gchar *retval = g_build_filename(resource_dir, "lib", NULL);
|
if (path == NULL)
|
||||||
g_free(resource_dir);
|
{
|
||||||
return retval;
|
gchar *resource_dir = get_bundle_path ();
|
||||||
|
path = g_build_filename (resource_dir, "lib", NULL);
|
||||||
|
g_free (resource_dir);
|
||||||
|
}
|
||||||
|
return path;
|
||||||
}
|
}
|
||||||
|
|
||||||
const gchar *
|
const gchar *
|
||||||
_gtk_get_localedir (void)
|
_gtk_get_localedir (void)
|
||||||
{
|
{
|
||||||
|
static gchar *path = NULL;
|
||||||
gchar *resource_dir = get_bundle_path();
|
if (path == NULL)
|
||||||
gchar *retval = g_build_filename(resource_dir, "share", "locale", NULL);
|
{
|
||||||
g_free(resource_dir);
|
gchar *resource_dir = get_bundle_path ();
|
||||||
return retval;
|
path = g_build_filename (resource_dir, "share", "locale", NULL);
|
||||||
|
g_free (resource_dir);
|
||||||
|
}
|
||||||
|
return path;
|
||||||
}
|
}
|
||||||
|
|
||||||
const gchar *
|
const gchar *
|
||||||
_gtk_get_sysconfdir (void)
|
_gtk_get_sysconfdir (void)
|
||||||
{
|
{
|
||||||
gchar *resource_dir = get_bundle_path();
|
static gchar *path = NULL;
|
||||||
gchar *retval = g_build_filename(resource_dir, "etc", NULL);
|
if (path == NULL)
|
||||||
g_free(resource_dir);
|
{
|
||||||
return retval;
|
gchar *resource_dir = get_bundle_path ();
|
||||||
|
path = g_build_filename (resource_dir, "etc", NULL);
|
||||||
|
g_free (resource_dir);
|
||||||
|
}
|
||||||
|
return path;
|
||||||
}
|
}
|
||||||
|
|
||||||
const gchar *
|
const gchar *
|
||||||
_gtk_get_data_prefix (void)
|
_gtk_get_data_prefix (void)
|
||||||
{
|
{
|
||||||
return get_bundle_path();
|
return get_bundle_path ();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user