mirror of
https://github.com/pbatard/rufus.git
synced 2024-08-14 23:57:05 +00:00
[core] improve Unicode support
* Microsoft's version of _wgetenv() is *BROKEN*! * Also set rufus-next to 2.15
This commit is contained in:
parent
e2481efcd9
commit
fff4465b1d
4 changed files with 28 additions and 33 deletions
|
@ -836,16 +836,6 @@ static __inline int _openU(const char *filename, int oflag, int pmode)
|
|||
wfree(filename);
|
||||
return ret;
|
||||
}
|
||||
|
||||
// returned UTF-8 string must be freed
|
||||
static __inline char* getenvU(const char* varname)
|
||||
{
|
||||
wconvert(varname);
|
||||
char* ret;
|
||||
ret = wchar_to_utf8(_wgetenv(wvarname));
|
||||
wfree(varname);
|
||||
return ret;
|
||||
}
|
||||
#else
|
||||
static __inline FILE* fopenU(const char* filename, const char* mode)
|
||||
{
|
||||
|
@ -872,21 +862,26 @@ static __inline int _openU(const char *filename, int oflag , int pmode)
|
|||
wfree(filename);
|
||||
return ret;
|
||||
}
|
||||
#endif
|
||||
|
||||
// returned UTF-8 string must be freed
|
||||
static __inline char* getenvU(const char* varname)
|
||||
{
|
||||
wconvert(varname);
|
||||
char *ret;
|
||||
wchar_t value[256];
|
||||
size_t value_size;
|
||||
// MinGW and WDK don't know wdupenv_s, so we use wgetenv_s
|
||||
_wgetenv_s(&value_size, value, ARRAYSIZE(value), wvarname);
|
||||
ret = wchar_to_utf8(value);
|
||||
char* ret = NULL;
|
||||
wchar_t* wbuf = NULL;
|
||||
// _wgetenv() is *BROKEN* in MS compilers => use GetEnvironmentVariableW()
|
||||
DWORD dwSize = GetEnvironmentVariableW(wvarname, wbuf, 0);
|
||||
wbuf = calloc(dwSize, sizeof(wchar_t));
|
||||
if (wbuf == NULL)
|
||||
return NULL;
|
||||
dwSize = GetEnvironmentVariableW(wvarname, wbuf, dwSize);
|
||||
if (dwSize != 0)
|
||||
ret = wchar_to_utf8(wbuf);
|
||||
free(wbuf);
|
||||
wfree(varname);
|
||||
return ret;
|
||||
}
|
||||
#endif
|
||||
|
||||
static __inline int _mkdirU(const char* dirname)
|
||||
{
|
||||
|
|
10
src/rufus.rc
10
src/rufus.rc
|
@ -33,7 +33,7 @@ LANGUAGE LANG_NEUTRAL, SUBLANG_NEUTRAL
|
|||
IDD_DIALOG DIALOGEX 12, 12, 242, 376
|
||||
STYLE DS_SETFONT | DS_MODALFRAME | DS_CENTER | WS_MINIMIZEBOX | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
||||
EXSTYLE WS_EX_ACCEPTFILES
|
||||
CAPTION "Rufus 2.14.1088"
|
||||
CAPTION "Rufus 2.15.1089"
|
||||
FONT 8, "Segoe UI Symbol", 400, 0, 0x0
|
||||
BEGIN
|
||||
LTEXT "Device",IDS_DEVICE_TXT,9,6,200,8
|
||||
|
@ -334,8 +334,8 @@ END
|
|||
//
|
||||
|
||||
VS_VERSION_INFO VERSIONINFO
|
||||
FILEVERSION 2,14,1088,0
|
||||
PRODUCTVERSION 2,14,1088,0
|
||||
FILEVERSION 2,15,1089,0
|
||||
PRODUCTVERSION 2,15,1089,0
|
||||
FILEFLAGSMASK 0x3fL
|
||||
#ifdef _DEBUG
|
||||
FILEFLAGS 0x1L
|
||||
|
@ -352,13 +352,13 @@ BEGIN
|
|||
BEGIN
|
||||
VALUE "CompanyName", "Akeo Consulting (http://akeo.ie)"
|
||||
VALUE "FileDescription", "Rufus"
|
||||
VALUE "FileVersion", "2.14.1088"
|
||||
VALUE "FileVersion", "2.15.1089"
|
||||
VALUE "InternalName", "Rufus"
|
||||
VALUE "LegalCopyright", "© 2011-2017 Pete Batard (GPL v3)"
|
||||
VALUE "LegalTrademarks", "http://www.gnu.org/copyleft/gpl.html"
|
||||
VALUE "OriginalFilename", "rufus.exe"
|
||||
VALUE "ProductName", "Rufus"
|
||||
VALUE "ProductVersion", "2.14.1088"
|
||||
VALUE "ProductVersion", "2.15.1089"
|
||||
END
|
||||
END
|
||||
BLOCK "VarFileInfo"
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue