1
0
Fork 0
mutter-performance-source/src/util.c

392 lines
6.8 KiB
C
Raw Normal View History

2001-05-30 15:36:31 +00:00
/* Metacity utilities */
/*
* Copyright (C) 2001 Havoc Pennington
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
* 02111-1307, USA.
*/
#include <config.h>
2001-05-30 15:36:31 +00:00
#include "util.h"
#include "main.h"
#include <stdio.h>
2001-05-31 03:30:58 +00:00
#include <stdlib.h>
#include <unistd.h>
#include <errno.h>
#include <string.h>
2001-05-30 15:36:31 +00:00
#ifdef HAVE_BACKTRACE
#include <execinfo.h>
static void
print_backtrace (void)
{
void *bt[500];
int bt_size;
int i;
char **syms;
bt_size = backtrace (bt, 500);
syms = backtrace_symbols (bt, bt_size);
i = 0;
while (i < bt_size)
{
meta_verbose (" %s\n", syms[i]);
++i;
}
free (syms);
}
#else
static void
print_backtrace (void)
{
meta_verbose ("Not compiled with backtrace support\n");
}
#endif
2001-05-31 06:42:58 +00:00
static gboolean is_verbose = FALSE;
static gboolean is_debugging = FALSE;
static gboolean replace_current = FALSE;
2001-06-10 19:23:28 +00:00
static int no_prefix = 0;
2001-06-11 05:47:51 +00:00
static FILE* logfile = NULL;
static void
ensure_logfile (void)
{
if (logfile == NULL && g_getenv ("METACITY_USE_LOGFILE"))
2001-06-11 05:47:51 +00:00
{
char *filename = NULL;
char *tmpl;
int fd;
GError *err;
2001-06-11 05:47:51 +00:00
tmpl = g_strdup_printf ("metacity-%d-debug-log-XXXXXX",
(int) getpid ());
err = NULL;
fd = g_file_open_tmp (tmpl,
&filename,
&err);
2001-06-11 05:47:51 +00:00
g_free (tmpl);
if (err != NULL)
{
meta_warning (_("Failed to open debug log: %s\n"),
err->message);
g_error_free (err);
return;
}
logfile = fdopen (fd, "w");
2001-06-11 05:47:51 +00:00
if (logfile == NULL)
{
meta_warning (_("Failed to fdopen() log file %s: %s\n"),
filename, strerror (errno));
close (fd);
}
2001-06-11 05:47:51 +00:00
else
{
g_print (_("Opened log file %s\n"), filename);
}
2001-06-11 05:47:51 +00:00
g_free (filename);
2001-06-11 05:47:51 +00:00
}
}
2001-05-30 15:36:31 +00:00
gboolean
meta_is_verbose (void)
{
return is_verbose;
}
void
meta_set_verbose (gboolean setting)
{
2001-06-11 05:47:51 +00:00
if (setting)
ensure_logfile ();
2001-05-30 15:36:31 +00:00
is_verbose = setting;
}
2001-05-31 06:42:58 +00:00
gboolean
meta_is_debugging (void)
{
return is_debugging;
}
void
meta_set_debugging (gboolean setting)
{
2001-06-11 05:47:51 +00:00
if (setting)
ensure_logfile ();
2001-05-31 06:42:58 +00:00
is_debugging = setting;
}
gboolean
meta_get_replace_current_wm (void)
{
return replace_current;
}
void
meta_set_replace_current_wm (gboolean setting)
{
replace_current = setting;
}
2001-05-30 15:36:31 +00:00
void
meta_debug_spew (const char *format, ...)
{
va_list args;
gchar *str;
2001-06-11 05:47:51 +00:00
FILE *out;
2001-05-30 15:36:31 +00:00
g_return_if_fail (format != NULL);
2001-05-31 06:42:58 +00:00
if (!is_debugging)
2001-05-30 15:36:31 +00:00
return;
va_start (args, format);
str = g_strdup_vprintf (format, args);
va_end (args);
2001-06-11 05:47:51 +00:00
out = logfile ? logfile : stderr;
2001-06-10 19:23:28 +00:00
if (no_prefix == 0)
2001-06-11 05:47:51 +00:00
fputs ("Window manager: ", out);
fputs (str, out);
2001-06-21 06:08:35 +00:00
fflush (out);
2001-05-30 15:36:31 +00:00
g_free (str);
}
void
meta_verbose (const char *format, ...)
{
va_list args;
gchar *str;
2001-06-11 05:47:51 +00:00
FILE *out;
2001-05-30 15:36:31 +00:00
g_return_if_fail (format != NULL);
if (!is_verbose)
return;
va_start (args, format);
str = g_strdup_vprintf (format, args);
va_end (args);
2001-06-11 05:47:51 +00:00
out = logfile ? logfile : stderr;
2001-06-10 19:23:28 +00:00
if (no_prefix == 0)
2001-06-11 05:47:51 +00:00
fputs ("Window manager: ", out);
fputs (str, out);
2001-06-21 06:08:35 +00:00
fflush (out);
2001-05-30 15:36:31 +00:00
g_free (str);
}
static const char*
topic_name (MetaDebugTopic topic)
{
switch (topic)
{
case META_DEBUG_FOCUS:
return "FOCUS";
case META_DEBUG_WORKAREA:
return "WORKAREA";
case META_DEBUG_STACK:
return "STACK";
case META_DEBUG_THEMES:
return "THEMES";
case META_DEBUG_SM:
return "SM";
case META_DEBUG_EVENTS:
return "EVENTS";
case META_DEBUG_WINDOW_STATE:
return "WINDOW_STATE";
case META_DEBUG_WINDOW_OPS:
return "WINDOW_OPS";
case META_DEBUG_PLACEMENT:
return "PLACEMENT";
case META_DEBUG_GEOMETRY:
return "GEOMETRY";
case META_DEBUG_PING:
return "PING";
case META_DEBUG_XINERAMA:
return "XINERAMA";
case META_DEBUG_KEYBINDINGS:
return "KEYBINDINGS";
}
return "Window manager";
}
void
meta_topic (MetaDebugTopic topic,
const char *format,
...)
{
va_list args;
gchar *str;
FILE *out;
g_return_if_fail (format != NULL);
if (!is_verbose)
return;
va_start (args, format);
str = g_strdup_vprintf (format, args);
va_end (args);
out = logfile ? logfile : stderr;
if (no_prefix == 0)
fprintf (out, "%s: ", topic_name (topic));
fputs (str, out);
fflush (out);
g_free (str);
}
2001-05-31 03:30:58 +00:00
void
meta_bug (const char *format, ...)
{
va_list args;
gchar *str;
2001-06-11 05:47:51 +00:00
FILE *out;
2001-05-31 03:30:58 +00:00
g_return_if_fail (format != NULL);
va_start (args, format);
str = g_strdup_vprintf (format, args);
va_end (args);
2001-06-11 05:47:51 +00:00
out = logfile ? logfile : stderr;
2001-06-10 19:23:28 +00:00
if (no_prefix == 0)
2001-06-11 05:47:51 +00:00
fputs ("Bug in window manager: ", out);
fputs (str, out);
2001-06-21 06:08:35 +00:00
fflush (out);
2001-05-31 03:30:58 +00:00
g_free (str);
print_backtrace ();
2001-05-31 03:30:58 +00:00
/* stop us in a debugger */
abort ();
}
2001-05-30 15:36:31 +00:00
void
meta_warning (const char *format, ...)
{
va_list args;
gchar *str;
2001-06-11 05:47:51 +00:00
FILE *out;
2001-05-30 15:36:31 +00:00
g_return_if_fail (format != NULL);
va_start (args, format);
str = g_strdup_vprintf (format, args);
va_end (args);
2001-06-11 05:47:51 +00:00
out = logfile ? logfile : stderr;
2001-06-10 19:23:28 +00:00
if (no_prefix == 0)
fputs ("Window manager warning: ", out);
2001-06-11 05:47:51 +00:00
fputs (str, out);
2001-05-30 15:36:31 +00:00
g_free (str);
}
void
meta_fatal (const char *format, ...)
{
va_list args;
gchar *str;
2001-06-11 05:47:51 +00:00
FILE *out;
2001-05-30 15:36:31 +00:00
g_return_if_fail (format != NULL);
va_start (args, format);
str = g_strdup_vprintf (format, args);
va_end (args);
2001-06-11 05:47:51 +00:00
out = logfile ? logfile : stderr;
2001-06-10 19:23:28 +00:00
if (no_prefix == 0)
fputs ("Window manager error: ", out);
2001-06-11 05:47:51 +00:00
fputs (str, out);
2001-06-21 06:08:35 +00:00
fflush (out);
2001-05-30 15:36:31 +00:00
g_free (str);
meta_exit (META_EXIT_ERROR);
}
2001-06-10 19:23:28 +00:00
void
meta_push_no_msg_prefix (void)
{
++no_prefix;
}
void
meta_pop_no_msg_prefix (void)
{
g_return_if_fail (no_prefix > 0);
--no_prefix;
}
void
meta_exit (MetaExitCode code)
{
exit (code);
}
gint
meta_unsigned_long_equal (gconstpointer v1,
gconstpointer v2)
{
return *((const gulong*) v1) == *((const gulong*) v2);
}
guint
meta_unsigned_long_hash (gconstpointer v)
{
gulong val = * (const gulong *) v;
/* I'm not sure this works so well. */
#if G_SIZEOF_LONG > 4
return (guint) (val ^ (val >> 32));
#else
return val;
#endif
}