| OpenTTD
    | 
Implementation of MS Windows system calls. More...
#include "../../stdafx.h"#include "../../debug.h"#include "../../gfx_func.h"#include "../../textbuf_gui.h"#include "../../fileio_func.h"#include <windows.h>#include <fcntl.h>#include <regstr.h>#include <shlobj.h>#include <shellapi.h>#include "win32.h"#include "../../fios.h"#include "../../core/alloc_func.hpp"#include "../../openttd.h"#include "../../core/random_func.hpp"#include "../../string_func.h"#include "../../crashlog.h"#include <errno.h>#include <sys/stat.h>#include "../../safeguards.h"Go to the source code of this file.
| Data Structures | |
| struct | DIR | 
| Macros | |
| #define | W(x) x "W" | 
| Functions | |
| bool | MyShowCursor (bool show, bool toggle) | 
| bool | LoadLibraryList (Function proc[], const char *dll) | 
| Helper function needed by dynamically loading libraries XXX: Hurray for MS only having an ANSI GetProcAddress function on normal windows and no Wide version except for in Windows Mobile/CE. | |
| void | ShowOSErrorBox (const char *buf, bool system) | 
| void | OSOpenBrowser (const char *url) | 
| static DIR * | dir_calloc () | 
| static void | dir_free (DIR *d) | 
| DIR * | opendir (const TCHAR *path) | 
| struct dirent * | readdir (DIR *d) | 
| int | closedir (DIR *d) | 
| bool | FiosIsRoot (const char *file) | 
| void | FiosGetDrives (FileList &file_list) | 
| bool | FiosIsValidFile (const char *path, const struct dirent *ent, struct stat *sb) | 
| bool | FiosIsHiddenFile (const struct dirent *ent) | 
| bool | FiosGetDiskFreeSpace (const char *path, uint64 *tot) | 
| static int | ParseCommandLine (char *line, char **argv, int max_argc) | 
| void | CreateConsole () | 
| static INT_PTR CALLBACK | HelpDialogFunc (HWND wnd, UINT msg, WPARAM wParam, LPARAM lParam) | 
| Callback function to handle the window. | |
| void | ShowInfo (const char *str) | 
| int APIENTRY | WinMain (HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow) | 
| char * | getcwd (char *buf, size_t size) | 
| void | DetermineBasePaths (const char *exe) | 
| bool | GetClipboardContents (char *buffer, const char *last) | 
| Try to retrieve the current clipboard contents. | |
| void | CSleep (int milliseconds) | 
| const char * | FS2OTTD (const TCHAR *name) | 
| Convert to OpenTTD's encoding from that of the local environment. | |
| const TCHAR * | OTTD2FS (const char *name, bool console_cp) | 
| Convert from OpenTTD's encoding to that of the local environment. | |
| char * | convert_from_fs (const TCHAR *name, char *utf8_buf, size_t buflen) | 
| Convert to OpenTTD's encoding from that of the environment in UNICODE. | |
| TCHAR * | convert_to_fs (const char *name, TCHAR *system_buf, size_t buflen, bool console_cp) | 
| Convert from OpenTTD's encoding to that of the environment in UNICODE. | |
| HRESULT | OTTDSHGetFolderPath (HWND hwnd, int csidl, HANDLE hToken, DWORD dwFlags, LPTSTR pszPath) | 
| Our very own SHGetFolderPath function for support of windows operating systems that don't have this function (eg Win9x, etc.). | |
| const char * | GetCurrentLocale (const char *) | 
| Determine the current user's locale. | |
| uint | GetCPUCoreCount () | 
| Get number of processor cores in the system, including HyperThreading or similar. | |
| Variables | |
| static bool | _has_console | 
| static bool | _cursor_disable = true | 
| static bool | _cursor_visible = true | 
| static DIR | _global_dir | 
| static LONG | _global_dir_is_in_use = false | 
| static const char * | _help_msg | 
| Temporary pointer to get the help message to the window. | |
Implementation of MS Windows system calls.
Definition in file win32.cpp.
| char* convert_from_fs | ( | const TCHAR * | name, | 
| char * | utf8_buf, | ||
| size_t | buflen | ||
| ) | 
Convert to OpenTTD's encoding from that of the environment in UNICODE.
OpenTTD encoding is UTF8, local is wide
| name | pointer to a valid string that will be converted | 
| utf8_buf | pointer to a valid buffer that will receive the converted string | 
| buflen | length in characters of the receiving buffer | 
Definition at line 646 of file win32.cpp.
References AllocaM.
Referenced by FS2OTTD(), and HandleIMEComposition().
| TCHAR* convert_to_fs | ( | const char * | name, | 
| TCHAR * | system_buf, | ||
| size_t | buflen, | ||
| bool | console_cp | ||
| ) | 
Convert from OpenTTD's encoding to that of the environment in UNICODE.
OpenTTD encoding is UTF8, local is wide
| name | pointer to a valid string that will be converted | 
| utf16_buf | pointer to a valid wide-char buffer that will receive the converted string | 
| buflen | length in wide characters of the receiving buffer | 
| console_cp | convert to the console encoding instead of the normal system encoding. | 
Definition at line 680 of file win32.cpp.
References AllocaM.
Referenced by HelpDialogFunc(), and OTTD2FS().
| const char* FS2OTTD | ( | const TCHAR * | name | ) | 
Convert to OpenTTD's encoding from that of the local environment.
When the project is built in UNICODE, the system codepage is irrelevant and the input string is wide. In ANSI mode, the string is in the local codepage which we'll convert to wide-char, and then to UTF-8. OpenTTD internal encoding is UTF8. The returned value's contents can only be guaranteed until the next call to this function. So if the value is needed for anything else, use convert_from_fs
| name | pointer to a valid string that will be converted (local, or wide) | 
Definition at line 613 of file win32.cpp.
References convert_from_fs(), and lengthof.
Referenced by FiosGetFileList(), GetClipboardContents(), GetLanguageList(), HandleIMEComposition(), NetworkAddress::Resolve(), and ScanPath().
| bool GetClipboardContents | ( | char * | buffer, | 
| const char * | last | ||
| ) | 
| uint GetCPUCoreCount | ( | ) | 
| const char* GetCurrentLocale | ( | const char * | ) | 
Determine the current user's locale.
Definition at line 768 of file win32.cpp.
References lengthof.
Referenced by InitializeLanguagePacks().
| const TCHAR* OTTD2FS | ( | const char * | name, | 
| bool | console_cp | ||
| ) | 
Convert from OpenTTD's encoding to that of the local environment.
When the project is built in UNICODE the system codepage is irrelevant and the converted string is wide. In ANSI mode, the UTF8 string is converted to multi-byte. OpenTTD internal encoding is UTF8. The returned value's contents can only be guaranteed until the next call to this function. So if the value is needed for anything else, use convert_from_fs
| name | pointer to a valid string that will be converted (UTF8) | 
| console_cp | convert to the console encoding instead of the normal system encoding. | 
Definition at line 631 of file win32.cpp.
References convert_to_fs(), and lengthof.
Referenced by FiosFileScanner::AddFile(), debug_print(), FileExists(), FioCreateDirectory(), IniFile::SaveToDisk(), and ttd_opendir().
| HRESULT OTTDSHGetFolderPath | ( | HWND | hwnd, | 
| int | csidl, | ||
| HANDLE | hToken, | ||
| DWORD | dwFlags, | ||
| LPTSTR | pszPath | ||
| ) | 
Our very own SHGetFolderPath function for support of windows operating systems that don't have this function (eg Win9x, etc.).
We try using the native function, and if that doesn't exist we will try a more crude approach of environment variables and hope for the best
Definition at line 708 of file win32.cpp.
References DEBUG, and LoadLibraryList().
 1.8.1.2
 1.8.1.2