From eebfe76ed16967c0199e9370a25f6b0634909dce Mon Sep 17 00:00:00 2001 From: Marcus Brinkmann Date: Tue, 16 Mar 2010 15:54:00 +0100 Subject: [PATCH 05/10] Port dbus tools to Windows CE. --- tools/dbus-launch-win.c | 136 +++++++++++++++++++++++++++++----------------- tools/dbus-monitor.c | 15 +++++ tools/dbus-send.c | 6 ++ 3 files changed, 107 insertions(+), 50 deletions(-) diff --git a/tools/dbus-launch-win.c b/tools/dbus-launch-win.c index 140238e..6e289a6 100644 --- a/tools/dbus-launch-win.c +++ b/tools/dbus-launch-win.c @@ -1,5 +1,5 @@ /* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */ -/* dbus-launch.c dbus-launch utility +/* dbus-launch-win.c dbus-launch utility * * Copyright (C) 2007 Ralf Habacker * @@ -20,34 +20,39 @@ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * */ + #include +#ifndef UNICODE +#define UNICODE 1 +#endif #include #include #include -#include #include -#if defined __MINGW32__ || (defined _MSC_VER && _MSC_VER <= 1310) -/* save string functions version -*/ +/* Save string functions. Instead of figuring out the exact _MSC_VER + that work, override for everybody. */ + #define errno_t int +#define wcscat_s my_wcscat_s +#define wcscpy_s my_wcscpy_s -errno_t strcat_s(char *dest, size_t size, char *src) +static errno_t +wcscat_s (wchar_t *dest, size_t size, wchar_t *src) { - assert(strlen(dest) + strlen(src) +1 <= size); - strcat(dest,src); + assert (sizeof (wchar_t) * (wcslen (dest) + wcslen (src) + 1) <= size); + wcscat (dest, src); return 0; } -errno_t strcpy_s(char *dest, size_t size, char *src) + +static errno_t +wcscpy_s (wchar_t *dest, size_t size, wchar_t *src) { - assert(strlen(src) +1 <= size); - strcpy(dest,src); + assert (sizeof (wchar_t) * (wcslen (src) + 1) <= size); + wcscpy (dest, src); return 0; } -#endif - -/* TODO: Use Unicode APIs */ /* TODO (tl): This Windows version of dbus-launch is curretly rather * pointless as it doesn't take the same command-line options as the @@ -72,69 +77,100 @@ errno_t strcpy_s(char *dest, size_t size, char *src) #define AUTO_ACTIVATE_CONSOLE_WHEN_VERBOSE_MODE 1 -int main(int argc,char **argv) +#define DIM(x) (sizeof(x) / sizeof(x[0])) +#define WCSTRINGIFY_(x) L ## x +#define WCSTRINGIFY(x) WCSTRINGIFY_(x) + +int +main (int argc, char **argv) { - char dbusDaemonPath[MAX_PATH*2+1]; - char command[MAX_PATH*2+1]; - char *p; - char *daemon_name; + wchar_t dbusDaemonPath[MAX_PATH * 2 + 1]; + wchar_t command[MAX_PATH * 2 + 1]; + wchar_t *p; + wchar_t *daemon_name; int result; int showConsole = 0; +#ifdef DBUS_WINCE + char *s = NULL; +#else char *s = getenv("DBUS_VERBOSE"); +#endif int verbose = s && *s != '\0' ? 1 : 0; + PROCESS_INFORMATION pi; - STARTUPINFO si; - HANDLE h; - + STARTUPINFOW si; + BOOL inherit = TRUE; + DWORD flags = 0; + #ifdef AUTO_ACTIVATE_CONSOLE_WHEN_VERBOSE_MODE if (verbose) showConsole = 1; #endif - GetModuleFileName(NULL,dbusDaemonPath,sizeof(dbusDaemonPath)); + GetModuleFileNameW (NULL, dbusDaemonPath, DIM (dbusDaemonPath)); - daemon_name = DBUS_DAEMON_NAME ".exe"; + daemon_name = WCSTRINGIFY(DBUS_DAEMON_NAME) L".exe"; - if ((p = _mbsrchr (dbusDaemonPath, '\\'))) + if ((p = wcsrchr (dbusDaemonPath, L'\\'))) { - *(p+1)= '\0'; - strcat_s(dbusDaemonPath,sizeof(dbusDaemonPath),daemon_name); + p[1] = L'\0'; + wcscat_s (dbusDaemonPath, sizeof (dbusDaemonPath), daemon_name); } else { if (verbose) - fprintf(stderr,"error: could not extract path from current applications module filename\n"); + fprintf (stderr, "error: could not extract path from current " + "applications module filename\n"); return 1; } + +#ifdef DBUS_WINCE + /* Windows CE has a different interpretation of cmdline: Start with argv[1]. */ + wcscpy_s (command, sizeof (command), L"--session"); + if (verbose) + fprintf (stderr, "%ls %ls\n", dbusDaemonPath, command); +#else + command[0] = L'\0'; + /* Windows CE has a different interpretation of cmdline: Start with argv[1]. */ + wcscpy_s (command, sizeof (command), dbusDaemonPath); + wcscat_s (command, sizeof (command), L" --session"); + if (verbose) + fprintf (stderr, "%ls\n", command); +#endif - strcpy_s(command,sizeof(command),dbusDaemonPath); - strcat_s(command,sizeof(command)," --session"); - if (verbose) - fprintf(stderr,"%s\n",command); + memset (&si, 0, sizeof (si)); + memset (&pi, 0, sizeof (pi)); + si.cb = sizeof (si); - memset(&si, 0, sizeof(si)); - memset(&pi, 0, sizeof(pi)); - si.cb = sizeof(si); - - result = CreateProcess(NULL, - command, - 0, - 0, - TRUE, - (showConsole ? CREATE_NEW_CONSOLE : 0) | NORMAL_PRIORITY_CLASS, - 0, - 0, - &si, - &pi); - - CloseHandle(pi.hProcess); - CloseHandle(pi.hThread); + if (verbose) + flags |= CREATE_NEW_CONSOLE; + +#ifdef DBUS_WINCE + inherit = FALSE; +#else + flags |= NORMAL_PRIORITY_CLASS; + if (!verbose) + flags |= DETACHED_PROCESS; + fprintf (stderr, "0b: %i\n", flags); +#endif + + fprintf (stderr, "1 %ls\n", dbusDaemonPath); + fprintf (stderr, "2 %ls\n", command); + fprintf (stderr, "3 %i\n", inherit); + fprintf (stderr, "4 %i\n", flags); + + result = CreateProcessW (dbusDaemonPath, command, 0, 0, + inherit, flags, 0, 0, &si, &pi); if (result == 0) { if (verbose) - fprintf(stderr, "Could not start " DBUS_DAEMON_NAME ". error=%d",GetLastError()); + fprintf (stderr, "Could not start " DBUS_DAEMON_NAME ". error=%d\n", + GetLastError ()); return 4; } + CloseHandle (pi.hProcess); + CloseHandle (pi.hThread); + return 0; } diff --git a/tools/dbus-monitor.c b/tools/dbus-monitor.c index c368128..41a7039 100644 --- a/tools/dbus-monitor.c +++ b/tools/dbus-monitor.c @@ -41,6 +41,21 @@ #define DBUS_SECONDS_SINCE_1601 11644473600LL #define DBUS_USEC_IN_SEC 1000000LL +#ifdef DBUS_WINCE + +#ifndef _IOLBF +#define _IOLBF 1 +#endif + +void +GetSystemTimeAsFileTime (LPFILETIME ftp) +{ + SYSTEMTIME st; + GetSystemTime (&st); + SystemTimeToFileTime (&st, ftp); +} +#endif + static int gettimeofday (struct timeval *__p, void *__t) diff --git a/tools/dbus-send.c b/tools/dbus-send.c index c9c9be2..dba1924 100644 --- a/tools/dbus-send.c +++ b/tools/dbus-send.c @@ -26,6 +26,12 @@ #include +#ifdef DBUS_WINCE +#ifndef strdup +#define strdup _strdup +#endif +#endif + #include "dbus-print-message.h" static const char *appname; -- 1.7.0