reactos/reactos/lib/kernel32/file/curdir.c
David Welch 6088637c5e Oops.
svn path=/trunk/; revision=1064
2000-03-16 20:50:48 +00:00

356 lines
7.4 KiB
C

/* $Id: curdir.c,v 1.23 2000/03/16 20:50:48 dwelch Exp $
*
* COPYRIGHT: See COPYING in the top level directory
* PROJECT: ReactOS system libraries
* FILE: lib/kernel32/file/curdir.c
* PURPOSE: Current directory functions
* UPDATE HISTORY:
* Created 30/09/98
*/
/* INCLUDES ******************************************************************/
#include <ddk/ntddk.h>
#include <ntdll/rtl.h>
#include <windows.h>
#define NDEBUG
#include <kernel32/kernel32.h>
/* GLOBAL VARIABLES **********************************************************/
/* FIXME initialize them on startup !! */
UNICODE_STRING SystemDirectory;
UNICODE_STRING WindowsDirectory;
/* FUNCTIONS *****************************************************************/
DWORD
STDCALL
GetCurrentDirectoryA (
DWORD nBufferLength,
LPSTR lpBuffer
)
{
ANSI_STRING AnsiString;
UNICODE_STRING UnicodeString;
/* initialize ansi string */
AnsiString.Length = 0;
AnsiString.MaximumLength = nBufferLength;
AnsiString.Buffer = lpBuffer;
/* allocate buffer for unicode string */
UnicodeString.Length = 0;
UnicodeString.MaximumLength = nBufferLength * sizeof(WCHAR);
UnicodeString.Buffer = RtlAllocateHeap (RtlGetProcessHeap (),
0,
UnicodeString.MaximumLength);
/* get current directory */
UnicodeString.Length = RtlGetCurrentDirectory_U (UnicodeString.MaximumLength,
UnicodeString.Buffer);
DPRINT("UnicodeString.Buffer %S\n", UnicodeString.Buffer);
/* convert unicode string to ansi (or oem) */
if (bIsFileApiAnsi)
RtlUnicodeStringToAnsiString (&AnsiString,
&UnicodeString,
FALSE);
else
RtlUnicodeStringToOemString (&AnsiString,
&UnicodeString,
FALSE);
DPRINT("AnsiString.Buffer %s\n", AnsiString.Buffer);
/* free unicode string */
RtlFreeHeap (RtlGetProcessHeap (),
0,
UnicodeString.Buffer);
return AnsiString.Length;
}
DWORD
STDCALL
GetCurrentDirectoryW (
DWORD nBufferLength,
LPWSTR lpBuffer
)
{
ULONG Length;
Length = RtlGetCurrentDirectory_U (nBufferLength,
lpBuffer);
return (Length / sizeof (WCHAR));
}
WINBOOL
STDCALL
SetCurrentDirectoryA (
LPCSTR lpPathName
)
{
ANSI_STRING AnsiString;
UNICODE_STRING UnicodeString;
NTSTATUS Status;
RtlInitAnsiString (&AnsiString,
(LPSTR)lpPathName);
/* convert ansi (or oem) to unicode */
if (bIsFileApiAnsi)
RtlAnsiStringToUnicodeString (&UnicodeString,
&AnsiString,
TRUE);
else
RtlOemStringToUnicodeString (&UnicodeString,
&AnsiString,
TRUE);
Status = RtlSetCurrentDirectory_U (&UnicodeString);
RtlFreeUnicodeString (&UnicodeString);
if (!NT_SUCCESS(Status))
{
SetLastError (RtlNtStatusToDosError (Status));
return FALSE;
}
return TRUE;
}
WINBOOL
STDCALL
SetCurrentDirectoryW (
LPCWSTR lpPathName
)
{
UNICODE_STRING UnicodeString;
NTSTATUS Status;
RtlInitUnicodeString (&UnicodeString,
lpPathName);
Status = RtlSetCurrentDirectory_U (&UnicodeString);
if (!NT_SUCCESS(Status))
{
SetLastError (RtlNtStatusToDosError (Status));
return FALSE;
}
return TRUE;
}
DWORD
STDCALL
GetTempPathA (
DWORD nBufferLength,
LPSTR lpBuffer
)
{
UNICODE_STRING UnicodeString;
ANSI_STRING AnsiString;
AnsiString.Length = 0;
AnsiString.MaximumLength = nBufferLength;
AnsiString.Buffer = lpBuffer;
/* initialize allocate unicode string */
UnicodeString.Length = 0;
UnicodeString.MaximumLength = nBufferLength * sizeof(WCHAR);
UnicodeString.Buffer = RtlAllocateHeap (RtlGetProcessHeap(),
0,
UnicodeString.MaximumLength);
UnicodeString.Length = GetTempPathW (nBufferLength,
UnicodeString.Buffer) * sizeof(WCHAR);
/* convert unicode string to ansi (or oem) */
if (bIsFileApiAnsi)
RtlUnicodeStringToAnsiString (&AnsiString,
&UnicodeString,
FALSE);
else
RtlUnicodeStringToOemString (&AnsiString,
&UnicodeString,
FALSE);
/* free unicode string buffer */
RtlFreeHeap (RtlGetProcessHeap (),
0,
UnicodeString.Buffer);
return AnsiString.Length;
}
DWORD
STDCALL
GetTempPathW (
DWORD nBufferLength,
LPWSTR lpBuffer
)
{
UNICODE_STRING Name;
UNICODE_STRING Value;
NTSTATUS Status;
Value.Length = 0;
Value.MaximumLength = nBufferLength * sizeof(WCHAR);
Value.Buffer = lpBuffer;
RtlInitUnicodeString (&Name,
L"TMP");
Status = RtlQueryEnvironmentVariable_U (NULL,
&Name,
&Value);
if (!NT_SUCCESS(Status))
{
RtlInitUnicodeString (&Name,
L"TEMP");
Status = RtlQueryEnvironmentVariable_U (NULL,
&Name,
&Value);
if (!NT_SUCCESS(Status))
{
Value.Length = RtlGetCurrentDirectory_U (Value.MaximumLength,
Value.Buffer);
}
}
return Value.Length / sizeof(WCHAR);
}
UINT
STDCALL
GetSystemDirectoryA (
LPSTR lpBuffer,
UINT uSize
)
{
ANSI_STRING String;
ULONG Length;
if (lpBuffer == NULL)
return 0;
Length = RtlUnicodeStringToAnsiSize (&SystemDirectory);
if (uSize > Length)
{
String.Length = 0;
String.MaximumLength = uSize;
String.Buffer = lpBuffer;
/* convert unicode string to ansi (or oem) */
if (bIsFileApiAnsi)
RtlUnicodeStringToAnsiString (&String,
&SystemDirectory,
FALSE);
else
RtlUnicodeStringToOemString (&String,
&SystemDirectory,
FALSE);
}
return Length;
}
UINT
STDCALL
GetSystemDirectoryW (
LPWSTR lpBuffer,
UINT uSize
)
{
ULONG Length;
if (lpBuffer == NULL)
return 0;
Length = SystemDirectory.Length / sizeof (WCHAR);
if (uSize > Length)
{
memmove (lpBuffer,
SystemDirectory.Buffer,
Length);
lpBuffer[Length] = 0;
}
return Length;
}
UINT
STDCALL
GetWindowsDirectoryA (
LPSTR lpBuffer,
UINT uSize
)
{
ANSI_STRING String;
ULONG Length;
if (lpBuffer == NULL)
return 0;
Length = RtlUnicodeStringToAnsiSize (&SystemDirectory);
if (uSize > Length)
{
String.Length = 0;
String.MaximumLength = uSize;
String.Buffer = lpBuffer;
/* convert unicode string to ansi (or oem) */
if (bIsFileApiAnsi)
RtlUnicodeStringToAnsiString (&String,
&WindowsDirectory,
FALSE);
else
RtlUnicodeStringToOemString (&String,
&WindowsDirectory,
FALSE);
}
return Length;
}
UINT
STDCALL
GetWindowsDirectoryW (
LPWSTR lpBuffer,
UINT uSize
)
{
ULONG Length;
if (lpBuffer == NULL)
return 0;
Length = SystemDirectory.Length / sizeof (WCHAR);
if (uSize > Length)
{
memmove (lpBuffer,
SystemDirectory.Buffer,
Length);
lpBuffer[Length] = 0;
}
return Length;
}
/* EOF */