/* * Win32 advapi functions * * Copyright 1995 Sven Verdoolaege * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #include "config.h" #include "wine/port.h" #include #include #include #include #include "windef.h" #include "winbase.h" #include "winnls.h" #include "winreg.h" #include "winerror.h" #include "wine/library.h" #include "wine/debug.h" WINE_DEFAULT_DEBUG_CHANNEL(advapi); /****************************************************************************** * GetUserNameA [ADVAPI32.@] * * Get the current user name. * * PARAMS * lpszName [O] Destination for the user name. * lpSize [I/O] Size of lpszName. * * RETURNS * Success: The length of the user name, including terminating NUL. * Failure: ERROR_MORE_DATA if *lpSize is too small. */ BOOL WINAPI GetUserNameA( LPSTR lpszName, LPDWORD lpSize ) { WCHAR *buffer; BOOL ret; DWORD sizeW = *lpSize * 2; if (!(buffer = HeapAlloc( GetProcessHeap(), 0, sizeW * sizeof(WCHAR) ))) { SetLastError( ERROR_NOT_ENOUGH_MEMORY ); return FALSE; } ret = GetUserNameW( buffer, &sizeW ); if (ret) { if (!(*lpSize = WideCharToMultiByte( CP_ACP, 0, buffer, -1, lpszName, *lpSize, NULL, NULL ))) { *lpSize = WideCharToMultiByte( CP_ACP, 0, buffer, -1, NULL, 0, NULL, NULL ); SetLastError( ERROR_MORE_DATA ); ret = FALSE; } } else *lpSize = sizeW * 2; HeapFree( GetProcessHeap(), 0, buffer ); return ret; } /****************************************************************************** * GetUserNameW [ADVAPI32.@] * * See GetUserNameA. */ BOOL WINAPI GetUserNameW( LPWSTR lpszName, LPDWORD lpSize ) { const char *name = wine_get_user_name(); DWORD len = MultiByteToWideChar( CP_UNIXCP, 0, name, -1, NULL, 0 ); if (len > *lpSize) { SetLastError(ERROR_MORE_DATA); *lpSize = len; return FALSE; } *lpSize = len; MultiByteToWideChar( CP_UNIXCP, 0, name, -1, lpszName, len ); return TRUE; } /****************************************************************************** * GetCurrentHwProfileA [ADVAPI32.@] * * Get the current hardware profile. * * PARAMS * pInfo [O] Destination for hardware profile information. * * RETURNS * Success: TRUE. pInfo is updated with the hardware profile details. * Failure: FALSE. */ BOOL WINAPI GetCurrentHwProfileA(LPHW_PROFILE_INFOA pInfo) { FIXME("(%p) semi-stub\n", pInfo); pInfo->dwDockInfo = DOCKINFO_DOCKED; strcpy(pInfo->szHwProfileGuid,"{12340001-1234-1234-1234-1233456789012}"); strcpy(pInfo->szHwProfileName,"Wine Profile"); return 1; } /****************************************************************************** * GetCurrentHwProfileW [ADVAPI32.@] * * See GetCurrentHwProfileA. */ BOOL WINAPI GetCurrentHwProfileW(LPHW_PROFILE_INFOW pInfo) { FIXME("(%p)\n", pInfo); return FALSE; } /****************************************************************************** * AbortSystemShutdownA [ADVAPI32.@] * * Stop a system shutdown if one is in progress. * * PARAMS * lpMachineName [I] Name of machine to not shutdown. * * RETURNS * Success: TRUE. * Failure: FALSE. * * NOTES * The Wine implementation of this function is a harmless stub. */ BOOL WINAPI AbortSystemShutdownA( LPSTR lpMachineName ) { TRACE("stub %s (harmless)\n", lpMachineName); return TRUE; } /****************************************************************************** * AbortSystemShutdownW [ADVAPI32.@] * * See AbortSystemShutdownA. */ BOOL WINAPI AbortSystemShutdownW( LPWSTR lpMachineName ) { TRACE("stub %s (harmless)\n", debugstr_w(lpMachineName)); return TRUE; } /****************************************************************************** * InitiateSystemShutdownExA [ADVAPI32.@] * * Initiate a shutdown or optionally restart the computer. * * PARAMS * lpMachineName [I] Network name of machine to shutdown. * lpMessage [I] Message displayed in shutdown dialog box. * dwTimeout [I] Number of seconds dialog is displayed before shutdown. * bForceAppsClosed [I] If TRUE, apps close without saving, else dialog is * displayed requesting user to close apps. * bRebootAfterShutdown [I] If TRUE, system reboots after restart, else the * system flushes all caches to disk and clears * the screen * dwReason [I] Reason for shutting down. Must be a system shutdown reason * code. * * RETURNS * Success: TRUE * Failure: FALSE * * NOTES * if lpMachineName is NULL, the local computer is shutdown. */ BOOL WINAPI InitiateSystemShutdownExA( LPSTR lpMachineName, LPSTR lpMessage, DWORD dwTimeout, BOOL bForceAppsClosed, BOOL bRebootAfterShutdown, DWORD dwReason) { FIXME("%s %s %ld %d %d %ld\n", debugstr_a(lpMachineName), debugstr_a(lpMessage), dwTimeout, bForceAppsClosed, bRebootAfterShutdown, dwReason); return TRUE; } /****************************************************************************** * InitiateSystemShutdownExW [ADVAPI32.@] * * see InitiateSystemShutdownExA */ BOOL WINAPI InitiateSystemShutdownExW( LPWSTR lpMachineName, LPWSTR lpMessage, DWORD dwTimeout, BOOL bForceAppsClosed, BOOL bRebootAfterShutdown, DWORD dwReason) { FIXME("%s %s %ld %d %d %ld\n", debugstr_w(lpMachineName), debugstr_w(lpMessage), dwTimeout, bForceAppsClosed, bRebootAfterShutdown, dwReason); return TRUE; } DWORD WINAPI CommandLineFromMsiDescriptor(WCHAR *Descriptor, WCHAR *CommandLine, DWORD *CommandLineLength) { FIXME("stub (%s)\n", debugstr_w(Descriptor)); return ERROR_CALL_NOT_IMPLEMENTED; }