com.cpp revision 831b4c533723665e3a004ca13c9f413f4221ffbb
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync/* $Id$ */
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync/** @file
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync * MS COM / XPCOM Abstraction Layer
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync */
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
c97989161fbe75bc14cea477a5443bbf474dd3advboxsync/*
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync * Copyright (C) 2006-2007 Sun Microsystems, Inc.
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync *
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync * This file is part of VirtualBox Open Source Edition (OSE), as
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync * available from http://www.virtualbox.org. This file is free software;
a16eb14ad7a4b5ef91ddc22d3e8e92d930f736fcvboxsync * you can redistribute it and/or modify it under the terms of the GNU
a16eb14ad7a4b5ef91ddc22d3e8e92d930f736fcvboxsync * General Public License (GPL) as published by the Free Software
a16eb14ad7a4b5ef91ddc22d3e8e92d930f736fcvboxsync * Foundation, in version 2 as it comes in the "COPYING" file of the
a16eb14ad7a4b5ef91ddc22d3e8e92d930f736fcvboxsync * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync *
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync * Clara, CA 95054 USA or visit http://www.sun.com if you need
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync * additional information or have any questions.
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync */
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#if !defined (VBOX_WITH_XPCOM)
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#include <objbase.h>
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#else /* !defined (VBOX_WITH_XPCOM) */
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#include <stdlib.h>
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#include <nsCOMPtr.h>
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#include <nsIServiceManagerUtils.h>
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#include <nsIInterfaceInfo.h>
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#include <nsIInterfaceInfoManager.h>
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#endif /* !defined (VBOX_WITH_XPCOM) */
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#include "VBox/com/com.h"
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#include "VBox/com/assert.h"
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#include "VBox/com/Guid.h"
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#include "VBox/com/array.h"
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
223cf005b18af2c21352a70693ebaf0582f68ebcvboxsync#include <iprt/param.h>
223cf005b18af2c21352a70693ebaf0582f68ebcvboxsync#include <iprt/path.h>
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#include <iprt/dir.h>
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#include <iprt/env.h>
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#include <iprt/string.h>
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#include <VBox/err.h>
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#ifdef RT_OS_DARWIN
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#define VBOX_USER_HOME_SUFFIX "Library/VirtualBox"
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#else
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#define VBOX_USER_HOME_SUFFIX ".VirtualBox"
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#endif
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#include "Logging.h"
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsyncnamespace com
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync{
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsyncvoid GetInterfaceNameByIID (const GUID &aIID, BSTR *aName)
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync{
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync Assert (aName);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync if (!aName)
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync return;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync *aName = NULL;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#if !defined (VBOX_WITH_XPCOM)
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync LONG rc;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync LPOLESTR iidStr = NULL;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync if (StringFromIID (aIID, &iidStr) == S_OK)
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync {
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync HKEY ifaceKey;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync rc = RegOpenKeyExW (HKEY_CLASSES_ROOT, L"Interface",
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync 0, KEY_QUERY_VALUE, &ifaceKey);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync if (rc == ERROR_SUCCESS)
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync {
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync HKEY iidKey;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync rc = RegOpenKeyExW (ifaceKey, iidStr, 0, KEY_QUERY_VALUE, &iidKey);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync if (rc == ERROR_SUCCESS)
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync {
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync /* determine the size and type */
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync DWORD sz, type;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync rc = RegQueryValueExW (iidKey, NULL, NULL, &type, NULL, &sz);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync if (rc == ERROR_SUCCESS && type == REG_SZ)
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync {
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync /* query the value to BSTR */
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync *aName = SysAllocStringLen (NULL, (sz + 1) /
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync sizeof (TCHAR) + 1);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync rc = RegQueryValueExW (iidKey, NULL, NULL, NULL,
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync (LPBYTE) *aName, &sz);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync if (rc != ERROR_SUCCESS)
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync {
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync SysFreeString (*aName);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync aName = NULL;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync }
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync }
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync RegCloseKey (iidKey);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync }
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync RegCloseKey (ifaceKey);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync }
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync CoTaskMemFree (iidStr);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync }
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#else /* !defined (VBOX_WITH_XPCOM) */
8f7bc6ad2b7bbcb4b3b96248cd2478e45f2e3b88vboxsync
8f7bc6ad2b7bbcb4b3b96248cd2478e45f2e3b88vboxsync nsresult rv;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync nsCOMPtr <nsIInterfaceInfoManager> iim =
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync do_GetService (NS_INTERFACEINFOMANAGER_SERVICE_CONTRACTID, &rv);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync if (NS_SUCCEEDED(rv))
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync {
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync nsCOMPtr <nsIInterfaceInfo> iinfo;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync rv = iim->GetInfoForIID (&aIID, getter_AddRefs (iinfo));
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync if (NS_SUCCEEDED(rv))
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync {
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync const char *iname = NULL;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync iinfo->GetNameShared (&iname);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync char *utf8IName = NULL;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync if (RT_SUCCESS(RTStrCurrentCPToUtf8 (&utf8IName, iname)))
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync {
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync PRTUTF16 utf16IName = NULL;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync if (RT_SUCCESS(RTStrToUtf16 (utf8IName, &utf16IName)))
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync {
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync *aName = SysAllocString ((OLECHAR *) utf16IName);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync RTUtf16Free (utf16IName);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync }
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync RTStrFree (utf8IName);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync }
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync }
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync }
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#endif /* !defined (VBOX_WITH_XPCOM) */
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync}
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsyncint GetVBoxUserHomeDirectory(char *aDir, size_t aDirLen)
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync{
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync AssertReturn(aDir, VERR_INVALID_POINTER);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync AssertReturn(aDirLen > 0, VERR_BUFFER_OVERFLOW);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync /* start with null */
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync *aDir = 0;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync const char *VBoxUserHome = RTEnvGet("VBOX_USER_HOME");
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync char path [RTPATH_MAX];
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync int vrc = VINF_SUCCESS;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync if (VBoxUserHome)
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync {
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync /* get the full path name */
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync char *VBoxUserHomeUtf8 = NULL;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync vrc = RTStrCurrentCPToUtf8(&VBoxUserHomeUtf8, VBoxUserHome);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync if (RT_SUCCESS(vrc))
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync {
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync vrc = RTPathAbs(VBoxUserHomeUtf8, path, sizeof (path));
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync if (RT_SUCCESS(vrc))
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync {
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync if (aDirLen < strlen(path) + 1)
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync vrc = VERR_BUFFER_OVERFLOW;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync else
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync strcpy(aDir, path);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync }
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync RTStrFree(VBoxUserHomeUtf8);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync }
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync }
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync else
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync {
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync /* compose the config directory (full path) */
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync vrc = RTPathUserHome(path, sizeof(path));
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync if (RT_SUCCESS(vrc))
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync {
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync size_t len = RTStrPrintf(aDir, aDirLen, "%s%c%s",
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync path, RTPATH_DELIMITER, VBOX_USER_HOME_SUFFIX);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync if (len != strlen(path) + 1 + strlen (VBOX_USER_HOME_SUFFIX))
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync vrc = VERR_BUFFER_OVERFLOW;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync }
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync }
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync /* ensure the home directory exists */
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync if (RT_SUCCESS(vrc))
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync if (!RTDirExists(aDir))
aaeb2e2f6ed5b164f1dec9a16a7adeb84f64cf31vboxsync vrc = RTDirCreateFullPath(aDir, 0777);
223cf005b18af2c21352a70693ebaf0582f68ebcvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync return vrc;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync}
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync/* static */
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsyncconst Guid Guid::Empty; /* default ctor is OK */
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#if defined (VBOX_WITH_XPCOM)
aaeb2e2f6ed5b164f1dec9a16a7adeb84f64cf31vboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync/* static */
aaeb2e2f6ed5b164f1dec9a16a7adeb84f64cf31vboxsyncconst nsID *SafeGUIDArray::nsIDRef::Empty = (const nsID *) Guid::Empty.raw();
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync#endif /* (VBOX_WITH_XPCOM) */
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync/**
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync * Used by ComPtr and friends to log details about reference counting.
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync * @param pcszFormat
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync */
aaeb2e2f6ed5b164f1dec9a16a7adeb84f64cf31vboxsyncvoid LogRef(const char *pcszFormat, ...)
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync{
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync char *pszNewMsg;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync va_list args;
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync va_start(args, pcszFormat);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync RTStrAPrintfV(&pszNewMsg, pcszFormat, args);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync LogDJ((pszNewMsg));
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync RTStrFree(pszNewMsg);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync va_end(args);
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync}
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync} /* namespace com */
d408b82da0773c7e8cd4b3a01cb8a065a2c73a2dvboxsync