瀏覽代碼

Bug 1911: Allow longer input on Edit file input box

https://winscp.net/tracker/1911

Source commit: 738e9670899f338b2fff11ffdc51f84960152218
Martin Prikryl 5 年之前
父節點
當前提交
b873a4afc8
共有 3 個文件被更改,包括 10 次插入9 次删除
  1. 1 1
      source/forms/CustomScpExplorer.cpp
  2. 8 7
      source/forms/InputDlg.cpp
  3. 1 1
      source/windows/WinInterface.h

+ 1 - 1
source/forms/CustomScpExplorer.cpp

@@ -3052,7 +3052,7 @@ void __fastcall TCustomScpExplorerForm::EditNew(TOperationSide Side)
   UnicodeString Names = Name;
   UnicodeString Names = Name;
   std::unique_ptr<TStrings> History(CloneStrings(CustomWinConfiguration->History[L"EditFile"]));
   std::unique_ptr<TStrings> History(CloneStrings(CustomWinConfiguration->History[L"EditFile"]));
   if (InputDialog(LoadStr(EDIT_FILE_CAPTION), LoadStr(EDIT_FILE_PROMPT), Names,
   if (InputDialog(LoadStr(EDIT_FILE_CAPTION), LoadStr(EDIT_FILE_PROMPT), Names,
-        HELP_EDIT_NEW, History.get(), true))
+        HELP_EDIT_NEW, History.get(), true, NULL, true, 400))
   {
   {
     while (!Names.IsEmpty())
     while (!Names.IsEmpty())
     {
     {

+ 8 - 7
source/forms/InputDlg.cpp

@@ -18,7 +18,7 @@ class TInputDialog : public TCustomDialog
 public:
 public:
   __fastcall TInputDialog(
   __fastcall TInputDialog(
     const UnicodeString & ACaption, const UnicodeString & Prompt, const UnicodeString & HelpKeyword,
     const UnicodeString & ACaption, const UnicodeString & Prompt, const UnicodeString & HelpKeyword,
-    TStrings * History, bool PathInput, TInputDialogInitialize OnInitialize, bool Echo);
+    TStrings * History, bool PathInput, TInputDialogInitialize OnInitialize, bool Echo, int AWidth);
 
 
   bool __fastcall Execute(UnicodeString & Value);
   bool __fastcall Execute(UnicodeString & Value);
 
 
@@ -35,7 +35,7 @@ private:
 //---------------------------------------------------------------------------
 //---------------------------------------------------------------------------
 __fastcall TInputDialog::TInputDialog(
 __fastcall TInputDialog::TInputDialog(
   const UnicodeString & ACaption, const UnicodeString & Prompt, const UnicodeString & HelpKeyword,
   const UnicodeString & ACaption, const UnicodeString & Prompt, const UnicodeString & HelpKeyword,
-  TStrings * History, bool PathInput, TInputDialogInitialize OnInitialize, bool Echo) :
+  TStrings * History, bool PathInput, TInputDialogInitialize OnInitialize, bool Echo, int AWidth) :
   TCustomDialog(HelpKeyword)
   TCustomDialog(HelpKeyword)
 {
 {
   Caption = ACaption;
   Caption = ACaption;
@@ -43,9 +43,10 @@ __fastcall TInputDialog::TInputDialog(
   FOnInitialize = OnInitialize;
   FOnInitialize = OnInitialize;
   FHistory = History;
   FHistory = History;
 
 
-  ClientWidth = ScaleByTextHeight(this, 275);
+  ClientWidth = ScaleByTextHeight(this, AWidth);
 
 
   TLabel * Label = CreateLabel(Prompt);
   TLabel * Label = CreateLabel(Prompt);
+  int MaxLength = FPathInput ? 0 : 255;
   if (History == NULL)
   if (History == NULL)
   {
   {
     if (Echo)
     if (Echo)
@@ -58,14 +59,14 @@ __fastcall TInputDialog::TInputDialog(
     }
     }
     HistoryCombo = NULL;
     HistoryCombo = NULL;
     AddEditLikeControl(Edit, Label);
     AddEditLikeControl(Edit, Label);
-    reinterpret_cast<TEdit *>(Edit)->MaxLength = 255;
+    reinterpret_cast<TEdit *>(Edit)->MaxLength = MaxLength;
   }
   }
   else
   else
   {
   {
     DebugAssert(Echo);
     DebugAssert(Echo);
     HistoryCombo = new THistoryComboBox(this);
     HistoryCombo = new THistoryComboBox(this);
     AddEditLikeControl(HistoryCombo, Label);
     AddEditLikeControl(HistoryCombo, Label);
-    HistoryCombo->MaxLength = 255;
+    HistoryCombo->MaxLength = MaxLength;
     HistoryCombo->AutoComplete = false;
     HistoryCombo->AutoComplete = false;
     Edit = NULL;
     Edit = NULL;
   }
   }
@@ -130,9 +131,9 @@ bool __fastcall TInputDialog::Execute(UnicodeString & Value)
 //---------------------------------------------------------------------------
 //---------------------------------------------------------------------------
 bool __fastcall InputDialog(const UnicodeString ACaption,
 bool __fastcall InputDialog(const UnicodeString ACaption,
   const UnicodeString APrompt, UnicodeString & Value, UnicodeString HelpKeyword,
   const UnicodeString APrompt, UnicodeString & Value, UnicodeString HelpKeyword,
-  TStrings * History, bool PathInput, TInputDialogInitialize OnInitialize, bool Echo)
+  TStrings * History, bool PathInput, TInputDialogInitialize OnInitialize, bool Echo, int Width)
 {
 {
-  std::unique_ptr<TInputDialog> Dialog(new TInputDialog(ACaption, APrompt, HelpKeyword, History, PathInput, OnInitialize, Echo));
+  std::unique_ptr<TInputDialog> Dialog(new TInputDialog(ACaption, APrompt, HelpKeyword, History, PathInput, OnInitialize, Echo, Width));
   return Dialog->Execute(Value);
   return Dialog->Execute(Value);
 }
 }
 //---------------------------------------------------------------------------
 //---------------------------------------------------------------------------

+ 1 - 1
source/windows/WinInterface.h

@@ -180,7 +180,7 @@ typedef void __fastcall (__closure *TInputDialogInitialize)
 bool __fastcall InputDialog(const UnicodeString ACaption,
 bool __fastcall InputDialog(const UnicodeString ACaption,
   const UnicodeString APrompt, UnicodeString & Value, UnicodeString HelpKeyword = HELP_NONE,
   const UnicodeString APrompt, UnicodeString & Value, UnicodeString HelpKeyword = HELP_NONE,
   TStrings * History = NULL, bool PathInput = false,
   TStrings * History = NULL, bool PathInput = false,
-  TInputDialogInitialize OnInitialize = NULL, bool Echo = true);
+  TInputDialogInitialize OnInitialize = NULL, bool Echo = true, int Width = 275);
 
 
 // forms\About.cpp
 // forms\About.cpp
 struct TRegistration
 struct TRegistration