1 /*=============================================================================
\r
5 ===============================================================================
\r
6 / Copyright (C) 1997-2007 Sota. All rights reserved.
\r
8 / Redistribution and use in source and binary forms, with or without
\r
9 / modification, are permitted provided that the following conditions
\r
12 / 1. Redistributions of source code must retain the above copyright
\r
13 / notice, this list of conditions and the following disclaimer.
\r
14 / 2. Redistributions in binary form must reproduce the above copyright
\r
15 / notice, this list of conditions and the following disclaimer in the
\r
16 / documentation and/or other materials provided with the distribution.
\r
18 / THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
\r
19 / IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
\r
20 / OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
\r
21 / IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
\r
22 / INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
\r
23 / BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
\r
24 / USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
\r
25 / ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
\r
26 / (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
\r
27 / THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
\r
28 /============================================================================*/
\r
32 #include <winsock2.h>
\r
33 #include <windows.h>
\r
37 #include <mbstring.h>
\r
38 #include <windowsx.h>
\r
39 #include <commctrl.h>
\r
42 #include "resource.h"
\r
44 #include <htmlhelp.h>
\r
48 #undef __MBSWRAPPER_H__
\r
49 #include "mbswrapper.h"
\r
52 /*===== プロトタイプ =====*/
\r
54 static int CheckRemoteFile(TRANSPACKET *Pkt, FILELIST *ListList);
\r
56 //static BOOL CALLBACK UpExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
57 static INT_PTR CALLBACK UpExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
59 static void DispMirrorFiles(FILELIST *Local, FILELIST *Remote);
\r
60 static void MirrorDeleteAllLocalDir(FILELIST *Local, TRANSPACKET *Pkt, TRANSPACKET **Base);
\r
61 static int CheckLocalFile(TRANSPACKET *Pkt);
\r
63 //static BOOL CALLBACK DownExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
64 static INT_PTR CALLBACK DownExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
65 static void RemoveAfterSemicolon(char *Path);
\r
66 static void MirrorDeleteAllDir(FILELIST *Remote, TRANSPACKET *Pkt, TRANSPACKET **Base);
\r
68 //static BOOL CALLBACK MirrorNotifyCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
69 //static BOOL CALLBACK MirrorDispListCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
70 static INT_PTR CALLBACK MirrorNotifyCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
71 static INT_PTR CALLBACK MirrorDispListCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
72 static void CountMirrorFiles(HWND hDlg, TRANSPACKET *Pkt);
\r
73 static int AskMirrorNoTrn(char *Fname, int Mode);
\r
74 static int AskUploadFileAttr(char *Fname);
\r
76 //static BOOL CALLBACK UpDownAsDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
77 static INT_PTR CALLBACK UpDownAsDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
78 #if defined(HAVE_TANDEM)
\r
79 static INT_PTR CALLBACK UpDownAsWithExtDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
81 static void DeleteAllDir(FILELIST *Dt, int Win, int *Sw, int *Flg, char *CurDir);
\r
82 static void DelNotifyAndDo(FILELIST *Dt, int Win, int *Sw, int *Flg, char *CurDir);
\r
84 //static BOOL CALLBACK DeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
85 //static BOOL CALLBACK RenameDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
86 static INT_PTR CALLBACK DeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
87 static INT_PTR CALLBACK RenameDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
88 static void SetAttrToDialog(HWND hWnd, int Attr);
\r
89 static int GetAttrFromDialog(HWND hDlg);
\r
90 static LRESULT CALLBACK SizeNotifyDlgWndProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam);
\r
91 static LRESULT CALLBACK SizeDlgWndProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam);
\r
92 static int RenameUnuseableName(char *Fname);
\r
96 extern HWND hHelpWin;
\r
99 extern int FnameCnv;
\r
100 extern int RecvMode;
\r
101 extern int SendMode;
\r
102 extern int MoveMode;
\r
103 extern char MirrorNoTrn[MIRROR_LEN+1];
\r
104 extern char MirrorNoDel[MIRROR_LEN+1];
\r
105 extern int MirrorFnameCnv;
\r
106 extern char DefAttrList[DEFATTRLIST_LEN+1];
\r
107 extern SIZE MirrorDlgSize;
\r
108 extern int VaxSemicolon;
\r
109 extern int DebugConsole;
\r
110 extern int CancelFlg;
\r
112 extern int MakeAllDir;
\r
114 extern int AbortOnListError;
\r
116 extern int MirrorNoTransferContents;
\r
118 /*===== ローカルなワーク =====*/
\r
120 static char TmpString[FMAX_PATH+80]; /* テンポラリ */
\r
121 #if defined(HAVE_TANDEM)
\r
122 static char TmpFileCode[5]; /* テンポラリ */
\r
124 static int CurWin; /* ウインドウ番号 */
\r
126 int UpExistMode = EXIST_OVW; /* アップロードで同じ名前のファイルがある時の扱い方 EXIST_xxx */
\r
127 int ExistMode = EXIST_OVW; /* 同じ名前のファイルがある時の扱い方 EXIST_xxx */
\r
128 static int ExistNotify; /* 確認ダイアログを出すかどうか YES/NO */
\r
130 static double FileSize; /* ファイル総容量 */
\r
134 /*----- ファイル一覧で指定されたファイルをダウンロードする --------------------
\r
137 * int ChName : 名前を変えるかどうか (YES/NO)
\r
138 * int ForceFile : ディレクトリをファイル見なすかどうか (YES/NO)
\r
139 * int All : 全てが選ばれている物として扱うかどうか (YES/NO)
\r
143 *----------------------------------------------------------------------------*/
\r
146 // ローカル側のパスから必要なフォルダを作成
\r
147 int MakeDirFromLocalPath(char* LocalFile, char* Old)
\r
155 pDelimiter = LocalFile;
\r
157 while(pNext = strchr(pDelimiter, '\\'))
\r
159 Len = pNext - LocalFile;
\r
160 strncpy(Pkt.LocalFile, LocalFile, Len);
\r
161 Pkt.LocalFile[Len] = '\0';
\r
162 if(strncmp(LocalFile, Old, Len + 1) != 0)
\r
164 Cat = Pkt.LocalFile + (pDelimiter - LocalFile);
\r
165 if(FnameCnv == FNAME_LOWER)
\r
167 else if(FnameCnv == FNAME_UPPER)
\r
169 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
171 strcpy(Pkt.Cmd, "MKD ");
\r
172 strcpy(Pkt.RemoteFile, "");
\r
173 AddTransFileList(&Pkt);
\r
177 pDelimiter = pNext + 1;
\r
182 void DownloadProc(int ChName, int ForceFile, int All)
\r
184 FILELIST *FileListBase;
\r
188 char Tmp[FMAX_PATH+1];
\r
195 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
200 // KeepTransferDialog(YES);
\r
202 FileListBase = NULL;
\r
204 // MakeSelectedFileList(WIN_REMOTE, (ForceFile == YES ? NO : YES), All, &FileListBase, &CancelFlg);
\r
205 ListSts = MakeSelectedFileList(WIN_REMOTE, (ForceFile == YES ? NO : YES), All, &FileListBase, &CancelFlg);
\r
207 if(AskNoFullPathMode() == YES)
\r
209 strcpy(Pkt.Cmd, "SETCUR");
\r
210 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
211 AddTransFileList(&Pkt);
\r
214 Pos = FileListBase;
\r
218 if((AbortOnListError == YES) && (ListSts == FFFTP_FAIL))
\r
220 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
221 SetYenTail(Pkt.LocalFile);
\r
222 strcpy(TmpString, Pos->File);
\r
223 if((ChName == NO) || ((ForceFile == NO) && (Pos->Node == NODE_DIR)))
\r
225 if(FnameCnv == FNAME_LOWER)
\r
226 _mbslwr(TmpString);
\r
227 else if(FnameCnv == FNAME_UPPER)
\r
228 _mbsupr(TmpString);
\r
229 RemoveAfterSemicolon(TmpString);
\r
230 if(RenameUnuseableName(TmpString) == FFFTP_FAIL)
\r
235 CurWin = WIN_REMOTE;
\r
236 if(DialogBox(GetFtpInst(), MAKEINTRESOURCE(updown_as_dlg), GetMainHwnd(), UpDownAsDialogCallBack) == YES)
\r
238 if(RenameUnuseableName(TmpString) == FFFTP_FAIL)
\r
244 strcat(Pkt.LocalFile, TmpString);
\r
245 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
247 if((ForceFile == NO) && (Pos->Node == NODE_DIR))
\r
249 strcpy(Pkt.Cmd, "MKD ");
\r
250 strcpy(Pkt.RemoteFile, "");
\r
251 AddTransFileList(&Pkt);
\r
253 else if((Pos->Node == NODE_FILE) ||
\r
254 ((ForceFile == YES) && (Pos->Node == NODE_DIR)))
\r
256 if(AskHostType() == HTYPE_ACOS)
\r
258 strcpy(Pkt.RemoteFile, "'");
\r
259 strcat(Pkt.RemoteFile, AskHostLsName());
\r
260 strcat(Pkt.RemoteFile, "(");
\r
261 strcat(Pkt.RemoteFile, Pos->File);
\r
262 strcat(Pkt.RemoteFile, ")");
\r
263 strcat(Pkt.RemoteFile, "'");
\r
265 else if(AskHostType() == HTYPE_ACOS_4)
\r
267 strcpy(Pkt.RemoteFile, Pos->File);
\r
271 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
272 SetSlashTail(Pkt.RemoteFile);
\r
273 strcat(Pkt.RemoteFile, Pos->File);
\r
274 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
277 strcpy(Pkt.Cmd, "RETR ");
\r
278 #if defined(HAVE_TANDEM)
\r
279 if(AskHostType() == HTYPE_TANDEM) {
\r
280 if(AskTransferType() != TYPE_X) {
\r
281 Pkt.Type = AskTransferType();
\r
283 Pkt.Attr = Pos->Attr;
\r
284 if (Pkt.Attr == 101)
\r
291 Pkt.Type = AskTransferTypeAssoc(Pkt.RemoteFile, AskTransferType());
\r
292 Pkt.Size = Pos->Size;
\r
293 Pkt.Time = Pos->Time;
\r
294 Pkt.KanjiCode = AskHostKanjiCode();
\r
296 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
297 Pkt.KanaCnv = AskHostKanaCnv();
\r
300 strcpy(Tmp, Pkt.LocalFile);
\r
301 Pkt.Mode = CheckLocalFile(&Pkt); /* Pkt.ExistSize がセットされる */
\r
303 Pkt.NoTransfer = NO;
\r
304 if(Pkt.Mode == EXIST_ABORT)
\r
306 else if(Pkt.Mode != EXIST_IGNORE)
\r
308 // AddTransFileList(&Pkt);
\r
310 if(MakeAllDir == YES)
\r
311 MakeDirFromLocalPath(Pkt.LocalFile, Tmp);
\r
312 AddTransFileList(&Pkt);
\r
318 if(AskNoFullPathMode() == YES)
\r
320 strcpy(Pkt.Cmd, "BACKCUR");
\r
321 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
322 AddTransFileList(&Pkt);
\r
324 DeleteFileList(&FileListBase);
\r
327 // strcpy(Pkt.Cmd, "GOQUIT");
\r
328 // AddTransFileList(&Pkt);
\r
331 AddNullTransFileList();
\r
333 GoForwardTransWindow();
\r
334 // KeepTransferDialog(NO);
\r
342 /*----- 指定されたファイルを一つダウンロードする ------------------------------
\r
345 * char *Fname : ファイル名
\r
349 *----------------------------------------------------------------------------*/
\r
351 void DirectDownloadProc(char *Fname)
\r
355 char Tmp[FMAX_PATH+1];
\r
360 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
365 // KeepTransferDialog(YES);
\r
367 if(AskNoFullPathMode() == YES)
\r
369 strcpy(Pkt.Cmd, "SETCUR");
\r
370 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
371 AddTransFileList(&Pkt);
\r
374 if(strlen(Fname) > 0)
\r
376 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
377 SetYenTail(Pkt.LocalFile);
\r
378 strcpy(TmpString, Fname);
\r
379 if(FnameCnv == FNAME_LOWER)
\r
380 _mbslwr(TmpString);
\r
381 else if(FnameCnv == FNAME_UPPER)
\r
382 _mbsupr(TmpString);
\r
383 RemoveAfterSemicolon(TmpString);
\r
385 if(RenameUnuseableName(TmpString) == FFFTP_SUCCESS)
\r
387 strcat(Pkt.LocalFile, TmpString);
\r
388 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
390 if(AskHostType() == HTYPE_ACOS)
\r
392 strcpy(Pkt.RemoteFile, "'");
\r
393 strcat(Pkt.RemoteFile, AskHostLsName());
\r
394 strcat(Pkt.RemoteFile, "(");
\r
395 strcat(Pkt.RemoteFile, Fname);
\r
396 strcat(Pkt.RemoteFile, ")");
\r
397 strcat(Pkt.RemoteFile, "'");
\r
399 else if(AskHostType() == HTYPE_ACOS_4)
\r
401 strcpy(Pkt.RemoteFile, Fname);
\r
405 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
406 SetSlashTail(Pkt.RemoteFile);
\r
407 strcat(Pkt.RemoteFile, Fname);
\r
408 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
411 strcpy(Pkt.Cmd, "RETR-S ");
\r
412 Pkt.Type = AskTransferTypeAssoc(Pkt.RemoteFile, AskTransferType());
\r
414 /* サイズと日付は転送側スレッドで取得し、セットする */
\r
416 Pkt.KanjiCode = AskHostKanjiCode();
\r
418 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
419 Pkt.KanaCnv = AskHostKanaCnv();
\r
422 strcpy(Tmp, Pkt.LocalFile);
\r
423 Pkt.Mode = CheckLocalFile(&Pkt); /* Pkt.ExistSize がセットされる */
\r
425 Pkt.NoTransfer = NO;
\r
426 if((Pkt.Mode != EXIST_ABORT) && (Pkt.Mode != EXIST_IGNORE))
\r
428 // AddTransFileList(&Pkt);
\r
430 if(MakeAllDir == YES)
\r
431 MakeDirFromLocalPath(Pkt.LocalFile, Tmp);
\r
432 AddTransFileList(&Pkt);
\r
437 if(AskNoFullPathMode() == YES)
\r
439 strcpy(Pkt.Cmd, "BACKCUR");
\r
440 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
441 AddTransFileList(&Pkt);
\r
445 // strcpy(Pkt.Cmd, "GOQUIT");
\r
446 // AddTransFileList(&Pkt);
\r
449 AddNullTransFileList();
\r
451 GoForwardTransWindow();
\r
452 // KeepTransferDialog(NO);
\r
460 /*----- 入力されたファイル名のファイルを一つダウンロードする ------------------
\r
467 *----------------------------------------------------------------------------*/
\r
469 void InputDownloadProc(void)
\r
471 char Path[FMAX_PATH+1];
\r
474 // DisableUserOpe();
\r
477 if(InputDialogBox(downname_dlg, GetMainHwnd(), NULL, Path, FMAX_PATH, &Tmp, IDH_HELP_TOPIC_0000001) == YES)
\r
479 DirectDownloadProc(Path);
\r
482 // EnableUserOpe();
\r
488 /*----- ミラーリングダウンロードを行う ----------------------------------------
\r
491 * int Notify : 確認を行うかどうか (YES/NO)
\r
495 *----------------------------------------------------------------------------*/
\r
497 void MirrorDownloadProc(int Notify)
\r
499 FILELIST *LocalListBase;
\r
500 FILELIST *RemoteListBase;
\r
501 FILELIST *LocalPos;
\r
502 FILELIST *RemotePos;
\r
505 char Name[FMAX_PATH+1];
\r
515 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
522 Notify = DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(mirror_down_dlg), GetMainHwnd(), MirrorNotifyCallBack, 0);
\r
526 if((Notify == YES) || (Notify == YES_LIST))
\r
528 /*===== ファイルリスト取得 =====*/
\r
530 LocalListBase = NULL;
\r
532 // MakeSelectedFileList(WIN_LOCAL, YES, YES, &LocalListBase, &CancelFlg);
\r
533 ListSts = MakeSelectedFileList(WIN_LOCAL, YES, YES, &LocalListBase, &CancelFlg);
\r
534 RemoteListBase = NULL;
\r
536 // MakeSelectedFileList(WIN_REMOTE, YES, YES, &RemoteListBase, &CancelFlg);
\r
537 if(ListSts == FFFTP_SUCCESS)
\r
538 ListSts = MakeSelectedFileList(WIN_REMOTE, YES, YES, &RemoteListBase, &CancelFlg);
\r
540 RemotePos = RemoteListBase;
\r
541 while(RemotePos != NULL)
\r
543 RemotePos->Attr = YES; /* RemotePos->Attrは転送するかどうかのフラグに使用 (YES/NO) */
\r
544 RemotePos = RemotePos->Next;
\r
547 LocalPos = LocalListBase;
\r
548 while(LocalPos != NULL)
\r
550 if(AskMirrorNoTrn(LocalPos->File, 1) == NO)
\r
552 LocalPos->Attr = YES;
\r
553 LocalPos = LocalPos->Next;
\r
557 LocalPos->Attr = NO; /* LocalPos->Attrは削除するかどうかのフラグに使用 (YES/NO) */
\r
559 if(LocalPos->Node == NODE_DIR)
\r
561 Level = AskDirLevel(LocalPos->File);
\r
562 LocalPos = LocalPos->Next;
\r
563 while(LocalPos != NULL)
\r
565 if((LocalPos->Node == NODE_DIR) &&
\r
566 (AskDirLevel(LocalPos->File) <= Level))
\r
570 LocalPos->Attr = NO;
\r
571 LocalPos = LocalPos->Next;
\r
575 LocalPos = LocalPos->Next;
\r
579 /*===== ファイルリスト比較 =====*/
\r
581 RemotePos = RemoteListBase;
\r
582 while(RemotePos != NULL)
\r
584 if(AskMirrorNoTrn(RemotePos->File, 0) == NO)
\r
586 strcpy(Name, RemotePos->File);
\r
587 // ReplaceAll(Name, '/', '\\');
\r
589 if(MirrorFnameCnv == YES)
\r
590 Mode = COMP_LOWERMATCH;
\r
592 Mode = COMP_STRICT;
\r
594 if((LocalPos = SearchFileList(Name, LocalListBase, Mode)) != NULL)
\r
596 if((RemotePos->Node == NODE_DIR) && (LocalPos->Node == NODE_DIR))
\r
598 LocalPos->Attr = NO;
\r
599 RemotePos->Attr = NO;
\r
601 else if((RemotePos->Node == NODE_FILE) && (LocalPos->Node == NODE_FILE))
\r
603 LocalPos->Attr = NO;
\r
604 if(CompareFileTime(&RemotePos->Time, &LocalPos->Time) <= 0)
\r
605 RemotePos->Attr = NO;
\r
608 RemotePos = RemotePos->Next;
\r
612 if(RemotePos->Node == NODE_FILE)
\r
614 RemotePos->Attr = NO;
\r
615 RemotePos = RemotePos->Next;
\r
619 RemotePos->Attr = NO;
\r
620 Level = AskDirLevel(RemotePos->File);
\r
621 RemotePos = RemotePos->Next;
\r
622 while(RemotePos != NULL)
\r
624 if((RemotePos->Node == NODE_DIR) &&
\r
625 (AskDirLevel(RemotePos->File) <= Level))
\r
629 RemotePos->Attr = NO;
\r
630 RemotePos = RemotePos->Next;
\r
636 DispMirrorFiles(LocalListBase, RemoteListBase);
\r
638 /*===== 削除/アップロード =====*/
\r
640 LocalPos = LocalListBase;
\r
641 while(LocalPos != NULL)
\r
643 if((LocalPos->Attr == YES) && (LocalPos->Node == NODE_FILE))
\r
645 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
646 SetYenTail(Pkt.LocalFile);
\r
647 strcat(Pkt.LocalFile, LocalPos->File);
\r
648 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
649 strcpy(Pkt.RemoteFile, "");
\r
650 strcpy(Pkt.Cmd, "L-DELE ");
\r
651 AddTmpTransFileList(&Pkt, &Base);
\r
653 LocalPos = LocalPos->Next;
\r
655 MirrorDeleteAllLocalDir(LocalListBase, &Pkt, &Base);
\r
658 RemotePos = RemoteListBase;
\r
659 while(RemotePos != NULL)
\r
661 if(RemotePos->Attr == YES)
\r
663 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
664 SetYenTail(Pkt.LocalFile);
\r
665 Cat = strchr(Pkt.LocalFile, NUL);
\r
666 strcat(Pkt.LocalFile, RemotePos->File);
\r
668 if(MirrorFnameCnv == YES)
\r
671 RemoveAfterSemicolon(Cat);
\r
672 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
674 if(RemotePos->Node == NODE_DIR)
\r
676 strcpy(Pkt.RemoteFile, "");
\r
677 strcpy(Pkt.Cmd, "L-MKD ");
\r
678 AddTmpTransFileList(&Pkt, &Base);
\r
680 else if(RemotePos->Node == NODE_FILE)
\r
682 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
683 SetSlashTail(Pkt.RemoteFile);
\r
684 strcat(Pkt.RemoteFile, RemotePos->File);
\r
685 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
687 strcpy(Pkt.Cmd, "RETR ");
\r
688 Pkt.Type = AskTransferTypeAssoc(Pkt.RemoteFile, AskTransferType());
\r
689 Pkt.Size = RemotePos->Size;
\r
690 Pkt.Time = RemotePos->Time;
\r
692 Pkt.KanjiCode = AskHostKanjiCode();
\r
694 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
695 Pkt.KanaCnv = AskHostKanaCnv();
\r
696 Pkt.Mode = EXIST_OVW;
\r
698 Pkt.NoTransfer = MirrorNoTransferContents;
\r
699 AddTmpTransFileList(&Pkt, &Base);
\r
702 RemotePos = RemotePos->Next;
\r
706 // if((Notify == YES) ||
\r
707 // (DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(mirrordown_notify_dlg), GetMainHwnd(), MirrorDispListCallBack, (LPARAM)&Base) == YES))
\r
708 if(((AbortOnListError == NO) || (ListSts == FFFTP_SUCCESS)) && ((Notify == YES) ||
\r
709 (DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(mirrordown_notify_dlg), GetMainHwnd(), MirrorDispListCallBack, (LPARAM)&Base) == YES)))
\r
711 if(AskNoFullPathMode() == YES)
\r
713 strcpy(Pkt.Cmd, "SETCUR");
\r
714 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
715 AddTransFileList(&Pkt);
\r
717 AppendTransFileList(Base);
\r
719 if(AskNoFullPathMode() == YES)
\r
721 strcpy(Pkt.Cmd, "BACKCUR");
\r
722 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
723 AddTransFileList(&Pkt);
\r
727 // strcpy(Pkt.Cmd, "GOQUIT");
\r
728 // AddTransFileList(&Pkt);
\r
731 EraseTmpTransFileList(&Base);
\r
734 AddNullTransFileList();
\r
736 DeleteFileList(&LocalListBase);
\r
737 DeleteFileList(&RemoteListBase);
\r
739 GoForwardTransWindow();
\r
748 /*----- ミラーリングのファイル一覧を表示 --------------------------------------
\r
751 * FILELIST *Local : ローカル側
\r
752 * FILELIST *Remote : リモート側
\r
756 *----------------------------------------------------------------------------*/
\r
758 static void DispMirrorFiles(FILELIST *Local, FILELIST *Remote)
\r
764 if(DebugConsole == YES)
\r
766 DoPrintf("---- MIRROR FILE LIST ----");
\r
767 while(Local != NULL)
\r
769 FileTimeToLocalFileTime(&Local->Time, &fTime);
\r
770 FileTimeToSystemTime(&fTime, &sTime);
\r
771 sprintf(Date, "%04d/%02d/%02d %02d:%02d:%02d.%04d",
\r
772 sTime.wYear, sTime.wMonth, sTime.wDay, sTime.wHour, sTime.wMinute, sTime.wSecond, sTime.wMilliseconds);
\r
773 DoPrintf("LOCAL : %s %s [%s] %s", Local->Attr==1?"YES":"NO ", Local->Node==NODE_DIR?"DIR ":"FILE", Date, Local->File);
\r
774 Local = Local->Next;
\r
776 while(Remote != NULL)
\r
778 FileTimeToLocalFileTime(&Remote->Time, &fTime);
\r
779 FileTimeToSystemTime(&fTime, &sTime);
\r
780 sprintf(Date, "%04d/%02d/%02d %02d:%02d:%02d.%04d",
\r
781 sTime.wYear, sTime.wMonth, sTime.wDay, sTime.wHour, sTime.wMinute, sTime.wSecond, sTime.wMilliseconds);
\r
782 DoPrintf("REMOTE : %s %s [%s] %s", Remote->Attr==1?"YES":"NO ", Remote->Node==NODE_DIR?"DIR ":"FILE", Date, Remote->File);
\r
783 Remote = Remote->Next;
\r
785 DoPrintf("---- END ----");
\r
791 /*----- ミラーリング時のローカル側のフォルダ削除 ------------------------------
\r
794 * FILELIST *Local : ファイルリスト
\r
795 * TRANSPACKET *Pkt :
\r
796 * TRANSPACKET **Base :
\r
800 *----------------------------------------------------------------------------*/
\r
802 static void MirrorDeleteAllLocalDir(FILELIST *Local, TRANSPACKET *Pkt, TRANSPACKET **Base)
\r
804 while(Local != NULL)
\r
806 if(Local->Node == NODE_DIR)
\r
808 MirrorDeleteAllLocalDir(Local->Next, Pkt, Base);
\r
810 if(Local->Attr == YES)
\r
812 AskLocalCurDir(Pkt->LocalFile, FMAX_PATH);
\r
813 SetYenTail(Pkt->LocalFile);
\r
814 strcat(Pkt->LocalFile, Local->File);
\r
815 ReplaceAll(Pkt->LocalFile, '/', '\\');
\r
816 strcpy(Pkt->RemoteFile, "");
\r
817 strcpy(Pkt->Cmd, "L-RMD ");
\r
818 AddTmpTransFileList(Pkt, Base);
\r
822 Local = Local->Next;
\r
828 /*----- ファイル名のセミコロン以降を取り除く ----------------------------------
\r
831 * char *Path : ファイル名
\r
838 * オプション設定によって処理を切替える
\r
839 *----------------------------------------------------------------------------*/
\r
841 static void RemoveAfterSemicolon(char *Path)
\r
845 if(VaxSemicolon == YES)
\r
847 if((Pos = strchr(Path, ';')) != NULL)
\r
854 /*----- ローカルに同じ名前のファイルがないかチェック --------------------------
\r
857 * TRANSPACKET *Pkt : 転送ファイル情報
\r
861 * EXIST_OVW/EXIST_RESUME/EXIST_IGNORE
\r
864 * Pkt.ExistSize, ExistMode、ExistNotify が変更される
\r
865 *----------------------------------------------------------------------------*/
\r
867 static int CheckLocalFile(TRANSPACKET *Pkt)
\r
870 WIN32_FIND_DATA Find;
\r
874 Pkt->ExistSize = 0;
\r
875 if(RecvMode != TRANS_OVW)
\r
877 if((fHnd = FindFirstFile(Pkt->LocalFile, &Find)) != INVALID_HANDLE_VALUE)
\r
881 Pkt->ExistSize = MakeLongLong(Find.nFileSizeHigh, Find.nFileSizeLow);
\r
883 if(ExistNotify == YES)
\r
885 SoundPlay(SND_ERROR);
\r
886 if(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(down_exist_dlg), GetMainHwnd(), DownExistDialogCallBack, (LPARAM)Pkt) == NO)
\r
894 if(Ret == EXIST_NEW)
\r
897 if(CompareFileTime(&Find.ftLastWriteTime, &Pkt->Time) < 0)
\r
900 Ret = EXIST_IGNORE;
\r
902 // 同じ名前のファイルの処理方法追加
\r
903 if(Ret == EXIST_LARGE)
\r
905 if(MakeLongLong(Find.nFileSizeHigh, Find.nFileSizeLow) < Pkt->Size)
\r
908 Ret = EXIST_IGNORE;
\r
916 /*----- ローカルに同じ名前のファイルがある時の確認ダイアログのコールバック ----
\r
919 * HWND hDlg : ウインドウハンドル
\r
920 * UINT message : メッセージ番号
\r
921 * WPARAM wParam : メッセージの WPARAM 引数
\r
922 * LPARAM lParam : メッセージの LPARAM 引数
\r
926 *----------------------------------------------------------------------------*/
\r
929 //static BOOL CALLBACK DownExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
930 static INT_PTR CALLBACK DownExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
932 static TRANSPACKET *Pkt;
\r
933 // 同じ名前のファイルの処理方法追加
\r
934 // static const RADIOBUTTON DownExistButton[] = {
\r
935 // { DOWN_EXIST_OVW, EXIST_OVW },
\r
936 // { DOWN_EXIST_NEW, EXIST_NEW },
\r
937 // { DOWN_EXIST_RESUME, EXIST_RESUME },
\r
938 // { DOWN_EXIST_IGNORE, EXIST_IGNORE }
\r
940 static const RADIOBUTTON DownExistButton[] = {
\r
941 { DOWN_EXIST_OVW, EXIST_OVW },
\r
942 { DOWN_EXIST_NEW, EXIST_NEW },
\r
943 { DOWN_EXIST_RESUME, EXIST_RESUME },
\r
944 { DOWN_EXIST_IGNORE, EXIST_IGNORE },
\r
945 { DOWN_EXIST_LARGE, EXIST_LARGE }
\r
947 #define DOWNEXISTBUTTONS (sizeof(DownExistButton)/sizeof(RADIOBUTTON))
\r
951 case WM_INITDIALOG :
\r
952 Pkt = (TRANSPACKET *)lParam;
\r
953 SendDlgItemMessage(hDlg, DOWN_EXIST_NAME, EM_LIMITTEXT, FMAX_PATH, 0);
\r
954 SendDlgItemMessage(hDlg, DOWN_EXIST_NAME, WM_SETTEXT, 0, (LPARAM)Pkt->LocalFile);
\r
956 if((Pkt->Type == TYPE_A) || (Pkt->ExistSize <= 0))
\r
957 EnableWindow(GetDlgItem(hDlg, DOWN_EXIST_RESUME), FALSE);
\r
959 SetRadioButtonByValue(hDlg, ExistMode, DownExistButton, DOWNEXISTBUTTONS);
\r
963 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
967 /* ここに break はない */
\r
970 ExistMode = AskRadioButtonValue(hDlg, DownExistButton, DOWNEXISTBUTTONS);
\r
971 SendDlgItemMessage(hDlg, DOWN_EXIST_NAME, WM_GETTEXT, FMAX_PATH, (LPARAM)Pkt->LocalFile);
\r
972 EndDialog(hDlg, YES);
\r
976 // ExistMode = EXIST_ABORT;
\r
977 EndDialog(hDlg, NO);
\r
981 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000009);
\r
994 /*----- ファイル一覧で指定されたファイルをアップロードする --------------------
\r
997 * int ChName : 名前を変えるかどうか (YES/NO)
\r
998 * int All : 全てが選ばれている物として扱うかどうか (YES/NO)
\r
1002 *----------------------------------------------------------------------------*/
\r
1005 // リモート側のパスから必要なディレクトリを作成
\r
1006 int MakeDirFromRemotePath(char* RemoteFile, char* Old, int FirstAdd)
\r
1015 pDelimiter = RemoteFile;
\r
1017 while(pNext = strchr(pDelimiter, '/'))
\r
1019 Len = pNext - RemoteFile;
\r
1020 strncpy(Pkt.RemoteFile, RemoteFile, Len);
\r
1021 Pkt.RemoteFile[Len] = '\0';
\r
1022 if(strncmp(RemoteFile, Old, Len + 1) != 0)
\r
1024 Cat = Pkt.RemoteFile + (pDelimiter - RemoteFile);
\r
1025 if(FnameCnv == FNAME_LOWER)
\r
1027 else if(FnameCnv == FNAME_UPPER)
\r
1029 #if defined(HAVE_TANDEM)
\r
1031 Pkt.PriExt = DEF_PRIEXT;
\r
1032 Pkt.SecExt = DEF_SECEXT;
\r
1033 Pkt.MaxExt = DEF_MAXEXT;
\r
1035 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
1037 if(AskHostType() == HTYPE_ACOS)
\r
1039 strcpy(Pkt.RemoteFile, "'");
\r
1040 strcat(Pkt.RemoteFile, AskHostLsName());
\r
1041 strcat(Pkt.RemoteFile, "(");
\r
1042 strcat(Pkt.RemoteFile, Cat);
\r
1043 strcat(Pkt.RemoteFile, ")");
\r
1044 strcat(Pkt.RemoteFile, "'");
\r
1046 else if(AskHostType() == HTYPE_ACOS_4)
\r
1047 strcpy(Pkt.RemoteFile, Cat);
\r
1049 if((FirstAdd == YES) && (AskNoFullPathMode() == YES))
\r
1051 strcpy(Pkt1.Cmd, "SETCUR");
\r
1052 AskRemoteCurDir(Pkt1.RemoteFile, FMAX_PATH);
\r
1053 AddTransFileList(&Pkt1);
\r
1056 strcpy(Pkt.Cmd, "MKD ");
\r
1057 strcpy(Pkt.LocalFile, "");
\r
1058 AddTransFileList(&Pkt);
\r
1062 pDelimiter = pNext + 1;
\r
1067 void UploadListProc(int ChName, int All)
\r
1069 FILELIST *FileListBase;
\r
1074 FILELIST *RemoteList;
\r
1075 char Tmp[FMAX_PATH+1];
\r
1083 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
1087 // ローカル側で選ばれているファイルをFileListBaseに登録
\r
1088 FileListBase = NULL;
\r
1090 // MakeSelectedFileList(WIN_LOCAL, YES, All, &FileListBase, &CancelFlg);
\r
1091 ListSts = MakeSelectedFileList(WIN_LOCAL, YES, All, &FileListBase, &CancelFlg);
\r
1093 // 現在ホスト側のファイル一覧に表示されているものをRemoteListに登録
\r
1095 RemoteList = NULL;
\r
1096 AddRemoteTreeToFileList(AskCurrentFileListNum(), "", RDIR_NONE, &RemoteList);
\r
1099 ExistNotify = YES;
\r
1101 Pos = FileListBase;
\r
1102 while(Pos != NULL)
\r
1105 if((AbortOnListError == YES) && (ListSts == FFFTP_FAIL))
\r
1107 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1108 SetSlashTail(Pkt.RemoteFile);
\r
1109 Cat = strchr(Pkt.RemoteFile, NUL);
\r
1110 if((ChName == NO) || (Pos->Node == NODE_DIR))
\r
1112 strcat(Pkt.RemoteFile, Pos->File);
\r
1113 if(FnameCnv == FNAME_LOWER)
\r
1115 else if(FnameCnv == FNAME_UPPER)
\r
1117 #if defined(HAVE_TANDEM)
\r
1119 Pkt.PriExt = DEF_PRIEXT;
\r
1120 Pkt.SecExt = DEF_SECEXT;
\r
1121 Pkt.MaxExt = DEF_MAXEXT;
\r
1127 strcpy(TmpString, Pos->File);
\r
1128 CurWin = WIN_LOCAL;
\r
1129 #if defined(HAVE_TANDEM)
\r
1130 strcpy(TmpFileCode, "0"); /* ASCII モードの場合は無視される */
\r
1131 if(AskHostType() == HTYPE_TANDEM && AskOSS() == NO) {
\r
1132 if(DialogBox(GetFtpInst(), MAKEINTRESOURCE(updown_as_with_ext_dlg), GetMainHwnd(), UpDownAsWithExtDialogCallBack) == YES) {
\r
1133 strcat(Pkt.RemoteFile, TmpString);
\r
1134 Pkt.FileCode = atoi(TmpFileCode);
\r
1140 if(DialogBox(GetFtpInst(), MAKEINTRESOURCE(updown_as_dlg), GetMainHwnd(), UpDownAsDialogCallBack) == YES)
\r
1141 strcat(Pkt.RemoteFile, TmpString);
\r
1146 AskRemoteCurDir(Tmp, FMAX_PATH);
\r
1147 SetSlashTail(Tmp);
\r
1148 if(strncmp(Pkt.RemoteFile, Tmp, strlen(Tmp)) != 0)
\r
1150 if((Cat = strrchr(Pkt.RemoteFile, '/')) != NULL)
\r
1153 Cat = Pkt.RemoteFile;
\r
1155 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
1157 if(AskHostType() == HTYPE_ACOS)
\r
1159 strcpy(Pkt.RemoteFile, "'");
\r
1160 strcat(Pkt.RemoteFile, AskHostLsName());
\r
1161 strcat(Pkt.RemoteFile, "(");
\r
1162 strcat(Pkt.RemoteFile, Cat);
\r
1163 strcat(Pkt.RemoteFile, ")");
\r
1164 strcat(Pkt.RemoteFile, "'");
\r
1166 else if(AskHostType() == HTYPE_ACOS_4)
\r
1167 strcpy(Pkt.RemoteFile, Cat);
\r
1169 if(Pos->Node == NODE_DIR)
\r
1173 // ホスト側のファイル一覧をRemoteListに登録
\r
1175 if(RemoteList != NULL)
\r
1176 DeleteFileList(&RemoteList);
\r
1177 RemoteList = NULL;
\r
1179 AskRemoteCurDir(Tmp, FMAX_PATH);
\r
1180 if(DoCWD(Pkt.RemoteFile, NO, NO, NO) == FTP_COMPLETE)
\r
1182 if(DoDirListCmdSkt("", "", 998, &CancelFlg) == FTP_COMPLETE)
\r
1183 AddRemoteTreeToFileList(998, "", RDIR_NONE, &RemoteList);
\r
1184 DoCWD(Tmp, NO, NO, NO);
\r
1189 if((FirstAdd == YES) && (AskNoFullPathMode() == YES))
\r
1191 strcpy(Pkt1.Cmd, "SETCUR");
\r
1192 AskRemoteCurDir(Pkt1.RemoteFile, FMAX_PATH);
\r
1193 AddTransFileList(&Pkt1);
\r
1196 strcpy(Pkt.Cmd, "MKD ");
\r
1197 strcpy(Pkt.LocalFile, "");
\r
1198 AddTransFileList(&Pkt);
\r
1201 else if(Pos->Node == NODE_FILE)
\r
1204 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
1205 SetYenTail(Pkt.LocalFile);
\r
1206 strcat(Pkt.LocalFile, Pos->File);
\r
1207 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
1209 strcpy(Pkt.Cmd, "STOR ");
\r
1210 Pkt.Type = AskTransferTypeAssoc(Pkt.LocalFile, AskTransferType());
\r
1213 Pkt.Size = Pos->Size;
\r
1214 Pkt.Time = Pos->Time;
\r
1215 Pkt.Attr = AskUploadFileAttr(Pkt.RemoteFile);
\r
1216 Pkt.KanjiCode = AskHostKanjiCode();
\r
1218 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
1219 Pkt.KanaCnv = AskHostKanaCnv();
\r
1220 #if defined(HAVE_TANDEM)
\r
1221 if(AskHostType() == HTYPE_TANDEM && AskOSS() == NO) {
\r
1222 CalcExtentSize(&Pkt, Pos->Size);
\r
1226 strcpy(Tmp, Pkt.RemoteFile);
\r
1227 Pkt.Mode = CheckRemoteFile(&Pkt, RemoteList);
\r
1229 Pkt.NoTransfer = NO;
\r
1230 if(Pkt.Mode == EXIST_ABORT)
\r
1232 else if(Pkt.Mode != EXIST_IGNORE)
\r
1235 if(MakeAllDir == YES)
\r
1237 if(MakeDirFromRemotePath(Pkt.RemoteFile, Tmp, FirstAdd) == YES)
\r
1240 if((FirstAdd == YES) && (AskNoFullPathMode() == YES))
\r
1242 strcpy(Pkt1.Cmd, "SETCUR");
\r
1243 AskRemoteCurDir(Pkt1.RemoteFile, FMAX_PATH);
\r
1244 AddTransFileList(&Pkt1);
\r
1247 AddTransFileList(&Pkt);
\r
1253 if((FirstAdd == NO) && (AskNoFullPathMode() == YES))
\r
1255 strcpy(Pkt.Cmd, "BACKCUR");
\r
1256 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1257 AddTransFileList(&Pkt);
\r
1260 if(RemoteList != NULL)
\r
1261 DeleteFileList(&RemoteList);
\r
1263 DeleteFileList(&FileListBase);
\r
1266 // strcpy(Pkt.Cmd, "GOQUIT");
\r
1267 // AddTransFileList(&Pkt);
\r
1270 AddNullTransFileList();
\r
1272 GoForwardTransWindow();
\r
1280 /*----- ドラッグ&ドロップで指定されたファイルをアップロードする --------------
\r
1283 * WPARAM wParam : ドロップされたファイルの情報
\r
1287 *----------------------------------------------------------------------------*/
\r
1289 void UploadDragProc(WPARAM wParam)
\r
1291 FILELIST *FileListBase;
\r
1296 FILELIST *RemoteList;
\r
1297 char Tmp[FMAX_PATH+1];
\r
1299 char Cur[FMAX_PATH+1];
\r
1304 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
1308 // ローカル側で選ばれているファイルをFileListBaseに登録
\r
1309 FileListBase = NULL;
\r
1310 MakeDroppedFileList(wParam, Cur, &FileListBase);
\r
1312 // 現在ホスト側のファイル一覧に表示されているものをRemoteListに登録
\r
1314 RemoteList = NULL;
\r
1315 AddRemoteTreeToFileList(AskCurrentFileListNum(), "", RDIR_NONE, &RemoteList);
\r
1318 ExistNotify = YES;
\r
1320 Pos = FileListBase;
\r
1321 while(Pos != NULL)
\r
1323 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1324 SetSlashTail(Pkt.RemoteFile);
\r
1325 Cat = strchr(Pkt.RemoteFile, NUL);
\r
1327 strcat(Pkt.RemoteFile, Pos->File);
\r
1328 if(FnameCnv == FNAME_LOWER)
\r
1330 else if(FnameCnv == FNAME_UPPER)
\r
1332 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
1333 #if defined(HAVE_TANDEM)
\r
1335 Pkt.PriExt = DEF_PRIEXT;
\r
1336 Pkt.SecExt = DEF_SECEXT;
\r
1337 Pkt.MaxExt = DEF_MAXEXT;
\r
1340 if(AskHostType() == HTYPE_ACOS)
\r
1342 strcpy(Pkt.RemoteFile, "'");
\r
1343 strcat(Pkt.RemoteFile, AskHostLsName());
\r
1344 strcat(Pkt.RemoteFile, "(");
\r
1345 strcat(Pkt.RemoteFile, Cat);
\r
1346 strcat(Pkt.RemoteFile, ")");
\r
1347 strcat(Pkt.RemoteFile, "'");
\r
1349 else if(AskHostType() == HTYPE_ACOS_4)
\r
1350 strcpy(Pkt.RemoteFile, Cat);
\r
1352 if(Pos->Node == NODE_DIR)
\r
1356 // ホスト側のファイル一覧をRemoteListに登録
\r
1358 if(RemoteList != NULL)
\r
1359 DeleteFileList(&RemoteList);
\r
1360 RemoteList = NULL;
\r
1362 AskRemoteCurDir(Tmp, FMAX_PATH);
\r
1363 if(DoCWD(Pkt.RemoteFile, NO, NO, NO) == FTP_COMPLETE)
\r
1365 if(DoDirListCmdSkt("", "", 998, &CancelFlg) == FTP_COMPLETE)
\r
1366 AddRemoteTreeToFileList(998, "", RDIR_NONE, &RemoteList);
\r
1367 DoCWD(Tmp, NO, NO, NO);
\r
1371 if((FirstAdd == YES) && (AskNoFullPathMode() == YES))
\r
1373 strcpy(Pkt1.Cmd, "SETCUR");
\r
1374 AskRemoteCurDir(Pkt1.RemoteFile, FMAX_PATH);
\r
1375 AddTransFileList(&Pkt1);
\r
1378 strcpy(Pkt.Cmd, "MKD ");
\r
1379 strcpy(Pkt.LocalFile, "");
\r
1380 AddTransFileList(&Pkt);
\r
1383 else if(Pos->Node == NODE_FILE)
\r
1386 strcpy(Pkt.LocalFile, Cur);
\r
1387 SetYenTail(Pkt.LocalFile);
\r
1388 strcat(Pkt.LocalFile, Pos->File);
\r
1389 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
1391 strcpy(Pkt.Cmd, "STOR ");
\r
1392 Pkt.Type = AskTransferTypeAssoc(Pkt.LocalFile, AskTransferType());
\r
1395 Pkt.Size = Pos->Size;
\r
1396 Pkt.Time = Pos->Time;
\r
1397 Pkt.Attr = AskUploadFileAttr(Pkt.RemoteFile);
\r
1398 Pkt.KanjiCode = AskHostKanjiCode();
\r
1400 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
1401 Pkt.KanaCnv = AskHostKanaCnv();
\r
1402 #if defined(HAVE_TANDEM)
\r
1403 if(AskHostType() == HTYPE_TANDEM && AskOSS() == NO) {
\r
1404 int a = Pos->InfoExist && FINFO_SIZE;
\r
1405 CalcExtentSize(&Pkt, Pos->Size);
\r
1409 strcpy(Tmp, Pkt.RemoteFile);
\r
1410 Pkt.Mode = CheckRemoteFile(&Pkt, RemoteList);
\r
1412 Pkt.NoTransfer = NO;
\r
1413 if(Pkt.Mode == EXIST_ABORT)
\r
1415 else if(Pkt.Mode != EXIST_IGNORE)
\r
1418 if(MakeAllDir == YES)
\r
1420 if(MakeDirFromRemotePath(Pkt.RemoteFile, Tmp, FirstAdd) == YES)
\r
1423 if((FirstAdd == YES) && (AskNoFullPathMode() == YES))
\r
1425 strcpy(Pkt1.Cmd, "SETCUR");
\r
1426 AskRemoteCurDir(Pkt1.RemoteFile, FMAX_PATH);
\r
1427 AddTransFileList(&Pkt1);
\r
1430 AddTransFileList(&Pkt);
\r
1436 if((FirstAdd == NO) && (AskNoFullPathMode() == YES))
\r
1438 strcpy(Pkt.Cmd, "BACKCUR");
\r
1439 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1440 AddTransFileList(&Pkt);
\r
1443 if(RemoteList != NULL)
\r
1444 DeleteFileList(&RemoteList);
\r
1446 DeleteFileList(&FileListBase);
\r
1449 // strcpy(Pkt.Cmd, "GOQUIT");
\r
1450 // AddTransFileList(&Pkt);
\r
1453 AddNullTransFileList();
\r
1455 GoForwardTransWindow();
\r
1463 /*----- ミラーリングアップロードを行う ----------------------------------------
\r
1466 * int Notify : 確認を行うかどうか (YES/NO)
\r
1470 *----------------------------------------------------------------------------*/
\r
1472 void MirrorUploadProc(int Notify)
\r
1474 FILELIST *LocalListBase;
\r
1475 FILELIST *RemoteListBase;
\r
1476 FILELIST *LocalPos;
\r
1477 FILELIST *RemotePos;
\r
1479 TRANSPACKET *Base;
\r
1480 char Name[FMAX_PATH+1];
\r
1484 SYSTEMTIME TmpStime;
\r
1485 FILETIME TmpFtimeL;
\r
1486 FILETIME TmpFtimeR;
\r
1493 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
1500 Notify = DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(mirror_up_dlg), GetMainHwnd(), MirrorNotifyCallBack, 1);
\r
1504 if((Notify == YES) || (Notify == YES_LIST))
\r
1506 /*===== ファイルリスト取得 =====*/
\r
1508 LocalListBase = NULL;
\r
1510 // MakeSelectedFileList(WIN_LOCAL, YES, YES, &LocalListBase, &CancelFlg);
\r
1511 ListSts = MakeSelectedFileList(WIN_LOCAL, YES, YES, &LocalListBase, &CancelFlg);
\r
1512 RemoteListBase = NULL;
\r
1514 // MakeSelectedFileList(WIN_REMOTE, YES, YES, &RemoteListBase, &CancelFlg);
\r
1515 if(ListSts == FFFTP_SUCCESS)
\r
1516 ListSts = MakeSelectedFileList(WIN_REMOTE, YES, YES, &RemoteListBase, &CancelFlg);
\r
1518 LocalPos = LocalListBase;
\r
1519 while(LocalPos != NULL)
\r
1521 LocalPos->Attr = YES; /* LocalPos->Attrは転送するかどうかのフラグに使用 (YES/NO) */
\r
1522 LocalPos = LocalPos->Next;
\r
1525 RemotePos = RemoteListBase;
\r
1526 while(RemotePos != NULL)
\r
1528 if(AskMirrorNoTrn(RemotePos->File, 1) == NO)
\r
1530 RemotePos->Attr = YES;
\r
1531 RemotePos = RemotePos->Next;
\r
1535 RemotePos->Attr = NO; /* RemotePos->Attrは削除するかどうかのフラグに使用 (YES/NO) */
\r
1537 if(RemotePos->Node == NODE_DIR)
\r
1539 Level = AskDirLevel(RemotePos->File);
\r
1540 RemotePos = RemotePos->Next;
\r
1541 while(RemotePos != NULL)
\r
1543 if((RemotePos->Node == NODE_DIR) &&
\r
1544 (AskDirLevel(RemotePos->File) <= Level))
\r
1548 RemotePos->Attr = NO;
\r
1549 RemotePos = RemotePos->Next;
\r
1553 RemotePos = RemotePos->Next;
\r
1557 /*===== ファイルリスト比較 =====*/
\r
1559 LocalPos = LocalListBase;
\r
1560 while(LocalPos != NULL)
\r
1562 if(AskMirrorNoTrn(LocalPos->File, 0) == NO)
\r
1564 strcpy(Name, LocalPos->File);
\r
1565 ReplaceAll(Name, '\\', '/');
\r
1567 if(MirrorFnameCnv == YES)
\r
1568 Mode = COMP_LOWERMATCH;
\r
1570 Mode = COMP_STRICT;
\r
1572 if(LocalPos->Node == NODE_DIR)
\r
1574 if((RemotePos = SearchFileList(Name, RemoteListBase, Mode)) != NULL)
\r
1576 if(RemotePos->Node == NODE_DIR)
\r
1578 RemotePos->Attr = NO;
\r
1579 LocalPos->Attr = NO;
\r
1583 else if(LocalPos->Node == NODE_FILE)
\r
1585 if((RemotePos = SearchFileList(Name, RemoteListBase, Mode)) != NULL)
\r
1587 if(RemotePos->Node == NODE_FILE)
\r
1589 FileTimeToLocalFileTime(&LocalPos->Time, &TmpFtimeL);
\r
1590 FileTimeToLocalFileTime(&RemotePos->Time, &TmpFtimeR);
\r
1591 if((RemotePos->InfoExist & FINFO_TIME) == 0)
\r
1593 FileTimeToSystemTime(&TmpFtimeL, &TmpStime);
\r
1594 TmpStime.wHour = 0;
\r
1595 TmpStime.wMinute = 0;
\r
1596 TmpStime.wSecond = 0;
\r
1597 TmpStime.wMilliseconds = 0;
\r
1598 SystemTimeToFileTime(&TmpStime, &TmpFtimeL);
\r
1600 FileTimeToSystemTime(&TmpFtimeR, &TmpStime);
\r
1601 TmpStime.wHour = 0;
\r
1602 TmpStime.wMinute = 0;
\r
1603 TmpStime.wSecond = 0;
\r
1604 TmpStime.wMilliseconds = 0;
\r
1605 SystemTimeToFileTime(&TmpStime, &TmpFtimeR);
\r
1607 RemotePos->Attr = NO;
\r
1608 if(CompareFileTime(&TmpFtimeL, &TmpFtimeR) <= 0)
\r
1609 LocalPos->Attr = NO;
\r
1614 LocalPos = LocalPos->Next;
\r
1618 if(LocalPos->Node == NODE_FILE)
\r
1620 LocalPos->Attr = NO;
\r
1621 LocalPos = LocalPos->Next;
\r
1625 LocalPos->Attr = NO;
\r
1626 Level = AskDirLevel(LocalPos->File);
\r
1627 LocalPos = LocalPos->Next;
\r
1628 while(LocalPos != NULL)
\r
1630 if((LocalPos->Node == NODE_DIR) &&
\r
1631 (AskDirLevel(LocalPos->File) <= Level))
\r
1635 LocalPos->Attr = NO;
\r
1636 LocalPos = LocalPos->Next;
\r
1642 DispMirrorFiles(LocalListBase, RemoteListBase);
\r
1644 /*===== 削除/アップロード =====*/
\r
1646 RemotePos = RemoteListBase;
\r
1647 while(RemotePos != NULL)
\r
1649 if((RemotePos->Attr == YES) && (RemotePos->Node == NODE_FILE))
\r
1651 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1652 SetSlashTail(Pkt.RemoteFile);
\r
1653 strcat(Pkt.RemoteFile, RemotePos->File);
\r
1654 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
1655 strcpy(Pkt.LocalFile, "");
\r
1656 strcpy(Pkt.Cmd, "R-DELE ");
\r
1657 AddTmpTransFileList(&Pkt, &Base);
\r
1659 RemotePos = RemotePos->Next;
\r
1661 MirrorDeleteAllDir(RemoteListBase, &Pkt, &Base);
\r
1663 LocalPos = LocalListBase;
\r
1664 while(LocalPos != NULL)
\r
1666 if(LocalPos->Attr == YES)
\r
1668 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1669 SetSlashTail(Pkt.RemoteFile);
\r
1670 Cat = strchr(Pkt.RemoteFile, NUL);
\r
1671 strcat(Pkt.RemoteFile, LocalPos->File);
\r
1673 if(MirrorFnameCnv == YES)
\r
1676 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
1678 if(LocalPos->Node == NODE_DIR)
\r
1680 strcpy(Pkt.LocalFile, "");
\r
1681 strcpy(Pkt.Cmd, "R-MKD ");
\r
1682 AddTmpTransFileList(&Pkt, &Base);
\r
1684 else if(LocalPos->Node == NODE_FILE)
\r
1686 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
1687 SetYenTail(Pkt.LocalFile);
\r
1688 strcat(Pkt.LocalFile, LocalPos->File);
\r
1689 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
1691 strcpy(Pkt.Cmd, "STOR ");
\r
1692 Pkt.Type = AskTransferTypeAssoc(Pkt.LocalFile, AskTransferType());
\r
1695 Pkt.Size = LocalPos->Size;
\r
1696 Pkt.Time = LocalPos->Time;
\r
1697 Pkt.Attr = AskUploadFileAttr(Pkt.RemoteFile);
\r
1698 Pkt.KanjiCode = AskHostKanjiCode();
\r
1700 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
1701 Pkt.KanaCnv = AskHostKanaCnv();
\r
1702 #if defined(HAVE_TANDEM)
\r
1703 if(AskHostType() == HTYPE_TANDEM && AskOSS() == NO) {
\r
1704 CalcExtentSize(&Pkt, LocalPos->Size);
\r
1707 Pkt.Mode = EXIST_OVW;
\r
1709 Pkt.NoTransfer = MirrorNoTransferContents;
\r
1710 AddTmpTransFileList(&Pkt, &Base);
\r
1713 LocalPos = LocalPos->Next;
\r
1717 // if((Notify == YES) ||
\r
1718 // (DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(mirror_notify_dlg), GetMainHwnd(), MirrorDispListCallBack, (LPARAM)&Base) == YES))
\r
1719 if(((AbortOnListError == NO) || (ListSts == FFFTP_SUCCESS)) && ((Notify == YES) ||
\r
1720 (DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(mirror_notify_dlg), GetMainHwnd(), MirrorDispListCallBack, (LPARAM)&Base) == YES)))
\r
1722 if(AskNoFullPathMode() == YES)
\r
1724 strcpy(Pkt.Cmd, "SETCUR");
\r
1725 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1726 AddTransFileList(&Pkt);
\r
1728 AppendTransFileList(Base);
\r
1730 if(AskNoFullPathMode() == YES)
\r
1732 strcpy(Pkt.Cmd, "BACKCUR");
\r
1733 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1734 AddTransFileList(&Pkt);
\r
1738 // strcpy(Pkt.Cmd, "GOQUIT");
\r
1739 // AddTransFileList(&Pkt);
\r
1742 EraseTmpTransFileList(&Base);
\r
1745 AddNullTransFileList();
\r
1747 DeleteFileList(&LocalListBase);
\r
1748 DeleteFileList(&RemoteListBase);
\r
1750 GoForwardTransWindow();
\r
1759 /*----- ミラーリング時のホスト側のフォルダ削除 --------------------------------
\r
1762 * FILELIST *Base : ファイルリスト
\r
1763 * TRANSPACKET *Pkt :
\r
1764 * TRANSPACKET **Base :
\r
1768 *----------------------------------------------------------------------------*/
\r
1770 static void MirrorDeleteAllDir(FILELIST *Remote, TRANSPACKET *Pkt, TRANSPACKET **Base)
\r
1772 while(Remote != NULL)
\r
1774 if(Remote->Node == NODE_DIR)
\r
1776 MirrorDeleteAllDir(Remote->Next, Pkt, Base);
\r
1778 if(Remote->Attr == YES)
\r
1780 AskRemoteCurDir(Pkt->RemoteFile, FMAX_PATH);
\r
1781 SetSlashTail(Pkt->RemoteFile);
\r
1782 strcat(Pkt->RemoteFile, Remote->File);
\r
1783 ReplaceAll(Pkt->RemoteFile, '\\', '/');
\r
1784 strcpy(Pkt->LocalFile, "");
\r
1785 strcpy(Pkt->Cmd, "R-RMD ");
\r
1786 AddTmpTransFileList(Pkt, Base);
\r
1790 Remote = Remote->Next;
\r
1796 /*----- ミラーリングアップロード開始確認ウインドウのコールバック --------------
\r
1799 * HWND hDlg : ウインドウハンドル
\r
1800 * UINT message : メッセージ番号
\r
1801 * WPARAM wParam : メッセージの WPARAM 引数
\r
1802 * LPARAM lParam : メッセージの LPARAM 引数
\r
1806 *----------------------------------------------------------------------------*/
\r
1809 //static BOOL CALLBACK MirrorNotifyCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
1810 static INT_PTR CALLBACK MirrorNotifyCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
1816 case WM_INITDIALOG :
\r
1821 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
1824 EndDialog(hDlg, YES);
\r
1828 EndDialog(hDlg, NO);
\r
1831 case MIRRORUP_DISP :
\r
1832 EndDialog(hDlg, YES_LIST);
\r
1837 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000013);
\r
1839 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000012);
\r
1847 /*----- ミラーリングアップロード処理内容確認ウインドウのコールバック ----------
\r
1850 * HWND hDlg : ウインドウハンドル
\r
1851 * UINT message : メッセージ番号
\r
1852 * WPARAM wParam : メッセージの WPARAM 引数
\r
1853 * LPARAM lParam : メッセージの LPARAM 引数
\r
1857 *----------------------------------------------------------------------------*/
\r
1860 //static BOOL CALLBACK MirrorDispListCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
1861 static INT_PTR CALLBACK MirrorDispListCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
1863 static DIALOGSIZE DlgSize = {
\r
1864 { MIRROR_DEL, MIRROR_SIZEGRIP, -1 },
\r
1865 { IDOK, IDCANCEL, IDHELP, MIRROR_DEL, MIRROR_COPYNUM, MIRROR_MAKENUM, MIRROR_DELNUM, MIRROR_SIZEGRIP, -1 },
\r
1866 { MIRROR_LIST, -1 },
\r
1871 static TRANSPACKET **Base;
\r
1873 char Tmp[FMAX_PATH+1+6];
\r
1879 case WM_INITDIALOG :
\r
1880 Base = (TRANSPACKET **)lParam;
\r
1882 while(Pos != NULL)
\r
1885 if((strncmp(Pos->Cmd, "R-DELE", 6) == 0) ||
\r
1886 (strncmp(Pos->Cmd, "R-RMD", 5) == 0))
\r
1887 sprintf(Tmp, MSGJPN052, Pos->RemoteFile);
\r
1888 else if(strncmp(Pos->Cmd, "R-MKD", 5) == 0)
\r
1889 sprintf(Tmp, MSGJPN053, Pos->RemoteFile);
\r
1890 else if(strncmp(Pos->Cmd, "STOR", 4) == 0)
\r
1891 sprintf(Tmp, MSGJPN054, Pos->RemoteFile);
\r
1892 else if((strncmp(Pos->Cmd, "L-DELE", 6) == 0) ||
\r
1893 (strncmp(Pos->Cmd, "L-RMD", 5) == 0))
\r
1894 sprintf(Tmp, MSGJPN055, Pos->LocalFile);
\r
1895 else if(strncmp(Pos->Cmd, "L-MKD", 5) == 0)
\r
1896 sprintf(Tmp, MSGJPN056, Pos->LocalFile);
\r
1897 else if(strncmp(Pos->Cmd, "RETR", 4) == 0)
\r
1898 sprintf(Tmp, MSGJPN057, Pos->LocalFile);
\r
1900 if(strlen(Tmp) > 0)
\r
1901 SendDlgItemMessage(hDlg, MIRROR_LIST, LB_ADDSTRING, 0, (LPARAM)Tmp);
\r
1904 CountMirrorFiles(hDlg, *Base);
\r
1905 DlgSizeInit(hDlg, &DlgSize, &MirrorDlgSize);
\r
1906 EnableWindow(GetDlgItem(hDlg, MIRROR_DEL), FALSE);
\r
1908 SendDlgItemMessage(hDlg, MIRROR_NO_TRANSFER, BM_SETCHECK, MirrorNoTransferContents, 0);
\r
1912 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
1915 AskDlgSize(hDlg, &DlgSize, &MirrorDlgSize);
\r
1916 EndDialog(hDlg, YES);
\r
1920 AskDlgSize(hDlg, &DlgSize, &MirrorDlgSize);
\r
1921 EndDialog(hDlg, NO);
\r
1925 Num = SendDlgItemMessage(hDlg, MIRROR_LIST, LB_GETSELCOUNT, 0, 0);
\r
1926 if((List = malloc(Num * sizeof(int))) != NULL)
\r
1928 Num = SendDlgItemMessage(hDlg, MIRROR_LIST, LB_GETSELITEMS, Num, (LPARAM)List);
\r
1929 for(Num--; Num >= 0; Num--)
\r
1931 if(RemoveTmpTransFileListItem(Base, List[Num]) == FFFTP_SUCCESS)
\r
1932 SendDlgItemMessage(hDlg, MIRROR_LIST, LB_DELETESTRING, List[Num], 0);
\r
1937 CountMirrorFiles(hDlg, *Base);
\r
1941 case MIRROR_LIST :
\r
1942 switch(GET_WM_COMMAND_CMD(wParam, lParam))
\r
1944 case LBN_SELCHANGE :
\r
1945 if(SendDlgItemMessage(hDlg, MIRROR_LIST, LB_GETSELCOUNT, 0, 0) > 0)
\r
1946 EnableWindow(GetDlgItem(hDlg, MIRROR_DEL), TRUE);
\r
1948 EnableWindow(GetDlgItem(hDlg, MIRROR_DEL), FALSE);
\r
1954 case MIRROR_NO_TRANSFER :
\r
1956 while(Pos != NULL)
\r
1958 if(strncmp(Pos->Cmd, "STOR", 4) == 0 || strncmp(Pos->Cmd, "RETR", 4) == 0)
\r
1959 Pos->NoTransfer = SendDlgItemMessage(hDlg, MIRROR_NO_TRANSFER, BM_GETCHECK, 0, 0);
\r
1965 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000012);
\r
1970 DlgSizeChange(hDlg, &DlgSize, (RECT *)lParam, (int)wParam);
\r
1977 /*----- ミラーリングで転送/削除するファイルの数を数えダイアログに表示---------
\r
1981 * TRANSPACKET *Pkt :
\r
1985 *----------------------------------------------------------------------------*/
\r
1987 static void CountMirrorFiles(HWND hDlg, TRANSPACKET *Pkt)
\r
1997 while(Pkt != NULL)
\r
1999 if((strncmp(Pkt->Cmd, "R-DELE", 6) == 0) ||
\r
2000 (strncmp(Pkt->Cmd, "R-RMD", 5) == 0) ||
\r
2001 (strncmp(Pkt->Cmd, "L-DELE", 6) == 0) ||
\r
2002 (strncmp(Pkt->Cmd, "L-RMD", 5) == 0))
\r
2006 else if((strncmp(Pkt->Cmd, "R-MKD", 5) == 0) ||
\r
2007 (strncmp(Pkt->Cmd, "L-MKD", 5) == 0))
\r
2011 else if((strncmp(Pkt->Cmd, "STOR", 4) == 0) ||
\r
2012 (strncmp(Pkt->Cmd, "RETR", 4) == 0))
\r
2020 sprintf(Tmp, MSGJPN058, Copy);
\r
2022 sprintf(Tmp, MSGJPN059);
\r
2023 SendDlgItemMessage(hDlg, MIRROR_COPYNUM, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
2026 sprintf(Tmp, MSGJPN060, Make);
\r
2028 sprintf(Tmp, MSGJPN061);
\r
2029 SendDlgItemMessage(hDlg, MIRROR_MAKENUM, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
2032 sprintf(Tmp, MSGJPN062, Del);
\r
2034 sprintf(Tmp, MSGJPN063);
\r
2035 SendDlgItemMessage(hDlg, MIRROR_DELNUM, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
2043 /*----- ミラーリングで転送/削除しないファイルかどうかを返す ------------------
\r
2046 * char Fname : ファイル名
\r
2048 * 0=転送しないファイル, 1=削除しないファイル
\r
2053 *----------------------------------------------------------------------------*/
\r
2055 static int AskMirrorNoTrn(char *Fname, int Mode)
\r
2060 Tbl = MirrorNoTrn;
\r
2062 Tbl = MirrorNoDel;
\r
2065 if(StrMultiLen(Tbl) > 0)
\r
2067 Fname = GetFileName(Fname);
\r
2068 while(*Tbl != NUL)
\r
2070 if(CheckFname(Fname, Tbl) == FFFTP_SUCCESS)
\r
2075 Tbl += strlen(Tbl) + 1;
\r
2082 /*----- アップロードするファイルの属性を返す ----------------------------------
\r
2085 * char Fname : ファイル名
\r
2088 * int 属性 (-1=設定なし)
\r
2089 *----------------------------------------------------------------------------*/
\r
2091 static int AskUploadFileAttr(char *Fname)
\r
2097 Tbl = DefAttrList;
\r
2098 Fname = GetFileName(Fname);
\r
2100 while(*Tbl != NUL)
\r
2102 Sts = CheckFname(Fname, Tbl);
\r
2103 Tbl += strlen(Tbl) + 1;
\r
2105 if((Sts == FFFTP_SUCCESS) && (*Tbl != NUL))
\r
2110 Tbl += strlen(Tbl) + 1;
\r
2116 /*----- ホストに同じ名前のファイルがないかチェック- ---------------------------a
\r
2119 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2120 * FILELIST *ListList :
\r
2124 * EXIST_OVW/EXIST_UNIQUE/EXIST_IGNORE
\r
2127 * Pkt.ExistSize, UpExistMode、ExistNotify が変更される
\r
2128 *----------------------------------------------------------------------------*/
\r
2130 static int CheckRemoteFile(TRANSPACKET *Pkt, FILELIST *ListList)
\r
2133 #if defined(HAVE_TANDEM)
\r
2139 Pkt->ExistSize = 0;
\r
2140 if(SendMode != TRANS_OVW)
\r
2142 #if defined(HAVE_TANDEM)
\r
2143 /* HP NonStop Server は大文字小文字の区別なし(すべて大文字) */
\r
2144 if(AskHostType() == HTYPE_TANDEM)
\r
2145 Mode = COMP_IGNORE;
\r
2147 Mode = COMP_STRICT;
\r
2149 if((Exist = SearchFileList(GetFileName(Pkt->RemoteFile), ListList, Mode)) != NULL)
\r
2151 if((Exist = SearchFileList(GetFileName(Pkt->RemoteFile), ListList, COMP_STRICT)) != NULL)
\r
2154 Pkt->ExistSize = Exist->Size;
\r
2156 if(ExistNotify == YES)
\r
2158 SoundPlay(SND_ERROR);
\r
2159 if(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(up_exist_dlg), GetMainHwnd(), UpExistDialogCallBack, (LPARAM)Pkt) == NO)
\r
2160 Ret = EXIST_ABORT;
\r
2162 Ret = UpExistMode;
\r
2165 Ret = UpExistMode;
\r
2167 if(Ret == EXIST_NEW)
\r
2170 if(CompareFileTime(&Exist->Time, &Pkt->Time) < 0)
\r
2173 Ret = EXIST_IGNORE;
\r
2175 // 同じ名前のファイルの処理方法追加
\r
2176 if(Ret == EXIST_LARGE)
\r
2178 if(Exist->Size < Pkt->Size)
\r
2181 Ret = EXIST_IGNORE;
\r
2189 /*----- ホストに同じ名前のファイルがある時の確認ダイアログのコールバック ------
\r
2192 * HWND hDlg : ウインドウハンドル
\r
2193 * UINT message : メッセージ番号
\r
2194 * WPARAM wParam : メッセージの WPARAM 引数
\r
2195 * LPARAM lParam : メッセージの LPARAM 引数
\r
2199 *----------------------------------------------------------------------------*/
\r
2202 //static BOOL CALLBACK UpExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2203 static INT_PTR CALLBACK UpExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2205 static TRANSPACKET *Pkt;
\r
2206 // 同じ名前のファイルの処理方法追加
\r
2207 // static const RADIOBUTTON UpExistButton[] = {
\r
2208 // { UP_EXIST_OVW, EXIST_OVW },
\r
2209 // { UP_EXIST_NEW, EXIST_NEW },
\r
2210 // { UP_EXIST_RESUME, EXIST_RESUME },
\r
2211 // { UP_EXIST_UNIQUE, EXIST_UNIQUE },
\r
2212 // { UP_EXIST_IGNORE, EXIST_IGNORE }
\r
2214 static const RADIOBUTTON UpExistButton[] = {
\r
2215 { UP_EXIST_OVW, EXIST_OVW },
\r
2216 { UP_EXIST_NEW, EXIST_NEW },
\r
2217 { UP_EXIST_RESUME, EXIST_RESUME },
\r
2218 { UP_EXIST_UNIQUE, EXIST_UNIQUE },
\r
2219 { UP_EXIST_IGNORE, EXIST_IGNORE },
\r
2220 { UP_EXIST_LARGE, EXIST_LARGE }
\r
2222 #define UPEXISTBUTTONS (sizeof(UpExistButton)/sizeof(RADIOBUTTON))
\r
2226 case WM_INITDIALOG :
\r
2227 Pkt = (TRANSPACKET *)lParam;
\r
2228 SendDlgItemMessage(hDlg, UP_EXIST_NAME, EM_LIMITTEXT, FMAX_PATH, 0);
\r
2229 SendDlgItemMessage(hDlg, UP_EXIST_NAME, WM_SETTEXT, 0, (LPARAM)Pkt->RemoteFile);
\r
2231 if((Pkt->Type == TYPE_A) || (Pkt->ExistSize <= 0))
\r
2232 EnableWindow(GetDlgItem(hDlg, UP_EXIST_RESUME), FALSE);
\r
2234 SetRadioButtonByValue(hDlg, UpExistMode, UpExistButton, UPEXISTBUTTONS);
\r
2238 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2242 /* ここに break はない */
\r
2245 UpExistMode = AskRadioButtonValue(hDlg, UpExistButton, UPEXISTBUTTONS);
\r
2246 SendDlgItemMessage(hDlg, UP_EXIST_NAME, WM_GETTEXT, FMAX_PATH, (LPARAM)Pkt->RemoteFile);
\r
2247 EndDialog(hDlg, YES);
\r
2251 // Pkt->Abort = ABORT_USER;
\r
2252 // UpExistMode = EXIST_IGNORE;
\r
2253 EndDialog(hDlg, NO);
\r
2257 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000011);
\r
2266 /*----- アップロード/ダウンロードファイル名入力ダイアログのコールバック ------
\r
2269 * HWND hDlg : ウインドウハンドル
\r
2270 * UINT message : メッセージ番号
\r
2271 * WPARAM wParam : メッセージの WPARAM 引数
\r
2272 * LPARAM lParam : メッセージの LPARAM 引数
\r
2276 *----------------------------------------------------------------------------*/
\r
2279 //static BOOL CALLBACK UpDownAsDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2280 static INT_PTR CALLBACK UpDownAsDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2284 case WM_INITDIALOG :
\r
2285 if(CurWin == WIN_LOCAL)
\r
2286 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN064);
\r
2288 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN065);
\r
2290 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, EM_LIMITTEXT, FMAX_PATH, 0);
\r
2291 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2292 SendDlgItemMessage(hDlg, UPDOWNAS_TEXT, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2296 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2299 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, WM_GETTEXT, FMAX_PATH, (LPARAM)TmpString);
\r
2300 EndDialog(hDlg, YES);
\r
2303 case UPDOWNAS_STOP :
\r
2304 EndDialog(hDlg, NO_ALL);
\r
2313 #if defined(HAVE_TANDEM)
\r
2314 /*----- アップロード/ダウンロードファイル名入力ダイアログのコールバック ------
\r
2317 * HWND hDlg : ウインドウハンドル
\r
2318 * UINT message : メッセージ番号
\r
2319 * WPARAM wParam : メッセージの WPARAM 引数
\r
2320 * LPARAM lParam : メッセージの LPARAM 引数
\r
2324 *----------------------------------------------------------------------------*/
\r
2326 static INT_PTR CALLBACK UpDownAsWithExtDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2330 case WM_INITDIALOG :
\r
2331 if(CurWin == WIN_LOCAL)
\r
2332 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN064);
\r
2334 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN065);
\r
2336 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, EM_LIMITTEXT, FMAX_PATH, 0);
\r
2337 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2338 SendDlgItemMessage(hDlg, UPDOWNAS_TEXT, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2339 SendDlgItemMessage(hDlg, UPDOWNAS_FILECODE, EM_LIMITTEXT, 4, 0);
\r
2340 SendDlgItemMessage(hDlg, UPDOWNAS_FILECODE, WM_SETTEXT, 0, (LPARAM)TmpFileCode);
\r
2345 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2348 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, WM_GETTEXT, FMAX_PATH, (LPARAM)TmpString);
\r
2349 SendDlgItemMessage(hDlg, UPDOWNAS_FILECODE, WM_GETTEXT, FMAX_PATH, (LPARAM)TmpFileCode);
\r
2350 EndDialog(hDlg, YES);
\r
2353 case UPDOWNAS_STOP :
\r
2354 EndDialog(hDlg, NO_ALL);
\r
2364 /*----- ファイル一覧で指定されたファイルを削除する ----------------------------
\r
2371 *----------------------------------------------------------------------------*/
\r
2373 void DeleteProc(void)
\r
2376 FILELIST *FileListBase;
\r
2380 char CurDir[FMAX_PATH+1];
\r
2381 char Tmp[FMAX_PATH+1];
\r
2389 AskRemoteCurDir(CurDir, FMAX_PATH);
\r
2390 FileListBase = NULL;
\r
2391 if(GetFocus() == GetLocalHwnd())
\r
2394 MakeSelectedFileList(Win, NO, NO, &FileListBase, &CancelFlg);
\r
2399 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2400 MakeSelectedFileList(Win, YES, NO, &FileListBase, &CancelFlg);
\r
2408 // DisableUserOpe();
\r
2412 Pos = FileListBase;
\r
2413 while(Pos != NULL)
\r
2415 if(Pos->Node == NODE_FILE)
\r
2417 DelNotifyAndDo(Pos, Win, &Sts, &DelFlg, CurDir);
\r
2425 DeleteAllDir(FileListBase, Win, &Sts, &DelFlg, CurDir);
\r
2427 if(Win == WIN_REMOTE)
\r
2429 AskRemoteCurDir(Tmp, FMAX_PATH);
\r
2430 if(strcmp(Tmp, CurDir) != 0)
\r
2431 DoCWD(Tmp, NO, NO, NO);
\r
2434 DeleteFileList(&FileListBase);
\r
2438 if(Win == WIN_LOCAL)
\r
2439 GetLocalDirForWnd();
\r
2441 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2445 // EnableUserOpe();
\r
2453 /*----- サブディレクトリ以下を全て削除する ------------------------------------
\r
2456 * FILELIST *Dt : 削除するファイルのリスト
\r
2457 * int Win : ウインドウ番号 (WIN_xxx)
\r
2458 * int *Sw : 操作方法 (YES/NO/YES_ALL/NO_ALL)
\r
2459 * int *Flg : ファイルを削除したかどうかのフラグ (YES/NO)
\r
2460 * char *CurDir : カレントディレクトリ
\r
2464 *----------------------------------------------------------------------------*/
\r
2466 static void DeleteAllDir(FILELIST *Dt, int Win, int *Sw, int *Flg, char *CurDir)
\r
2470 if(Dt->Node == NODE_DIR)
\r
2472 DeleteAllDir(Dt->Next, Win, Sw, Flg, CurDir);
\r
2476 DelNotifyAndDo(Dt, Win, Sw, Flg, CurDir);
\r
2485 /*----- 削除するかどうかの確認と削除実行 --------------------------------------
\r
2488 * FILELIST *Dt : 削除するファイルのリスト
\r
2489 * int Win : ウインドウ番号 (WIN_xxx)
\r
2490 * int *Sw : 操作方法 (YES/NO/YES_ALL/NO_ALL)
\r
2491 * int *Flg : ファイルを削除したかどうかのフラグ (YES/NO)
\r
2492 * char *CurDir : カレントディレクトリ
\r
2496 *----------------------------------------------------------------------------*/
\r
2498 static void DelNotifyAndDo(FILELIST *Dt, int Win, int *Sw, int *Flg, char *CurDir)
\r
2500 char Path[FMAX_PATH+1];
\r
2502 if(Win == WIN_LOCAL)
\r
2504 AskLocalCurDir(Path, FMAX_PATH);
\r
2506 strcat(Path, Dt->File);
\r
2507 ReplaceAll(Path, '/', '\\');
\r
2511 AskRemoteCurDir(Path, FMAX_PATH);
\r
2512 SetSlashTail(Path);
\r
2513 strcat(Path, Dt->File);
\r
2514 ReplaceAll(Path, '\\', '/');
\r
2517 if(*Sw != YES_ALL)
\r
2519 sprintf(TmpString, "%s", Path);
\r
2521 // ローカルのファイルのパスの最後の'\\'が消えるバグ修正
\r
2522 // if(AskHostType() == HTYPE_VMS)
\r
2523 if(Win == WIN_REMOTE && AskHostType() == HTYPE_VMS)
\r
2524 ReformToVMSstylePathName(TmpString);
\r
2527 *Sw = DialogBox(GetFtpInst(), MAKEINTRESOURCE(delete_dlg), GetMainHwnd(), DeleteDialogCallBack);
\r
2530 if((*Sw == YES) || (*Sw == YES_ALL))
\r
2532 if(Win == WIN_LOCAL)
\r
2534 if(Dt->Node == NODE_FILE)
\r
2535 DoLocalDELE(Path);
\r
2542 /* フルパスを使わない時のための処理 */
\r
2544 // if(ProcForNonFullpath(Path, CurDir, GetMainHwnd(), 0) == FFFTP_FAIL)
\r
2545 if(ProcForNonFullpath(AskCmdCtrlSkt(), Path, CurDir, GetMainHwnd(), &CancelFlg) == FFFTP_FAIL)
\r
2550 if(Dt->Node == NODE_FILE)
\r
2562 /*----- ファイル削除ダイアログのコールバック ----------------------------------
\r
2565 * HWND hDlg : ウインドウハンドル
\r
2566 * UINT message : メッセージ番号
\r
2567 * WPARAM wParam : メッセージの WPARAM 引数
\r
2568 * LPARAM lParam : メッセージの LPARAM 引数
\r
2572 *----------------------------------------------------------------------------*/
\r
2575 //static BOOL CALLBACK DeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2576 static INT_PTR CALLBACK DeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2580 case WM_INITDIALOG :
\r
2581 if(CurWin == WIN_LOCAL)
\r
2582 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN066);
\r
2584 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN067);
\r
2585 SendDlgItemMessage(hDlg, DELETE_TEXT, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2589 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2592 EndDialog(hDlg, YES);
\r
2596 EndDialog(hDlg, NO);
\r
2600 EndDialog(hDlg, YES_ALL);
\r
2604 EndDialog(hDlg, NO_ALL);
\r
2613 /*----- ファイル一覧で指定されたファイルの名前を変更する ----------------------
\r
2620 *----------------------------------------------------------------------------*/
\r
2622 void RenameProc(void)
\r
2625 FILELIST *FileListBase;
\r
2627 char New[FMAX_PATH+1];
\r
2634 Sts = FFFTP_SUCCESS;
\r
2635 if(GetFocus() == GetLocalHwnd())
\r
2640 Sts = CheckClosedAndReconnect();
\r
2643 if(Sts == FFFTP_SUCCESS)
\r
2647 FileListBase = NULL;
\r
2648 MakeSelectedFileList(Win, NO, NO, &FileListBase, &CancelFlg);
\r
2652 Pos = FileListBase;
\r
2653 while(Pos != NULL)
\r
2655 if((Pos->Node == NODE_FILE) || (Pos->Node == NODE_DIR))
\r
2657 strcpy(TmpString, Pos->File);
\r
2659 Sts = DialogBox(GetFtpInst(), MAKEINTRESOURCE(rename_dlg), GetMainHwnd(), RenameDialogCallBack);
\r
2664 if((Sts == YES) && (strlen(TmpString) != 0))
\r
2666 strcpy(New, TmpString);
\r
2667 if(Win == WIN_LOCAL)
\r
2668 DoLocalRENAME(Pos->File, New);
\r
2670 DoRENAME(Pos->File, New);
\r
2676 DeleteFileList(&FileListBase);
\r
2680 if(Win == WIN_LOCAL)
\r
2681 GetLocalDirForWnd();
\r
2683 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2693 // リモート側でのファイルの移動(リネーム)を行う
\r
2695 // RenameProc()をベースに改造。(2007.9.5 yutaka)
\r
2697 void MoveRemoteFileProc(int drop_index)
\r
2700 FILELIST *FileListBase;
\r
2703 char New[FMAX_PATH+1];
\r
2704 char Old[FMAX_PATH+1];
\r
2705 char HostDir[FMAX_PATH+1];
\r
2712 if(MoveMode == MOVE_DISABLE)
\r
2717 AskRemoteCurDir(HostDir, FMAX_PATH);
\r
2721 // GetNodeName(WIN_REMOTE, drop_index, Pkt.File, FMAX_PATH);
\r
2722 if(drop_index >= 0)
\r
2723 GetNodeName(WIN_REMOTE, drop_index, Pkt.File, FMAX_PATH);
\r
2725 strcpy(Pkt.File, "..");
\r
2727 if(MoveMode == MOVE_DLG)
\r
2729 if(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(move_notify_dlg), GetRemoteHwnd(), ExeEscTextDialogProc, (LPARAM)Pkt.File) == NO)
\r
2735 Sts = FFFTP_SUCCESS;
\r
2737 if(GetFocus() == GetLocalHwnd())
\r
2742 Sts = CheckClosedAndReconnect();
\r
2746 Sts = CheckClosedAndReconnect();
\r
2749 if(Sts == FFFTP_SUCCESS)
\r
2753 FileListBase = NULL;
\r
2754 MakeSelectedFileList(Win, NO, NO, &FileListBase, &CancelFlg);
\r
2758 Pos = FileListBase;
\r
2759 while(Pos != NULL)
\r
2761 if((Pos->Node == NODE_FILE) || (Pos->Node == NODE_DIR))
\r
2763 strcpy(TmpString, Pos->File);
\r
2766 Sts = DialogBox(GetFtpInst(), MAKEINTRESOURCE(rename_dlg), GetMainHwnd(), RenameDialogCallBack);
\r
2774 if((Sts == YES) && (strlen(TmpString) != 0))
\r
2777 strncpy_s(Old, sizeof(Old), HostDir, _TRUNCATE);
\r
2778 strncat_s(Old, sizeof(Old), "/", _TRUNCATE);
\r
2779 strncat_s(Old, sizeof(Old), Pos->File, _TRUNCATE);
\r
2782 strncpy_s(New, sizeof(New), HostDir, _TRUNCATE);
\r
2783 strncat_s(New, sizeof(New), "/", _TRUNCATE);
\r
2784 strncat_s(New, sizeof(New), Pkt.File, _TRUNCATE);
\r
2785 strncat_s(New, sizeof(New), "/", _TRUNCATE);
\r
2786 strncat_s(New, sizeof(New), Pos->File, _TRUNCATE);
\r
2788 if(Win == WIN_LOCAL)
\r
2789 DoLocalRENAME(Old, New);
\r
2791 DoRENAME(Old, New);
\r
2797 DeleteFileList(&FileListBase);
\r
2801 if(Win == WIN_LOCAL) {
\r
2802 GetLocalDirForWnd();
\r
2804 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2806 strncpy_s(New, sizeof(New), HostDir, _TRUNCATE);
\r
2807 strncat_s(New, sizeof(New), "/", _TRUNCATE);
\r
2808 strncat_s(New, sizeof(New), Pkt.File, _TRUNCATE);
\r
2809 DoCWD(New, YES, YES, YES);
\r
2810 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2821 /*----- 新ファイル名入力ダイアログのコールバック ------------------------------
\r
2824 * HWND hDlg : ウインドウハンドル
\r
2825 * UINT message : メッセージ番号
\r
2826 * WPARAM wParam : メッセージの WPARAM 引数
\r
2827 * LPARAM lParam : メッセージの LPARAM 引数
\r
2831 *----------------------------------------------------------------------------*/
\r
2834 //static BOOL CALLBACK RenameDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2835 static INT_PTR CALLBACK RenameDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2839 case WM_INITDIALOG :
\r
2840 if(CurWin == WIN_LOCAL)
\r
2841 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN068);
\r
2843 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN069);
\r
2844 SendDlgItemMessage(hDlg, RENAME_NEW, EM_LIMITTEXT, FMAX_PATH, 0);
\r
2845 SendDlgItemMessage(hDlg, RENAME_NEW, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2846 SendDlgItemMessage(hDlg, RENAME_TEXT, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2850 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2853 SendDlgItemMessage(hDlg, RENAME_NEW, WM_GETTEXT, FMAX_PATH, (LPARAM)TmpString);
\r
2854 EndDialog(hDlg, YES);
\r
2858 EndDialog(hDlg, NO);
\r
2861 case RENAME_STOP :
\r
2862 EndDialog(hDlg, NO_ALL);
\r
2871 /*----- 新しいディレクトリを作成する ------------------------------------------
\r
2878 *----------------------------------------------------------------------------*/
\r
2880 void MkdirProc(void)
\r
2884 char Path[FMAX_PATH+1];
\r
2891 if(GetFocus() == GetLocalHwnd())
\r
2894 Title = MSGJPN070;
\r
2899 Title = MSGJPN071;
\r
2903 Sts = InputDialogBox(mkdir_dlg, GetMainHwnd(), Title, Path, FMAX_PATH+1, &Tmp, IDH_HELP_TOPIC_0000001);
\r
2905 if((Sts == YES) && (strlen(Path) != 0))
\r
2907 if(Win == WIN_LOCAL)
\r
2911 GetLocalDirForWnd();
\r
2916 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2920 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2929 /*----- ヒストリリストを使ったディレクトリの移動 ------------------------------
\r
2932 * HWND hWnd : コンボボックスのウインドウハンドル
\r
2936 *----------------------------------------------------------------------------*/
\r
2938 void ChangeDirComboProc(HWND hWnd)
\r
2940 char Tmp[FMAX_PATH+1];
\r
2946 if((i = SendMessage(hWnd, CB_GETCURSEL, 0, 0)) != CB_ERR)
\r
2948 SendMessage(hWnd, CB_GETLBTEXT, i, (LPARAM)Tmp);
\r
2950 if(hWnd == GetLocalHistHwnd())
\r
2954 GetLocalDirForWnd();
\r
2959 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2962 if(DoCWD(Tmp, YES, NO, YES) < FTP_RETRY)
\r
2963 GetRemoteDirForWnd(CACHE_NORMAL, &CancelFlg);
\r
2972 /*----- ブックマークを使ったディレクトリの移動 --------------------------------
\r
2975 * int MarkID : ブックマークのメニューID
\r
2979 *----------------------------------------------------------------------------*/
\r
2981 void ChangeDirBmarkProc(int MarkID)
\r
2983 char Local[FMAX_PATH+1];
\r
2984 char Remote[FMAX_PATH+1];
\r
2990 Sts = AskBookMarkText(MarkID, Local, Remote, FMAX_PATH+1);
\r
2991 if((Sts == BMARK_TYPE_LOCAL) || (Sts == BMARK_TYPE_BOTH))
\r
2994 if(DoLocalCWD(Local) == FFFTP_SUCCESS)
\r
2995 GetLocalDirForWnd();
\r
2999 if((Sts == BMARK_TYPE_REMOTE) || (Sts == BMARK_TYPE_BOTH))
\r
3001 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
3004 if(DoCWD(Remote, YES, NO, YES) < FTP_RETRY)
\r
3005 GetRemoteDirForWnd(CACHE_NORMAL, &CancelFlg);
\r
3013 /*----- ディレクトリ名を入力してディレクトリの移動 ----------------------------
\r
3016 * int Win : ウインドウ番号 (WIN_xxx)
\r
3020 *----------------------------------------------------------------------------*/
\r
3022 void ChangeDirDirectProc(int Win)
\r
3025 char Path[FMAX_PATH+1];
\r
3032 if(Win == WIN_LOCAL)
\r
3033 Title = MSGJPN072;
\r
3035 Title = MSGJPN073;
\r
3038 if(Win == WIN_LOCAL)
\r
3039 // フォルダ選択ダイアログを直接表示
\r
3040 // Sts = InputDialogBox(chdir_br_dlg, GetMainHwnd(), Title, Path, FMAX_PATH+1, &Tmp, IDH_HELP_TOPIC_0000001);
\r
3042 if(SelectDir(GetMainHwnd(), Path, FMAX_PATH) == TRUE)
\r
3046 Sts = InputDialogBox(chdir_dlg, GetMainHwnd(), Title, Path, FMAX_PATH+1, &Tmp, IDH_HELP_TOPIC_0000001);
\r
3048 if((Sts == YES) && (strlen(Path) != 0))
\r
3050 if(Win == WIN_LOCAL)
\r
3054 GetLocalDirForWnd();
\r
3059 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
3062 if(DoCWD(Path, YES, NO, YES) < FTP_RETRY)
\r
3063 GetRemoteDirForWnd(CACHE_NORMAL, &CancelFlg);
\r
3072 /*----- Dropされたファイルによるディレクトリの移動 ----------------------------
\r
3075 * WPARAM wParam : ドロップされたファイルの情報
\r
3079 *----------------------------------------------------------------------------*/
\r
3081 void ChangeDirDropFileProc(WPARAM wParam)
\r
3083 char Path[FMAX_PATH+1];
\r
3086 MakeDroppedDir(wParam, Path);
\r
3088 GetLocalDirForWnd();
\r
3094 /*----- ファイルの属性変更 ----------------------------------------------------
\r
3101 *----------------------------------------------------------------------------*/
\r
3103 void ChmodProc(void)
\r
3106 FILELIST *FileListBase;
\r
3116 if(GetFocus() == GetRemoteHwnd())
\r
3118 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
3121 FileListBase = NULL;
\r
3122 MakeSelectedFileList(WIN_REMOTE, NO, NO, &FileListBase, &CancelFlg);
\r
3123 if(FileListBase != NULL)
\r
3125 sprintf(Tmp, "%03X", FileListBase->Attr);
\r
3126 if(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(chmod_dlg), GetMainHwnd(), ChmodDialogCallBack, (LPARAM)Tmp) == YES)
\r
3129 Pos = FileListBase;
\r
3130 while(Pos != NULL)
\r
3132 if((Pos->Node == NODE_FILE) || (Pos->Node == NODE_DIR))
\r
3134 DoCHMOD(Pos->File, Tmp);
\r
3139 if(ChmodFlg == YES)
\r
3140 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
3143 DeleteFileList(&FileListBase);
\r
3147 else if(GetFocus() == GetLocalHwnd())
\r
3150 FileListBase = NULL;
\r
3151 MakeSelectedFileList(WIN_LOCAL, NO, NO, &FileListBase, &CancelFlg);
\r
3152 if(FileListBase != NULL)
\r
3154 if((Buf = malloc(1)) != NULL)
\r
3158 Pos = FileListBase;
\r
3159 while(Pos != NULL)
\r
3161 if((BufTmp = realloc(Buf, BufLen + strlen(Pos->File) + 2)) != NULL)
\r
3164 strcpy(Buf+BufLen, Pos->File);
\r
3165 BufLen += strlen(Pos->File) + 1;
\r
3170 memset(Buf+BufLen, NUL, 1);
\r
3171 DispFileProperty(Buf);
\r
3175 DeleteFileList(&FileListBase);
\r
3182 /*----- 属性変更ダイアログのコールバック --------------------------------------
\r
3185 * HWND hDlg : ウインドウハンドル
\r
3186 * UINT message : メッセージ番号
\r
3187 * WPARAM wParam : メッセージの WPARAM 引数
\r
3188 * LPARAM lParam : メッセージの LPARAM 引数
\r
3192 *----------------------------------------------------------------------------*/
\r
3195 //BOOL CALLBACK ChmodDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
3196 INT_PTR CALLBACK ChmodDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
3204 case WM_INITDIALOG :
\r
3205 Buf = (char *)lParam;
\r
3206 SendDlgItemMessage(hDlg, PERM_NOW, EM_LIMITTEXT, 4, 0);
\r
3207 SendDlgItemMessage(hDlg, PERM_NOW, WM_SETTEXT, 0, (LPARAM)Buf);
\r
3208 SetAttrToDialog(hDlg, xtoi(Buf));
\r
3212 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
3215 SendDlgItemMessage(hDlg, PERM_NOW, WM_GETTEXT, 5, (LPARAM)Buf);
\r
3216 EndDialog(hDlg, YES);
\r
3220 EndDialog(hDlg, NO);
\r
3223 case PERM_O_READ :
\r
3224 case PERM_O_WRITE :
\r
3225 case PERM_O_EXEC :
\r
3226 case PERM_G_READ :
\r
3227 case PERM_G_WRITE :
\r
3228 case PERM_G_EXEC :
\r
3229 case PERM_A_READ :
\r
3230 case PERM_A_WRITE :
\r
3231 case PERM_A_EXEC :
\r
3232 Tmp = GetAttrFromDialog(hDlg);
\r
3233 sprintf(Str, "%03X", Tmp);
\r
3234 SendDlgItemMessage(hDlg, PERM_NOW, WM_SETTEXT, 0, (LPARAM)Str);
\r
3238 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000017);
\r
3247 /*----- 属性をダイアログボックスに設定 ----------------------------------------
\r
3250 * HWND hWnd : ダイアログボックスのウインドウハンドル
\r
3255 *----------------------------------------------------------------------------*/
\r
3257 static void SetAttrToDialog(HWND hDlg, int Attr)
\r
3260 SendDlgItemMessage(hDlg, PERM_O_READ, BM_SETCHECK, 1, 0);
\r
3262 SendDlgItemMessage(hDlg, PERM_O_WRITE, BM_SETCHECK, 1, 0);
\r
3264 SendDlgItemMessage(hDlg, PERM_O_EXEC, BM_SETCHECK, 1, 0);
\r
3267 SendDlgItemMessage(hDlg, PERM_G_READ, BM_SETCHECK, 1, 0);
\r
3269 SendDlgItemMessage(hDlg, PERM_G_WRITE, BM_SETCHECK, 1, 0);
\r
3271 SendDlgItemMessage(hDlg, PERM_G_EXEC, BM_SETCHECK, 1, 0);
\r
3274 SendDlgItemMessage(hDlg, PERM_A_READ, BM_SETCHECK, 1, 0);
\r
3276 SendDlgItemMessage(hDlg, PERM_A_WRITE, BM_SETCHECK, 1, 0);
\r
3278 SendDlgItemMessage(hDlg, PERM_A_EXEC, BM_SETCHECK, 1, 0);
\r
3284 /*----- ダイアログボックスの内容から属性を取得 --------------------------------
\r
3287 * HWND hWnd : ダイアログボックスのウインドウハンドル
\r
3291 *----------------------------------------------------------------------------*/
\r
3293 static int GetAttrFromDialog(HWND hDlg)
\r
3299 if(SendDlgItemMessage(hDlg, PERM_O_READ, BM_GETCHECK, 0, 0) == 1)
\r
3301 if(SendDlgItemMessage(hDlg, PERM_O_WRITE, BM_GETCHECK, 0, 0) == 1)
\r
3303 if(SendDlgItemMessage(hDlg, PERM_O_EXEC, BM_GETCHECK, 0, 0) == 1)
\r
3306 if(SendDlgItemMessage(hDlg, PERM_G_READ, BM_GETCHECK, 0, 0) == 1)
\r
3308 if(SendDlgItemMessage(hDlg, PERM_G_WRITE, BM_GETCHECK, 0, 0) == 1)
\r
3310 if(SendDlgItemMessage(hDlg, PERM_G_EXEC, BM_GETCHECK, 0, 0) == 1)
\r
3313 if(SendDlgItemMessage(hDlg, PERM_A_READ, BM_GETCHECK, 0, 0) == 1)
\r
3315 if(SendDlgItemMessage(hDlg, PERM_A_WRITE, BM_GETCHECK, 0, 0) == 1)
\r
3317 if(SendDlgItemMessage(hDlg, PERM_A_EXEC, BM_GETCHECK, 0, 0) == 1)
\r
3326 /*----- 任意のコマンドを送る --------------------------------------------------
\r
3333 *----------------------------------------------------------------------------*/
\r
3335 void SomeCmdProc(void)
\r
3339 FILELIST *FileListBase;
\r
3344 if(GetFocus() == GetRemoteHwnd())
\r
3346 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
3349 FileListBase = NULL;
\r
3350 MakeSelectedFileList(WIN_REMOTE, NO, NO, &FileListBase, &CancelFlg);
\r
3351 memset(Cmd, NUL, 81);
\r
3352 if(FileListBase != NULL)
\r
3354 strncpy(Cmd, FileListBase->File, 80);
\r
3356 DeleteFileList(&FileListBase);
\r
3358 if(InputDialogBox(somecmd_dlg, GetMainHwnd(), NULL, Cmd, 81, &Tmp, IDH_HELP_TOPIC_0000023) == YES)
\r
3362 DoQUOTE(AskCmdCtrlSkt(), Cmd, &CancelFlg);
\r
3373 /*----- ファイル総容量の計算を行う --------------------------------------------
\r
3380 *----------------------------------------------------------------------------*/
\r
3382 void CalcFileSizeProc(void)
\r
3384 FILELIST *ListBase;
\r
3393 if((All = DialogBox(GetFtpInst(), MAKEINTRESOURCE(filesize_notify_dlg), GetMainHwnd(), SizeNotifyDlgWndProc)) != NO_ALL)
\r
3395 Sts = FFFTP_SUCCESS;
\r
3396 if(GetFocus() == GetLocalHwnd())
\r
3401 Sts = CheckClosedAndReconnect();
\r
3404 if(Sts == FFFTP_SUCCESS)
\r
3407 MakeSelectedFileList(Win, YES, All, &ListBase, &CancelFlg);
\r
3411 while(Pos != NULL)
\r
3413 if(Pos->Node != NODE_DIR)
\r
3414 FileSize += Pos->Size;
\r
3417 DeleteFileList(&ListBase);
\r
3418 DialogBox(GetFtpInst(), MAKEINTRESOURCE(filesize_dlg), GetMainHwnd(), SizeDlgWndProc);
\r
3425 /*----- ファイル容量検索確認ダイアログのコールバック --------------------------
\r
3428 * HWND hDlg : ウインドウハンドル
\r
3429 * UINT message : メッセージ番号
\r
3430 * WPARAM wParam : メッセージの WPARAM 引数
\r
3431 * LPARAM lParam : メッセージの LPARAM 引数
\r
3435 *----------------------------------------------------------------------------*/
\r
3437 static LRESULT CALLBACK SizeNotifyDlgWndProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
\r
3441 case WM_INITDIALOG :
\r
3442 if(GetFocus() == GetLocalHwnd())
\r
3443 SendDlgItemMessage(hDlg, FSNOTIFY_TITLE, WM_SETTEXT, 0, (LPARAM)MSGJPN074);
\r
3445 SendDlgItemMessage(hDlg, FSNOTIFY_TITLE, WM_SETTEXT, 0, (LPARAM)MSGJPN075);
\r
3449 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
3452 if(SendDlgItemMessage(hDlg, FSNOTIFY_SEL_ONLY, BM_GETCHECK, 0, 0) == 1)
\r
3453 EndDialog(hDlg, NO);
\r
3455 EndDialog(hDlg, YES);
\r
3459 EndDialog(hDlg, NO_ALL);
\r
3468 /*----- ファイル容量検索ダイアログのコールバック ------------------------------
\r
3471 * HWND hDlg : ウインドウハンドル
\r
3472 * UINT message : メッセージ番号
\r
3473 * WPARAM wParam : メッセージの WPARAM 引数
\r
3474 * LPARAM lParam : メッセージの LPARAM 引数
\r
3478 *----------------------------------------------------------------------------*/
\r
3480 static LRESULT CALLBACK SizeDlgWndProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
\r
3482 char Tmp[FMAX_PATH+1];
\r
3486 case WM_INITDIALOG :
\r
3487 if(GetFocus() == GetLocalHwnd())
\r
3488 SendDlgItemMessage(hDlg, FSIZE_TITLE, WM_SETTEXT, 0, (LPARAM)MSGJPN076);
\r
3490 SendDlgItemMessage(hDlg, FSIZE_TITLE, WM_SETTEXT, 0, (LPARAM)MSGJPN077);
\r
3492 MakeSizeString(FileSize, Tmp);
\r
3493 SendDlgItemMessage(hDlg, FSIZE_SIZE, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
3497 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
3501 EndDialog(hDlg, YES);
\r
3511 /*----- ディレクトリ移動失敗時のエラーを表示 ----------------------------------
\r
3514 * HWND hDlg : ウインドウハンドル
\r
3518 *----------------------------------------------------------------------------*/
\r
3520 void DispCWDerror(HWND hWnd)
\r
3522 DialogBox(GetFtpInst(), MAKEINTRESOURCE(cwderr_dlg), hWnd, ExeEscDialogProc);
\r
3527 /*----- URLをクリップボードにコピー -------------------------------------------
\r
3534 *----------------------------------------------------------------------------*/
\r
3536 void CopyURLtoClipBoard(void)
\r
3538 FILELIST *FileListBase;
\r
3541 char Path[FMAX_PATH+1];
\r
3542 char Host[HOST_ADRS_LEN+1];
\r
3547 if(GetFocus() == GetRemoteHwnd())
\r
3549 FileListBase = NULL;
\r
3550 MakeSelectedFileList(WIN_REMOTE, NO, NO, &FileListBase, &CancelFlg);
\r
3551 if(FileListBase != NULL)
\r
3553 strcpy(Host, AskHostAdrs());
\r
3556 Pos = FileListBase;
\r
3557 while(Pos != NULL)
\r
3559 AskRemoteCurDir(Path, FMAX_PATH);
\r
3560 SetSlashTail(Path);
\r
3561 strcat(Path, Pos->File);
\r
3563 if(AskHostType() == HTYPE_VMS)
\r
3564 ReformToVMSstylePathName(Path);
\r
3567 if(AskHostPort() != PORT_NOR)
\r
3568 sprintf(Port, ":%d", AskHostPort());
\r
3571 Total += strlen(Path) + strlen(Host) + strlen(Port) + 8; /* 8は "ftp://\r\n" のぶん */
\r
3572 if(AskHostType() == HTYPE_VMS)
\r
3575 if((Buf = realloc(Buf, Total+1)) == NULL)
\r
3578 if(AskHostType() != HTYPE_VMS)
\r
3579 sprintf(Buf + Set, "ftp://%s%s%s\r\n", Host, Port, Path);
\r
3581 sprintf(Buf + Set, "ftp://%s%s/%s\r\n", Host, Port, Path);
\r
3588 CopyStrToClipBoard(Buf);
\r
3592 DeleteFileList(&FileListBase);
\r
3598 /*----- フルパスを使わないファイルアクセスの準備 ------------------------------
\r
3601 * char *Path : パス名
\r
3602 * char *CurDir : カレントディレクトリ
\r
3603 * HWND hWnd : エラーウインドウを表示する際の親ウインドウ
\r
3604 * int Type : 使用するソケットの種類
\r
3605 * 0=コマンドソケット, 1=転送ソケット
\r
3608 * int ステータス(FFFTP_SUCCESS/FFFTP_FAIL)
\r
3612 * このモジュール内で CWD を行ない、
\r
3613 * Path にファイル名のみ残す。(パス名は消す)
\r
3614 *----------------------------------------------------------------------------*/
\r
3617 //int ProcForNonFullpath(char *Path, char *CurDir, HWND hWnd, int Type)
\r
3618 int ProcForNonFullpath(SOCKET cSkt, char *Path, char *CurDir, HWND hWnd, int *CancelCheckWork)
\r
3622 char Tmp[FMAX_PATH+1];
\r
3624 Sts = FFFTP_SUCCESS;
\r
3625 if(AskNoFullPathMode() == YES)
\r
3627 strcpy(Tmp, Path);
\r
3628 if(AskHostType() == HTYPE_VMS)
\r
3630 GetUpperDirEraseTopSlash(Tmp);
\r
3631 ReformToVMSstyleDirName(Tmp);
\r
3633 else if(AskHostType() == HTYPE_STRATUS)
\r
3634 GetUpperDirEraseTopSlash(Tmp);
\r
3638 if(strcmp(Tmp, CurDir) != 0)
\r
3642 // Cmd = CommandProcCmd(NULL, "CWD %s", Tmp);
\r
3644 // Cmd = CommandProcTrn(NULL, "CWD %s", Tmp);
\r
3645 Cmd = CommandProcTrn(cSkt, NULL, CancelCheckWork, "CWD %s", Tmp);
\r
3647 if(Cmd/100 != FTP_COMPLETE)
\r
3649 DispCWDerror(hWnd);
\r
3653 strcpy(CurDir, Tmp);
\r
3655 strcpy(Path, GetFileName(Path));
\r
3661 /*----- ディレクトリ名をVAX VMSスタイルに変換する -----------------------------
\r
3664 * char *Path : パス名
\r
3670 * ddd:[xxx.yyy]/rrr/ppp --> ddd:[xxx.yyy.rrr.ppp]
\r
3671 *----------------------------------------------------------------------------*/
\r
3673 void ReformToVMSstyleDirName(char *Path)
\r
3678 if((Btm = strchr(Path, ']')) != NULL)
\r
3681 while((Pos = strchr(Pos, '/')) != NULL)
\r
3684 memmove(Btm, Btm+1, strlen(Btm+1)+1);
\r
3685 Pos = strchr(Path, NUL);
\r
3686 if(*(Pos-1) == '.')
\r
3697 /*----- ファイル名をVAX VMSスタイルに変換する ---------------------------------
\r
3700 * char *Path : パス名
\r
3706 * ddd:[xxx.yyy]/rrr/ppp --> ddd:[xxx.yyy.rrr]ppp
\r
3707 *----------------------------------------------------------------------------*/
\r
3709 void ReformToVMSstylePathName(char *Path)
\r
3711 char Fname[FMAX_PATH+1];
\r
3713 strcpy(Fname, GetFileName(Path));
\r
3715 GetUpperDirEraseTopSlash(Path);
\r
3716 ReformToVMSstyleDirName(Path);
\r
3718 strcat(Path, Fname);
\r
3724 #if defined(HAVE_OPENVMS)
\r
3725 /*----- VMSの"HOGE.DIR;?"というディレクトリ名から"HOGE"を取り出す ---------------
\r
3728 * char *DirName : "HOGE.DIR;?"形式のディレクトリ名
\r
3729 * int Flg : ";"のチェックをする(TRUE)かしない(FALSE)か
\r
3736 *----------------------------------------------------------------------------*/
\r
3738 void ReformVMSDirName(char *DirName, int Flg)
\r
3742 if (Flg == TRUE) {
\r
3743 /* ';'がない場合はVMS形式じゃなさそうなので何もしない */
\r
3744 if ((p = strrchr(DirName, ';')) == NULL)
\r
3748 /* ".DIR"があったらつぶす */
\r
3749 if ((p = strrchr(DirName, '.'))) {
\r
3750 if (memcmp(p + 1, "DIR", 3) == 0)
\r
3757 /*----- ファイル名に使えない文字がないかチェックし名前を変更する --------------
\r
3760 * char *Fname : ファイル名
\r
3764 * FFFTP_SUCCESS/FFFTP_FAIL=中止する
\r
3768 *----------------------------------------------------------------------------*/
\r
3770 static int RenameUnuseableName(char *Fname)
\r
3775 Ret = FFFTP_SUCCESS;
\r
3778 if((_mbschr(Fname, ':') != NULL) ||
\r
3779 (_mbschr(Fname, '*') != NULL) ||
\r
3780 (_mbschr(Fname, '?') != NULL) ||
\r
3781 (_mbschr(Fname, '<') != NULL) ||
\r
3782 (_mbschr(Fname, '>') != NULL) ||
\r
3783 (_mbschr(Fname, '|') != NULL) ||
\r
3784 (_mbschr(Fname, '\x22') != NULL) ||
\r
3785 (_mbschr(Fname, '\\') != NULL))
\r
3787 if(InputDialogBox(forcerename_dlg, GetMainHwnd(), NULL, Fname, FMAX_PATH+1, &Tmp, IDH_HELP_TOPIC_0000001) == NO)
\r
3801 // NOOPコマンドでは効果が無いホストが多いためLISTコマンドを使用
\r
3802 void NoopProc(int Force)
\r
3804 // CancelFlg = NO;
\r
3805 if(Force == YES || (AskConnecting() == YES && AskUserOpeDisabled() == NO))
\r
3807 if(AskReuseCmdSkt() == NO || AskShareProh() == YES || AskTransferNow() == NO)
\r
3810 DoDirListCmdSkt("", "", 999, &CancelFlg);
\r
3817 void AbortRecoveryProc(void)
\r
3820 if(AskConnecting() == YES && AskUserOpeDisabled() == NO)
\r
3822 if(AskReuseCmdSkt() == NO || AskShareProh() == YES || AskTransferNow() == NO)
\r
3824 if(AskErrorReconnect() == YES)
\r
3827 ReConnectCmdSkt();
\r
3828 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
3832 RemoveReceivedData(AskCmdCtrlSkt());
\r