windows-nt/Source/XPSP1/NT/base/crts/crtw32/dos/chdir.c

111 lines
3.9 KiB
C
Raw Normal View History

2020-09-26 03:20:57 -05:00
/***
*chdir.c - change directory
*
* Copyright (c) 1989-2001, Microsoft Corporation. All rights reserved.
*
*Purpose:
* This file has the _chdir() function - change current directory.
*
*Revision History:
* 06-06-89 PHG Module created, based on asm version
* 03-07-90 GJF Made calling type _CALLTYPE2 (for now), added #include
* <cruntime.h>, fixed copyright and fixed compiler
* warnings. Also, cleaned up the formatting a bit.
* 03-30-90 GJF Now _CALLTYPE1.
* 07-24-90 SBM Removed '32' from API names
* 09-27-90 GJF New-style function declarator.
* 12-04-90 SRW Changed to include <oscalls.h> instead of <doscalls.h>
* 12-06-90 SRW Added _CRUISER_ and _WIN32 conditionals.
* 01-16-91 GJF ANSI naming.
* 05-19-92 GJF Revised to support the 'current directory' environment
* variables of Win32/NT.
* 04-06-93 SKS Replace _CRTAPI* with __cdecl
* 11-24-93 CFW Rip out Cruiser.
* 11-24-93 CFW No longer store current drive in CRT env strings.
* 12-01-93 CFW Set OS drive letter variables.
* 12-07-93 CFW Wide char enable.
* 01-25-95 GJF New current directory can be a UNC path!
* 02-08-95 JWM Spliced _WIN32 & Mac versions.
* 07-01-96 GJF Replaced defined(_WIN32) with !defined(_MAC). Also,
* detab-ed and cleaned up the format a bit.
* 05-17-99 PML Remove all Macintosh support.
*
*******************************************************************************/
#include <cruntime.h>
#include <oscalls.h>
#include <mtdll.h>
#include <internal.h>
#include <direct.h>
#include <stdlib.h>
#include <tchar.h>
/***
*int _chdir(path) - change current directory
*
*Purpose:
* Changes the current working directory to that given in path.
*
*Entry:
* _TSCHAR *path - directory to change to
*
*Exit:
* returns 0 if successful,
* returns -1 and sets errno if unsuccessful
*
*Exceptions:
*
*******************************************************************************/
int __cdecl _tchdir (
const _TSCHAR *path
)
{
_TSCHAR env_var[4];
_TSCHAR abspath[MAX_PATH+1];
if ( SetCurrentDirectory((LPTSTR)path) )
{
/*
* If the new current directory path is NOT a UNC path, we must
* update the OS environment variable specifying the current
* directory for what is now current drive. To do this, get the
* full current directory, build the environment variable string
* and call SetEnvironmentVariable(). We need to do this because
* SetCurrentDirectory does not (i.e., does not update the
* current-directory-on-drive environment variables) and other
* functions (fullpath, spawn, etc) need them to be set.
*
* If associated with a 'drive', the current directory should
* have the form of the example below:
*
* D:\nt\private\mytests
*
* so that the environment variable should be of the form:
*
* =D:=D:\nt\private\mytests
*
*/
if ( GetCurrentDirectory(MAX_PATH+1, (LPTSTR)abspath) != 0 )
{
/*
* check if it is a UNC name, just return if is
*/
if ( ((abspath[0] == _T('\\')) || (abspath[0] == _T('/'))) &&
(abspath[0] == abspath[1]) )
return 0;
env_var[0] = _T('=');
env_var[1] = (_TSCHAR) _totupper((_TUCHAR)abspath[0]);
env_var[2] = _T(':');
env_var[3] = _T('\0');
if ( SetEnvironmentVariable(env_var, abspath) )
return 0;
}
}
_dosmaperr(GetLastError());
return -1;
}