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 /*===== ローカルなワーク =====*/
\r
116 static char TmpString[FMAX_PATH+80]; /* テンポラリ */
\r
117 #if defined(HAVE_TANDEM)
\r
118 static char TmpFileCode[5]; /* テンポラリ */
\r
120 static int CurWin; /* ウインドウ番号 */
\r
122 int UpExistMode = EXIST_OVW; /* アップロードで同じ名前のファイルがある時の扱い方 EXIST_xxx */
\r
123 int ExistMode = EXIST_OVW; /* 同じ名前のファイルがある時の扱い方 EXIST_xxx */
\r
124 static int ExistNotify; /* 確認ダイアログを出すかどうか YES/NO */
\r
126 static double FileSize; /* ファイル総容量 */
\r
130 /*----- ファイル一覧で指定されたファイルをダウンロードする --------------------
\r
133 * int ChName : 名前を変えるかどうか (YES/NO)
\r
134 * int ForceFile : ディレクトリをファイル見なすかどうか (YES/NO)
\r
135 * int All : 全てが選ばれている物として扱うかどうか (YES/NO)
\r
139 *----------------------------------------------------------------------------*/
\r
142 // ローカル側のパスから必要なフォルダを作成
\r
143 int MakeDirFromLocalPath(char* LocalFile, char* Old)
\r
151 pDelimiter = LocalFile;
\r
153 while(pNext = strchr(pDelimiter, '\\'))
\r
155 Len = pNext - LocalFile;
\r
156 strncpy(Pkt.LocalFile, LocalFile, Len);
\r
157 Pkt.LocalFile[Len] = '\0';
\r
158 if(strncmp(LocalFile, Old, Len + 1) != 0)
\r
160 Cat = Pkt.LocalFile + (pDelimiter - LocalFile);
\r
161 if(FnameCnv == FNAME_LOWER)
\r
163 else if(FnameCnv == FNAME_UPPER)
\r
165 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
167 strcpy(Pkt.Cmd, "MKD ");
\r
168 strcpy(Pkt.RemoteFile, "");
\r
169 AddTransFileList(&Pkt);
\r
173 pDelimiter = pNext + 1;
\r
178 void DownloadProc(int ChName, int ForceFile, int All)
\r
180 FILELIST *FileListBase;
\r
184 char Tmp[FMAX_PATH+1];
\r
189 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
194 // KeepTransferDialog(YES);
\r
196 FileListBase = NULL;
\r
197 MakeSelectedFileList(WIN_REMOTE, (ForceFile == YES ? NO : YES), All, &FileListBase, &CancelFlg);
\r
199 if(AskNoFullPathMode() == YES)
\r
201 strcpy(Pkt.Cmd, "SETCUR");
\r
202 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
203 AddTransFileList(&Pkt);
\r
206 Pos = FileListBase;
\r
209 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
210 SetYenTail(Pkt.LocalFile);
\r
211 strcpy(TmpString, Pos->File);
\r
212 if((ChName == NO) || ((ForceFile == NO) && (Pos->Node == NODE_DIR)))
\r
214 if(FnameCnv == FNAME_LOWER)
\r
215 _mbslwr(TmpString);
\r
216 else if(FnameCnv == FNAME_UPPER)
\r
217 _mbsupr(TmpString);
\r
218 RemoveAfterSemicolon(TmpString);
\r
219 if(RenameUnuseableName(TmpString) == FFFTP_FAIL)
\r
224 CurWin = WIN_REMOTE;
\r
225 if(DialogBox(GetFtpInst(), MAKEINTRESOURCE(updown_as_dlg), GetMainHwnd(), UpDownAsDialogCallBack) == YES)
\r
227 if(RenameUnuseableName(TmpString) == FFFTP_FAIL)
\r
233 strcat(Pkt.LocalFile, TmpString);
\r
234 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
236 if((ForceFile == NO) && (Pos->Node == NODE_DIR))
\r
238 strcpy(Pkt.Cmd, "MKD ");
\r
239 strcpy(Pkt.RemoteFile, "");
\r
240 AddTransFileList(&Pkt);
\r
242 else if((Pos->Node == NODE_FILE) ||
\r
243 ((ForceFile == YES) && (Pos->Node == NODE_DIR)))
\r
245 if(AskHostType() == HTYPE_ACOS)
\r
247 strcpy(Pkt.RemoteFile, "'");
\r
248 strcat(Pkt.RemoteFile, AskHostLsName());
\r
249 strcat(Pkt.RemoteFile, "(");
\r
250 strcat(Pkt.RemoteFile, Pos->File);
\r
251 strcat(Pkt.RemoteFile, ")");
\r
252 strcat(Pkt.RemoteFile, "'");
\r
254 else if(AskHostType() == HTYPE_ACOS_4)
\r
256 strcpy(Pkt.RemoteFile, Pos->File);
\r
260 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
261 SetSlashTail(Pkt.RemoteFile);
\r
262 strcat(Pkt.RemoteFile, Pos->File);
\r
263 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
266 strcpy(Pkt.Cmd, "RETR ");
\r
267 #if defined(HAVE_TANDEM)
\r
268 if(AskHostType() == HTYPE_TANDEM) {
\r
269 if(AskTransferType() != TYPE_X) {
\r
270 Pkt.Type = AskTransferType();
\r
272 Pkt.Attr = Pos->Attr;
\r
273 if (Pkt.Attr == 101)
\r
280 Pkt.Type = AskTransferTypeAssoc(Pkt.RemoteFile, AskTransferType());
\r
281 Pkt.Size = Pos->Size;
\r
282 Pkt.Time = Pos->Time;
\r
283 Pkt.KanjiCode = AskHostKanjiCode();
\r
285 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
286 Pkt.KanaCnv = AskHostKanaCnv();
\r
289 strcpy(Tmp, Pkt.LocalFile);
\r
290 Pkt.Mode = CheckLocalFile(&Pkt); /* Pkt.ExistSize がセットされる */
\r
291 if(Pkt.Mode == EXIST_ABORT)
\r
293 else if(Pkt.Mode != EXIST_IGNORE)
\r
295 // AddTransFileList(&Pkt);
\r
297 if(MakeAllDir == YES)
\r
298 MakeDirFromLocalPath(Pkt.LocalFile, Tmp);
\r
299 AddTransFileList(&Pkt);
\r
305 if(AskNoFullPathMode() == YES)
\r
307 strcpy(Pkt.Cmd, "BACKCUR");
\r
308 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
309 AddTransFileList(&Pkt);
\r
311 DeleteFileList(&FileListBase);
\r
314 // strcpy(Pkt.Cmd, "GOQUIT");
\r
315 // AddTransFileList(&Pkt);
\r
318 AddNullTransFileList();
\r
320 GoForwardTransWindow();
\r
321 // KeepTransferDialog(NO);
\r
329 /*----- 指定されたファイルを一つダウンロードする ------------------------------
\r
332 * char *Fname : ファイル名
\r
336 *----------------------------------------------------------------------------*/
\r
338 void DirectDownloadProc(char *Fname)
\r
342 char Tmp[FMAX_PATH+1];
\r
347 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
352 // KeepTransferDialog(YES);
\r
354 if(AskNoFullPathMode() == YES)
\r
356 strcpy(Pkt.Cmd, "SETCUR");
\r
357 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
358 AddTransFileList(&Pkt);
\r
361 if(strlen(Fname) > 0)
\r
363 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
364 SetYenTail(Pkt.LocalFile);
\r
365 strcpy(TmpString, Fname);
\r
366 if(FnameCnv == FNAME_LOWER)
\r
367 _mbslwr(TmpString);
\r
368 else if(FnameCnv == FNAME_UPPER)
\r
369 _mbsupr(TmpString);
\r
370 RemoveAfterSemicolon(TmpString);
\r
372 if(RenameUnuseableName(TmpString) == FFFTP_SUCCESS)
\r
374 strcat(Pkt.LocalFile, TmpString);
\r
375 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
377 if(AskHostType() == HTYPE_ACOS)
\r
379 strcpy(Pkt.RemoteFile, "'");
\r
380 strcat(Pkt.RemoteFile, AskHostLsName());
\r
381 strcat(Pkt.RemoteFile, "(");
\r
382 strcat(Pkt.RemoteFile, Fname);
\r
383 strcat(Pkt.RemoteFile, ")");
\r
384 strcat(Pkt.RemoteFile, "'");
\r
386 else if(AskHostType() == HTYPE_ACOS_4)
\r
388 strcpy(Pkt.RemoteFile, Fname);
\r
392 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
393 SetSlashTail(Pkt.RemoteFile);
\r
394 strcat(Pkt.RemoteFile, Fname);
\r
395 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
398 strcpy(Pkt.Cmd, "RETR-S ");
\r
399 Pkt.Type = AskTransferTypeAssoc(Pkt.RemoteFile, AskTransferType());
\r
401 /* サイズと日付は転送側スレッドで取得し、セットする */
\r
403 Pkt.KanjiCode = AskHostKanjiCode();
\r
405 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
406 Pkt.KanaCnv = AskHostKanaCnv();
\r
409 strcpy(Tmp, Pkt.LocalFile);
\r
410 Pkt.Mode = CheckLocalFile(&Pkt); /* Pkt.ExistSize がセットされる */
\r
411 if((Pkt.Mode != EXIST_ABORT) && (Pkt.Mode != EXIST_IGNORE))
\r
413 // AddTransFileList(&Pkt);
\r
415 if(MakeAllDir == YES)
\r
416 MakeDirFromLocalPath(Pkt.LocalFile, Tmp);
\r
417 AddTransFileList(&Pkt);
\r
422 if(AskNoFullPathMode() == YES)
\r
424 strcpy(Pkt.Cmd, "BACKCUR");
\r
425 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
426 AddTransFileList(&Pkt);
\r
430 // strcpy(Pkt.Cmd, "GOQUIT");
\r
431 // AddTransFileList(&Pkt);
\r
434 AddNullTransFileList();
\r
436 GoForwardTransWindow();
\r
437 // KeepTransferDialog(NO);
\r
445 /*----- 入力されたファイル名のファイルを一つダウンロードする ------------------
\r
452 *----------------------------------------------------------------------------*/
\r
454 void InputDownloadProc(void)
\r
456 char Path[FMAX_PATH+1];
\r
459 // DisableUserOpe();
\r
462 if(InputDialogBox(downname_dlg, GetMainHwnd(), NULL, Path, FMAX_PATH, &Tmp, IDH_HELP_TOPIC_0000001) == YES)
\r
464 DirectDownloadProc(Path);
\r
467 // EnableUserOpe();
\r
473 /*----- ミラーリングダウンロードを行う ----------------------------------------
\r
476 * int Notify : 確認を行うかどうか (YES/NO)
\r
480 *----------------------------------------------------------------------------*/
\r
482 void MirrorDownloadProc(int Notify)
\r
484 FILELIST *LocalListBase;
\r
485 FILELIST *RemoteListBase;
\r
486 FILELIST *LocalPos;
\r
487 FILELIST *RemotePos;
\r
490 char Name[FMAX_PATH+1];
\r
498 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
505 Notify = DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(mirror_down_dlg), GetMainHwnd(), MirrorNotifyCallBack, 0);
\r
509 if((Notify == YES) || (Notify == YES_LIST))
\r
511 /*===== ファイルリスト取得 =====*/
\r
513 LocalListBase = NULL;
\r
514 MakeSelectedFileList(WIN_LOCAL, YES, YES, &LocalListBase, &CancelFlg);
\r
515 RemoteListBase = NULL;
\r
516 MakeSelectedFileList(WIN_REMOTE, YES, YES, &RemoteListBase, &CancelFlg);
\r
518 RemotePos = RemoteListBase;
\r
519 while(RemotePos != NULL)
\r
521 RemotePos->Attr = YES; /* RemotePos->Attrは転送するかどうかのフラグに使用 (YES/NO) */
\r
522 RemotePos = RemotePos->Next;
\r
525 LocalPos = LocalListBase;
\r
526 while(LocalPos != NULL)
\r
528 if(AskMirrorNoTrn(LocalPos->File, 1) == NO)
\r
530 LocalPos->Attr = YES;
\r
531 LocalPos = LocalPos->Next;
\r
535 LocalPos->Attr = NO; /* LocalPos->Attrは削除するかどうかのフラグに使用 (YES/NO) */
\r
537 if(LocalPos->Node == NODE_DIR)
\r
539 Level = AskDirLevel(LocalPos->File);
\r
540 LocalPos = LocalPos->Next;
\r
541 while(LocalPos != NULL)
\r
543 if((LocalPos->Node == NODE_DIR) &&
\r
544 (AskDirLevel(LocalPos->File) <= Level))
\r
548 LocalPos->Attr = NO;
\r
549 LocalPos = LocalPos->Next;
\r
553 LocalPos = LocalPos->Next;
\r
557 /*===== ファイルリスト比較 =====*/
\r
559 RemotePos = RemoteListBase;
\r
560 while(RemotePos != NULL)
\r
562 if(AskMirrorNoTrn(RemotePos->File, 0) == NO)
\r
564 strcpy(Name, RemotePos->File);
\r
565 // ReplaceAll(Name, '/', '\\');
\r
567 if(MirrorFnameCnv == YES)
\r
568 Mode = COMP_LOWERMATCH;
\r
570 Mode = COMP_STRICT;
\r
572 if((LocalPos = SearchFileList(Name, LocalListBase, Mode)) != NULL)
\r
574 if((RemotePos->Node == NODE_DIR) && (LocalPos->Node == NODE_DIR))
\r
576 LocalPos->Attr = NO;
\r
577 RemotePos->Attr = NO;
\r
579 else if((RemotePos->Node == NODE_FILE) && (LocalPos->Node == NODE_FILE))
\r
581 LocalPos->Attr = NO;
\r
582 if(CompareFileTime(&RemotePos->Time, &LocalPos->Time) <= 0)
\r
583 RemotePos->Attr = NO;
\r
586 RemotePos = RemotePos->Next;
\r
590 if(RemotePos->Node == NODE_FILE)
\r
592 RemotePos->Attr = NO;
\r
593 RemotePos = RemotePos->Next;
\r
597 RemotePos->Attr = NO;
\r
598 Level = AskDirLevel(RemotePos->File);
\r
599 RemotePos = RemotePos->Next;
\r
600 while(RemotePos != NULL)
\r
602 if((RemotePos->Node == NODE_DIR) &&
\r
603 (AskDirLevel(RemotePos->File) <= Level))
\r
607 RemotePos->Attr = NO;
\r
608 RemotePos = RemotePos->Next;
\r
614 DispMirrorFiles(LocalListBase, RemoteListBase);
\r
616 /*===== 削除/アップロード =====*/
\r
618 LocalPos = LocalListBase;
\r
619 while(LocalPos != NULL)
\r
621 if((LocalPos->Attr == YES) && (LocalPos->Node == NODE_FILE))
\r
623 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
624 SetYenTail(Pkt.LocalFile);
\r
625 strcat(Pkt.LocalFile, LocalPos->File);
\r
626 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
627 strcpy(Pkt.RemoteFile, "");
\r
628 strcpy(Pkt.Cmd, "L-DELE ");
\r
629 AddTmpTransFileList(&Pkt, &Base);
\r
631 LocalPos = LocalPos->Next;
\r
633 MirrorDeleteAllLocalDir(LocalListBase, &Pkt, &Base);
\r
636 RemotePos = RemoteListBase;
\r
637 while(RemotePos != NULL)
\r
639 if(RemotePos->Attr == YES)
\r
641 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
642 SetYenTail(Pkt.LocalFile);
\r
643 Cat = strchr(Pkt.LocalFile, NUL);
\r
644 strcat(Pkt.LocalFile, RemotePos->File);
\r
646 if(MirrorFnameCnv == YES)
\r
649 RemoveAfterSemicolon(Cat);
\r
650 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
652 if(RemotePos->Node == NODE_DIR)
\r
654 strcpy(Pkt.RemoteFile, "");
\r
655 strcpy(Pkt.Cmd, "L-MKD ");
\r
656 AddTmpTransFileList(&Pkt, &Base);
\r
658 else if(RemotePos->Node == NODE_FILE)
\r
660 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
661 SetSlashTail(Pkt.RemoteFile);
\r
662 strcat(Pkt.RemoteFile, RemotePos->File);
\r
663 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
665 strcpy(Pkt.Cmd, "RETR ");
\r
666 Pkt.Type = AskTransferTypeAssoc(Pkt.RemoteFile, AskTransferType());
\r
667 Pkt.Size = RemotePos->Size;
\r
668 Pkt.Time = RemotePos->Time;
\r
670 Pkt.KanjiCode = AskHostKanjiCode();
\r
672 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
673 Pkt.KanaCnv = AskHostKanaCnv();
\r
674 Pkt.Mode = EXIST_OVW;
\r
675 AddTmpTransFileList(&Pkt, &Base);
\r
678 RemotePos = RemotePos->Next;
\r
681 if((Notify == YES) ||
\r
682 (DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(mirrordown_notify_dlg), GetMainHwnd(), MirrorDispListCallBack, (LPARAM)&Base) == YES))
\r
684 if(AskNoFullPathMode() == YES)
\r
686 strcpy(Pkt.Cmd, "SETCUR");
\r
687 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
688 AddTransFileList(&Pkt);
\r
690 AppendTransFileList(Base);
\r
692 if(AskNoFullPathMode() == YES)
\r
694 strcpy(Pkt.Cmd, "BACKCUR");
\r
695 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
696 AddTransFileList(&Pkt);
\r
700 // strcpy(Pkt.Cmd, "GOQUIT");
\r
701 // AddTransFileList(&Pkt);
\r
704 EraseTmpTransFileList(&Base);
\r
707 AddNullTransFileList();
\r
709 DeleteFileList(&LocalListBase);
\r
710 DeleteFileList(&RemoteListBase);
\r
712 GoForwardTransWindow();
\r
721 /*----- ミラーリングのファイル一覧を表示 --------------------------------------
\r
724 * FILELIST *Local : ローカル側
\r
725 * FILELIST *Remote : リモート側
\r
729 *----------------------------------------------------------------------------*/
\r
731 static void DispMirrorFiles(FILELIST *Local, FILELIST *Remote)
\r
737 if(DebugConsole == YES)
\r
739 DoPrintf("---- MIRROR FILE LIST ----");
\r
740 while(Local != NULL)
\r
742 FileTimeToLocalFileTime(&Local->Time, &fTime);
\r
743 FileTimeToSystemTime(&fTime, &sTime);
\r
744 sprintf(Date, "%04d/%02d/%02d %02d:%02d:%02d.%04d",
\r
745 sTime.wYear, sTime.wMonth, sTime.wDay, sTime.wHour, sTime.wMinute, sTime.wSecond, sTime.wMilliseconds);
\r
746 DoPrintf("LOCAL : %s %s [%s] %s", Local->Attr==1?"YES":"NO ", Local->Node==NODE_DIR?"DIR ":"FILE", Date, Local->File);
\r
747 Local = Local->Next;
\r
749 while(Remote != NULL)
\r
751 FileTimeToLocalFileTime(&Remote->Time, &fTime);
\r
752 FileTimeToSystemTime(&fTime, &sTime);
\r
753 sprintf(Date, "%04d/%02d/%02d %02d:%02d:%02d.%04d",
\r
754 sTime.wYear, sTime.wMonth, sTime.wDay, sTime.wHour, sTime.wMinute, sTime.wSecond, sTime.wMilliseconds);
\r
755 DoPrintf("REMOTE : %s %s [%s] %s", Remote->Attr==1?"YES":"NO ", Remote->Node==NODE_DIR?"DIR ":"FILE", Date, Remote->File);
\r
756 Remote = Remote->Next;
\r
758 DoPrintf("---- END ----");
\r
764 /*----- ミラーリング時のローカル側のフォルダ削除 ------------------------------
\r
767 * FILELIST *Local : ファイルリスト
\r
768 * TRANSPACKET *Pkt :
\r
769 * TRANSPACKET **Base :
\r
773 *----------------------------------------------------------------------------*/
\r
775 static void MirrorDeleteAllLocalDir(FILELIST *Local, TRANSPACKET *Pkt, TRANSPACKET **Base)
\r
777 while(Local != NULL)
\r
779 if(Local->Node == NODE_DIR)
\r
781 MirrorDeleteAllLocalDir(Local->Next, Pkt, Base);
\r
783 if(Local->Attr == YES)
\r
785 AskLocalCurDir(Pkt->LocalFile, FMAX_PATH);
\r
786 SetYenTail(Pkt->LocalFile);
\r
787 strcat(Pkt->LocalFile, Local->File);
\r
788 ReplaceAll(Pkt->LocalFile, '/', '\\');
\r
789 strcpy(Pkt->RemoteFile, "");
\r
790 strcpy(Pkt->Cmd, "L-RMD ");
\r
791 AddTmpTransFileList(Pkt, Base);
\r
795 Local = Local->Next;
\r
801 /*----- ファイル名のセミコロン以降を取り除く ----------------------------------
\r
804 * char *Path : ファイル名
\r
811 * オプション設定によって処理を切替える
\r
812 *----------------------------------------------------------------------------*/
\r
814 static void RemoveAfterSemicolon(char *Path)
\r
818 if(VaxSemicolon == YES)
\r
820 if((Pos = strchr(Path, ';')) != NULL)
\r
827 /*----- ローカルに同じ名前のファイルがないかチェック --------------------------
\r
830 * TRANSPACKET *Pkt : 転送ファイル情報
\r
834 * EXIST_OVW/EXIST_RESUME/EXIST_IGNORE
\r
837 * Pkt.ExistSize, ExistMode、ExistNotify が変更される
\r
838 *----------------------------------------------------------------------------*/
\r
840 static int CheckLocalFile(TRANSPACKET *Pkt)
\r
843 WIN32_FIND_DATA Find;
\r
847 Pkt->ExistSize = 0;
\r
848 if(RecvMode != TRANS_OVW)
\r
850 if((fHnd = FindFirstFile(Pkt->LocalFile, &Find)) != INVALID_HANDLE_VALUE)
\r
854 Pkt->ExistSize = MakeLongLong(Find.nFileSizeHigh, Find.nFileSizeLow);
\r
856 if(ExistNotify == YES)
\r
858 SoundPlay(SND_ERROR);
\r
859 if(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(down_exist_dlg), GetMainHwnd(), DownExistDialogCallBack, (LPARAM)Pkt) == NO)
\r
867 if(Ret == EXIST_NEW)
\r
870 if(CompareFileTime(&Find.ftLastWriteTime, &Pkt->Time) < 0)
\r
873 Ret = EXIST_IGNORE;
\r
875 // 同じ名前のファイルの処理方法追加
\r
876 if(Ret == EXIST_LARGE)
\r
878 if(MakeLongLong(Find.nFileSizeHigh, Find.nFileSizeLow) < Pkt->Size)
\r
881 Ret = EXIST_IGNORE;
\r
889 /*----- ローカルに同じ名前のファイルがある時の確認ダイアログのコールバック ----
\r
892 * HWND hDlg : ウインドウハンドル
\r
893 * UINT message : メッセージ番号
\r
894 * WPARAM wParam : メッセージの WPARAM 引数
\r
895 * LPARAM lParam : メッセージの LPARAM 引数
\r
899 *----------------------------------------------------------------------------*/
\r
902 //static BOOL CALLBACK DownExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
903 static INT_PTR CALLBACK DownExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
905 static TRANSPACKET *Pkt;
\r
906 // 同じ名前のファイルの処理方法追加
\r
907 // static const RADIOBUTTON DownExistButton[] = {
\r
908 // { DOWN_EXIST_OVW, EXIST_OVW },
\r
909 // { DOWN_EXIST_NEW, EXIST_NEW },
\r
910 // { DOWN_EXIST_RESUME, EXIST_RESUME },
\r
911 // { DOWN_EXIST_IGNORE, EXIST_IGNORE }
\r
913 static const RADIOBUTTON DownExistButton[] = {
\r
914 { DOWN_EXIST_OVW, EXIST_OVW },
\r
915 { DOWN_EXIST_NEW, EXIST_NEW },
\r
916 { DOWN_EXIST_RESUME, EXIST_RESUME },
\r
917 { DOWN_EXIST_IGNORE, EXIST_IGNORE },
\r
918 { DOWN_EXIST_LARGE, EXIST_LARGE }
\r
920 #define DOWNEXISTBUTTONS (sizeof(DownExistButton)/sizeof(RADIOBUTTON))
\r
924 case WM_INITDIALOG :
\r
925 Pkt = (TRANSPACKET *)lParam;
\r
926 SendDlgItemMessage(hDlg, DOWN_EXIST_NAME, EM_LIMITTEXT, FMAX_PATH, 0);
\r
927 SendDlgItemMessage(hDlg, DOWN_EXIST_NAME, WM_SETTEXT, 0, (LPARAM)Pkt->LocalFile);
\r
929 if((Pkt->Type == TYPE_A) || (Pkt->ExistSize <= 0))
\r
930 EnableWindow(GetDlgItem(hDlg, DOWN_EXIST_RESUME), FALSE);
\r
932 SetRadioButtonByValue(hDlg, ExistMode, DownExistButton, DOWNEXISTBUTTONS);
\r
936 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
940 /* ここに break はない */
\r
943 ExistMode = AskRadioButtonValue(hDlg, DownExistButton, DOWNEXISTBUTTONS);
\r
944 SendDlgItemMessage(hDlg, DOWN_EXIST_NAME, WM_GETTEXT, FMAX_PATH, (LPARAM)Pkt->LocalFile);
\r
945 EndDialog(hDlg, YES);
\r
949 // ExistMode = EXIST_ABORT;
\r
950 EndDialog(hDlg, NO);
\r
954 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000009);
\r
967 /*----- ファイル一覧で指定されたファイルをアップロードする --------------------
\r
970 * int ChName : 名前を変えるかどうか (YES/NO)
\r
971 * int All : 全てが選ばれている物として扱うかどうか (YES/NO)
\r
975 *----------------------------------------------------------------------------*/
\r
978 // リモート側のパスから必要なディレクトリを作成
\r
979 int MakeDirFromRemotePath(char* RemoteFile, char* Old, int FirstAdd)
\r
988 pDelimiter = RemoteFile;
\r
990 while(pNext = strchr(pDelimiter, '/'))
\r
992 Len = pNext - RemoteFile;
\r
993 strncpy(Pkt.RemoteFile, RemoteFile, Len);
\r
994 Pkt.RemoteFile[Len] = '\0';
\r
995 if(strncmp(RemoteFile, Old, Len + 1) != 0)
\r
997 Cat = Pkt.RemoteFile + (pDelimiter - RemoteFile);
\r
998 if(FnameCnv == FNAME_LOWER)
\r
1000 else if(FnameCnv == FNAME_UPPER)
\r
1002 #if defined(HAVE_TANDEM)
\r
1004 Pkt.PriExt = DEF_PRIEXT;
\r
1005 Pkt.SecExt = DEF_SECEXT;
\r
1006 Pkt.MaxExt = DEF_MAXEXT;
\r
1008 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
1010 if(AskHostType() == HTYPE_ACOS)
\r
1012 strcpy(Pkt.RemoteFile, "'");
\r
1013 strcat(Pkt.RemoteFile, AskHostLsName());
\r
1014 strcat(Pkt.RemoteFile, "(");
\r
1015 strcat(Pkt.RemoteFile, Cat);
\r
1016 strcat(Pkt.RemoteFile, ")");
\r
1017 strcat(Pkt.RemoteFile, "'");
\r
1019 else if(AskHostType() == HTYPE_ACOS_4)
\r
1020 strcpy(Pkt.RemoteFile, Cat);
\r
1022 if((FirstAdd == YES) && (AskNoFullPathMode() == YES))
\r
1024 strcpy(Pkt1.Cmd, "SETCUR");
\r
1025 AskRemoteCurDir(Pkt1.RemoteFile, FMAX_PATH);
\r
1026 AddTransFileList(&Pkt1);
\r
1029 strcpy(Pkt.Cmd, "MKD ");
\r
1030 strcpy(Pkt.LocalFile, "");
\r
1031 AddTransFileList(&Pkt);
\r
1035 pDelimiter = pNext + 1;
\r
1040 void UploadListProc(int ChName, int All)
\r
1042 FILELIST *FileListBase;
\r
1047 FILELIST *RemoteList;
\r
1048 char Tmp[FMAX_PATH+1];
\r
1054 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
1058 // ローカル側で選ばれているファイルをFileListBaseに登録
\r
1059 FileListBase = NULL;
\r
1060 MakeSelectedFileList(WIN_LOCAL, YES, All, &FileListBase, &CancelFlg);
\r
1062 // 現在ホスト側のファイル一覧に表示されているものをRemoteListに登録
\r
1064 RemoteList = NULL;
\r
1065 AddRemoteTreeToFileList(AskCurrentFileListNum(), "", RDIR_NONE, &RemoteList);
\r
1068 ExistNotify = YES;
\r
1070 Pos = FileListBase;
\r
1071 while(Pos != NULL)
\r
1073 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1074 SetSlashTail(Pkt.RemoteFile);
\r
1075 Cat = strchr(Pkt.RemoteFile, NUL);
\r
1076 if((ChName == NO) || (Pos->Node == NODE_DIR))
\r
1078 strcat(Pkt.RemoteFile, Pos->File);
\r
1079 if(FnameCnv == FNAME_LOWER)
\r
1081 else if(FnameCnv == FNAME_UPPER)
\r
1083 #if defined(HAVE_TANDEM)
\r
1085 Pkt.PriExt = DEF_PRIEXT;
\r
1086 Pkt.SecExt = DEF_SECEXT;
\r
1087 Pkt.MaxExt = DEF_MAXEXT;
\r
1093 strcpy(TmpString, Pos->File);
\r
1094 CurWin = WIN_LOCAL;
\r
1095 #if defined(HAVE_TANDEM)
\r
1096 strcpy(TmpFileCode, "0"); /* ASCII モードの場合は無視される */
\r
1097 if(AskHostType() == HTYPE_TANDEM && AskOSS() == NO) {
\r
1098 if(DialogBox(GetFtpInst(), MAKEINTRESOURCE(updown_as_with_ext_dlg), GetMainHwnd(), UpDownAsWithExtDialogCallBack) == YES) {
\r
1099 strcat(Pkt.RemoteFile, TmpString);
\r
1100 Pkt.FileCode = atoi(TmpFileCode);
\r
1106 if(DialogBox(GetFtpInst(), MAKEINTRESOURCE(updown_as_dlg), GetMainHwnd(), UpDownAsDialogCallBack) == YES)
\r
1107 strcat(Pkt.RemoteFile, TmpString);
\r
1112 AskRemoteCurDir(Tmp, FMAX_PATH);
\r
1113 SetSlashTail(Tmp);
\r
1114 if(strncmp(Pkt.RemoteFile, Tmp, strlen(Tmp)) != 0)
\r
1116 if((Cat = strrchr(Pkt.RemoteFile, '/')) != NULL)
\r
1119 Cat = Pkt.RemoteFile;
\r
1121 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
1123 if(AskHostType() == HTYPE_ACOS)
\r
1125 strcpy(Pkt.RemoteFile, "'");
\r
1126 strcat(Pkt.RemoteFile, AskHostLsName());
\r
1127 strcat(Pkt.RemoteFile, "(");
\r
1128 strcat(Pkt.RemoteFile, Cat);
\r
1129 strcat(Pkt.RemoteFile, ")");
\r
1130 strcat(Pkt.RemoteFile, "'");
\r
1132 else if(AskHostType() == HTYPE_ACOS_4)
\r
1133 strcpy(Pkt.RemoteFile, Cat);
\r
1135 if(Pos->Node == NODE_DIR)
\r
1139 // ホスト側のファイル一覧をRemoteListに登録
\r
1141 if(RemoteList != NULL)
\r
1142 DeleteFileList(&RemoteList);
\r
1143 RemoteList = NULL;
\r
1145 AskRemoteCurDir(Tmp, FMAX_PATH);
\r
1146 if(DoCWD(Pkt.RemoteFile, NO, NO, NO) == FTP_COMPLETE)
\r
1148 if(DoDirListCmdSkt("", "", 998, &CancelFlg) == FTP_COMPLETE)
\r
1149 AddRemoteTreeToFileList(998, "", RDIR_NONE, &RemoteList);
\r
1150 DoCWD(Tmp, NO, NO, NO);
\r
1155 if((FirstAdd == YES) && (AskNoFullPathMode() == YES))
\r
1157 strcpy(Pkt1.Cmd, "SETCUR");
\r
1158 AskRemoteCurDir(Pkt1.RemoteFile, FMAX_PATH);
\r
1159 AddTransFileList(&Pkt1);
\r
1162 strcpy(Pkt.Cmd, "MKD ");
\r
1163 strcpy(Pkt.LocalFile, "");
\r
1164 AddTransFileList(&Pkt);
\r
1167 else if(Pos->Node == NODE_FILE)
\r
1170 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
1171 SetYenTail(Pkt.LocalFile);
\r
1172 strcat(Pkt.LocalFile, Pos->File);
\r
1173 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
1175 strcpy(Pkt.Cmd, "STOR ");
\r
1176 Pkt.Type = AskTransferTypeAssoc(Pkt.LocalFile, AskTransferType());
\r
1179 Pkt.Size = Pos->Size;
\r
1180 Pkt.Time = Pos->Time;
\r
1181 Pkt.Attr = AskUploadFileAttr(Pkt.RemoteFile);
\r
1182 Pkt.KanjiCode = AskHostKanjiCode();
\r
1184 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
1185 Pkt.KanaCnv = AskHostKanaCnv();
\r
1186 #if defined(HAVE_TANDEM)
\r
1187 if(AskHostType() == HTYPE_TANDEM && AskOSS() == NO) {
\r
1188 CalcExtentSize(&Pkt, Pos->Size);
\r
1192 strcpy(Tmp, Pkt.RemoteFile);
\r
1193 Pkt.Mode = CheckRemoteFile(&Pkt, RemoteList);
\r
1194 if(Pkt.Mode == EXIST_ABORT)
\r
1196 else if(Pkt.Mode != EXIST_IGNORE)
\r
1199 if(MakeAllDir == YES)
\r
1201 if(MakeDirFromRemotePath(Pkt.RemoteFile, Tmp, FirstAdd) == YES)
\r
1204 if((FirstAdd == YES) && (AskNoFullPathMode() == YES))
\r
1206 strcpy(Pkt1.Cmd, "SETCUR");
\r
1207 AskRemoteCurDir(Pkt1.RemoteFile, FMAX_PATH);
\r
1208 AddTransFileList(&Pkt1);
\r
1211 AddTransFileList(&Pkt);
\r
1217 if((FirstAdd == NO) && (AskNoFullPathMode() == YES))
\r
1219 strcpy(Pkt.Cmd, "BACKCUR");
\r
1220 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1221 AddTransFileList(&Pkt);
\r
1224 if(RemoteList != NULL)
\r
1225 DeleteFileList(&RemoteList);
\r
1227 DeleteFileList(&FileListBase);
\r
1230 // strcpy(Pkt.Cmd, "GOQUIT");
\r
1231 // AddTransFileList(&Pkt);
\r
1234 AddNullTransFileList();
\r
1236 GoForwardTransWindow();
\r
1244 /*----- ドラッグ&ドロップで指定されたファイルをアップロードする --------------
\r
1247 * WPARAM wParam : ドロップされたファイルの情報
\r
1251 *----------------------------------------------------------------------------*/
\r
1253 void UploadDragProc(WPARAM wParam)
\r
1255 FILELIST *FileListBase;
\r
1260 FILELIST *RemoteList;
\r
1261 char Tmp[FMAX_PATH+1];
\r
1263 char Cur[FMAX_PATH+1];
\r
1268 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
1272 // ローカル側で選ばれているファイルをFileListBaseに登録
\r
1273 FileListBase = NULL;
\r
1274 MakeDroppedFileList(wParam, Cur, &FileListBase);
\r
1276 // 現在ホスト側のファイル一覧に表示されているものをRemoteListに登録
\r
1278 RemoteList = NULL;
\r
1279 AddRemoteTreeToFileList(AskCurrentFileListNum(), "", RDIR_NONE, &RemoteList);
\r
1282 ExistNotify = YES;
\r
1284 Pos = FileListBase;
\r
1285 while(Pos != NULL)
\r
1287 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1288 SetSlashTail(Pkt.RemoteFile);
\r
1289 Cat = strchr(Pkt.RemoteFile, NUL);
\r
1291 strcat(Pkt.RemoteFile, Pos->File);
\r
1292 if(FnameCnv == FNAME_LOWER)
\r
1294 else if(FnameCnv == FNAME_UPPER)
\r
1296 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
1297 #if defined(HAVE_TANDEM)
\r
1299 Pkt.PriExt = DEF_PRIEXT;
\r
1300 Pkt.SecExt = DEF_SECEXT;
\r
1301 Pkt.MaxExt = DEF_MAXEXT;
\r
1304 if(AskHostType() == HTYPE_ACOS)
\r
1306 strcpy(Pkt.RemoteFile, "'");
\r
1307 strcat(Pkt.RemoteFile, AskHostLsName());
\r
1308 strcat(Pkt.RemoteFile, "(");
\r
1309 strcat(Pkt.RemoteFile, Cat);
\r
1310 strcat(Pkt.RemoteFile, ")");
\r
1311 strcat(Pkt.RemoteFile, "'");
\r
1313 else if(AskHostType() == HTYPE_ACOS_4)
\r
1314 strcpy(Pkt.RemoteFile, Cat);
\r
1316 if(Pos->Node == NODE_DIR)
\r
1320 // ホスト側のファイル一覧をRemoteListに登録
\r
1322 if(RemoteList != NULL)
\r
1323 DeleteFileList(&RemoteList);
\r
1324 RemoteList = NULL;
\r
1326 AskRemoteCurDir(Tmp, FMAX_PATH);
\r
1327 if(DoCWD(Pkt.RemoteFile, NO, NO, NO) == FTP_COMPLETE)
\r
1329 if(DoDirListCmdSkt("", "", 998, &CancelFlg) == FTP_COMPLETE)
\r
1330 AddRemoteTreeToFileList(998, "", RDIR_NONE, &RemoteList);
\r
1331 DoCWD(Tmp, NO, NO, NO);
\r
1335 if((FirstAdd == YES) && (AskNoFullPathMode() == YES))
\r
1337 strcpy(Pkt1.Cmd, "SETCUR");
\r
1338 AskRemoteCurDir(Pkt1.RemoteFile, FMAX_PATH);
\r
1339 AddTransFileList(&Pkt1);
\r
1342 strcpy(Pkt.Cmd, "MKD ");
\r
1343 strcpy(Pkt.LocalFile, "");
\r
1344 AddTransFileList(&Pkt);
\r
1347 else if(Pos->Node == NODE_FILE)
\r
1350 strcpy(Pkt.LocalFile, Cur);
\r
1351 SetYenTail(Pkt.LocalFile);
\r
1352 strcat(Pkt.LocalFile, Pos->File);
\r
1353 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
1355 strcpy(Pkt.Cmd, "STOR ");
\r
1356 Pkt.Type = AskTransferTypeAssoc(Pkt.LocalFile, AskTransferType());
\r
1359 Pkt.Size = Pos->Size;
\r
1360 Pkt.Time = Pos->Time;
\r
1361 Pkt.Attr = AskUploadFileAttr(Pkt.RemoteFile);
\r
1362 Pkt.KanjiCode = AskHostKanjiCode();
\r
1364 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
1365 Pkt.KanaCnv = AskHostKanaCnv();
\r
1366 #if defined(HAVE_TANDEM)
\r
1367 if(AskHostType() == HTYPE_TANDEM && AskOSS() == NO) {
\r
1368 int a = Pos->InfoExist && FINFO_SIZE;
\r
1369 CalcExtentSize(&Pkt, Pos->Size);
\r
1373 strcpy(Tmp, Pkt.RemoteFile);
\r
1374 Pkt.Mode = CheckRemoteFile(&Pkt, RemoteList);
\r
1375 if(Pkt.Mode == EXIST_ABORT)
\r
1377 else if(Pkt.Mode != EXIST_IGNORE)
\r
1380 if(MakeAllDir == YES)
\r
1382 if(MakeDirFromRemotePath(Pkt.RemoteFile, Tmp, FirstAdd) == YES)
\r
1385 if((FirstAdd == YES) && (AskNoFullPathMode() == YES))
\r
1387 strcpy(Pkt1.Cmd, "SETCUR");
\r
1388 AskRemoteCurDir(Pkt1.RemoteFile, FMAX_PATH);
\r
1389 AddTransFileList(&Pkt1);
\r
1392 AddTransFileList(&Pkt);
\r
1398 if((FirstAdd == NO) && (AskNoFullPathMode() == YES))
\r
1400 strcpy(Pkt.Cmd, "BACKCUR");
\r
1401 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1402 AddTransFileList(&Pkt);
\r
1405 if(RemoteList != NULL)
\r
1406 DeleteFileList(&RemoteList);
\r
1408 DeleteFileList(&FileListBase);
\r
1411 // strcpy(Pkt.Cmd, "GOQUIT");
\r
1412 // AddTransFileList(&Pkt);
\r
1415 AddNullTransFileList();
\r
1417 GoForwardTransWindow();
\r
1425 /*----- ミラーリングアップロードを行う ----------------------------------------
\r
1428 * int Notify : 確認を行うかどうか (YES/NO)
\r
1432 *----------------------------------------------------------------------------*/
\r
1434 void MirrorUploadProc(int Notify)
\r
1436 FILELIST *LocalListBase;
\r
1437 FILELIST *RemoteListBase;
\r
1438 FILELIST *LocalPos;
\r
1439 FILELIST *RemotePos;
\r
1441 TRANSPACKET *Base;
\r
1442 char Name[FMAX_PATH+1];
\r
1446 SYSTEMTIME TmpStime;
\r
1447 FILETIME TmpFtimeL;
\r
1448 FILETIME TmpFtimeR;
\r
1453 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
1460 Notify = DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(mirror_up_dlg), GetMainHwnd(), MirrorNotifyCallBack, 1);
\r
1464 if((Notify == YES) || (Notify == YES_LIST))
\r
1466 /*===== ファイルリスト取得 =====*/
\r
1468 LocalListBase = NULL;
\r
1469 MakeSelectedFileList(WIN_LOCAL, YES, YES, &LocalListBase, &CancelFlg);
\r
1470 RemoteListBase = NULL;
\r
1471 MakeSelectedFileList(WIN_REMOTE, YES, YES, &RemoteListBase, &CancelFlg);
\r
1473 LocalPos = LocalListBase;
\r
1474 while(LocalPos != NULL)
\r
1476 LocalPos->Attr = YES; /* LocalPos->Attrは転送するかどうかのフラグに使用 (YES/NO) */
\r
1477 LocalPos = LocalPos->Next;
\r
1480 RemotePos = RemoteListBase;
\r
1481 while(RemotePos != NULL)
\r
1483 if(AskMirrorNoTrn(RemotePos->File, 1) == NO)
\r
1485 RemotePos->Attr = YES;
\r
1486 RemotePos = RemotePos->Next;
\r
1490 RemotePos->Attr = NO; /* RemotePos->Attrは削除するかどうかのフラグに使用 (YES/NO) */
\r
1492 if(RemotePos->Node == NODE_DIR)
\r
1494 Level = AskDirLevel(RemotePos->File);
\r
1495 RemotePos = RemotePos->Next;
\r
1496 while(RemotePos != NULL)
\r
1498 if((RemotePos->Node == NODE_DIR) &&
\r
1499 (AskDirLevel(RemotePos->File) <= Level))
\r
1503 RemotePos->Attr = NO;
\r
1504 RemotePos = RemotePos->Next;
\r
1508 RemotePos = RemotePos->Next;
\r
1512 /*===== ファイルリスト比較 =====*/
\r
1514 LocalPos = LocalListBase;
\r
1515 while(LocalPos != NULL)
\r
1517 if(AskMirrorNoTrn(LocalPos->File, 0) == NO)
\r
1519 strcpy(Name, LocalPos->File);
\r
1520 ReplaceAll(Name, '\\', '/');
\r
1522 if(MirrorFnameCnv == YES)
\r
1523 Mode = COMP_LOWERMATCH;
\r
1525 Mode = COMP_STRICT;
\r
1527 if(LocalPos->Node == NODE_DIR)
\r
1529 if((RemotePos = SearchFileList(Name, RemoteListBase, Mode)) != NULL)
\r
1531 if(RemotePos->Node == NODE_DIR)
\r
1533 RemotePos->Attr = NO;
\r
1534 LocalPos->Attr = NO;
\r
1538 else if(LocalPos->Node == NODE_FILE)
\r
1540 if((RemotePos = SearchFileList(Name, RemoteListBase, Mode)) != NULL)
\r
1542 if(RemotePos->Node == NODE_FILE)
\r
1544 FileTimeToLocalFileTime(&LocalPos->Time, &TmpFtimeL);
\r
1545 FileTimeToLocalFileTime(&RemotePos->Time, &TmpFtimeR);
\r
1546 if((RemotePos->InfoExist & FINFO_TIME) == 0)
\r
1548 FileTimeToSystemTime(&TmpFtimeL, &TmpStime);
\r
1549 TmpStime.wHour = 0;
\r
1550 TmpStime.wMinute = 0;
\r
1551 TmpStime.wSecond = 0;
\r
1552 TmpStime.wMilliseconds = 0;
\r
1553 SystemTimeToFileTime(&TmpStime, &TmpFtimeL);
\r
1555 FileTimeToSystemTime(&TmpFtimeR, &TmpStime);
\r
1556 TmpStime.wHour = 0;
\r
1557 TmpStime.wMinute = 0;
\r
1558 TmpStime.wSecond = 0;
\r
1559 TmpStime.wMilliseconds = 0;
\r
1560 SystemTimeToFileTime(&TmpStime, &TmpFtimeR);
\r
1562 RemotePos->Attr = NO;
\r
1563 if(CompareFileTime(&TmpFtimeL, &TmpFtimeR) <= 0)
\r
1564 LocalPos->Attr = NO;
\r
1569 LocalPos = LocalPos->Next;
\r
1573 if(LocalPos->Node == NODE_FILE)
\r
1575 LocalPos->Attr = NO;
\r
1576 LocalPos = LocalPos->Next;
\r
1580 LocalPos->Attr = NO;
\r
1581 Level = AskDirLevel(LocalPos->File);
\r
1582 LocalPos = LocalPos->Next;
\r
1583 while(LocalPos != NULL)
\r
1585 if((LocalPos->Node == NODE_DIR) &&
\r
1586 (AskDirLevel(LocalPos->File) <= Level))
\r
1590 LocalPos->Attr = NO;
\r
1591 LocalPos = LocalPos->Next;
\r
1597 DispMirrorFiles(LocalListBase, RemoteListBase);
\r
1599 /*===== 削除/アップロード =====*/
\r
1601 RemotePos = RemoteListBase;
\r
1602 while(RemotePos != NULL)
\r
1604 if((RemotePos->Attr == YES) && (RemotePos->Node == NODE_FILE))
\r
1606 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1607 SetSlashTail(Pkt.RemoteFile);
\r
1608 strcat(Pkt.RemoteFile, RemotePos->File);
\r
1609 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
1610 strcpy(Pkt.LocalFile, "");
\r
1611 strcpy(Pkt.Cmd, "R-DELE ");
\r
1612 AddTmpTransFileList(&Pkt, &Base);
\r
1614 RemotePos = RemotePos->Next;
\r
1616 MirrorDeleteAllDir(RemoteListBase, &Pkt, &Base);
\r
1618 LocalPos = LocalListBase;
\r
1619 while(LocalPos != NULL)
\r
1621 if(LocalPos->Attr == YES)
\r
1623 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1624 SetSlashTail(Pkt.RemoteFile);
\r
1625 Cat = strchr(Pkt.RemoteFile, NUL);
\r
1626 strcat(Pkt.RemoteFile, LocalPos->File);
\r
1628 if(MirrorFnameCnv == YES)
\r
1631 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
1633 if(LocalPos->Node == NODE_DIR)
\r
1635 strcpy(Pkt.LocalFile, "");
\r
1636 strcpy(Pkt.Cmd, "R-MKD ");
\r
1637 AddTmpTransFileList(&Pkt, &Base);
\r
1639 else if(LocalPos->Node == NODE_FILE)
\r
1641 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
1642 SetYenTail(Pkt.LocalFile);
\r
1643 strcat(Pkt.LocalFile, LocalPos->File);
\r
1644 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
1646 strcpy(Pkt.Cmd, "STOR ");
\r
1647 Pkt.Type = AskTransferTypeAssoc(Pkt.LocalFile, AskTransferType());
\r
1650 Pkt.Size = LocalPos->Size;
\r
1651 Pkt.Time = LocalPos->Time;
\r
1652 Pkt.Attr = AskUploadFileAttr(Pkt.RemoteFile);
\r
1653 Pkt.KanjiCode = AskHostKanjiCode();
\r
1655 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
1656 Pkt.KanaCnv = AskHostKanaCnv();
\r
1657 #if defined(HAVE_TANDEM)
\r
1658 if(AskHostType() == HTYPE_TANDEM && AskOSS() == NO) {
\r
1659 CalcExtentSize(&Pkt, LocalPos->Size);
\r
1662 Pkt.Mode = EXIST_OVW;
\r
1663 AddTmpTransFileList(&Pkt, &Base);
\r
1666 LocalPos = LocalPos->Next;
\r
1669 if((Notify == YES) ||
\r
1670 (DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(mirror_notify_dlg), GetMainHwnd(), MirrorDispListCallBack, (LPARAM)&Base) == YES))
\r
1672 if(AskNoFullPathMode() == YES)
\r
1674 strcpy(Pkt.Cmd, "SETCUR");
\r
1675 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1676 AddTransFileList(&Pkt);
\r
1678 AppendTransFileList(Base);
\r
1680 if(AskNoFullPathMode() == YES)
\r
1682 strcpy(Pkt.Cmd, "BACKCUR");
\r
1683 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1684 AddTransFileList(&Pkt);
\r
1688 // strcpy(Pkt.Cmd, "GOQUIT");
\r
1689 // AddTransFileList(&Pkt);
\r
1692 EraseTmpTransFileList(&Base);
\r
1695 AddNullTransFileList();
\r
1697 DeleteFileList(&LocalListBase);
\r
1698 DeleteFileList(&RemoteListBase);
\r
1700 GoForwardTransWindow();
\r
1709 /*----- ミラーリング時のホスト側のフォルダ削除 --------------------------------
\r
1712 * FILELIST *Base : ファイルリスト
\r
1713 * TRANSPACKET *Pkt :
\r
1714 * TRANSPACKET **Base :
\r
1718 *----------------------------------------------------------------------------*/
\r
1720 static void MirrorDeleteAllDir(FILELIST *Remote, TRANSPACKET *Pkt, TRANSPACKET **Base)
\r
1722 while(Remote != NULL)
\r
1724 if(Remote->Node == NODE_DIR)
\r
1726 MirrorDeleteAllDir(Remote->Next, Pkt, Base);
\r
1728 if(Remote->Attr == YES)
\r
1730 AskRemoteCurDir(Pkt->RemoteFile, FMAX_PATH);
\r
1731 SetSlashTail(Pkt->RemoteFile);
\r
1732 strcat(Pkt->RemoteFile, Remote->File);
\r
1733 ReplaceAll(Pkt->RemoteFile, '\\', '/');
\r
1734 strcpy(Pkt->LocalFile, "");
\r
1735 strcpy(Pkt->Cmd, "R-RMD ");
\r
1736 AddTmpTransFileList(Pkt, Base);
\r
1740 Remote = Remote->Next;
\r
1746 /*----- ミラーリングアップロード開始確認ウインドウのコールバック --------------
\r
1749 * HWND hDlg : ウインドウハンドル
\r
1750 * UINT message : メッセージ番号
\r
1751 * WPARAM wParam : メッセージの WPARAM 引数
\r
1752 * LPARAM lParam : メッセージの LPARAM 引数
\r
1756 *----------------------------------------------------------------------------*/
\r
1759 //static BOOL CALLBACK MirrorNotifyCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
1760 static INT_PTR CALLBACK MirrorNotifyCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
1766 case WM_INITDIALOG :
\r
1771 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
1774 EndDialog(hDlg, YES);
\r
1778 EndDialog(hDlg, NO);
\r
1781 case MIRRORUP_DISP :
\r
1782 EndDialog(hDlg, YES_LIST);
\r
1787 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000013);
\r
1789 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000012);
\r
1797 /*----- ミラーリングアップロード処理内容確認ウインドウのコールバック ----------
\r
1800 * HWND hDlg : ウインドウハンドル
\r
1801 * UINT message : メッセージ番号
\r
1802 * WPARAM wParam : メッセージの WPARAM 引数
\r
1803 * LPARAM lParam : メッセージの LPARAM 引数
\r
1807 *----------------------------------------------------------------------------*/
\r
1810 //static BOOL CALLBACK MirrorDispListCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
1811 static INT_PTR CALLBACK MirrorDispListCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
1813 static DIALOGSIZE DlgSize = {
\r
1814 { MIRROR_DEL, MIRROR_SIZEGRIP, -1 },
\r
1815 { IDOK, IDCANCEL, IDHELP, MIRROR_DEL, MIRROR_COPYNUM, MIRROR_MAKENUM, MIRROR_DELNUM, MIRROR_SIZEGRIP, -1 },
\r
1816 { MIRROR_LIST, -1 },
\r
1821 static TRANSPACKET **Base;
\r
1823 char Tmp[FMAX_PATH+1+6];
\r
1829 case WM_INITDIALOG :
\r
1830 Base = (TRANSPACKET **)lParam;
\r
1832 while(Pos != NULL)
\r
1835 if((strncmp(Pos->Cmd, "R-DELE", 6) == 0) ||
\r
1836 (strncmp(Pos->Cmd, "R-RMD", 5) == 0))
\r
1837 sprintf(Tmp, MSGJPN052, Pos->RemoteFile);
\r
1838 else if(strncmp(Pos->Cmd, "R-MKD", 5) == 0)
\r
1839 sprintf(Tmp, MSGJPN053, Pos->RemoteFile);
\r
1840 else if(strncmp(Pos->Cmd, "STOR", 4) == 0)
\r
1841 sprintf(Tmp, MSGJPN054, Pos->RemoteFile);
\r
1842 else if((strncmp(Pos->Cmd, "L-DELE", 6) == 0) ||
\r
1843 (strncmp(Pos->Cmd, "L-RMD", 5) == 0))
\r
1844 sprintf(Tmp, MSGJPN055, Pos->LocalFile);
\r
1845 else if(strncmp(Pos->Cmd, "L-MKD", 5) == 0)
\r
1846 sprintf(Tmp, MSGJPN056, Pos->LocalFile);
\r
1847 else if(strncmp(Pos->Cmd, "RETR", 4) == 0)
\r
1848 sprintf(Tmp, MSGJPN057, Pos->LocalFile);
\r
1850 if(strlen(Tmp) > 0)
\r
1851 SendDlgItemMessage(hDlg, MIRROR_LIST, LB_ADDSTRING, 0, (LPARAM)Tmp);
\r
1854 CountMirrorFiles(hDlg, *Base);
\r
1855 DlgSizeInit(hDlg, &DlgSize, &MirrorDlgSize);
\r
1856 EnableWindow(GetDlgItem(hDlg, MIRROR_DEL), FALSE);
\r
1860 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
1863 AskDlgSize(hDlg, &DlgSize, &MirrorDlgSize);
\r
1864 EndDialog(hDlg, YES);
\r
1868 AskDlgSize(hDlg, &DlgSize, &MirrorDlgSize);
\r
1869 EndDialog(hDlg, NO);
\r
1873 Num = SendDlgItemMessage(hDlg, MIRROR_LIST, LB_GETSELCOUNT, 0, 0);
\r
1874 if((List = malloc(Num * sizeof(int))) != NULL)
\r
1876 Num = SendDlgItemMessage(hDlg, MIRROR_LIST, LB_GETSELITEMS, Num, (LPARAM)List);
\r
1877 for(Num--; Num >= 0; Num--)
\r
1879 if(RemoveTmpTransFileListItem(Base, List[Num]) == FFFTP_SUCCESS)
\r
1880 SendDlgItemMessage(hDlg, MIRROR_LIST, LB_DELETESTRING, List[Num], 0);
\r
1885 CountMirrorFiles(hDlg, *Base);
\r
1889 case MIRROR_LIST :
\r
1890 switch(GET_WM_COMMAND_CMD(wParam, lParam))
\r
1892 case LBN_SELCHANGE :
\r
1893 if(SendDlgItemMessage(hDlg, MIRROR_LIST, LB_GETSELCOUNT, 0, 0) > 0)
\r
1894 EnableWindow(GetDlgItem(hDlg, MIRROR_DEL), TRUE);
\r
1896 EnableWindow(GetDlgItem(hDlg, MIRROR_DEL), FALSE);
\r
1902 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000012);
\r
1907 DlgSizeChange(hDlg, &DlgSize, (RECT *)lParam, (int)wParam);
\r
1914 /*----- ミラーリングで転送/削除するファイルの数を数えダイアログに表示---------
\r
1918 * TRANSPACKET *Pkt :
\r
1922 *----------------------------------------------------------------------------*/
\r
1924 static void CountMirrorFiles(HWND hDlg, TRANSPACKET *Pkt)
\r
1934 while(Pkt != NULL)
\r
1936 if((strncmp(Pkt->Cmd, "R-DELE", 6) == 0) ||
\r
1937 (strncmp(Pkt->Cmd, "R-RMD", 5) == 0) ||
\r
1938 (strncmp(Pkt->Cmd, "L-DELE", 6) == 0) ||
\r
1939 (strncmp(Pkt->Cmd, "L-RMD", 5) == 0))
\r
1943 else if((strncmp(Pkt->Cmd, "R-MKD", 5) == 0) ||
\r
1944 (strncmp(Pkt->Cmd, "L-MKD", 5) == 0))
\r
1948 else if((strncmp(Pkt->Cmd, "STOR", 4) == 0) ||
\r
1949 (strncmp(Pkt->Cmd, "RETR", 4) == 0))
\r
1957 sprintf(Tmp, MSGJPN058, Copy);
\r
1959 sprintf(Tmp, MSGJPN059);
\r
1960 SendDlgItemMessage(hDlg, MIRROR_COPYNUM, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
1963 sprintf(Tmp, MSGJPN060, Make);
\r
1965 sprintf(Tmp, MSGJPN061);
\r
1966 SendDlgItemMessage(hDlg, MIRROR_MAKENUM, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
1969 sprintf(Tmp, MSGJPN062, Del);
\r
1971 sprintf(Tmp, MSGJPN063);
\r
1972 SendDlgItemMessage(hDlg, MIRROR_DELNUM, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
1980 /*----- ミラーリングで転送/削除しないファイルかどうかを返す ------------------
\r
1983 * char Fname : ファイル名
\r
1985 * 0=転送しないファイル, 1=削除しないファイル
\r
1990 *----------------------------------------------------------------------------*/
\r
1992 static int AskMirrorNoTrn(char *Fname, int Mode)
\r
1997 Tbl = MirrorNoTrn;
\r
1999 Tbl = MirrorNoDel;
\r
2002 if(StrMultiLen(Tbl) > 0)
\r
2004 Fname = GetFileName(Fname);
\r
2005 while(*Tbl != NUL)
\r
2007 if(CheckFname(Fname, Tbl) == FFFTP_SUCCESS)
\r
2012 Tbl += strlen(Tbl) + 1;
\r
2019 /*----- アップロードするファイルの属性を返す ----------------------------------
\r
2022 * char Fname : ファイル名
\r
2025 * int 属性 (-1=設定なし)
\r
2026 *----------------------------------------------------------------------------*/
\r
2028 static int AskUploadFileAttr(char *Fname)
\r
2034 Tbl = DefAttrList;
\r
2035 Fname = GetFileName(Fname);
\r
2037 while(*Tbl != NUL)
\r
2039 Sts = CheckFname(Fname, Tbl);
\r
2040 Tbl += strlen(Tbl) + 1;
\r
2042 if((Sts == FFFTP_SUCCESS) && (*Tbl != NUL))
\r
2047 Tbl += strlen(Tbl) + 1;
\r
2053 /*----- ホストに同じ名前のファイルがないかチェック- ---------------------------a
\r
2056 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2057 * FILELIST *ListList :
\r
2061 * EXIST_OVW/EXIST_UNIQUE/EXIST_IGNORE
\r
2064 * Pkt.ExistSize, UpExistMode、ExistNotify が変更される
\r
2065 *----------------------------------------------------------------------------*/
\r
2067 static int CheckRemoteFile(TRANSPACKET *Pkt, FILELIST *ListList)
\r
2070 #if defined(HAVE_TANDEM)
\r
2076 Pkt->ExistSize = 0;
\r
2077 if(SendMode != TRANS_OVW)
\r
2079 #if defined(HAVE_TANDEM)
\r
2080 /* HP NonStop Server は大文字小文字の区別なし(すべて大文字) */
\r
2081 if(AskHostType() == HTYPE_TANDEM)
\r
2082 Mode = COMP_IGNORE;
\r
2084 Mode = COMP_STRICT;
\r
2086 if((Exist = SearchFileList(GetFileName(Pkt->RemoteFile), ListList, Mode)) != NULL)
\r
2088 if((Exist = SearchFileList(GetFileName(Pkt->RemoteFile), ListList, COMP_STRICT)) != NULL)
\r
2091 Pkt->ExistSize = Exist->Size;
\r
2093 if(ExistNotify == YES)
\r
2095 SoundPlay(SND_ERROR);
\r
2096 if(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(up_exist_dlg), GetMainHwnd(), UpExistDialogCallBack, (LPARAM)Pkt) == NO)
\r
2097 Ret = EXIST_ABORT;
\r
2099 Ret = UpExistMode;
\r
2102 Ret = UpExistMode;
\r
2104 if(Ret == EXIST_NEW)
\r
2107 if(CompareFileTime(&Exist->Time, &Pkt->Time) < 0)
\r
2110 Ret = EXIST_IGNORE;
\r
2112 // 同じ名前のファイルの処理方法追加
\r
2113 if(Ret == EXIST_LARGE)
\r
2115 if(Exist->Size < Pkt->Size)
\r
2118 Ret = EXIST_IGNORE;
\r
2126 /*----- ホストに同じ名前のファイルがある時の確認ダイアログのコールバック ------
\r
2129 * HWND hDlg : ウインドウハンドル
\r
2130 * UINT message : メッセージ番号
\r
2131 * WPARAM wParam : メッセージの WPARAM 引数
\r
2132 * LPARAM lParam : メッセージの LPARAM 引数
\r
2136 *----------------------------------------------------------------------------*/
\r
2139 //static BOOL CALLBACK UpExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2140 static INT_PTR CALLBACK UpExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2142 static TRANSPACKET *Pkt;
\r
2143 // 同じ名前のファイルの処理方法追加
\r
2144 // static const RADIOBUTTON UpExistButton[] = {
\r
2145 // { UP_EXIST_OVW, EXIST_OVW },
\r
2146 // { UP_EXIST_NEW, EXIST_NEW },
\r
2147 // { UP_EXIST_RESUME, EXIST_RESUME },
\r
2148 // { UP_EXIST_UNIQUE, EXIST_UNIQUE },
\r
2149 // { UP_EXIST_IGNORE, EXIST_IGNORE }
\r
2151 static const RADIOBUTTON UpExistButton[] = {
\r
2152 { UP_EXIST_OVW, EXIST_OVW },
\r
2153 { UP_EXIST_NEW, EXIST_NEW },
\r
2154 { UP_EXIST_RESUME, EXIST_RESUME },
\r
2155 { UP_EXIST_UNIQUE, EXIST_UNIQUE },
\r
2156 { UP_EXIST_IGNORE, EXIST_IGNORE },
\r
2157 { UP_EXIST_LARGE, EXIST_LARGE }
\r
2159 #define UPEXISTBUTTONS (sizeof(UpExistButton)/sizeof(RADIOBUTTON))
\r
2163 case WM_INITDIALOG :
\r
2164 Pkt = (TRANSPACKET *)lParam;
\r
2165 SendDlgItemMessage(hDlg, UP_EXIST_NAME, EM_LIMITTEXT, FMAX_PATH, 0);
\r
2166 SendDlgItemMessage(hDlg, UP_EXIST_NAME, WM_SETTEXT, 0, (LPARAM)Pkt->RemoteFile);
\r
2168 if((Pkt->Type == TYPE_A) || (Pkt->ExistSize <= 0))
\r
2169 EnableWindow(GetDlgItem(hDlg, UP_EXIST_RESUME), FALSE);
\r
2171 SetRadioButtonByValue(hDlg, UpExistMode, UpExistButton, UPEXISTBUTTONS);
\r
2175 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2179 /* ここに break はない */
\r
2182 UpExistMode = AskRadioButtonValue(hDlg, UpExistButton, UPEXISTBUTTONS);
\r
2183 SendDlgItemMessage(hDlg, UP_EXIST_NAME, WM_GETTEXT, FMAX_PATH, (LPARAM)Pkt->RemoteFile);
\r
2184 EndDialog(hDlg, YES);
\r
2188 // Pkt->Abort = ABORT_USER;
\r
2189 // UpExistMode = EXIST_IGNORE;
\r
2190 EndDialog(hDlg, NO);
\r
2194 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000011);
\r
2203 /*----- アップロード/ダウンロードファイル名入力ダイアログのコールバック ------
\r
2206 * HWND hDlg : ウインドウハンドル
\r
2207 * UINT message : メッセージ番号
\r
2208 * WPARAM wParam : メッセージの WPARAM 引数
\r
2209 * LPARAM lParam : メッセージの LPARAM 引数
\r
2213 *----------------------------------------------------------------------------*/
\r
2216 //static BOOL CALLBACK UpDownAsDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2217 static INT_PTR CALLBACK UpDownAsDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2221 case WM_INITDIALOG :
\r
2222 if(CurWin == WIN_LOCAL)
\r
2223 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN064);
\r
2225 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN065);
\r
2227 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, EM_LIMITTEXT, FMAX_PATH, 0);
\r
2228 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2229 SendDlgItemMessage(hDlg, UPDOWNAS_TEXT, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2233 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2236 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, WM_GETTEXT, FMAX_PATH, (LPARAM)TmpString);
\r
2237 EndDialog(hDlg, YES);
\r
2240 case UPDOWNAS_STOP :
\r
2241 EndDialog(hDlg, NO_ALL);
\r
2250 #if defined(HAVE_TANDEM)
\r
2251 /*----- アップロード/ダウンロードファイル名入力ダイアログのコールバック ------
\r
2254 * HWND hDlg : ウインドウハンドル
\r
2255 * UINT message : メッセージ番号
\r
2256 * WPARAM wParam : メッセージの WPARAM 引数
\r
2257 * LPARAM lParam : メッセージの LPARAM 引数
\r
2261 *----------------------------------------------------------------------------*/
\r
2263 static INT_PTR CALLBACK UpDownAsWithExtDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2267 case WM_INITDIALOG :
\r
2268 if(CurWin == WIN_LOCAL)
\r
2269 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN064);
\r
2271 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN065);
\r
2273 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, EM_LIMITTEXT, FMAX_PATH, 0);
\r
2274 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2275 SendDlgItemMessage(hDlg, UPDOWNAS_TEXT, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2276 SendDlgItemMessage(hDlg, UPDOWNAS_FILECODE, EM_LIMITTEXT, 4, 0);
\r
2277 SendDlgItemMessage(hDlg, UPDOWNAS_FILECODE, WM_SETTEXT, 0, (LPARAM)TmpFileCode);
\r
2282 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2285 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, WM_GETTEXT, FMAX_PATH, (LPARAM)TmpString);
\r
2286 SendDlgItemMessage(hDlg, UPDOWNAS_FILECODE, WM_GETTEXT, FMAX_PATH, (LPARAM)TmpFileCode);
\r
2287 EndDialog(hDlg, YES);
\r
2290 case UPDOWNAS_STOP :
\r
2291 EndDialog(hDlg, NO_ALL);
\r
2301 /*----- ファイル一覧で指定されたファイルを削除する ----------------------------
\r
2308 *----------------------------------------------------------------------------*/
\r
2310 void DeleteProc(void)
\r
2313 FILELIST *FileListBase;
\r
2317 char CurDir[FMAX_PATH+1];
\r
2318 char Tmp[FMAX_PATH+1];
\r
2326 AskRemoteCurDir(CurDir, FMAX_PATH);
\r
2327 FileListBase = NULL;
\r
2328 if(GetFocus() == GetLocalHwnd())
\r
2331 MakeSelectedFileList(Win, NO, NO, &FileListBase, &CancelFlg);
\r
2336 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2337 MakeSelectedFileList(Win, YES, NO, &FileListBase, &CancelFlg);
\r
2345 // DisableUserOpe();
\r
2349 Pos = FileListBase;
\r
2350 while(Pos != NULL)
\r
2352 if(Pos->Node == NODE_FILE)
\r
2354 DelNotifyAndDo(Pos, Win, &Sts, &DelFlg, CurDir);
\r
2362 DeleteAllDir(FileListBase, Win, &Sts, &DelFlg, CurDir);
\r
2364 if(Win == WIN_REMOTE)
\r
2366 AskRemoteCurDir(Tmp, FMAX_PATH);
\r
2367 if(strcmp(Tmp, CurDir) != 0)
\r
2368 DoCWD(Tmp, NO, NO, NO);
\r
2371 DeleteFileList(&FileListBase);
\r
2375 if(Win == WIN_LOCAL)
\r
2376 GetLocalDirForWnd();
\r
2378 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2382 // EnableUserOpe();
\r
2390 /*----- サブディレクトリ以下を全て削除する ------------------------------------
\r
2393 * FILELIST *Dt : 削除するファイルのリスト
\r
2394 * int Win : ウインドウ番号 (WIN_xxx)
\r
2395 * int *Sw : 操作方法 (YES/NO/YES_ALL/NO_ALL)
\r
2396 * int *Flg : ファイルを削除したかどうかのフラグ (YES/NO)
\r
2397 * char *CurDir : カレントディレクトリ
\r
2401 *----------------------------------------------------------------------------*/
\r
2403 static void DeleteAllDir(FILELIST *Dt, int Win, int *Sw, int *Flg, char *CurDir)
\r
2407 if(Dt->Node == NODE_DIR)
\r
2409 DeleteAllDir(Dt->Next, Win, Sw, Flg, CurDir);
\r
2413 DelNotifyAndDo(Dt, Win, Sw, Flg, CurDir);
\r
2422 /*----- 削除するかどうかの確認と削除実行 --------------------------------------
\r
2425 * FILELIST *Dt : 削除するファイルのリスト
\r
2426 * int Win : ウインドウ番号 (WIN_xxx)
\r
2427 * int *Sw : 操作方法 (YES/NO/YES_ALL/NO_ALL)
\r
2428 * int *Flg : ファイルを削除したかどうかのフラグ (YES/NO)
\r
2429 * char *CurDir : カレントディレクトリ
\r
2433 *----------------------------------------------------------------------------*/
\r
2435 static void DelNotifyAndDo(FILELIST *Dt, int Win, int *Sw, int *Flg, char *CurDir)
\r
2437 char Path[FMAX_PATH+1];
\r
2439 if(Win == WIN_LOCAL)
\r
2441 AskLocalCurDir(Path, FMAX_PATH);
\r
2443 strcat(Path, Dt->File);
\r
2444 ReplaceAll(Path, '/', '\\');
\r
2448 AskRemoteCurDir(Path, FMAX_PATH);
\r
2449 SetSlashTail(Path);
\r
2450 strcat(Path, Dt->File);
\r
2451 ReplaceAll(Path, '\\', '/');
\r
2454 if(*Sw != YES_ALL)
\r
2456 sprintf(TmpString, "%s", Path);
\r
2458 // ローカルのファイルのパスの最後の'\\'が消えるバグ修正
\r
2459 // if(AskHostType() == HTYPE_VMS)
\r
2460 if(Win == WIN_REMOTE && AskHostType() == HTYPE_VMS)
\r
2461 ReformToVMSstylePathName(TmpString);
\r
2464 *Sw = DialogBox(GetFtpInst(), MAKEINTRESOURCE(delete_dlg), GetMainHwnd(), DeleteDialogCallBack);
\r
2467 if((*Sw == YES) || (*Sw == YES_ALL))
\r
2469 if(Win == WIN_LOCAL)
\r
2471 if(Dt->Node == NODE_FILE)
\r
2472 DoLocalDELE(Path);
\r
2479 /* フルパスを使わない時のための処理 */
\r
2481 // if(ProcForNonFullpath(Path, CurDir, GetMainHwnd(), 0) == FFFTP_FAIL)
\r
2482 if(ProcForNonFullpath(AskCmdCtrlSkt(), Path, CurDir, GetMainHwnd(), &CancelFlg) == FFFTP_FAIL)
\r
2487 if(Dt->Node == NODE_FILE)
\r
2499 /*----- ファイル削除ダイアログのコールバック ----------------------------------
\r
2502 * HWND hDlg : ウインドウハンドル
\r
2503 * UINT message : メッセージ番号
\r
2504 * WPARAM wParam : メッセージの WPARAM 引数
\r
2505 * LPARAM lParam : メッセージの LPARAM 引数
\r
2509 *----------------------------------------------------------------------------*/
\r
2512 //static BOOL CALLBACK DeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2513 static INT_PTR CALLBACK DeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2517 case WM_INITDIALOG :
\r
2518 if(CurWin == WIN_LOCAL)
\r
2519 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN066);
\r
2521 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN067);
\r
2522 SendDlgItemMessage(hDlg, DELETE_TEXT, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2526 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2529 EndDialog(hDlg, YES);
\r
2533 EndDialog(hDlg, NO);
\r
2537 EndDialog(hDlg, YES_ALL);
\r
2541 EndDialog(hDlg, NO_ALL);
\r
2550 /*----- ファイル一覧で指定されたファイルの名前を変更する ----------------------
\r
2557 *----------------------------------------------------------------------------*/
\r
2559 void RenameProc(void)
\r
2562 FILELIST *FileListBase;
\r
2564 char New[FMAX_PATH+1];
\r
2571 Sts = FFFTP_SUCCESS;
\r
2572 if(GetFocus() == GetLocalHwnd())
\r
2577 Sts = CheckClosedAndReconnect();
\r
2580 if(Sts == FFFTP_SUCCESS)
\r
2584 FileListBase = NULL;
\r
2585 MakeSelectedFileList(Win, NO, NO, &FileListBase, &CancelFlg);
\r
2589 Pos = FileListBase;
\r
2590 while(Pos != NULL)
\r
2592 if((Pos->Node == NODE_FILE) || (Pos->Node == NODE_DIR))
\r
2594 strcpy(TmpString, Pos->File);
\r
2596 Sts = DialogBox(GetFtpInst(), MAKEINTRESOURCE(rename_dlg), GetMainHwnd(), RenameDialogCallBack);
\r
2601 if((Sts == YES) && (strlen(TmpString) != 0))
\r
2603 strcpy(New, TmpString);
\r
2604 if(Win == WIN_LOCAL)
\r
2605 DoLocalRENAME(Pos->File, New);
\r
2607 DoRENAME(Pos->File, New);
\r
2613 DeleteFileList(&FileListBase);
\r
2617 if(Win == WIN_LOCAL)
\r
2618 GetLocalDirForWnd();
\r
2620 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2630 // リモート側でのファイルの移動(リネーム)を行う
\r
2632 // RenameProc()をベースに改造。(2007.9.5 yutaka)
\r
2634 void MoveRemoteFileProc(int drop_index)
\r
2637 FILELIST *FileListBase;
\r
2640 char New[FMAX_PATH+1];
\r
2641 char Old[FMAX_PATH+1];
\r
2642 char HostDir[FMAX_PATH+1];
\r
2649 if(MoveMode == MOVE_DISABLE)
\r
2654 AskRemoteCurDir(HostDir, FMAX_PATH);
\r
2658 // GetNodeName(WIN_REMOTE, drop_index, Pkt.File, FMAX_PATH);
\r
2659 if(drop_index >= 0)
\r
2660 GetNodeName(WIN_REMOTE, drop_index, Pkt.File, FMAX_PATH);
\r
2662 strcpy(Pkt.File, "..");
\r
2664 if(MoveMode == MOVE_DLG)
\r
2666 if(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(move_notify_dlg), GetRemoteHwnd(), ExeEscTextDialogProc, (LPARAM)Pkt.File) == NO)
\r
2672 Sts = FFFTP_SUCCESS;
\r
2674 if(GetFocus() == GetLocalHwnd())
\r
2679 Sts = CheckClosedAndReconnect();
\r
2683 Sts = CheckClosedAndReconnect();
\r
2686 if(Sts == FFFTP_SUCCESS)
\r
2690 FileListBase = NULL;
\r
2691 MakeSelectedFileList(Win, NO, NO, &FileListBase, &CancelFlg);
\r
2695 Pos = FileListBase;
\r
2696 while(Pos != NULL)
\r
2698 if((Pos->Node == NODE_FILE) || (Pos->Node == NODE_DIR))
\r
2700 strcpy(TmpString, Pos->File);
\r
2703 Sts = DialogBox(GetFtpInst(), MAKEINTRESOURCE(rename_dlg), GetMainHwnd(), RenameDialogCallBack);
\r
2711 if((Sts == YES) && (strlen(TmpString) != 0))
\r
2714 strncpy_s(Old, sizeof(Old), HostDir, _TRUNCATE);
\r
2715 strncat_s(Old, sizeof(Old), "/", _TRUNCATE);
\r
2716 strncat_s(Old, sizeof(Old), Pos->File, _TRUNCATE);
\r
2719 strncpy_s(New, sizeof(New), HostDir, _TRUNCATE);
\r
2720 strncat_s(New, sizeof(New), "/", _TRUNCATE);
\r
2721 strncat_s(New, sizeof(New), Pkt.File, _TRUNCATE);
\r
2722 strncat_s(New, sizeof(New), "/", _TRUNCATE);
\r
2723 strncat_s(New, sizeof(New), Pos->File, _TRUNCATE);
\r
2725 if(Win == WIN_LOCAL)
\r
2726 DoLocalRENAME(Old, New);
\r
2728 DoRENAME(Old, New);
\r
2734 DeleteFileList(&FileListBase);
\r
2738 if(Win == WIN_LOCAL) {
\r
2739 GetLocalDirForWnd();
\r
2741 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2743 strncpy_s(New, sizeof(New), HostDir, _TRUNCATE);
\r
2744 strncat_s(New, sizeof(New), "/", _TRUNCATE);
\r
2745 strncat_s(New, sizeof(New), Pkt.File, _TRUNCATE);
\r
2746 DoCWD(New, YES, YES, YES);
\r
2747 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2758 /*----- 新ファイル名入力ダイアログのコールバック ------------------------------
\r
2761 * HWND hDlg : ウインドウハンドル
\r
2762 * UINT message : メッセージ番号
\r
2763 * WPARAM wParam : メッセージの WPARAM 引数
\r
2764 * LPARAM lParam : メッセージの LPARAM 引数
\r
2768 *----------------------------------------------------------------------------*/
\r
2771 //static BOOL CALLBACK RenameDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2772 static INT_PTR CALLBACK RenameDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2776 case WM_INITDIALOG :
\r
2777 if(CurWin == WIN_LOCAL)
\r
2778 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN068);
\r
2780 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN069);
\r
2781 SendDlgItemMessage(hDlg, RENAME_NEW, EM_LIMITTEXT, FMAX_PATH, 0);
\r
2782 SendDlgItemMessage(hDlg, RENAME_NEW, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2783 SendDlgItemMessage(hDlg, RENAME_TEXT, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2787 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2790 SendDlgItemMessage(hDlg, RENAME_NEW, WM_GETTEXT, FMAX_PATH, (LPARAM)TmpString);
\r
2791 EndDialog(hDlg, YES);
\r
2795 EndDialog(hDlg, NO);
\r
2798 case RENAME_STOP :
\r
2799 EndDialog(hDlg, NO_ALL);
\r
2808 /*----- 新しいディレクトリを作成する ------------------------------------------
\r
2815 *----------------------------------------------------------------------------*/
\r
2817 void MkdirProc(void)
\r
2821 char Path[FMAX_PATH+1];
\r
2828 if(GetFocus() == GetLocalHwnd())
\r
2831 Title = MSGJPN070;
\r
2836 Title = MSGJPN071;
\r
2840 Sts = InputDialogBox(mkdir_dlg, GetMainHwnd(), Title, Path, FMAX_PATH+1, &Tmp, IDH_HELP_TOPIC_0000001);
\r
2842 if((Sts == YES) && (strlen(Path) != 0))
\r
2844 if(Win == WIN_LOCAL)
\r
2848 GetLocalDirForWnd();
\r
2853 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2857 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2866 /*----- ヒストリリストを使ったディレクトリの移動 ------------------------------
\r
2869 * HWND hWnd : コンボボックスのウインドウハンドル
\r
2873 *----------------------------------------------------------------------------*/
\r
2875 void ChangeDirComboProc(HWND hWnd)
\r
2877 char Tmp[FMAX_PATH+1];
\r
2883 if((i = SendMessage(hWnd, CB_GETCURSEL, 0, 0)) != CB_ERR)
\r
2885 SendMessage(hWnd, CB_GETLBTEXT, i, (LPARAM)Tmp);
\r
2887 if(hWnd == GetLocalHistHwnd())
\r
2891 GetLocalDirForWnd();
\r
2896 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2899 if(DoCWD(Tmp, YES, NO, YES) < FTP_RETRY)
\r
2900 GetRemoteDirForWnd(CACHE_NORMAL, &CancelFlg);
\r
2909 /*----- ブックマークを使ったディレクトリの移動 --------------------------------
\r
2912 * int MarkID : ブックマークのメニューID
\r
2916 *----------------------------------------------------------------------------*/
\r
2918 void ChangeDirBmarkProc(int MarkID)
\r
2920 char Local[FMAX_PATH+1];
\r
2921 char Remote[FMAX_PATH+1];
\r
2927 Sts = AskBookMarkText(MarkID, Local, Remote, FMAX_PATH+1);
\r
2928 if((Sts == BMARK_TYPE_LOCAL) || (Sts == BMARK_TYPE_BOTH))
\r
2931 if(DoLocalCWD(Local) == FFFTP_SUCCESS)
\r
2932 GetLocalDirForWnd();
\r
2936 if((Sts == BMARK_TYPE_REMOTE) || (Sts == BMARK_TYPE_BOTH))
\r
2938 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2941 if(DoCWD(Remote, YES, NO, YES) < FTP_RETRY)
\r
2942 GetRemoteDirForWnd(CACHE_NORMAL, &CancelFlg);
\r
2950 /*----- ディレクトリ名を入力してディレクトリの移動 ----------------------------
\r
2953 * int Win : ウインドウ番号 (WIN_xxx)
\r
2957 *----------------------------------------------------------------------------*/
\r
2959 void ChangeDirDirectProc(int Win)
\r
2962 char Path[FMAX_PATH+1];
\r
2969 if(Win == WIN_LOCAL)
\r
2970 Title = MSGJPN072;
\r
2972 Title = MSGJPN073;
\r
2975 if(Win == WIN_LOCAL)
\r
2976 // フォルダ選択ダイアログを直接表示
\r
2977 // Sts = InputDialogBox(chdir_br_dlg, GetMainHwnd(), Title, Path, FMAX_PATH+1, &Tmp, IDH_HELP_TOPIC_0000001);
\r
2979 if(SelectDir(GetMainHwnd(), Path, FMAX_PATH) == TRUE)
\r
2983 Sts = InputDialogBox(chdir_dlg, GetMainHwnd(), Title, Path, FMAX_PATH+1, &Tmp, IDH_HELP_TOPIC_0000001);
\r
2985 if((Sts == YES) && (strlen(Path) != 0))
\r
2987 if(Win == WIN_LOCAL)
\r
2991 GetLocalDirForWnd();
\r
2996 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2999 if(DoCWD(Path, YES, NO, YES) < FTP_RETRY)
\r
3000 GetRemoteDirForWnd(CACHE_NORMAL, &CancelFlg);
\r
3009 /*----- Dropされたファイルによるディレクトリの移動 ----------------------------
\r
3012 * WPARAM wParam : ドロップされたファイルの情報
\r
3016 *----------------------------------------------------------------------------*/
\r
3018 void ChangeDirDropFileProc(WPARAM wParam)
\r
3020 char Path[FMAX_PATH+1];
\r
3023 MakeDroppedDir(wParam, Path);
\r
3025 GetLocalDirForWnd();
\r
3031 /*----- ファイルの属性変更 ----------------------------------------------------
\r
3038 *----------------------------------------------------------------------------*/
\r
3040 void ChmodProc(void)
\r
3043 FILELIST *FileListBase;
\r
3053 if(GetFocus() == GetRemoteHwnd())
\r
3055 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
3058 FileListBase = NULL;
\r
3059 MakeSelectedFileList(WIN_REMOTE, NO, NO, &FileListBase, &CancelFlg);
\r
3060 if(FileListBase != NULL)
\r
3062 sprintf(Tmp, "%03X", FileListBase->Attr);
\r
3063 if(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(chmod_dlg), GetMainHwnd(), ChmodDialogCallBack, (LPARAM)Tmp) == YES)
\r
3066 Pos = FileListBase;
\r
3067 while(Pos != NULL)
\r
3069 if((Pos->Node == NODE_FILE) || (Pos->Node == NODE_DIR))
\r
3071 DoCHMOD(Pos->File, Tmp);
\r
3076 if(ChmodFlg == YES)
\r
3077 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
3080 DeleteFileList(&FileListBase);
\r
3084 else if(GetFocus() == GetLocalHwnd())
\r
3087 FileListBase = NULL;
\r
3088 MakeSelectedFileList(WIN_LOCAL, NO, NO, &FileListBase, &CancelFlg);
\r
3089 if(FileListBase != NULL)
\r
3091 if((Buf = malloc(1)) != NULL)
\r
3095 Pos = FileListBase;
\r
3096 while(Pos != NULL)
\r
3098 if((BufTmp = realloc(Buf, BufLen + strlen(Pos->File) + 2)) != NULL)
\r
3101 strcpy(Buf+BufLen, Pos->File);
\r
3102 BufLen += strlen(Pos->File) + 1;
\r
3107 memset(Buf+BufLen, NUL, 1);
\r
3108 DispFileProperty(Buf);
\r
3112 DeleteFileList(&FileListBase);
\r
3119 /*----- 属性変更ダイアログのコールバック --------------------------------------
\r
3122 * HWND hDlg : ウインドウハンドル
\r
3123 * UINT message : メッセージ番号
\r
3124 * WPARAM wParam : メッセージの WPARAM 引数
\r
3125 * LPARAM lParam : メッセージの LPARAM 引数
\r
3129 *----------------------------------------------------------------------------*/
\r
3132 //BOOL CALLBACK ChmodDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
3133 INT_PTR CALLBACK ChmodDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
3141 case WM_INITDIALOG :
\r
3142 Buf = (char *)lParam;
\r
3143 SendDlgItemMessage(hDlg, PERM_NOW, EM_LIMITTEXT, 4, 0);
\r
3144 SendDlgItemMessage(hDlg, PERM_NOW, WM_SETTEXT, 0, (LPARAM)Buf);
\r
3145 SetAttrToDialog(hDlg, xtoi(Buf));
\r
3149 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
3152 SendDlgItemMessage(hDlg, PERM_NOW, WM_GETTEXT, 5, (LPARAM)Buf);
\r
3153 EndDialog(hDlg, YES);
\r
3157 EndDialog(hDlg, NO);
\r
3160 case PERM_O_READ :
\r
3161 case PERM_O_WRITE :
\r
3162 case PERM_O_EXEC :
\r
3163 case PERM_G_READ :
\r
3164 case PERM_G_WRITE :
\r
3165 case PERM_G_EXEC :
\r
3166 case PERM_A_READ :
\r
3167 case PERM_A_WRITE :
\r
3168 case PERM_A_EXEC :
\r
3169 Tmp = GetAttrFromDialog(hDlg);
\r
3170 sprintf(Str, "%03X", Tmp);
\r
3171 SendDlgItemMessage(hDlg, PERM_NOW, WM_SETTEXT, 0, (LPARAM)Str);
\r
3175 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000017);
\r
3184 /*----- 属性をダイアログボックスに設定 ----------------------------------------
\r
3187 * HWND hWnd : ダイアログボックスのウインドウハンドル
\r
3192 *----------------------------------------------------------------------------*/
\r
3194 static void SetAttrToDialog(HWND hDlg, int Attr)
\r
3197 SendDlgItemMessage(hDlg, PERM_O_READ, BM_SETCHECK, 1, 0);
\r
3199 SendDlgItemMessage(hDlg, PERM_O_WRITE, BM_SETCHECK, 1, 0);
\r
3201 SendDlgItemMessage(hDlg, PERM_O_EXEC, BM_SETCHECK, 1, 0);
\r
3204 SendDlgItemMessage(hDlg, PERM_G_READ, BM_SETCHECK, 1, 0);
\r
3206 SendDlgItemMessage(hDlg, PERM_G_WRITE, BM_SETCHECK, 1, 0);
\r
3208 SendDlgItemMessage(hDlg, PERM_G_EXEC, BM_SETCHECK, 1, 0);
\r
3211 SendDlgItemMessage(hDlg, PERM_A_READ, BM_SETCHECK, 1, 0);
\r
3213 SendDlgItemMessage(hDlg, PERM_A_WRITE, BM_SETCHECK, 1, 0);
\r
3215 SendDlgItemMessage(hDlg, PERM_A_EXEC, BM_SETCHECK, 1, 0);
\r
3221 /*----- ダイアログボックスの内容から属性を取得 --------------------------------
\r
3224 * HWND hWnd : ダイアログボックスのウインドウハンドル
\r
3228 *----------------------------------------------------------------------------*/
\r
3230 static int GetAttrFromDialog(HWND hDlg)
\r
3236 if(SendDlgItemMessage(hDlg, PERM_O_READ, BM_GETCHECK, 0, 0) == 1)
\r
3238 if(SendDlgItemMessage(hDlg, PERM_O_WRITE, BM_GETCHECK, 0, 0) == 1)
\r
3240 if(SendDlgItemMessage(hDlg, PERM_O_EXEC, BM_GETCHECK, 0, 0) == 1)
\r
3243 if(SendDlgItemMessage(hDlg, PERM_G_READ, BM_GETCHECK, 0, 0) == 1)
\r
3245 if(SendDlgItemMessage(hDlg, PERM_G_WRITE, BM_GETCHECK, 0, 0) == 1)
\r
3247 if(SendDlgItemMessage(hDlg, PERM_G_EXEC, BM_GETCHECK, 0, 0) == 1)
\r
3250 if(SendDlgItemMessage(hDlg, PERM_A_READ, BM_GETCHECK, 0, 0) == 1)
\r
3252 if(SendDlgItemMessage(hDlg, PERM_A_WRITE, BM_GETCHECK, 0, 0) == 1)
\r
3254 if(SendDlgItemMessage(hDlg, PERM_A_EXEC, BM_GETCHECK, 0, 0) == 1)
\r
3263 /*----- 任意のコマンドを送る --------------------------------------------------
\r
3270 *----------------------------------------------------------------------------*/
\r
3272 void SomeCmdProc(void)
\r
3276 FILELIST *FileListBase;
\r
3281 if(GetFocus() == GetRemoteHwnd())
\r
3283 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
3286 FileListBase = NULL;
\r
3287 MakeSelectedFileList(WIN_REMOTE, NO, NO, &FileListBase, &CancelFlg);
\r
3288 memset(Cmd, NUL, 81);
\r
3289 if(FileListBase != NULL)
\r
3291 strncpy(Cmd, FileListBase->File, 80);
\r
3293 DeleteFileList(&FileListBase);
\r
3295 if(InputDialogBox(somecmd_dlg, GetMainHwnd(), NULL, Cmd, 81, &Tmp, IDH_HELP_TOPIC_0000023) == YES)
\r
3299 DoQUOTE(AskCmdCtrlSkt(), Cmd, &CancelFlg);
\r
3310 /*----- ファイル総容量の計算を行う --------------------------------------------
\r
3317 *----------------------------------------------------------------------------*/
\r
3319 void CalcFileSizeProc(void)
\r
3321 FILELIST *ListBase;
\r
3330 if((All = DialogBox(GetFtpInst(), MAKEINTRESOURCE(filesize_notify_dlg), GetMainHwnd(), SizeNotifyDlgWndProc)) != NO_ALL)
\r
3332 Sts = FFFTP_SUCCESS;
\r
3333 if(GetFocus() == GetLocalHwnd())
\r
3338 Sts = CheckClosedAndReconnect();
\r
3341 if(Sts == FFFTP_SUCCESS)
\r
3344 MakeSelectedFileList(Win, YES, All, &ListBase, &CancelFlg);
\r
3348 while(Pos != NULL)
\r
3350 if(Pos->Node != NODE_DIR)
\r
3351 FileSize += Pos->Size;
\r
3354 DeleteFileList(&ListBase);
\r
3355 DialogBox(GetFtpInst(), MAKEINTRESOURCE(filesize_dlg), GetMainHwnd(), SizeDlgWndProc);
\r
3362 /*----- ファイル容量検索確認ダイアログのコールバック --------------------------
\r
3365 * HWND hDlg : ウインドウハンドル
\r
3366 * UINT message : メッセージ番号
\r
3367 * WPARAM wParam : メッセージの WPARAM 引数
\r
3368 * LPARAM lParam : メッセージの LPARAM 引数
\r
3372 *----------------------------------------------------------------------------*/
\r
3374 static LRESULT CALLBACK SizeNotifyDlgWndProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
\r
3378 case WM_INITDIALOG :
\r
3379 if(GetFocus() == GetLocalHwnd())
\r
3380 SendDlgItemMessage(hDlg, FSNOTIFY_TITLE, WM_SETTEXT, 0, (LPARAM)MSGJPN074);
\r
3382 SendDlgItemMessage(hDlg, FSNOTIFY_TITLE, WM_SETTEXT, 0, (LPARAM)MSGJPN075);
\r
3386 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
3389 if(SendDlgItemMessage(hDlg, FSNOTIFY_SEL_ONLY, BM_GETCHECK, 0, 0) == 1)
\r
3390 EndDialog(hDlg, NO);
\r
3392 EndDialog(hDlg, YES);
\r
3396 EndDialog(hDlg, NO_ALL);
\r
3405 /*----- ファイル容量検索ダイアログのコールバック ------------------------------
\r
3408 * HWND hDlg : ウインドウハンドル
\r
3409 * UINT message : メッセージ番号
\r
3410 * WPARAM wParam : メッセージの WPARAM 引数
\r
3411 * LPARAM lParam : メッセージの LPARAM 引数
\r
3415 *----------------------------------------------------------------------------*/
\r
3417 static LRESULT CALLBACK SizeDlgWndProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
\r
3419 char Tmp[FMAX_PATH+1];
\r
3423 case WM_INITDIALOG :
\r
3424 if(GetFocus() == GetLocalHwnd())
\r
3425 SendDlgItemMessage(hDlg, FSIZE_TITLE, WM_SETTEXT, 0, (LPARAM)MSGJPN076);
\r
3427 SendDlgItemMessage(hDlg, FSIZE_TITLE, WM_SETTEXT, 0, (LPARAM)MSGJPN077);
\r
3429 MakeSizeString(FileSize, Tmp);
\r
3430 SendDlgItemMessage(hDlg, FSIZE_SIZE, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
3434 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
3438 EndDialog(hDlg, YES);
\r
3448 /*----- ディレクトリ移動失敗時のエラーを表示 ----------------------------------
\r
3451 * HWND hDlg : ウインドウハンドル
\r
3455 *----------------------------------------------------------------------------*/
\r
3457 void DispCWDerror(HWND hWnd)
\r
3459 DialogBox(GetFtpInst(), MAKEINTRESOURCE(cwderr_dlg), hWnd, ExeEscDialogProc);
\r
3464 /*----- URLをクリップボードにコピー -------------------------------------------
\r
3471 *----------------------------------------------------------------------------*/
\r
3473 void CopyURLtoClipBoard(void)
\r
3475 FILELIST *FileListBase;
\r
3478 char Path[FMAX_PATH+1];
\r
3479 char Host[HOST_ADRS_LEN+1];
\r
3484 if(GetFocus() == GetRemoteHwnd())
\r
3486 FileListBase = NULL;
\r
3487 MakeSelectedFileList(WIN_REMOTE, NO, NO, &FileListBase, &CancelFlg);
\r
3488 if(FileListBase != NULL)
\r
3490 strcpy(Host, AskHostAdrs());
\r
3493 Pos = FileListBase;
\r
3494 while(Pos != NULL)
\r
3496 AskRemoteCurDir(Path, FMAX_PATH);
\r
3497 SetSlashTail(Path);
\r
3498 strcat(Path, Pos->File);
\r
3500 if(AskHostType() == HTYPE_VMS)
\r
3501 ReformToVMSstylePathName(Path);
\r
3504 if(AskHostPort() != PORT_NOR)
\r
3505 sprintf(Port, ":%d", AskHostPort());
\r
3508 Total += strlen(Path) + strlen(Host) + strlen(Port) + 8; /* 8は "ftp://\r\n" のぶん */
\r
3509 if(AskHostType() == HTYPE_VMS)
\r
3512 if((Buf = realloc(Buf, Total+1)) == NULL)
\r
3515 if(AskHostType() != HTYPE_VMS)
\r
3516 sprintf(Buf + Set, "ftp://%s%s%s\r\n", Host, Port, Path);
\r
3518 sprintf(Buf + Set, "ftp://%s%s/%s\r\n", Host, Port, Path);
\r
3525 CopyStrToClipBoard(Buf);
\r
3529 DeleteFileList(&FileListBase);
\r
3535 /*----- フルパスを使わないファイルアクセスの準備 ------------------------------
\r
3538 * char *Path : パス名
\r
3539 * char *CurDir : カレントディレクトリ
\r
3540 * HWND hWnd : エラーウインドウを表示する際の親ウインドウ
\r
3541 * int Type : 使用するソケットの種類
\r
3542 * 0=コマンドソケット, 1=転送ソケット
\r
3545 * int ステータス(FFFTP_SUCCESS/FFFTP_FAIL)
\r
3549 * このモジュール内で CWD を行ない、
\r
3550 * Path にファイル名のみ残す。(パス名は消す)
\r
3551 *----------------------------------------------------------------------------*/
\r
3554 //int ProcForNonFullpath(char *Path, char *CurDir, HWND hWnd, int Type)
\r
3555 int ProcForNonFullpath(SOCKET cSkt, char *Path, char *CurDir, HWND hWnd, int *CancelCheckWork)
\r
3559 char Tmp[FMAX_PATH+1];
\r
3561 Sts = FFFTP_SUCCESS;
\r
3562 if(AskNoFullPathMode() == YES)
\r
3564 strcpy(Tmp, Path);
\r
3565 if(AskHostType() == HTYPE_VMS)
\r
3567 GetUpperDirEraseTopSlash(Tmp);
\r
3568 ReformToVMSstyleDirName(Tmp);
\r
3570 else if(AskHostType() == HTYPE_STRATUS)
\r
3571 GetUpperDirEraseTopSlash(Tmp);
\r
3575 if(strcmp(Tmp, CurDir) != 0)
\r
3579 // Cmd = CommandProcCmd(NULL, "CWD %s", Tmp);
\r
3581 // Cmd = CommandProcTrn(NULL, "CWD %s", Tmp);
\r
3582 Cmd = CommandProcTrn(cSkt, NULL, CancelCheckWork, "CWD %s", Tmp);
\r
3584 if(Cmd/100 != FTP_COMPLETE)
\r
3586 DispCWDerror(hWnd);
\r
3590 strcpy(CurDir, Tmp);
\r
3592 strcpy(Path, GetFileName(Path));
\r
3598 /*----- ディレクトリ名をVAX VMSスタイルに変換する -----------------------------
\r
3601 * char *Path : パス名
\r
3607 * ddd:[xxx.yyy]/rrr/ppp --> ddd:[xxx.yyy.rrr.ppp]
\r
3608 *----------------------------------------------------------------------------*/
\r
3610 void ReformToVMSstyleDirName(char *Path)
\r
3615 if((Btm = strchr(Path, ']')) != NULL)
\r
3618 while((Pos = strchr(Pos, '/')) != NULL)
\r
3621 memmove(Btm, Btm+1, strlen(Btm+1)+1);
\r
3622 Pos = strchr(Path, NUL);
\r
3623 if(*(Pos-1) == '.')
\r
3634 /*----- ファイル名をVAX VMSスタイルに変換する ---------------------------------
\r
3637 * char *Path : パス名
\r
3643 * ddd:[xxx.yyy]/rrr/ppp --> ddd:[xxx.yyy.rrr]ppp
\r
3644 *----------------------------------------------------------------------------*/
\r
3646 void ReformToVMSstylePathName(char *Path)
\r
3648 char Fname[FMAX_PATH+1];
\r
3650 strcpy(Fname, GetFileName(Path));
\r
3652 GetUpperDirEraseTopSlash(Path);
\r
3653 ReformToVMSstyleDirName(Path);
\r
3655 strcat(Path, Fname);
\r
3661 #if defined(HAVE_OPENVMS)
\r
3662 /*----- VMSの"HOGE.DIR;?"というディレクトリ名から"HOGE"を取り出す ---------------
\r
3665 * char *DirName : "HOGE.DIR;?"形式のディレクトリ名
\r
3666 * int Flg : ";"のチェックをする(TRUE)かしない(FALSE)か
\r
3673 *----------------------------------------------------------------------------*/
\r
3675 void ReformVMSDirName(char *DirName, int Flg)
\r
3679 if (Flg == TRUE) {
\r
3680 /* ';'がない場合はVMS形式じゃなさそうなので何もしない */
\r
3681 if ((p = strrchr(DirName, ';')) == NULL)
\r
3685 /* ".DIR"があったらつぶす */
\r
3686 if ((p = strrchr(DirName, '.'))) {
\r
3687 if (memcmp(p + 1, "DIR", 3) == 0)
\r
3694 /*----- ファイル名に使えない文字がないかチェックし名前を変更する --------------
\r
3697 * char *Fname : ファイル名
\r
3701 * FFFTP_SUCCESS/FFFTP_FAIL=中止する
\r
3705 *----------------------------------------------------------------------------*/
\r
3707 static int RenameUnuseableName(char *Fname)
\r
3712 Ret = FFFTP_SUCCESS;
\r
3715 if((_mbschr(Fname, ':') != NULL) ||
\r
3716 (_mbschr(Fname, '*') != NULL) ||
\r
3717 (_mbschr(Fname, '?') != NULL) ||
\r
3718 (_mbschr(Fname, '<') != NULL) ||
\r
3719 (_mbschr(Fname, '>') != NULL) ||
\r
3720 (_mbschr(Fname, '|') != NULL) ||
\r
3721 (_mbschr(Fname, '\x22') != NULL) ||
\r
3722 (_mbschr(Fname, '\\') != NULL))
\r
3724 if(InputDialogBox(forcerename_dlg, GetMainHwnd(), NULL, Fname, FMAX_PATH+1, &Tmp, IDH_HELP_TOPIC_0000001) == NO)
\r
3738 // NOOPコマンドでは効果が無いホストが多いためLISTコマンドを使用
\r
3739 void NoopProc(int Force)
\r
3741 int CancelCheckWork;
\r
3742 CancelCheckWork = NO;
\r
3743 if(Force == YES || (AskConnecting() == YES && AskUserOpeDisabled() == NO))
\r
3745 if(AskReuseCmdSkt() == NO || AskShareProh() == YES || AskTransferNow() == NO)
\r
3748 DoDirListCmdSkt("", "", 999, &CancelCheckWork);
\r