| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304 |
- //---------------------------------------------------------------------
- #include <vcl.h>
- #pragma hdrstop
- #include <Common.h>
- #include <Terminal.h>
- #include <VCLCommon.h>
- #include "WinInterface.h"
- #include "FileSystemInfo.h"
- #include "TextsWin.h"
- #include "GUITools.h"
- //---------------------------------------------------------------------
- #pragma link "XPThemes"
- #pragma link "HistoryComboBox"
- #pragma resource "*.dfm"
- //---------------------------------------------------------------------
- void __fastcall DoFileSystemInfoDialog(const TFileSystemInfo & FileSystemInfo,
- AnsiString SpaceAvailablePath, TGetSpaceAvailable OnGetSpaceAvailable)
- {
- TFileSystemInfoDialog * Dialog = new TFileSystemInfoDialog(Application,
- OnGetSpaceAvailable);
- try
- {
- Dialog->Execute(FileSystemInfo, SpaceAvailablePath);
- }
- __finally
- {
- delete Dialog;
- }
- }
- //---------------------------------------------------------------------
- __fastcall TFileSystemInfoDialog::TFileSystemInfoDialog(TComponent * AOwner,
- TGetSpaceAvailable OnGetSpaceAvailable)
- : TForm(AOwner)
- {
- UseSystemSettings(this);
- FOnGetSpaceAvailable = OnGetSpaceAvailable;
- FSpaceAvailableLoaded = false;
- FLastListItem = 0;
- InstallPathWordBreakProc(SpaceAvailablePathEdit);
- }
- //---------------------------------------------------------------------
- void __fastcall TFileSystemInfoDialog::Execute(const TFileSystemInfo & FileSystemInfo,
- AnsiString SpaceAvailablePath)
- {
- FFileSystemInfo = FileSystemInfo;
- SpaceAvailablePathEdit->Text = SpaceAvailablePath;
- UpdateControls();
- ShowModal();
- }
- //---------------------------------------------------------------------
- AnsiString __fastcall TFileSystemInfoDialog::CapabilityStr(TFSCapability Capability)
- {
- return BooleanToStr(FFileSystemInfo.IsCapable[Capability]);
- }
- //---------------------------------------------------------------------
- AnsiString __fastcall TFileSystemInfoDialog::CapabilityStr(TFSCapability Capability1,
- TFSCapability Capability2)
- {
- return FORMAT("%s/%s", (CapabilityStr(Capability1), CapabilityStr(Capability2)));
- }
- //---------------------------------------------------------------------
- AnsiString __fastcall TFileSystemInfoDialog::SpaceStr(__int64 Bytes)
- {
- AnsiString Result;
- if (Bytes == 0)
- {
- Result = LoadStr(FSINFO_BYTES_UNKNOWN);
- }
- else
- {
- Result = FormatBytes(Bytes);
- AnsiString SizeUnorderedStr = FormatBytes(Bytes, false);
- if (Result != SizeUnorderedStr)
- {
- Result = FORMAT("%s (%s)", (Result, SizeUnorderedStr));
- }
- }
- return Result;
- }
- //---------------------------------------------------------------------
- void __fastcall TFileSystemInfoDialog::Feed(TFeedFileSystemData AddItem)
- {
- AddItem(ServerView, FSINFO_SSH_VERSION, FORMAT("SSH-%d", (FFileSystemInfo.SshVersion)));
- AddItem(ServerView, FSINFO_SSH_IMPLEMENTATION, FFileSystemInfo.SshImplementation);
- AnsiString Str = CipherNames[FFileSystemInfo.CSCipher];
- if (FFileSystemInfo.CSCipher != FFileSystemInfo.SCCipher)
- {
- Str += FORMAT("/%s", (CipherNames[FFileSystemInfo.SCCipher]));
- }
- AddItem(ServerView, FSINFO_CIPHER, Str);
- Str = BooleanToStr(FFileSystemInfo.CSCompression != ctNone);
- if (FFileSystemInfo.CSCompression != FFileSystemInfo.SCCompression)
- {
- Str += FORMAT("/%s", (BooleanToStr(FFileSystemInfo.SCCompression != ctNone)));
- }
- AddItem(ServerView, FSINFO_COMPRESSION, Str);
- AddItem(ServerView, FSINFO_FS_PROTOCOL, FFileSystemInfo.ProtocolName);
- AddItem(HostKeyFingerprintEdit, 0, FFileSystemInfo.HostKeyFingerprint);
- AddItem(ProtocolView, FSINFO_MODE_CHANGING, CapabilityStr(fcModeChanging));
- AddItem(ProtocolView, FSINFO_OWNER_GROUP_CHANGING, CapabilityStr(fcGroupChanging));
- AddItem(ProtocolView, FSINFO_ANY_COMMAND, CapabilityStr(fcAnyCommand));
- AddItem(ProtocolView, FSINFO_SYMBOLIC_HARD_LINK, CapabilityStr(fcSymbolicLink, fcHardLink));
- AddItem(ProtocolView, FSINFO_USER_GROUP_LISTING, CapabilityStr(fcUserGroupListing));
- AddItem(ProtocolView, FSINFO_REMOTE_COPY, CapabilityStr(fcRemoteCopy));
- AddItem(ProtocolView, FSINFO_CHECKING_SPACE_AVAILABLE, CapabilityStr(fcCheckingSpaceAvailable));
- AddItem(ProtocolView, FSINFO_NATIVE_TEXT_MODE, CapabilityStr(fcNativeTextMode));
- AddItem(InfoMemo, 0, FFileSystemInfo.AdditionalInfo);
- AddItem(SpaceAvailableView, FSINFO_BYTES_ON_DEVICE, SpaceStr(FSpaceAvailable.BytesOnDevice));
- AddItem(SpaceAvailableView, FSINFO_UNUSED_BYTES_ON_DEVICE, SpaceStr(FSpaceAvailable.UnusedBytesOnDevice));
- AddItem(SpaceAvailableView, FSINFO_BYTES_AVAILABLE_TO_USER, SpaceStr(FSpaceAvailable.BytesAvailableToUser));
- AddItem(SpaceAvailableView, FSINFO_UNUSED_BYTES_AVAILABLE_TO_USER, SpaceStr(FSpaceAvailable.UnusedBytesAvailableToUser));
- AddItem(SpaceAvailableView, FSINFO_BYTES_PER_ALLOCATION_UNIT, SpaceStr(FSpaceAvailable.BytesPerAllocationUnit));
- }
- //---------------------------------------------------------------------
- void __fastcall TFileSystemInfoDialog::ControlsAddItem(TControl * Control,
- int Label, AnsiString Value)
- {
- if (FLastFeededControl != Control)
- {
- FLastFeededControl = Control;
- FLastListItem = 0;
- }
- if (Control == HostKeyFingerprintEdit)
- {
- HostKeyFingerprintEdit->Text = Value;
- }
- else if (Control == InfoMemo)
- {
- InfoMemo->Lines->Text = Value;
- }
- else
- {
- TListView * ListView = dynamic_cast<TListView *>(Control);
- assert(ListView != NULL);
- TListItem * Item;
- if (ListView->Items->Count > FLastListItem)
- {
- Item = ListView->Items->Item[FLastListItem];
- }
- else
- {
- Item = ListView->Items->Add();
- }
- FLastListItem++;
- Item->Caption = LoadStr(Label);
- if (Item->SubItems->Count > 0)
- {
- Item->SubItems->Strings[0] = Value;
- }
- else
- {
- Item->SubItems->Add(Value);
- }
- }
- }
- //---------------------------------------------------------------------
- void __fastcall TFileSystemInfoDialog::FeedControls()
- {
- FLastFeededControl = NULL;
- Feed(ControlsAddItem);
- }
- //---------------------------------------------------------------------
- void __fastcall TFileSystemInfoDialog::UpdateControls()
- {
- EnableControl(SpaceAvailableSheet, SpaceAvailableSupported());
- EnableControl(SpaceAvailableButton, SpaceAvailableSheet->Enabled &&
- !SpaceAvailablePathEdit->Text.IsEmpty());
- }
- //---------------------------------------------------------------------
- void __fastcall TFileSystemInfoDialog::HelpButtonClick(TObject * /*Sender*/)
- {
- FormHelp(this);
- }
- //---------------------------------------------------------------------
- void __fastcall TFileSystemInfoDialog::ClipboardAddItem(TControl * Control,
- int Label, AnsiString Value)
- {
- if (Control->Enabled)
- {
- if (FLastFeededControl != Control)
- {
- if (FLastFeededControl != NULL)
- {
- FClipboard += AnsiString::StringOfChar('-', 60) + "\r\n";
- }
- FLastFeededControl = Control;
- }
- if (dynamic_cast<TListView *>(Control) == NULL)
- {
- TXPGroupBox * Group = dynamic_cast<TXPGroupBox *>(Control->Parent);
- assert(Group != NULL);
- if ((Value.Length() >= 2) && (Value.SubString(Value.Length() - 1, 2) == "\r\n"))
- {
- Value.SetLength(Value.Length() - 2);
- }
- FClipboard += FORMAT("%s\r\n%s\r\n", (Group->Caption, Value));
- }
- else
- {
- assert(dynamic_cast<TListView *>(Control) != NULL);
- FClipboard += FORMAT("%s = %s\r\n", (LoadStr(Label), Value));
- }
- }
- }
- //---------------------------------------------------------------------------
- void __fastcall TFileSystemInfoDialog::ClipboardButtonClick(
- TObject * /*Sender*/)
- {
- NeedSpaceAvailable();
- FLastFeededControl = NULL;
- FClipboard = "";
- Feed(ClipboardAddItem);
- CopyToClipboard(FClipboard);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFileSystemInfoDialog::CopyClick(TObject * /*Sender*/)
- {
- TListView * ListView = dynamic_cast<TListView *>(ListViewMenu->PopupComponent);
- assert(ListView != NULL);
- AnsiString Text;
- for (int Index = 0; Index < ListView->Items->Count; Index++)
- {
- TListItem * Item = ListView->Items->Item[Index];
- if (Item->Selected)
- {
- Text += FORMAT("%s = %s\r\n", (Item->Caption, Item->SubItems->Strings[0]));
- }
- }
- CopyToClipboard(Text);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFileSystemInfoDialog::FormShow(TObject * /*Sender*/)
- {
- PageControl->ActivePage = SshSheet;
- FeedControls();
- }
- //---------------------------------------------------------------------------
- void __fastcall TFileSystemInfoDialog::SpaceAvailableButtonClick(
- TObject * /*Sender*/)
- {
- CheckSpaceAvailable();
- }
- //---------------------------------------------------------------------------
- void __fastcall TFileSystemInfoDialog::CheckSpaceAvailable()
- {
- assert(FOnGetSpaceAvailable != NULL);
- assert(!SpaceAvailablePathEdit->Text.IsEmpty());
- FSpaceAvailableLoaded = true;
- bool DoClose = false;
- try
- {
- FOnGetSpaceAvailable(SpaceAvailablePathEdit->Text, FSpaceAvailable, DoClose);
- }
- __finally
- {
- FeedControls();
- if (DoClose)
- {
- Close();
- }
- }
- }
- //---------------------------------------------------------------------------
- void __fastcall TFileSystemInfoDialog::NeedSpaceAvailable()
- {
- if (!FSpaceAvailableLoaded && SpaceAvailableSupported())
- {
- CheckSpaceAvailable();
- }
- }
- //---------------------------------------------------------------------------
- bool __fastcall TFileSystemInfoDialog::SpaceAvailableSupported()
- {
- return (FOnGetSpaceAvailable != NULL);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFileSystemInfoDialog::PageControlChange(TObject * /*Sender*/)
- {
- if (PageControl->ActivePage == SpaceAvailableSheet)
- {
- NeedSpaceAvailable();
- }
- }
- //---------------------------------------------------------------------------
- void __fastcall TFileSystemInfoDialog::ControlChange(TObject * /*Sender*/)
- {
- UpdateControls();
- }
- //---------------------------------------------------------------------------
|