gconf r2743 - in branches/gnome-2-22: . gconf
- From: tml svn gnome org
- To: svn-commits-list gnome org
- Subject: gconf r2743 - in branches/gnome-2-22: . gconf
- Date: Tue, 27 Jan 2009 15:20:41 +0000 (UTC)
Author: tml
Date: Tue Jan 27 15:20:40 2009
New Revision: 2743
URL: http://svn.gnome.org/viewvc/gconf?rev=2743&view=rev
Log:
2009-01-27 Tor Lillqvist <tml novell com>
Committing this here in the gnome-2-22 branch because this is what
is still used on Windows without dbus.
* gconf/Makefile.am (gconfd_2_LDFLAGS): Use the -mwindows flag
when linking on Windows, so that we build a "GUI" executable.
* gconf/gconfd.c (main): On Windows, with GCONF_DEBUG_OUTPUT set,
make sure stdout and stderr go somewhere. Use the parent's console
window if possible, otherwise open an own console window. If we
had to open an own console window, give the user a chance to read
the output when exiting. Same idea that has been successfully used
in GIMP for a while.
Modified:
branches/gnome-2-22/ChangeLog
branches/gnome-2-22/gconf/Makefile.am
branches/gnome-2-22/gconf/gconfd.c
Modified: branches/gnome-2-22/gconf/Makefile.am
==============================================================================
--- branches/gnome-2-22/gconf/Makefile.am (original)
+++ branches/gnome-2-22/gconf/Makefile.am Tue Jan 27 15:20:40 2009
@@ -73,6 +73,9 @@
gconf-sources.h \
gconfd.h \
gconfd.c
+if OS_WIN32
+gconfd_2_LDFLAGS = -mwindows
+endif
gconfd_2_LDADD = $(EFENCE) $(INTLLIBS) $(DEPENDENT_LIBS) libgconf-$(MAJOR_VERSION).la
Modified: branches/gnome-2-22/gconf/gconfd.c
==============================================================================
--- branches/gnome-2-22/gconf/gconfd.c (original)
+++ branches/gnome-2-22/gconf/gconfd.c Tue Jan 27 15:20:40 2009
@@ -55,6 +55,13 @@
#endif
#include <locale.h>
+#ifdef G_OS_WIN32
+#include <io.h>
+#include <conio.h>
+#define _WIN32_WINNT 0x0500
+#include <windows.h>
+#endif
+
/* This makes hash table safer when debugging */
#ifndef GCONF_ENABLE_DEBUG
#define safe_g_hash_table_insert g_hash_table_insert
@@ -550,6 +557,19 @@
return TRUE;
}
+#ifdef G_OS_WIN32
+
+static void
+wait_console_window (void)
+{
+ SetConsoleTitle ("GConf daemon exiting. Type any character to close this window.");
+ printf ("\n"
+ "(GConf daemon exiting. Type any character to close this window)\n");
+ _getch ();
+}
+
+#endif
+
int
main(int argc, char** argv)
{
@@ -601,6 +621,49 @@
else
{
gconf_log_debug_messages = TRUE;
+#ifdef G_OS_WIN32
+ if (fileno (stdout) != -1 &&
+ _get_osfhandle (fileno (stdout)) != -1)
+ {
+ /* stdout is fine, presumably redirected to a file or pipe.
+ * Make sure stdout goes somewhere, too.
+ */
+ if (_get_osfhandle (fileno (stderr)) == -1)
+ dup2 (fileno (stdout), fileno (stderr));
+ }
+ else
+ {
+ int allocated_new_console = FALSE;
+
+ typedef BOOL (* WINAPI AttachConsole_t) (DWORD);
+
+ AttachConsole_t p_AttachConsole =
+ (AttachConsole_t) GetProcAddress (GetModuleHandle ("kernel32.dll"), "AttachConsole");
+
+ if (p_AttachConsole != NULL)
+ {
+ if (!AttachConsole (ATTACH_PARENT_PROCESS))
+ {
+ if (AllocConsole ())
+ allocated_new_console = TRUE;
+ }
+
+ freopen ("CONOUT$", "w", stdout);
+ dup2 (fileno (stdout), 1);
+ freopen ("CONOUT$", "w", stderr);
+ dup2 (fileno (stderr), 2);
+
+ if (allocated_new_console)
+ {
+ SetConsoleTitle ("GConf daemon debugging output. You can minimize this window, but don't close it.");
+ printf ("You asked for debugging output by setting the GCONF_DEBUG_OUTPUT\n"
+ "environment variable, so here it is.\n"
+ "\n");
+ atexit (wait_console_window);
+ }
+ }
+ }
+#endif
}
umask (022);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]