Queue.h 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526
  1. //---------------------------------------------------------------------------
  2. #ifndef QueueH
  3. #define QueueH
  4. //---------------------------------------------------------------------------
  5. #include "Terminal.h"
  6. #include "FileOperationProgress.h"
  7. //---------------------------------------------------------------------------
  8. class TSimpleThread
  9. {
  10. public:
  11. __fastcall TSimpleThread();
  12. virtual __fastcall ~TSimpleThread();
  13. virtual void __fastcall Start();
  14. void __fastcall WaitFor(unsigned int Milliseconds = INFINITE);
  15. virtual void __fastcall Terminate() = 0;
  16. void __fastcall Close();
  17. bool __fastcall IsFinished();
  18. protected:
  19. HANDLE FThread;
  20. TThreadID FThreadId;
  21. bool FFinished;
  22. virtual void __fastcall Execute() = 0;
  23. virtual bool __fastcall Finished();
  24. static int __fastcall ThreadProc(void * Thread);
  25. };
  26. //---------------------------------------------------------------------------
  27. class TSignalThread : public TSimpleThread
  28. {
  29. public:
  30. virtual void __fastcall Start();
  31. virtual void __fastcall Terminate();
  32. void __fastcall TriggerEvent();
  33. protected:
  34. HANDLE FEvent;
  35. bool FTerminated;
  36. __fastcall TSignalThread(bool LowPriority, HANDLE Event = NULL);
  37. virtual __fastcall ~TSignalThread();
  38. virtual bool __fastcall WaitForEvent();
  39. int __fastcall WaitForEvent(unsigned int Timeout);
  40. virtual void __fastcall Execute();
  41. virtual void __fastcall ProcessEvent() = 0;
  42. };
  43. //---------------------------------------------------------------------------
  44. class TTerminal;
  45. class TQueueItem;
  46. class TTerminalQueue;
  47. class TQueueItemProxy;
  48. class TTerminalQueueStatus;
  49. class TQueueFileList;
  50. class TTerminalItem;
  51. //---------------------------------------------------------------------------
  52. typedef void __fastcall (__closure * TQueueListUpdate)
  53. (TTerminalQueue * Queue);
  54. typedef void __fastcall (__closure * TQueueItemUpdateEvent)
  55. (TTerminalQueue * Queue, TQueueItem * Item);
  56. enum TQueueEvent { qeEmpty, qeEmptyButMonitored, qePendingUserAction };
  57. typedef void __fastcall (__closure * TQueueEventEvent)
  58. (TTerminalQueue * Queue, TQueueEvent Event);
  59. //---------------------------------------------------------------------------
  60. class TTerminalQueue : public TSignalThread
  61. {
  62. friend class TQueueItem;
  63. friend class TQueueItemProxy;
  64. friend class TTransferQueueItem;
  65. friend class TParallelTransferQueueItem;
  66. public:
  67. __fastcall TTerminalQueue(TTerminal * Terminal, TConfiguration * Configuration);
  68. virtual __fastcall ~TTerminalQueue();
  69. void __fastcall AddItem(TQueueItem * Item);
  70. TTerminalQueueStatus * __fastcall CreateStatus(TTerminalQueueStatus * Current);
  71. void __fastcall Idle();
  72. __property bool IsEmpty = { read = GetIsEmpty };
  73. __property int TransfersLimit = { read = FTransfersLimit, write = SetTransfersLimit };
  74. __property int KeepDoneItemsFor = { read = FKeepDoneItemsFor, write = SetKeepDoneItemsFor };
  75. __property int ParallelDurationThreshold = { read = GetParallelDurationThreshold };
  76. __property bool Enabled = { read = FEnabled, write = SetEnabled };
  77. __property TQueryUserEvent OnQueryUser = { read = FOnQueryUser, write = FOnQueryUser };
  78. __property TPromptUserEvent OnPromptUser = { read = FOnPromptUser, write = FOnPromptUser };
  79. __property TExtendedExceptionEvent OnShowExtendedException = { read = FOnShowExtendedException, write = FOnShowExtendedException };
  80. __property TQueueListUpdate OnListUpdate = { read = FOnListUpdate, write = FOnListUpdate };
  81. __property TQueueItemUpdateEvent OnQueueItemUpdate = { read = FOnQueueItemUpdate, write = FOnQueueItemUpdate };
  82. __property TQueueEventEvent OnEvent = { read = FOnEvent, write = FOnEvent };
  83. protected:
  84. friend class TTerminalItem;
  85. friend class TQueryUserAction;
  86. friend class TPromptUserAction;
  87. friend class TShowExtendedExceptionAction;
  88. TQueryUserEvent FOnQueryUser;
  89. TPromptUserEvent FOnPromptUser;
  90. TExtendedExceptionEvent FOnShowExtendedException;
  91. TQueueItemUpdateEvent FOnQueueItemUpdate;
  92. TQueueListUpdate FOnListUpdate;
  93. TQueueEventEvent FOnEvent;
  94. TTerminal * FTerminal;
  95. TConfiguration * FConfiguration;
  96. TSessionData * FSessionData;
  97. TList * FItems;
  98. TList * FDoneItems;
  99. int FItemsInProcess;
  100. TCriticalSection * FItemsSection;
  101. int FFreeTerminals;
  102. TList * FTerminals;
  103. TList * FForcedItems;
  104. int FTemporaryTerminals;
  105. int FOverallTerminals;
  106. int FTransfersLimit;
  107. int FKeepDoneItemsFor;
  108. bool FEnabled;
  109. TDateTime FIdleInterval;
  110. TDateTime FLastIdle;
  111. inline static TQueueItem * __fastcall GetItem(TList * List, int Index);
  112. inline TQueueItem * __fastcall GetItem(int Index);
  113. void __fastcall FreeItemsList(TList * List);
  114. void __fastcall UpdateStatusForList(
  115. TTerminalQueueStatus * Status, TList * List, TTerminalQueueStatus * Current);
  116. bool __fastcall ItemGetData(TQueueItem * Item, TQueueItemProxy * Proxy, TQueueFileList * FileList);
  117. bool __fastcall ItemProcessUserAction(TQueueItem * Item, void * Arg);
  118. bool __fastcall ItemMove(TQueueItem * Item, TQueueItem * BeforeItem);
  119. bool __fastcall ItemExecuteNow(TQueueItem * Item);
  120. bool __fastcall ItemDelete(TQueueItem * Item);
  121. bool __fastcall ItemPause(TQueueItem * Item, bool Pause);
  122. bool __fastcall ItemSetCPSLimit(TQueueItem * Item, unsigned long CPSLimit);
  123. bool __fastcall ItemGetCPSLimit(TQueueItem * Item, unsigned long & CPSLimit);
  124. void __fastcall RetryItem(TQueueItem * Item);
  125. void __fastcall DeleteItem(TQueueItem * Item, bool CanKeep);
  126. virtual bool __fastcall WaitForEvent();
  127. virtual void __fastcall ProcessEvent();
  128. void __fastcall TerminalFinished(TTerminalItem * TerminalItem);
  129. bool __fastcall TerminalFree(TTerminalItem * TerminalItem);
  130. int __fastcall GetParallelDurationThreshold();
  131. void __fastcall DoQueueItemUpdate(TQueueItem * Item);
  132. void __fastcall DoListUpdate();
  133. void __fastcall DoEvent(TQueueEvent Event);
  134. void __fastcall SetTransfersLimit(int value);
  135. void __fastcall SetKeepDoneItemsFor(int value);
  136. void __fastcall SetEnabled(bool value);
  137. bool __fastcall GetIsEmpty();
  138. bool __fastcall TryAddParallelOperation(TQueueItem * Item, bool Force);
  139. bool __fastcall ContinueParallelOperation();
  140. };
  141. //---------------------------------------------------------------------------
  142. class TQueueItem
  143. {
  144. friend class TTerminalQueue;
  145. friend class TTerminalItem;
  146. friend class TParallelTransferQueueItem;
  147. public:
  148. enum TStatus {
  149. qsPending, qsConnecting, qsProcessing, qsPrompt, qsQuery, qsError,
  150. qsPaused, qsDone };
  151. struct TInfo
  152. {
  153. TFileOperation Operation;
  154. TOperationSide Side;
  155. UnicodeString Source;
  156. UnicodeString Destination;
  157. UnicodeString ModifiedLocal;
  158. UnicodeString ModifiedRemote;
  159. bool SingleFile;
  160. bool Primary;
  161. void * GroupToken;
  162. };
  163. static bool __fastcall IsUserActionStatus(TStatus Status);
  164. __property TStatus Status = { read = GetStatus };
  165. __property HANDLE CompleteEvent = { read = FCompleteEvent, write = FCompleteEvent };
  166. protected:
  167. TStatus FStatus;
  168. TCriticalSection * FSection;
  169. TTerminalItem * FTerminalItem;
  170. TFileOperationProgressType * FProgressData;
  171. TQueueItem::TInfo * FInfo;
  172. TTerminalQueue * FQueue;
  173. HANDLE FCompleteEvent;
  174. long FCPSLimit;
  175. TDateTime FDoneAt;
  176. __fastcall TQueueItem();
  177. virtual __fastcall ~TQueueItem();
  178. void __fastcall SetStatus(TStatus Status);
  179. TStatus __fastcall GetStatus();
  180. void __fastcall Execute();
  181. virtual void __fastcall DoExecute(TTerminal * Terminal) = 0;
  182. void __fastcall SetProgress(TFileOperationProgressType & ProgressData);
  183. void __fastcall GetData(TQueueItemProxy * Proxy);
  184. virtual bool __fastcall UpdateFileList(TQueueFileList * FileList);
  185. void __fastcall SetCPSLimit(unsigned long CPSLimit);
  186. unsigned long __fastcall GetCPSLimit();
  187. virtual unsigned long __fastcall DefaultCPSLimit();
  188. virtual UnicodeString __fastcall StartupDirectory() const;
  189. virtual void __fastcall ProgressUpdated();
  190. virtual TQueueItem * __fastcall CreateParallelOperation();
  191. virtual bool __fastcall Complete();
  192. bool IsExecutionCancelled();
  193. };
  194. //---------------------------------------------------------------------------
  195. class TQueueItemProxy
  196. {
  197. friend class TQueueItem;
  198. friend class TTerminalQueueStatus;
  199. friend class TTerminalQueue;
  200. public:
  201. bool __fastcall Update();
  202. bool __fastcall UpdateFileList(TQueueFileList * FileList);
  203. bool __fastcall ProcessUserAction();
  204. bool __fastcall Move(bool Sooner);
  205. bool __fastcall Move(TQueueItemProxy * BeforeItem);
  206. bool __fastcall ExecuteNow();
  207. bool __fastcall Delete();
  208. bool __fastcall Pause();
  209. bool __fastcall Resume();
  210. bool __fastcall SetCPSLimit(unsigned long CPSLimit);
  211. bool __fastcall GetCPSLimit(unsigned long & CPSLimit);
  212. __property TFileOperationProgressType * ProgressData = { read = GetProgressData };
  213. __property __int64 TotalTransferred = { read = GetTotalTransferred };
  214. __property TQueueItem::TInfo * Info = { read = FInfo };
  215. __property TQueueItem::TStatus Status = { read = FStatus };
  216. __property bool ProcessingUserAction = { read = FProcessingUserAction };
  217. __property int Index = { read = GetIndex };
  218. // Clang warns on property backed by private field which is never used
  219. void * UserData;
  220. private:
  221. TFileOperationProgressType * FProgressData;
  222. TQueueItem::TStatus FStatus;
  223. TTerminalQueue * FQueue;
  224. TQueueItem * FQueueItem;
  225. TTerminalQueueStatus * FQueueStatus;
  226. TQueueItem::TInfo * FInfo;
  227. bool FProcessingUserAction;
  228. __fastcall TQueueItemProxy(TTerminalQueue * Queue, TQueueItem * QueueItem);
  229. virtual __fastcall ~TQueueItemProxy();
  230. int __fastcall GetIndex();
  231. TFileOperationProgressType * __fastcall GetProgressData();
  232. __int64 __fastcall GetTotalTransferred();
  233. };
  234. //---------------------------------------------------------------------------
  235. class TTerminalQueueStatus
  236. {
  237. friend class TTerminalQueue;
  238. friend class TQueueItemProxy;
  239. public:
  240. virtual __fastcall ~TTerminalQueueStatus();
  241. TQueueItemProxy * __fastcall FindByQueueItem(TQueueItem * QueueItem);
  242. __property int Count = { read = GetCount };
  243. __property int DoneCount = { read = FDoneCount };
  244. __property int ActiveCount = { read = GetActiveCount };
  245. __property int DoneAndActiveCount = { read = GetDoneAndActiveCount };
  246. __property int ActivePrimaryCount = { read = GetActivePrimaryCount };
  247. __property int ActiveAndPendingPrimaryCount = { read = GetActiveAndPendingPrimaryCount };
  248. __property TQueueItemProxy * Items[int Index] = { read = GetItem };
  249. bool __fastcall IsOnlyOneActiveAndNoPending();
  250. bool __fastcall UpdateFileList(TQueueItemProxy * ItemProxy, TQueueFileList * FileList);
  251. protected:
  252. __fastcall TTerminalQueueStatus();
  253. void __fastcall Add(TQueueItemProxy * ItemProxy);
  254. void __fastcall Delete(TQueueItemProxy * ItemProxy);
  255. void __fastcall ResetStats();
  256. void __fastcall NeedStats();
  257. private:
  258. TList * FList;
  259. int FDoneCount;
  260. int FActiveCount;
  261. int FActivePrimaryCount;
  262. int FActiveAndPendingPrimaryCount;
  263. int __fastcall GetCount();
  264. int __fastcall GetActiveCount();
  265. int __fastcall GetDoneAndActiveCount();
  266. int __fastcall GetActivePrimaryCount();
  267. int __fastcall GetActiveAndPendingPrimaryCount();
  268. void __fastcall SetDoneCount(int Value);
  269. TQueueItemProxy * __fastcall GetItem(int Index);
  270. };
  271. //---------------------------------------------------------------------------
  272. class TBootstrapQueueItem : public TQueueItem
  273. {
  274. public:
  275. __fastcall TBootstrapQueueItem();
  276. protected:
  277. virtual void __fastcall DoExecute(TTerminal * Terminal);
  278. virtual bool __fastcall Complete();
  279. };
  280. //---------------------------------------------------------------------------
  281. class TLocatedQueueItem : public TQueueItem
  282. {
  283. protected:
  284. __fastcall TLocatedQueueItem(TTerminal * Terminal);
  285. __fastcall TLocatedQueueItem(const TLocatedQueueItem & Source);
  286. virtual void __fastcall DoExecute(TTerminal * Terminal);
  287. virtual UnicodeString __fastcall StartupDirectory() const;
  288. private:
  289. UnicodeString FCurrentDir;
  290. };
  291. //---------------------------------------------------------------------------
  292. class TTransferQueueItem : public TLocatedQueueItem
  293. {
  294. public:
  295. __fastcall TTransferQueueItem(TTerminal * Terminal,
  296. TStrings * FilesToCopy, const UnicodeString & TargetDir,
  297. const TCopyParamType * CopyParam, int Params, TOperationSide Side,
  298. bool SingleFile, bool Parallel);
  299. virtual __fastcall ~TTransferQueueItem();
  300. protected:
  301. TStrings * FFilesToCopy;
  302. UnicodeString FTargetDir;
  303. TCopyParamType * FCopyParam;
  304. int FParams;
  305. bool FParallel;
  306. DWORD FLastParallelOperationAdded;
  307. std::unique_ptr<TParallelOperation> FParallelOperation;
  308. virtual unsigned long __fastcall DefaultCPSLimit();
  309. virtual void __fastcall DoExecute(TTerminal * Terminal);
  310. virtual void __fastcall DoTransferExecute(TTerminal * Terminal, TParallelOperation * ParallelOperation) = 0;
  311. virtual void __fastcall ProgressUpdated();
  312. virtual TQueueItem * __fastcall CreateParallelOperation();
  313. virtual bool __fastcall UpdateFileList(TQueueFileList * FileList);
  314. };
  315. //---------------------------------------------------------------------------
  316. class TUploadQueueItem : public TTransferQueueItem
  317. {
  318. public:
  319. __fastcall TUploadQueueItem(TTerminal * Terminal,
  320. TStrings * FilesToCopy, const UnicodeString & TargetDir,
  321. const TCopyParamType * CopyParam, int Params, bool Parallel);
  322. protected:
  323. virtual void __fastcall DoTransferExecute(TTerminal * Terminal, TParallelOperation * ParallelOperation);
  324. };
  325. //---------------------------------------------------------------------------
  326. class TDownloadQueueItem : public TTransferQueueItem
  327. {
  328. public:
  329. __fastcall TDownloadQueueItem(TTerminal * Terminal,
  330. TStrings * FilesToCopy, const UnicodeString & TargetDir,
  331. const TCopyParamType * CopyParam, int Params, bool Parallel);
  332. protected:
  333. virtual void __fastcall DoTransferExecute(TTerminal * Terminal, TParallelOperation * ParallelOperation);
  334. };
  335. //---------------------------------------------------------------------------
  336. class TRemoteDeleteQueueItem : public TLocatedQueueItem
  337. {
  338. public:
  339. TRemoteDeleteQueueItem(TTerminal * Terminal, TStrings * FilesToDelete, int Params);
  340. protected:
  341. virtual void __fastcall DoExecute(TTerminal * Terminal);
  342. private:
  343. std::unique_ptr<TStrings> FFilesToDelete;
  344. int FParams;
  345. };
  346. //---------------------------------------------------------------------------
  347. class TLocalDeleteQueueItem : public TQueueItem
  348. {
  349. public:
  350. TLocalDeleteQueueItem(TStrings * FilesToDelete, int Params);
  351. protected:
  352. virtual void __fastcall DoExecute(TTerminal * Terminal);
  353. private:
  354. std::unique_ptr<TStrings> FFilesToDelete;
  355. int FParams;
  356. };
  357. //---------------------------------------------------------------------------
  358. class TUserAction;
  359. class TInformationUserAction;
  360. enum TTerminalReopenResult { trrPending, trrSucceeded, trrFailed, trrNeedsInteraction };
  361. class TTerminalThread : public TSignalThread
  362. {
  363. public:
  364. __fastcall TTerminalThread(TTerminal * Terminal);
  365. virtual __fastcall ~TTerminalThread();
  366. void __fastcall TerminalOpen();
  367. void __fastcall TerminalReopen();
  368. void StartTerminalReopenNonInteractive();
  369. TTerminalReopenResult IsTerminalReopenComplete();
  370. void ContinueTerminalReopenInteractive();
  371. bool Abandoned();
  372. void __fastcall Cancel();
  373. bool __fastcall Release();
  374. void __fastcall Idle();
  375. __property TNotifyEvent OnIdle = { read = FOnIdle, write = FOnIdle };
  376. __property bool Cancelling = { read = FCancel };
  377. __property bool AllowAbandon = { read = FAllowAbandon, write = FAllowAbandon };
  378. protected:
  379. virtual void __fastcall ProcessEvent();
  380. virtual bool __fastcall Finished();
  381. private:
  382. TTerminal * FTerminal;
  383. TInformationEvent FOnInformation;
  384. TQueryUserEvent FOnQueryUser;
  385. TPromptUserEvent FOnPromptUser;
  386. TExtendedExceptionEvent FOnShowExtendedException;
  387. TDisplayBannerEvent FOnDisplayBanner;
  388. TNotifyEvent FOnChangeDirectory;
  389. TReadDirectoryEvent FOnReadDirectory;
  390. TNotifyEvent FOnStartReadDirectory;
  391. TReadDirectoryProgressEvent FOnReadDirectoryProgress;
  392. TNotifyEvent FOnInitializeLog;
  393. TNotifyEvent FOnIdle;
  394. TNotifyEvent FAction;
  395. HANDLE FActionEvent;
  396. TUserAction * FUserAction;
  397. Exception * FException;
  398. Exception * FIdleException;
  399. bool FCancel;
  400. TDateTime FCancelAfter;
  401. bool FAbandoned;
  402. bool FCancelled;
  403. bool FPendingIdle;
  404. bool FAllowAbandon;
  405. bool FNonInteractive;
  406. bool FNeedsInteraction;
  407. typedef std::list<TInformationUserAction *> TInformationList;
  408. TInformationList FNonInteractiveInformation;
  409. DWORD FMainThread;
  410. TCriticalSection * FSection;
  411. void __fastcall WaitForUserAction(TUserAction * UserAction);
  412. void StartAction(TNotifyEvent Action);
  413. void RunAction(TNotifyEvent Action);
  414. static void __fastcall SaveException(Exception & E, Exception *& Exception);
  415. static void __fastcall Rethrow(Exception *& Exception);
  416. void __fastcall FatalAbort();
  417. void __fastcall CheckCancel();
  418. void __fastcall TerminalOpenEvent(TObject * Sender);
  419. void __fastcall TerminalReopenEvent(TObject * Sender);
  420. void __fastcall TerminalInformation(
  421. TTerminal * Terminal, const UnicodeString & Str, int Phase, const UnicodeString & Additional);
  422. void __fastcall TerminalQueryUser(TObject * Sender,
  423. const UnicodeString Query, TStrings * MoreMessages, unsigned int Answers,
  424. const TQueryParams * Params, unsigned int & Answer, TQueryType Type, void * Arg);
  425. void __fastcall TerminalPromptUser(TTerminal * Terminal, TPromptKind Kind,
  426. UnicodeString Name, UnicodeString Instructions,
  427. TStrings * Prompts, TStrings * Results, bool & Result, void * Arg);
  428. void __fastcall TerminalShowExtendedException(TTerminal * Terminal,
  429. Exception * E, void * Arg);
  430. void __fastcall TerminalDisplayBanner(TTerminal * Terminal,
  431. UnicodeString SessionName, const UnicodeString & Banner,
  432. bool & NeverShowAgain, int Options, unsigned int & Params);
  433. void __fastcall TerminalChangeDirectory(TObject * Sender);
  434. void __fastcall TerminalReadDirectory(TObject * Sender, Boolean ReloadOnly);
  435. void __fastcall TerminalStartReadDirectory(TObject * Sender);
  436. void __fastcall TerminalReadDirectoryProgress(TObject * Sender, int Progress, int ResolvedLinks, bool & Cancel);
  437. void __fastcall TerminalInitializeLog(TObject * Sender);
  438. void DiscardException();
  439. bool WaitForActionEvent(unsigned int Wait);
  440. void CompleteAction();
  441. void NeedsInteraction();
  442. };
  443. //---------------------------------------------------------------------------
  444. enum TQueueFileState { qfsQueued = 0, qfsProcessed = 1 };
  445. //---------------------------------------------------------------------------
  446. class TQueueFileList
  447. {
  448. friend class TParallelOperation;
  449. public:
  450. TQueueFileList();
  451. void Clear();
  452. void Add(const UnicodeString & FileName, int State);
  453. UnicodeString GetFileName(int Index) const;
  454. int GetState(int Index) const;
  455. void SetState(int Index, int State);
  456. int GetCount() const;
  457. private:
  458. std::unique_ptr<TStrings> FList;
  459. TParallelOperation * FLastParallelOperation;
  460. int FLastParallelOperationVersion;
  461. };
  462. //---------------------------------------------------------------------------
  463. #endif