X-Git-Url: http://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Fshared%2Fenvvars.pas;h=a76315f42d40f9ddfc84f2d8ecead137bcd2cd2d;hb=0e9597f8ac286b719ea050f6e6f2433c20375fe5;hp=3774eab2fe277edbd168c160de436c954d3c5007;hpb=055a225d4c2a18e9aff2f0e682cf89048d1efefe;p=d2df-sdl.git diff --git a/src/shared/envvars.pas b/src/shared/envvars.pas index 3774eab..a76315f 100644 --- a/src/shared/envvars.pas +++ b/src/shared/envvars.pas @@ -2,8 +2,7 @@ * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. + * the Free Software Foundation, version 3 of the License ONLY. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of @@ -26,8 +25,14 @@ interface implementation + uses +{$IFDEF WINDOWS} + Windows, +{$ENDIF} + utils; + + {$IFDEF WINDOWS} -uses Windows; function setenv(const VarStr: PChar; const VarVal: PChar; Repl: cint): cint; begin if (SetEnvironmentVariable(VarStr, VarVal)) then @@ -47,15 +52,25 @@ begin Result := (setenv(PChar(VarName), PChar(VarVal), 1) = 0); end; - function GetUserName: String; + (* Get system username already in cp1251 *) + function GetUserName: AnsiString; + var i: Integer; begin {$IF DEFINED(WINDOWS)} - Result := SysUtils.GetEnvironmentVariable('USERNAME') + Result := utf2win(UTF8String(SysUtils.GetEnvironmentVariable(WideString('USERNAME')))); {$ELSEIF DEFINED(UNIX)} - Result := SysUtils.GetEnvironmentVariable('USER') + Result := utf2win(SysUtils.GetEnvironmentVariable('USER')); {$ELSE} - Result := '' + Result := ''; {$ENDIF} + (* invalidate username with non-cp1251 symbols *) + i := Low(Result); + while i <= High(Result) do + begin + if Result[i] = '?' then + Result := ''; + Inc(i) + end end; end.