X-Git-Url: https://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Feditor%2Ff_options.pas;h=aa7012f58f987771b474f9153853a64c0fd2218f;hb=3c2fc40a5ba59f7570d4ae61c743de3ab1508434;hp=a663bb20d5fc1200c972a87c0cb26eaec9636122;hpb=aac9a5a0163636f33249acf6ce27ea770818c6cb;p=d2df-editor.git diff --git a/src/editor/f_options.pas b/src/editor/f_options.pas index a663bb2..aa7012f 100644 --- a/src/editor/f_options.pas +++ b/src/editor/f_options.pas @@ -7,7 +7,7 @@ interface uses LCLIntf, LCLType, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls, - ExtCtrls, ComCtrls, Registry, Math, Types; + ExtCtrls, ComCtrls, ActnList, Registry, Math, Types; type @@ -19,6 +19,7 @@ type cbCheckerboard: TCheckBox; cbCompress: TCheckBox; cbBackup: TCheckBox; + cbLanguage: TComboBox; PageControl: TPageControl; TabGeneral: TTabSheet; TabFiles: TTabSheet; @@ -54,8 +55,6 @@ type eRecent: TEdit; UpDown3: TUpDown; LabelLanguage: TLabel; - rbRussian: TRadioButton; - rbEnglish: TRadioButton; LabelGridSize: TLabel; cbDotSize: TComboBox; // Map testing: @@ -105,7 +104,7 @@ procedure RegisterFileType(ext: String; FileName: String); implementation uses - f_main, StdConvs, CONFIG, g_language, g_resources, g_options; + LazFileUtils, f_main, StdConvs, CONFIG, g_language, g_resources, g_options; {$R *.lfm} @@ -146,6 +145,8 @@ begin end; procedure TOptionsForm.FormActivate(Sender: TObject); + const langfilename = 'editor'; + var info: TSearchRec; begin sDotColor.Brush.Color := DotColor; cbShowDots.Checked := DotEnable; @@ -168,17 +169,21 @@ begin cbDotSize.ItemIndex := 0; eRecent.Text := IntToStr(RecentCount); -// Язык: - if gLanguage = LANGUAGE_RUSSIAN then + try + cbLanguage.Items.BeginUpdate; + cbLanguage.Items.Clear; + cbLanguage.Items.Add('Auto'); + if FindFirst(LangDir + DirectorySeparator + langfilename + '.*.mo', faAnyFile, info) = 0 then begin - rbRussian.Checked := True; - rbEnglish.Checked := False; - end - else - begin - rbRussian.Checked := False; - rbEnglish.Checked := True; + repeat + cbLanguage.Items.Add(Copy(ExtractFileNameWithoutExt(info.Name), Length(langfilename) + 2)); + until FindNext(info) <> 0; + FindClose(info); end; + cbLanguage.ItemIndex := IfThen(gLanguage = '', 0, cbLanguage.Items.IndexOf(gLanguage)); + finally + cbLanguage.Items.EndUpdate; + end; if TestGameMode = 'TDM' then rbTDM.Checked := True @@ -211,17 +216,10 @@ var begin // General tab - if rbRussian.Checked then - str := LANGUAGE_RUSSIAN - else - str := LANGUAGE_ENGLISH; - -// Нужно сменить язык: - if gLanguage <> str then + if cbLanguage.ItemIndex <= 0 then str := '' else str := cbLanguage.Items[cbLanguage.ItemIndex]; + if (str = '') or (gLanguage <> str) then begin gLanguage := str; - //e_WriteLog('Read language file', MSG_NOTIFY); - //g_Language_Load(EditorDir+'\data\'+gLanguage+LANGUAGE_FILE_NAME); g_Language_Set(gLanguage); end;