The GetSystemDirectory function retrieves the path of the Windows system directory. The system directory contains such files as Windows libraries, drivers, and font files. <br><br>UINT GetSystemDirectory(<br><br> LPTSTR lpBuffer, // address of buffer for system directory <br> UINT uSize // size of directory buffer <br> <br> <br><br>Parameters<br><br>lpBuffer<br><br>Points to the buffer to receive the null-terminated string containing the path. This path does not end with a backslash unless the system directory is the root directory. For example, if the system directory is named WINDOWS/SYSTEM on drive C, the path of the system directory retrieved by this function is C:/WINDOWS/SYSTEM. <br><br>uSize<br><br>Specifies the maximum size of the buffer, in characters. This value should be set to at least MAX_PATH. <br><br> <br><br>Return Values<br><br>If the function succeeds, the return value is the length, in characters, of the string copied to the buffer, not including the terminating null character. If the length is greater than the size of the buffer, the return value is the size of the buffer required to hold the path. <br>If the function fails, the return value is zero. To get extended error information, call GetLastError. <br><br>Remarks<br><br>Applications should not create files in the system directory. If the user is running a shared version of Windows, the application does not have write access to the system directory. Applications should create files only in the directory returned by the GetWindowsDirectory function.
procedure TForm1.Button1Click(Sender: TObject);<br>var<br> SysDir: array[0..MAX_PATH] of Char; // holds the system directory<br>begin<br> {retrieve the system directory and display it}<br> GetSystemDirectory(SysDir, MAX_PATH);<br> Label1.Caption := StrPas(SysDir)<br>end;<br>