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 /*===== ローカルなワーク =====*/
\r
114 static char TmpString[FMAX_PATH+80]; /* テンポラリ */
\r
115 #if defined(HAVE_TANDEM)
\r
116 static char TmpFileCode[5]; /* テンポラリ */
\r
118 static int CurWin; /* ウインドウ番号 */
\r
120 int UpExistMode = EXIST_OVW; /* アップロードで同じ名前のファイルがある時の扱い方 EXIST_xxx */
\r
121 int ExistMode = EXIST_OVW; /* 同じ名前のファイルがある時の扱い方 EXIST_xxx */
\r
122 static int ExistNotify; /* 確認ダイアログを出すかどうか YES/NO */
\r
124 static double FileSize; /* ファイル総容量 */
\r
128 /*----- ファイル一覧で指定されたファイルをダウンロードする --------------------
\r
131 * int ChName : 名前を変えるかどうか (YES/NO)
\r
132 * int ForceFile : ディレクトリをファイル見なすかどうか (YES/NO)
\r
133 * int All : 全てが選ばれている物として扱うかどうか (YES/NO)
\r
137 *----------------------------------------------------------------------------*/
\r
139 void DownLoadProc(int ChName, int ForceFile, int All)
\r
141 FILELIST *FileListBase;
\r
148 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
153 // KeepTransferDialog(YES);
\r
155 FileListBase = NULL;
\r
156 MakeSelectedFileList(WIN_REMOTE, (ForceFile == YES ? NO : YES), All, &FileListBase, &CancelFlg);
\r
158 if(AskNoFullPathMode() == YES)
\r
160 strcpy(Pkt.Cmd, "SETCUR");
\r
161 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
162 AddTransFileList(&Pkt);
\r
165 Pos = FileListBase;
\r
168 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
169 SetYenTail(Pkt.LocalFile);
\r
170 strcpy(TmpString, Pos->File);
\r
171 if((ChName == NO) || ((ForceFile == NO) && (Pos->Node == NODE_DIR)))
\r
173 if(FnameCnv == FNAME_LOWER)
\r
174 _mbslwr(TmpString);
\r
175 else if(FnameCnv == FNAME_UPPER)
\r
176 _mbsupr(TmpString);
\r
177 RemoveAfterSemicolon(TmpString);
\r
178 if(RenameUnuseableName(TmpString) == FFFTP_FAIL)
\r
183 CurWin = WIN_REMOTE;
\r
184 if(DialogBox(GetFtpInst(), MAKEINTRESOURCE(updown_as_dlg), GetMainHwnd(), UpDownAsDialogCallBack) == YES)
\r
186 if(RenameUnuseableName(TmpString) == FFFTP_FAIL)
\r
192 strcat(Pkt.LocalFile, TmpString);
\r
193 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
195 if((ForceFile == NO) && (Pos->Node == NODE_DIR))
\r
197 strcpy(Pkt.Cmd, "MKD ");
\r
198 strcpy(Pkt.RemoteFile, "");
\r
199 AddTransFileList(&Pkt);
\r
201 else if((Pos->Node == NODE_FILE) ||
\r
202 ((ForceFile == YES) && (Pos->Node == NODE_DIR)))
\r
204 if(AskHostType() == HTYPE_ACOS)
\r
206 strcpy(Pkt.RemoteFile, "'");
\r
207 strcat(Pkt.RemoteFile, AskHostLsName());
\r
208 strcat(Pkt.RemoteFile, "(");
\r
209 strcat(Pkt.RemoteFile, Pos->File);
\r
210 strcat(Pkt.RemoteFile, ")");
\r
211 strcat(Pkt.RemoteFile, "'");
\r
213 else if(AskHostType() == HTYPE_ACOS_4)
\r
215 strcpy(Pkt.RemoteFile, Pos->File);
\r
219 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
220 SetSlashTail(Pkt.RemoteFile);
\r
221 strcat(Pkt.RemoteFile, Pos->File);
\r
222 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
225 strcpy(Pkt.Cmd, "RETR ");
\r
226 #if defined(HAVE_TANDEM)
\r
227 if(AskHostType() == HTYPE_TANDEM) {
\r
228 if(AskTransferType() != TYPE_X) {
\r
229 Pkt.Type = AskTransferType();
\r
231 Pkt.Attr = Pos->Attr;
\r
232 if (Pkt.Attr == 101)
\r
239 Pkt.Type = AskTransferTypeAssoc(Pkt.RemoteFile, AskTransferType());
\r
240 Pkt.Size = Pos->Size;
\r
241 Pkt.Time = Pos->Time;
\r
242 Pkt.KanjiCode = AskHostKanjiCode();
\r
244 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
245 Pkt.KanaCnv = AskHostKanaCnv();
\r
247 Pkt.Mode = CheckLocalFile(&Pkt); /* Pkt.ExistSize がセットされる */
\r
248 if(Pkt.Mode == EXIST_ABORT)
\r
250 else if(Pkt.Mode != EXIST_IGNORE)
\r
251 AddTransFileList(&Pkt);
\r
256 if(AskNoFullPathMode() == YES)
\r
258 strcpy(Pkt.Cmd, "BACKCUR");
\r
259 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
260 AddTransFileList(&Pkt);
\r
262 DeleteFileList(&FileListBase);
\r
264 strcpy(Pkt.Cmd, "GOQUIT");
\r
265 AddTransFileList(&Pkt);
\r
267 GoForwardTransWindow();
\r
268 // KeepTransferDialog(NO);
\r
276 /*----- 指定されたファイルを一つダウンロードする ------------------------------
\r
279 * char *Fname : ファイル名
\r
283 *----------------------------------------------------------------------------*/
\r
285 void DirectDownLoadProc(char *Fname)
\r
292 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
297 // KeepTransferDialog(YES);
\r
299 if(AskNoFullPathMode() == YES)
\r
301 strcpy(Pkt.Cmd, "SETCUR");
\r
302 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
303 AddTransFileList(&Pkt);
\r
306 if(strlen(Fname) > 0)
\r
308 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
309 SetYenTail(Pkt.LocalFile);
\r
310 strcpy(TmpString, Fname);
\r
311 if(FnameCnv == FNAME_LOWER)
\r
312 _mbslwr(TmpString);
\r
313 else if(FnameCnv == FNAME_UPPER)
\r
314 _mbsupr(TmpString);
\r
315 RemoveAfterSemicolon(TmpString);
\r
317 if(RenameUnuseableName(TmpString) == FFFTP_SUCCESS)
\r
319 strcat(Pkt.LocalFile, TmpString);
\r
320 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
322 if(AskHostType() == HTYPE_ACOS)
\r
324 strcpy(Pkt.RemoteFile, "'");
\r
325 strcat(Pkt.RemoteFile, AskHostLsName());
\r
326 strcat(Pkt.RemoteFile, "(");
\r
327 strcat(Pkt.RemoteFile, Fname);
\r
328 strcat(Pkt.RemoteFile, ")");
\r
329 strcat(Pkt.RemoteFile, "'");
\r
331 else if(AskHostType() == HTYPE_ACOS_4)
\r
333 strcpy(Pkt.RemoteFile, Fname);
\r
337 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
338 SetSlashTail(Pkt.RemoteFile);
\r
339 strcat(Pkt.RemoteFile, Fname);
\r
340 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
343 strcpy(Pkt.Cmd, "RETR-S ");
\r
344 Pkt.Type = AskTransferTypeAssoc(Pkt.RemoteFile, AskTransferType());
\r
346 /* サイズと日付は転送側スレッドで取得し、セットする */
\r
348 Pkt.KanjiCode = AskHostKanjiCode();
\r
350 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
351 Pkt.KanaCnv = AskHostKanaCnv();
\r
353 Pkt.Mode = CheckLocalFile(&Pkt); /* Pkt.ExistSize がセットされる */
\r
354 if((Pkt.Mode != EXIST_ABORT) && (Pkt.Mode != EXIST_IGNORE))
\r
355 AddTransFileList(&Pkt);
\r
359 if(AskNoFullPathMode() == YES)
\r
361 strcpy(Pkt.Cmd, "BACKCUR");
\r
362 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
363 AddTransFileList(&Pkt);
\r
366 strcpy(Pkt.Cmd, "GOQUIT");
\r
367 AddTransFileList(&Pkt);
\r
369 GoForwardTransWindow();
\r
370 // KeepTransferDialog(NO);
\r
378 /*----- 入力されたファイル名のファイルを一つダウンロードする ------------------
\r
385 *----------------------------------------------------------------------------*/
\r
387 void InputDownLoadProc(void)
\r
389 char Path[FMAX_PATH+1];
\r
392 // DisableUserOpe();
\r
395 if(InputDialogBox(downname_dlg, GetMainHwnd(), NULL, Path, FMAX_PATH, &Tmp, IDH_HELP_TOPIC_0000001) == YES)
\r
397 DirectDownLoadProc(Path);
\r
400 // EnableUserOpe();
\r
406 /*----- ミラーリングダウンロードを行う ----------------------------------------
\r
409 * int Notify : 確認を行うかどうか (YES/NO)
\r
413 *----------------------------------------------------------------------------*/
\r
415 void MirrorDownloadProc(int Notify)
\r
417 FILELIST *LocalListBase;
\r
418 FILELIST *RemoteListBase;
\r
419 FILELIST *LocalPos;
\r
420 FILELIST *RemotePos;
\r
423 char Name[FMAX_PATH+1];
\r
431 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
438 Notify = DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(mirror_down_dlg), GetMainHwnd(), MirrorNotifyCallBack, 0);
\r
442 if((Notify == YES) || (Notify == YES_LIST))
\r
444 /*===== ファイルリスト取得 =====*/
\r
446 LocalListBase = NULL;
\r
447 MakeSelectedFileList(WIN_LOCAL, YES, YES, &LocalListBase, &CancelFlg);
\r
448 RemoteListBase = NULL;
\r
449 MakeSelectedFileList(WIN_REMOTE, YES, YES, &RemoteListBase, &CancelFlg);
\r
451 RemotePos = RemoteListBase;
\r
452 while(RemotePos != NULL)
\r
454 RemotePos->Attr = YES; /* RemotePos->Attrは転送するかどうかのフラグに使用 (YES/NO) */
\r
455 RemotePos = RemotePos->Next;
\r
458 LocalPos = LocalListBase;
\r
459 while(LocalPos != NULL)
\r
461 if(AskMirrorNoTrn(LocalPos->File, 1) == NO)
\r
463 LocalPos->Attr = YES;
\r
464 LocalPos = LocalPos->Next;
\r
468 LocalPos->Attr = NO; /* LocalPos->Attrは削除するかどうかのフラグに使用 (YES/NO) */
\r
470 if(LocalPos->Node == NODE_DIR)
\r
472 Level = AskDirLevel(LocalPos->File);
\r
473 LocalPos = LocalPos->Next;
\r
474 while(LocalPos != NULL)
\r
476 if((LocalPos->Node == NODE_DIR) &&
\r
477 (AskDirLevel(LocalPos->File) <= Level))
\r
481 LocalPos->Attr = NO;
\r
482 LocalPos = LocalPos->Next;
\r
486 LocalPos = LocalPos->Next;
\r
490 /*===== ファイルリスト比較 =====*/
\r
492 RemotePos = RemoteListBase;
\r
493 while(RemotePos != NULL)
\r
495 if(AskMirrorNoTrn(RemotePos->File, 0) == NO)
\r
497 strcpy(Name, RemotePos->File);
\r
498 // ReplaceAll(Name, '/', '\\');
\r
500 if(MirrorFnameCnv == YES)
\r
501 Mode = COMP_LOWERMATCH;
\r
503 Mode = COMP_STRICT;
\r
505 if((LocalPos = SearchFileList(Name, LocalListBase, Mode)) != NULL)
\r
507 if((RemotePos->Node == NODE_DIR) && (LocalPos->Node == NODE_DIR))
\r
509 LocalPos->Attr = NO;
\r
510 RemotePos->Attr = NO;
\r
512 else if((RemotePos->Node == NODE_FILE) && (LocalPos->Node == NODE_FILE))
\r
514 LocalPos->Attr = NO;
\r
515 if(CompareFileTime(&RemotePos->Time, &LocalPos->Time) <= 0)
\r
516 RemotePos->Attr = NO;
\r
519 RemotePos = RemotePos->Next;
\r
523 if(RemotePos->Node == NODE_FILE)
\r
525 RemotePos->Attr = NO;
\r
526 RemotePos = RemotePos->Next;
\r
530 RemotePos->Attr = NO;
\r
531 Level = AskDirLevel(RemotePos->File);
\r
532 RemotePos = RemotePos->Next;
\r
533 while(RemotePos != NULL)
\r
535 if((RemotePos->Node == NODE_DIR) &&
\r
536 (AskDirLevel(RemotePos->File) <= Level))
\r
540 RemotePos->Attr = NO;
\r
541 RemotePos = RemotePos->Next;
\r
547 DispMirrorFiles(LocalListBase, RemoteListBase);
\r
549 /*===== 削除/アップロード =====*/
\r
551 LocalPos = LocalListBase;
\r
552 while(LocalPos != NULL)
\r
554 if((LocalPos->Attr == YES) && (LocalPos->Node == NODE_FILE))
\r
556 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
557 SetYenTail(Pkt.LocalFile);
\r
558 strcat(Pkt.LocalFile, LocalPos->File);
\r
559 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
560 strcpy(Pkt.RemoteFile, "");
\r
561 strcpy(Pkt.Cmd, "L-DELE ");
\r
562 AddTmpTransFileList(&Pkt, &Base);
\r
564 LocalPos = LocalPos->Next;
\r
566 MirrorDeleteAllLocalDir(LocalListBase, &Pkt, &Base);
\r
569 RemotePos = RemoteListBase;
\r
570 while(RemotePos != NULL)
\r
572 if(RemotePos->Attr == YES)
\r
574 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
575 SetYenTail(Pkt.LocalFile);
\r
576 Cat = strchr(Pkt.LocalFile, NUL);
\r
577 strcat(Pkt.LocalFile, RemotePos->File);
\r
579 if(MirrorFnameCnv == YES)
\r
582 RemoveAfterSemicolon(Cat);
\r
583 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
585 if(RemotePos->Node == NODE_DIR)
\r
587 strcpy(Pkt.RemoteFile, "");
\r
588 strcpy(Pkt.Cmd, "L-MKD ");
\r
589 AddTmpTransFileList(&Pkt, &Base);
\r
591 else if(RemotePos->Node == NODE_FILE)
\r
593 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
594 SetSlashTail(Pkt.RemoteFile);
\r
595 strcat(Pkt.RemoteFile, RemotePos->File);
\r
596 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
598 strcpy(Pkt.Cmd, "RETR ");
\r
599 Pkt.Type = AskTransferTypeAssoc(Pkt.RemoteFile, AskTransferType());
\r
600 Pkt.Size = RemotePos->Size;
\r
601 Pkt.Time = RemotePos->Time;
\r
603 Pkt.KanjiCode = AskHostKanjiCode();
\r
605 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
606 Pkt.KanaCnv = AskHostKanaCnv();
\r
607 Pkt.Mode = EXIST_OVW;
\r
608 AddTmpTransFileList(&Pkt, &Base);
\r
611 RemotePos = RemotePos->Next;
\r
614 if((Notify == YES) ||
\r
615 (DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(mirrordown_notify_dlg), GetMainHwnd(), MirrorDispListCallBack, (LPARAM)&Base) == YES))
\r
617 if(AskNoFullPathMode() == YES)
\r
619 strcpy(Pkt.Cmd, "SETCUR");
\r
620 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
621 AddTransFileList(&Pkt);
\r
623 AppendTransFileList(Base);
\r
625 if(AskNoFullPathMode() == YES)
\r
627 strcpy(Pkt.Cmd, "BACKCUR");
\r
628 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
629 AddTransFileList(&Pkt);
\r
632 strcpy(Pkt.Cmd, "GOQUIT");
\r
633 AddTransFileList(&Pkt);
\r
636 EraseTmpTransFileList(&Base);
\r
638 DeleteFileList(&LocalListBase);
\r
639 DeleteFileList(&RemoteListBase);
\r
641 GoForwardTransWindow();
\r
650 /*----- ミラーリングのファイル一覧を表示 --------------------------------------
\r
653 * FILELIST *Local : ローカル側
\r
654 * FILELIST *Remote : リモート側
\r
658 *----------------------------------------------------------------------------*/
\r
660 static void DispMirrorFiles(FILELIST *Local, FILELIST *Remote)
\r
666 if(DebugConsole == YES)
\r
668 DoPrintf("---- MIRROR FILE LIST ----");
\r
669 while(Local != NULL)
\r
671 FileTimeToLocalFileTime(&Local->Time, &fTime);
\r
672 FileTimeToSystemTime(&fTime, &sTime);
\r
673 sprintf(Date, "%04d/%02d/%02d %02d:%02d:%02d.%04d",
\r
674 sTime.wYear, sTime.wMonth, sTime.wDay, sTime.wHour, sTime.wMinute, sTime.wSecond, sTime.wMilliseconds);
\r
675 DoPrintf("LOCAL : %s %s [%s] %s", Local->Attr==1?"YES":"NO ", Local->Node==NODE_DIR?"DIR ":"FILE", Date, Local->File);
\r
676 Local = Local->Next;
\r
678 while(Remote != NULL)
\r
680 FileTimeToLocalFileTime(&Remote->Time, &fTime);
\r
681 FileTimeToSystemTime(&fTime, &sTime);
\r
682 sprintf(Date, "%04d/%02d/%02d %02d:%02d:%02d.%04d",
\r
683 sTime.wYear, sTime.wMonth, sTime.wDay, sTime.wHour, sTime.wMinute, sTime.wSecond, sTime.wMilliseconds);
\r
684 DoPrintf("REMOTE : %s %s [%s] %s", Remote->Attr==1?"YES":"NO ", Remote->Node==NODE_DIR?"DIR ":"FILE", Date, Remote->File);
\r
685 Remote = Remote->Next;
\r
687 DoPrintf("---- END ----");
\r
693 /*----- ミラーリング時のローカル側のフォルダ削除 ------------------------------
\r
696 * FILELIST *Local : ファイルリスト
\r
697 * TRANSPACKET *Pkt :
\r
698 * TRANSPACKET **Base :
\r
702 *----------------------------------------------------------------------------*/
\r
704 static void MirrorDeleteAllLocalDir(FILELIST *Local, TRANSPACKET *Pkt, TRANSPACKET **Base)
\r
706 while(Local != NULL)
\r
708 if(Local->Node == NODE_DIR)
\r
710 MirrorDeleteAllLocalDir(Local->Next, Pkt, Base);
\r
712 if(Local->Attr == YES)
\r
714 AskLocalCurDir(Pkt->LocalFile, FMAX_PATH);
\r
715 SetYenTail(Pkt->LocalFile);
\r
716 strcat(Pkt->LocalFile, Local->File);
\r
717 ReplaceAll(Pkt->LocalFile, '/', '\\');
\r
718 strcpy(Pkt->RemoteFile, "");
\r
719 strcpy(Pkt->Cmd, "L-RMD ");
\r
720 AddTmpTransFileList(Pkt, Base);
\r
724 Local = Local->Next;
\r
730 /*----- ファイル名のセミコロン以降を取り除く ----------------------------------
\r
733 * char *Path : ファイル名
\r
740 * オプション設定によって処理を切替える
\r
741 *----------------------------------------------------------------------------*/
\r
743 static void RemoveAfterSemicolon(char *Path)
\r
747 if(VaxSemicolon == YES)
\r
749 if((Pos = strchr(Path, ';')) != NULL)
\r
756 /*----- ローカルに同じ名前のファイルがないかチェック --------------------------
\r
759 * TRANSPACKET *Pkt : 転送ファイル情報
\r
763 * EXIST_OVW/EXIST_RESUME/EXIST_IGNORE
\r
766 * Pkt.ExistSize, ExistMode、ExistNotify が変更される
\r
767 *----------------------------------------------------------------------------*/
\r
769 static int CheckLocalFile(TRANSPACKET *Pkt)
\r
772 WIN32_FIND_DATA Find;
\r
776 Pkt->ExistSize = 0;
\r
777 if(RecvMode != TRANS_OVW)
\r
779 if((fHnd = FindFirstFile(Pkt->LocalFile, &Find)) != INVALID_HANDLE_VALUE)
\r
783 Pkt->ExistSize = MakeLongLong(Find.nFileSizeHigh, Find.nFileSizeLow);
\r
785 if(ExistNotify == YES)
\r
787 SoundPlay(SND_ERROR);
\r
788 if(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(down_exist_dlg), GetMainHwnd(), DownExistDialogCallBack, (LPARAM)Pkt) == NO)
\r
796 if(Ret == EXIST_NEW)
\r
799 if(CompareFileTime(&Find.ftLastWriteTime, &Pkt->Time) < 0)
\r
802 Ret = EXIST_IGNORE;
\r
810 /*----- ローカルに同じ名前のファイルがある時の確認ダイアログのコールバック ----
\r
813 * HWND hDlg : ウインドウハンドル
\r
814 * UINT message : メッセージ番号
\r
815 * WPARAM wParam : メッセージの WPARAM 引数
\r
816 * LPARAM lParam : メッセージの LPARAM 引数
\r
820 *----------------------------------------------------------------------------*/
\r
823 //static BOOL CALLBACK DownExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
824 static INT_PTR CALLBACK DownExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
826 static TRANSPACKET *Pkt;
\r
827 static const RADIOBUTTON DownExistButton[] = {
\r
828 { DOWN_EXIST_OVW, EXIST_OVW },
\r
829 { DOWN_EXIST_NEW, EXIST_NEW },
\r
830 { DOWN_EXIST_RESUME, EXIST_RESUME },
\r
831 { DOWN_EXIST_IGNORE, EXIST_IGNORE }
\r
833 #define DOWNEXISTBUTTONS (sizeof(DownExistButton)/sizeof(RADIOBUTTON))
\r
837 case WM_INITDIALOG :
\r
838 Pkt = (TRANSPACKET *)lParam;
\r
839 SendDlgItemMessage(hDlg, DOWN_EXIST_NAME, EM_LIMITTEXT, FMAX_PATH, 0);
\r
840 SendDlgItemMessage(hDlg, DOWN_EXIST_NAME, WM_SETTEXT, 0, (LPARAM)Pkt->LocalFile);
\r
842 if((Pkt->Type == TYPE_A) || (Pkt->ExistSize <= 0))
\r
843 EnableWindow(GetDlgItem(hDlg, DOWN_EXIST_RESUME), FALSE);
\r
845 SetRadioButtonByValue(hDlg, ExistMode, DownExistButton, DOWNEXISTBUTTONS);
\r
849 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
853 /* ここに break はない */
\r
856 ExistMode = AskRadioButtonValue(hDlg, DownExistButton, DOWNEXISTBUTTONS);
\r
857 SendDlgItemMessage(hDlg, DOWN_EXIST_NAME, WM_GETTEXT, FMAX_PATH, (LPARAM)Pkt->LocalFile);
\r
858 EndDialog(hDlg, YES);
\r
862 // ExistMode = EXIST_ABORT;
\r
863 EndDialog(hDlg, NO);
\r
867 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000009);
\r
880 /*----- ファイル一覧で指定されたファイルをアップロードする --------------------
\r
883 * int ChName : 名前を変えるかどうか (YES/NO)
\r
884 * int All : 全てが選ばれている物として扱うかどうか (YES/NO)
\r
888 *----------------------------------------------------------------------------*/
\r
890 void UpLoadListProc(int ChName, int All)
\r
892 FILELIST *FileListBase;
\r
897 FILELIST *RemoteList;
\r
898 char Tmp[FMAX_PATH+1];
\r
904 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
908 // ローカル側で選ばれているファイルをFileListBaseに登録
\r
909 FileListBase = NULL;
\r
910 MakeSelectedFileList(WIN_LOCAL, YES, All, &FileListBase, &CancelFlg);
\r
912 // 現在ホスト側のファイル一覧に表示されているものをRemoteListに登録
\r
915 AddRemoteTreeToFileList(AskCurrentFileListNum(), "", RDIR_NONE, &RemoteList);
\r
920 Pos = FileListBase;
\r
923 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
924 SetSlashTail(Pkt.RemoteFile);
\r
925 Cat = strchr(Pkt.RemoteFile, NUL);
\r
926 if((ChName == NO) || (Pos->Node == NODE_DIR))
\r
928 strcat(Pkt.RemoteFile, Pos->File);
\r
929 if(FnameCnv == FNAME_LOWER)
\r
931 else if(FnameCnv == FNAME_UPPER)
\r
933 #if defined(HAVE_TANDEM)
\r
935 Pkt.PriExt = DEF_PRIEXT;
\r
936 Pkt.SecExt = DEF_SECEXT;
\r
937 Pkt.MaxExt = DEF_MAXEXT;
\r
943 strcpy(TmpString, Pos->File);
\r
944 CurWin = WIN_LOCAL;
\r
945 #if defined(HAVE_TANDEM)
\r
946 strcpy(TmpFileCode, "0"); /* ASCII モードの場合は無視される */
\r
947 if(AskHostType() == HTYPE_TANDEM && AskOSS() == NO) {
\r
948 if(DialogBox(GetFtpInst(), MAKEINTRESOURCE(updown_as_with_ext_dlg), GetMainHwnd(), UpDownAsWithExtDialogCallBack) == YES) {
\r
949 strcat(Pkt.RemoteFile, TmpString);
\r
950 Pkt.FileCode = atoi(TmpFileCode);
\r
956 if(DialogBox(GetFtpInst(), MAKEINTRESOURCE(updown_as_dlg), GetMainHwnd(), UpDownAsDialogCallBack) == YES)
\r
957 strcat(Pkt.RemoteFile, TmpString);
\r
961 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
963 if(AskHostType() == HTYPE_ACOS)
\r
965 strcpy(Pkt.RemoteFile, "'");
\r
966 strcat(Pkt.RemoteFile, AskHostLsName());
\r
967 strcat(Pkt.RemoteFile, "(");
\r
968 strcat(Pkt.RemoteFile, Cat);
\r
969 strcat(Pkt.RemoteFile, ")");
\r
970 strcat(Pkt.RemoteFile, "'");
\r
972 else if(AskHostType() == HTYPE_ACOS_4)
\r
973 strcpy(Pkt.RemoteFile, Cat);
\r
975 if(Pos->Node == NODE_DIR)
\r
979 // ホスト側のファイル一覧をRemoteListに登録
\r
981 if(RemoteList != NULL)
\r
982 DeleteFileList(&RemoteList);
\r
985 AskRemoteCurDir(Tmp, FMAX_PATH);
\r
986 if(DoCWD(Pkt.RemoteFile, NO, NO, NO) == FTP_COMPLETE)
\r
988 if(DoDirListCmdSkt("", "", 998, &CancelFlg) == FTP_COMPLETE)
\r
989 AddRemoteTreeToFileList(998, "", RDIR_NONE, &RemoteList);
\r
990 DoCWD(Tmp, NO, NO, NO);
\r
995 if((FirstAdd == YES) && (AskNoFullPathMode() == YES))
\r
997 strcpy(Pkt1.Cmd, "SETCUR");
\r
998 AskRemoteCurDir(Pkt1.RemoteFile, FMAX_PATH);
\r
999 AddTransFileList(&Pkt1);
\r
1002 strcpy(Pkt.Cmd, "MKD ");
\r
1003 strcpy(Pkt.LocalFile, "");
\r
1004 AddTransFileList(&Pkt);
\r
1007 else if(Pos->Node == NODE_FILE)
\r
1010 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
1011 SetYenTail(Pkt.LocalFile);
\r
1012 strcat(Pkt.LocalFile, Pos->File);
\r
1013 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
1015 strcpy(Pkt.Cmd, "STOR ");
\r
1016 Pkt.Type = AskTransferTypeAssoc(Pkt.LocalFile, AskTransferType());
\r
1018 Pkt.Time = Pos->Time;
\r
1019 Pkt.Attr = AskUpLoadFileAttr(Pkt.RemoteFile);
\r
1020 Pkt.KanjiCode = AskHostKanjiCode();
\r
1022 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
1023 Pkt.KanaCnv = AskHostKanaCnv();
\r
1024 #if defined(HAVE_TANDEM)
\r
1025 if(AskHostType() == HTYPE_TANDEM && AskOSS() == NO) {
\r
1026 CalcExtentSize(&Pkt, Pos->Size);
\r
1029 Pkt.Mode = CheckRemoteFile(&Pkt, RemoteList);
\r
1030 if(Pkt.Mode == EXIST_ABORT)
\r
1032 else if(Pkt.Mode != EXIST_IGNORE)
\r
1034 if((FirstAdd == YES) && (AskNoFullPathMode() == YES))
\r
1036 strcpy(Pkt1.Cmd, "SETCUR");
\r
1037 AskRemoteCurDir(Pkt1.RemoteFile, FMAX_PATH);
\r
1038 AddTransFileList(&Pkt1);
\r
1041 AddTransFileList(&Pkt);
\r
1047 if((FirstAdd == NO) && (AskNoFullPathMode() == YES))
\r
1049 strcpy(Pkt.Cmd, "BACKCUR");
\r
1050 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1051 AddTransFileList(&Pkt);
\r
1054 if(RemoteList != NULL)
\r
1055 DeleteFileList(&RemoteList);
\r
1057 DeleteFileList(&FileListBase);
\r
1059 strcpy(Pkt.Cmd, "GOQUIT");
\r
1060 AddTransFileList(&Pkt);
\r
1062 GoForwardTransWindow();
\r
1070 /*----- ドラッグ&ドロップで指定されたファイルをアップロードする --------------
\r
1073 * WPARAM wParam : ドロップされたファイルの情報
\r
1077 *----------------------------------------------------------------------------*/
\r
1079 void UpLoadDragProc(WPARAM wParam)
\r
1081 FILELIST *FileListBase;
\r
1086 FILELIST *RemoteList;
\r
1087 char Tmp[FMAX_PATH+1];
\r
1089 char Cur[FMAX_PATH+1];
\r
1094 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
1098 // ローカル側で選ばれているファイルをFileListBaseに登録
\r
1099 FileListBase = NULL;
\r
1100 MakeDroppedFileList(wParam, Cur, &FileListBase);
\r
1102 // 現在ホスト側のファイル一覧に表示されているものをRemoteListに登録
\r
1104 RemoteList = NULL;
\r
1105 AddRemoteTreeToFileList(AskCurrentFileListNum(), "", RDIR_NONE, &RemoteList);
\r
1108 ExistNotify = YES;
\r
1110 Pos = FileListBase;
\r
1111 while(Pos != NULL)
\r
1113 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1114 SetSlashTail(Pkt.RemoteFile);
\r
1115 Cat = strchr(Pkt.RemoteFile, NUL);
\r
1117 strcat(Pkt.RemoteFile, Pos->File);
\r
1118 if(FnameCnv == FNAME_LOWER)
\r
1120 else if(FnameCnv == FNAME_UPPER)
\r
1122 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
1123 #if defined(HAVE_TANDEM)
\r
1125 Pkt.PriExt = DEF_PRIEXT;
\r
1126 Pkt.SecExt = DEF_SECEXT;
\r
1127 Pkt.MaxExt = DEF_MAXEXT;
\r
1130 if(AskHostType() == HTYPE_ACOS)
\r
1132 strcpy(Pkt.RemoteFile, "'");
\r
1133 strcat(Pkt.RemoteFile, AskHostLsName());
\r
1134 strcat(Pkt.RemoteFile, "(");
\r
1135 strcat(Pkt.RemoteFile, Cat);
\r
1136 strcat(Pkt.RemoteFile, ")");
\r
1137 strcat(Pkt.RemoteFile, "'");
\r
1139 else if(AskHostType() == HTYPE_ACOS_4)
\r
1140 strcpy(Pkt.RemoteFile, Cat);
\r
1142 if(Pos->Node == NODE_DIR)
\r
1146 // ホスト側のファイル一覧をRemoteListに登録
\r
1148 if(RemoteList != NULL)
\r
1149 DeleteFileList(&RemoteList);
\r
1150 RemoteList = NULL;
\r
1152 AskRemoteCurDir(Tmp, FMAX_PATH);
\r
1153 if(DoCWD(Pkt.RemoteFile, NO, NO, NO) == FTP_COMPLETE)
\r
1155 if(DoDirListCmdSkt("", "", 998, &CancelFlg) == FTP_COMPLETE)
\r
1156 AddRemoteTreeToFileList(998, "", RDIR_NONE, &RemoteList);
\r
1157 DoCWD(Tmp, NO, NO, NO);
\r
1161 if((FirstAdd == YES) && (AskNoFullPathMode() == YES))
\r
1163 strcpy(Pkt1.Cmd, "SETCUR");
\r
1164 AskRemoteCurDir(Pkt1.RemoteFile, FMAX_PATH);
\r
1165 AddTransFileList(&Pkt1);
\r
1168 strcpy(Pkt.Cmd, "MKD ");
\r
1169 strcpy(Pkt.LocalFile, "");
\r
1170 AddTransFileList(&Pkt);
\r
1173 else if(Pos->Node == NODE_FILE)
\r
1176 strcpy(Pkt.LocalFile, Cur);
\r
1177 SetYenTail(Pkt.LocalFile);
\r
1178 strcat(Pkt.LocalFile, Pos->File);
\r
1179 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
1181 strcpy(Pkt.Cmd, "STOR ");
\r
1182 Pkt.Type = AskTransferTypeAssoc(Pkt.LocalFile, AskTransferType());
\r
1184 Pkt.Time = Pos->Time;
\r
1185 Pkt.Attr = AskUpLoadFileAttr(Pkt.RemoteFile);
\r
1186 Pkt.KanjiCode = AskHostKanjiCode();
\r
1188 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
1189 Pkt.KanaCnv = AskHostKanaCnv();
\r
1190 #if defined(HAVE_TANDEM)
\r
1191 if(AskHostType() == HTYPE_TANDEM && AskOSS() == NO) {
\r
1192 int a = Pos->InfoExist && FINFO_SIZE;
\r
1193 CalcExtentSize(&Pkt, Pos->Size);
\r
1196 Pkt.Mode = CheckRemoteFile(&Pkt, RemoteList);
\r
1197 if(Pkt.Mode == EXIST_ABORT)
\r
1199 else if(Pkt.Mode != EXIST_IGNORE)
\r
1201 if((FirstAdd == YES) && (AskNoFullPathMode() == YES))
\r
1203 strcpy(Pkt1.Cmd, "SETCUR");
\r
1204 AskRemoteCurDir(Pkt1.RemoteFile, FMAX_PATH);
\r
1205 AddTransFileList(&Pkt1);
\r
1208 AddTransFileList(&Pkt);
\r
1214 if((FirstAdd == NO) && (AskNoFullPathMode() == YES))
\r
1216 strcpy(Pkt.Cmd, "BACKCUR");
\r
1217 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1218 AddTransFileList(&Pkt);
\r
1221 if(RemoteList != NULL)
\r
1222 DeleteFileList(&RemoteList);
\r
1224 DeleteFileList(&FileListBase);
\r
1226 strcpy(Pkt.Cmd, "GOQUIT");
\r
1227 AddTransFileList(&Pkt);
\r
1229 GoForwardTransWindow();
\r
1237 /*----- ミラーリングアップロードを行う ----------------------------------------
\r
1240 * int Notify : 確認を行うかどうか (YES/NO)
\r
1244 *----------------------------------------------------------------------------*/
\r
1246 void MirrorUploadProc(int Notify)
\r
1248 FILELIST *LocalListBase;
\r
1249 FILELIST *RemoteListBase;
\r
1250 FILELIST *LocalPos;
\r
1251 FILELIST *RemotePos;
\r
1253 TRANSPACKET *Base;
\r
1254 char Name[FMAX_PATH+1];
\r
1258 SYSTEMTIME TmpStime;
\r
1259 FILETIME TmpFtimeL;
\r
1260 FILETIME TmpFtimeR;
\r
1265 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
1272 Notify = DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(mirror_up_dlg), GetMainHwnd(), MirrorNotifyCallBack, 1);
\r
1276 if((Notify == YES) || (Notify == YES_LIST))
\r
1278 /*===== ファイルリスト取得 =====*/
\r
1280 LocalListBase = NULL;
\r
1281 MakeSelectedFileList(WIN_LOCAL, YES, YES, &LocalListBase, &CancelFlg);
\r
1282 RemoteListBase = NULL;
\r
1283 MakeSelectedFileList(WIN_REMOTE, YES, YES, &RemoteListBase, &CancelFlg);
\r
1285 LocalPos = LocalListBase;
\r
1286 while(LocalPos != NULL)
\r
1288 LocalPos->Attr = YES; /* LocalPos->Attrは転送するかどうかのフラグに使用 (YES/NO) */
\r
1289 LocalPos = LocalPos->Next;
\r
1292 RemotePos = RemoteListBase;
\r
1293 while(RemotePos != NULL)
\r
1295 if(AskMirrorNoTrn(RemotePos->File, 1) == NO)
\r
1297 RemotePos->Attr = YES;
\r
1298 RemotePos = RemotePos->Next;
\r
1302 RemotePos->Attr = NO; /* RemotePos->Attrは削除するかどうかのフラグに使用 (YES/NO) */
\r
1304 if(RemotePos->Node == NODE_DIR)
\r
1306 Level = AskDirLevel(RemotePos->File);
\r
1307 RemotePos = RemotePos->Next;
\r
1308 while(RemotePos != NULL)
\r
1310 if((RemotePos->Node == NODE_DIR) &&
\r
1311 (AskDirLevel(RemotePos->File) <= Level))
\r
1315 RemotePos->Attr = NO;
\r
1316 RemotePos = RemotePos->Next;
\r
1320 RemotePos = RemotePos->Next;
\r
1324 /*===== ファイルリスト比較 =====*/
\r
1326 LocalPos = LocalListBase;
\r
1327 while(LocalPos != NULL)
\r
1329 if(AskMirrorNoTrn(LocalPos->File, 0) == NO)
\r
1331 strcpy(Name, LocalPos->File);
\r
1332 ReplaceAll(Name, '\\', '/');
\r
1334 if(MirrorFnameCnv == YES)
\r
1335 Mode = COMP_LOWERMATCH;
\r
1337 Mode = COMP_STRICT;
\r
1339 if(LocalPos->Node == NODE_DIR)
\r
1341 if((RemotePos = SearchFileList(Name, RemoteListBase, Mode)) != NULL)
\r
1343 if(RemotePos->Node == NODE_DIR)
\r
1345 RemotePos->Attr = NO;
\r
1346 LocalPos->Attr = NO;
\r
1350 else if(LocalPos->Node == NODE_FILE)
\r
1352 if((RemotePos = SearchFileList(Name, RemoteListBase, Mode)) != NULL)
\r
1354 if(RemotePos->Node == NODE_FILE)
\r
1356 FileTimeToLocalFileTime(&LocalPos->Time, &TmpFtimeL);
\r
1357 FileTimeToLocalFileTime(&RemotePos->Time, &TmpFtimeR);
\r
1358 if((RemotePos->InfoExist & FINFO_TIME) == 0)
\r
1360 FileTimeToSystemTime(&TmpFtimeL, &TmpStime);
\r
1361 TmpStime.wHour = 0;
\r
1362 TmpStime.wMinute = 0;
\r
1363 TmpStime.wSecond = 0;
\r
1364 TmpStime.wMilliseconds = 0;
\r
1365 SystemTimeToFileTime(&TmpStime, &TmpFtimeL);
\r
1367 FileTimeToSystemTime(&TmpFtimeR, &TmpStime);
\r
1368 TmpStime.wHour = 0;
\r
1369 TmpStime.wMinute = 0;
\r
1370 TmpStime.wSecond = 0;
\r
1371 TmpStime.wMilliseconds = 0;
\r
1372 SystemTimeToFileTime(&TmpStime, &TmpFtimeR);
\r
1374 RemotePos->Attr = NO;
\r
1375 if(CompareFileTime(&TmpFtimeL, &TmpFtimeR) <= 0)
\r
1376 LocalPos->Attr = NO;
\r
1381 LocalPos = LocalPos->Next;
\r
1385 if(LocalPos->Node == NODE_FILE)
\r
1387 LocalPos->Attr = NO;
\r
1388 LocalPos = LocalPos->Next;
\r
1392 LocalPos->Attr = NO;
\r
1393 Level = AskDirLevel(LocalPos->File);
\r
1394 LocalPos = LocalPos->Next;
\r
1395 while(LocalPos != NULL)
\r
1397 if((LocalPos->Node == NODE_DIR) &&
\r
1398 (AskDirLevel(LocalPos->File) <= Level))
\r
1402 LocalPos->Attr = NO;
\r
1403 LocalPos = LocalPos->Next;
\r
1409 DispMirrorFiles(LocalListBase, RemoteListBase);
\r
1411 /*===== 削除/アップロード =====*/
\r
1413 RemotePos = RemoteListBase;
\r
1414 while(RemotePos != NULL)
\r
1416 if((RemotePos->Attr == YES) && (RemotePos->Node == NODE_FILE))
\r
1418 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1419 SetSlashTail(Pkt.RemoteFile);
\r
1420 strcat(Pkt.RemoteFile, RemotePos->File);
\r
1421 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
1422 strcpy(Pkt.LocalFile, "");
\r
1423 strcpy(Pkt.Cmd, "R-DELE ");
\r
1424 AddTmpTransFileList(&Pkt, &Base);
\r
1426 RemotePos = RemotePos->Next;
\r
1428 MirrorDeleteAllDir(RemoteListBase, &Pkt, &Base);
\r
1430 LocalPos = LocalListBase;
\r
1431 while(LocalPos != NULL)
\r
1433 if(LocalPos->Attr == YES)
\r
1435 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1436 SetSlashTail(Pkt.RemoteFile);
\r
1437 Cat = strchr(Pkt.RemoteFile, NUL);
\r
1438 strcat(Pkt.RemoteFile, LocalPos->File);
\r
1440 if(MirrorFnameCnv == YES)
\r
1443 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
1445 if(LocalPos->Node == NODE_DIR)
\r
1447 strcpy(Pkt.LocalFile, "");
\r
1448 strcpy(Pkt.Cmd, "R-MKD ");
\r
1449 AddTmpTransFileList(&Pkt, &Base);
\r
1451 else if(LocalPos->Node == NODE_FILE)
\r
1453 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
1454 SetYenTail(Pkt.LocalFile);
\r
1455 strcat(Pkt.LocalFile, LocalPos->File);
\r
1456 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
1458 strcpy(Pkt.Cmd, "STOR ");
\r
1459 Pkt.Type = AskTransferTypeAssoc(Pkt.LocalFile, AskTransferType());
\r
1461 Pkt.Time = LocalPos->Time;
\r
1462 Pkt.Attr = AskUpLoadFileAttr(Pkt.RemoteFile);
\r
1463 Pkt.KanjiCode = AskHostKanjiCode();
\r
1465 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
1466 Pkt.KanaCnv = AskHostKanaCnv();
\r
1467 #if defined(HAVE_TANDEM)
\r
1468 if(AskHostType() == HTYPE_TANDEM && AskOSS() == NO) {
\r
1469 CalcExtentSize(&Pkt, LocalPos->Size);
\r
1472 Pkt.Mode = EXIST_OVW;
\r
1473 AddTmpTransFileList(&Pkt, &Base);
\r
1476 LocalPos = LocalPos->Next;
\r
1479 if((Notify == YES) ||
\r
1480 (DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(mirror_notify_dlg), GetMainHwnd(), MirrorDispListCallBack, (LPARAM)&Base) == YES))
\r
1482 if(AskNoFullPathMode() == YES)
\r
1484 strcpy(Pkt.Cmd, "SETCUR");
\r
1485 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1486 AddTransFileList(&Pkt);
\r
1488 AppendTransFileList(Base);
\r
1490 if(AskNoFullPathMode() == YES)
\r
1492 strcpy(Pkt.Cmd, "BACKCUR");
\r
1493 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1494 AddTransFileList(&Pkt);
\r
1497 strcpy(Pkt.Cmd, "GOQUIT");
\r
1498 AddTransFileList(&Pkt);
\r
1501 EraseTmpTransFileList(&Base);
\r
1503 DeleteFileList(&LocalListBase);
\r
1504 DeleteFileList(&RemoteListBase);
\r
1506 GoForwardTransWindow();
\r
1515 /*----- ミラーリング時のホスト側のフォルダ削除 --------------------------------
\r
1518 * FILELIST *Base : ファイルリスト
\r
1519 * TRANSPACKET *Pkt :
\r
1520 * TRANSPACKET **Base :
\r
1524 *----------------------------------------------------------------------------*/
\r
1526 static void MirrorDeleteAllDir(FILELIST *Remote, TRANSPACKET *Pkt, TRANSPACKET **Base)
\r
1528 while(Remote != NULL)
\r
1530 if(Remote->Node == NODE_DIR)
\r
1532 MirrorDeleteAllDir(Remote->Next, Pkt, Base);
\r
1534 if(Remote->Attr == YES)
\r
1536 AskRemoteCurDir(Pkt->RemoteFile, FMAX_PATH);
\r
1537 SetSlashTail(Pkt->RemoteFile);
\r
1538 strcat(Pkt->RemoteFile, Remote->File);
\r
1539 ReplaceAll(Pkt->RemoteFile, '\\', '/');
\r
1540 strcpy(Pkt->LocalFile, "");
\r
1541 strcpy(Pkt->Cmd, "R-RMD ");
\r
1542 AddTmpTransFileList(Pkt, Base);
\r
1546 Remote = Remote->Next;
\r
1552 /*----- ミラーリングアップロード開始確認ウインドウのコールバック --------------
\r
1555 * HWND hDlg : ウインドウハンドル
\r
1556 * UINT message : メッセージ番号
\r
1557 * WPARAM wParam : メッセージの WPARAM 引数
\r
1558 * LPARAM lParam : メッセージの LPARAM 引数
\r
1562 *----------------------------------------------------------------------------*/
\r
1565 //static BOOL CALLBACK MirrorNotifyCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
1566 static INT_PTR CALLBACK MirrorNotifyCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
1572 case WM_INITDIALOG :
\r
1577 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
1580 EndDialog(hDlg, YES);
\r
1584 EndDialog(hDlg, NO);
\r
1587 case MIRRORUP_DISP :
\r
1588 EndDialog(hDlg, YES_LIST);
\r
1593 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000013);
\r
1595 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000012);
\r
1603 /*----- ミラーリングアップロード処理内容確認ウインドウのコールバック ----------
\r
1606 * HWND hDlg : ウインドウハンドル
\r
1607 * UINT message : メッセージ番号
\r
1608 * WPARAM wParam : メッセージの WPARAM 引数
\r
1609 * LPARAM lParam : メッセージの LPARAM 引数
\r
1613 *----------------------------------------------------------------------------*/
\r
1616 //static BOOL CALLBACK MirrorDispListCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
1617 static INT_PTR CALLBACK MirrorDispListCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
1619 static DIALOGSIZE DlgSize = {
\r
1620 { MIRROR_DEL, MIRROR_SIZEGRIP, -1 },
\r
1621 { IDOK, IDCANCEL, IDHELP, MIRROR_DEL, MIRROR_COPYNUM, MIRROR_MAKENUM, MIRROR_DELNUM, MIRROR_SIZEGRIP, -1 },
\r
1622 { MIRROR_LIST, -1 },
\r
1627 static TRANSPACKET **Base;
\r
1629 char Tmp[FMAX_PATH+1+6];
\r
1635 case WM_INITDIALOG :
\r
1636 Base = (TRANSPACKET **)lParam;
\r
1638 while(Pos != NULL)
\r
1641 if((strncmp(Pos->Cmd, "R-DELE", 6) == 0) ||
\r
1642 (strncmp(Pos->Cmd, "R-RMD", 5) == 0))
\r
1643 sprintf(Tmp, MSGJPN052, Pos->RemoteFile);
\r
1644 else if(strncmp(Pos->Cmd, "R-MKD", 5) == 0)
\r
1645 sprintf(Tmp, MSGJPN053, Pos->RemoteFile);
\r
1646 else if(strncmp(Pos->Cmd, "STOR", 4) == 0)
\r
1647 sprintf(Tmp, MSGJPN054, Pos->RemoteFile);
\r
1648 else if((strncmp(Pos->Cmd, "L-DELE", 6) == 0) ||
\r
1649 (strncmp(Pos->Cmd, "L-RMD", 5) == 0))
\r
1650 sprintf(Tmp, MSGJPN055, Pos->LocalFile);
\r
1651 else if(strncmp(Pos->Cmd, "L-MKD", 5) == 0)
\r
1652 sprintf(Tmp, MSGJPN056, Pos->LocalFile);
\r
1653 else if(strncmp(Pos->Cmd, "RETR", 4) == 0)
\r
1654 sprintf(Tmp, MSGJPN057, Pos->LocalFile);
\r
1656 if(strlen(Tmp) > 0)
\r
1657 SendDlgItemMessage(hDlg, MIRROR_LIST, LB_ADDSTRING, 0, (LPARAM)Tmp);
\r
1660 CountMirrorFiles(hDlg, *Base);
\r
1661 DlgSizeInit(hDlg, &DlgSize, &MirrorDlgSize);
\r
1662 EnableWindow(GetDlgItem(hDlg, MIRROR_DEL), FALSE);
\r
1666 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
1669 AskDlgSize(hDlg, &DlgSize, &MirrorDlgSize);
\r
1670 EndDialog(hDlg, YES);
\r
1674 AskDlgSize(hDlg, &DlgSize, &MirrorDlgSize);
\r
1675 EndDialog(hDlg, NO);
\r
1679 Num = SendDlgItemMessage(hDlg, MIRROR_LIST, LB_GETSELCOUNT, 0, 0);
\r
1680 if((List = malloc(Num * sizeof(int))) != NULL)
\r
1682 Num = SendDlgItemMessage(hDlg, MIRROR_LIST, LB_GETSELITEMS, Num, (LPARAM)List);
\r
1683 for(Num--; Num >= 0; Num--)
\r
1685 if(RemoveTmpTransFileListItem(Base, List[Num]) == FFFTP_SUCCESS)
\r
1686 SendDlgItemMessage(hDlg, MIRROR_LIST, LB_DELETESTRING, List[Num], 0);
\r
1691 CountMirrorFiles(hDlg, *Base);
\r
1695 case MIRROR_LIST :
\r
1696 switch(GET_WM_COMMAND_CMD(wParam, lParam))
\r
1698 case LBN_SELCHANGE :
\r
1699 if(SendDlgItemMessage(hDlg, MIRROR_LIST, LB_GETSELCOUNT, 0, 0) > 0)
\r
1700 EnableWindow(GetDlgItem(hDlg, MIRROR_DEL), TRUE);
\r
1702 EnableWindow(GetDlgItem(hDlg, MIRROR_DEL), FALSE);
\r
1708 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000012);
\r
1713 DlgSizeChange(hDlg, &DlgSize, (RECT *)lParam, (int)wParam);
\r
1720 /*----- ミラーリングで転送/削除するファイルの数を数えダイアログに表示---------
\r
1724 * TRANSPACKET *Pkt :
\r
1728 *----------------------------------------------------------------------------*/
\r
1730 static void CountMirrorFiles(HWND hDlg, TRANSPACKET *Pkt)
\r
1740 while(Pkt != NULL)
\r
1742 if((strncmp(Pkt->Cmd, "R-DELE", 6) == 0) ||
\r
1743 (strncmp(Pkt->Cmd, "R-RMD", 5) == 0) ||
\r
1744 (strncmp(Pkt->Cmd, "L-DELE", 6) == 0) ||
\r
1745 (strncmp(Pkt->Cmd, "L-RMD", 5) == 0))
\r
1749 else if((strncmp(Pkt->Cmd, "R-MKD", 5) == 0) ||
\r
1750 (strncmp(Pkt->Cmd, "L-MKD", 5) == 0))
\r
1754 else if((strncmp(Pkt->Cmd, "STOR", 4) == 0) ||
\r
1755 (strncmp(Pkt->Cmd, "RETR", 4) == 0))
\r
1763 sprintf(Tmp, MSGJPN058, Copy);
\r
1765 sprintf(Tmp, MSGJPN059);
\r
1766 SendDlgItemMessage(hDlg, MIRROR_COPYNUM, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
1769 sprintf(Tmp, MSGJPN060, Make);
\r
1771 sprintf(Tmp, MSGJPN061);
\r
1772 SendDlgItemMessage(hDlg, MIRROR_MAKENUM, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
1775 sprintf(Tmp, MSGJPN062, Del);
\r
1777 sprintf(Tmp, MSGJPN063);
\r
1778 SendDlgItemMessage(hDlg, MIRROR_DELNUM, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
1786 /*----- ミラーリングで転送/削除しないファイルかどうかを返す ------------------
\r
1789 * char Fname : ファイル名
\r
1791 * 0=転送しないファイル, 1=削除しないファイル
\r
1796 *----------------------------------------------------------------------------*/
\r
1798 static int AskMirrorNoTrn(char *Fname, int Mode)
\r
1803 Tbl = MirrorNoTrn;
\r
1805 Tbl = MirrorNoDel;
\r
1808 if(StrMultiLen(Tbl) > 0)
\r
1810 Fname = GetFileName(Fname);
\r
1811 while(*Tbl != NUL)
\r
1813 if(CheckFname(Fname, Tbl) == FFFTP_SUCCESS)
\r
1818 Tbl += strlen(Tbl) + 1;
\r
1825 /*----- アップロードするファイルの属性を返す ----------------------------------
\r
1828 * char Fname : ファイル名
\r
1831 * int 属性 (-1=設定なし)
\r
1832 *----------------------------------------------------------------------------*/
\r
1834 static int AskUpLoadFileAttr(char *Fname)
\r
1840 Tbl = DefAttrList;
\r
1841 Fname = GetFileName(Fname);
\r
1843 while(*Tbl != NUL)
\r
1845 Sts = CheckFname(Fname, Tbl);
\r
1846 Tbl += strlen(Tbl) + 1;
\r
1848 if((Sts == FFFTP_SUCCESS) && (*Tbl != NUL))
\r
1853 Tbl += strlen(Tbl) + 1;
\r
1859 /*----- ホストに同じ名前のファイルがないかチェック- ---------------------------a
\r
1862 * TRANSPACKET *Pkt : 転送ファイル情報
\r
1863 * FILELIST *ListList :
\r
1867 * EXIST_OVW/EXIST_UNIQUE/EXIST_IGNORE
\r
1870 * Pkt.ExistSize, UpExistMode、ExistNotify が変更される
\r
1871 *----------------------------------------------------------------------------*/
\r
1873 static int CheckRemoteFile(TRANSPACKET *Pkt, FILELIST *ListList)
\r
1876 #if defined(HAVE_TANDEM)
\r
1882 Pkt->ExistSize = 0;
\r
1883 if(SendMode != TRANS_OVW)
\r
1885 #if defined(HAVE_TANDEM)
\r
1886 /* HP NonStop Server は大文字小文字の区別なし(すべて大文字) */
\r
1887 if(AskHostType() == HTYPE_TANDEM)
\r
1888 Mode = COMP_IGNORE;
\r
1890 Mode = COMP_STRICT;
\r
1892 if((Exist = SearchFileList(GetFileName(Pkt->RemoteFile), ListList, Mode)) != NULL)
\r
1894 if((Exist = SearchFileList(GetFileName(Pkt->RemoteFile), ListList, COMP_STRICT)) != NULL)
\r
1897 Pkt->ExistSize = Exist->Size;
\r
1899 if(ExistNotify == YES)
\r
1901 SoundPlay(SND_ERROR);
\r
1902 if(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(up_exist_dlg), GetMainHwnd(), UpExistDialogCallBack, (LPARAM)Pkt) == NO)
\r
1903 Ret = EXIST_ABORT;
\r
1905 Ret = UpExistMode;
\r
1908 Ret = UpExistMode;
\r
1910 if(Ret == EXIST_NEW)
\r
1913 if(CompareFileTime(&Exist->Time, &Pkt->Time) < 0)
\r
1916 Ret = EXIST_IGNORE;
\r
1924 /*----- ホストに同じ名前のファイルがある時の確認ダイアログのコールバック ------
\r
1927 * HWND hDlg : ウインドウハンドル
\r
1928 * UINT message : メッセージ番号
\r
1929 * WPARAM wParam : メッセージの WPARAM 引数
\r
1930 * LPARAM lParam : メッセージの LPARAM 引数
\r
1934 *----------------------------------------------------------------------------*/
\r
1937 //static BOOL CALLBACK UpExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
1938 static INT_PTR CALLBACK UpExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
1940 static TRANSPACKET *Pkt;
\r
1941 static const RADIOBUTTON UpExistButton[] = {
\r
1942 { UP_EXIST_OVW, EXIST_OVW },
\r
1943 { UP_EXIST_NEW, EXIST_NEW },
\r
1944 { UP_EXIST_RESUME, EXIST_RESUME },
\r
1945 { UP_EXIST_UNIQUE, EXIST_UNIQUE },
\r
1946 { UP_EXIST_IGNORE, EXIST_IGNORE }
\r
1948 #define UPEXISTBUTTONS (sizeof(UpExistButton)/sizeof(RADIOBUTTON))
\r
1952 case WM_INITDIALOG :
\r
1953 Pkt = (TRANSPACKET *)lParam;
\r
1954 SendDlgItemMessage(hDlg, UP_EXIST_NAME, EM_LIMITTEXT, FMAX_PATH, 0);
\r
1955 SendDlgItemMessage(hDlg, UP_EXIST_NAME, WM_SETTEXT, 0, (LPARAM)Pkt->RemoteFile);
\r
1957 if((Pkt->Type == TYPE_A) || (Pkt->ExistSize <= 0))
\r
1958 EnableWindow(GetDlgItem(hDlg, UP_EXIST_RESUME), FALSE);
\r
1960 SetRadioButtonByValue(hDlg, UpExistMode, UpExistButton, UPEXISTBUTTONS);
\r
1964 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
1968 /* ここに break はない */
\r
1971 UpExistMode = AskRadioButtonValue(hDlg, UpExistButton, UPEXISTBUTTONS);
\r
1972 SendDlgItemMessage(hDlg, UP_EXIST_NAME, WM_GETTEXT, FMAX_PATH, (LPARAM)Pkt->RemoteFile);
\r
1973 EndDialog(hDlg, YES);
\r
1977 // Pkt->Abort = ABORT_USER;
\r
1978 // UpExistMode = EXIST_IGNORE;
\r
1979 EndDialog(hDlg, NO);
\r
1983 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000011);
\r
1992 /*----- アップロード/ダウンロードファイル名入力ダイアログのコールバック ------
\r
1995 * HWND hDlg : ウインドウハンドル
\r
1996 * UINT message : メッセージ番号
\r
1997 * WPARAM wParam : メッセージの WPARAM 引数
\r
1998 * LPARAM lParam : メッセージの LPARAM 引数
\r
2002 *----------------------------------------------------------------------------*/
\r
2005 //static BOOL CALLBACK UpDownAsDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2006 static INT_PTR CALLBACK UpDownAsDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2010 case WM_INITDIALOG :
\r
2011 if(CurWin == WIN_LOCAL)
\r
2012 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN064);
\r
2014 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN065);
\r
2016 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, EM_LIMITTEXT, FMAX_PATH, 0);
\r
2017 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2018 SendDlgItemMessage(hDlg, UPDOWNAS_TEXT, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2022 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2025 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, WM_GETTEXT, FMAX_PATH, (LPARAM)TmpString);
\r
2026 EndDialog(hDlg, YES);
\r
2029 case UPDOWNAS_STOP :
\r
2030 EndDialog(hDlg, NO_ALL);
\r
2039 #if defined(HAVE_TANDEM)
\r
2040 /*----- アップロード/ダウンロードファイル名入力ダイアログのコールバック ------
\r
2043 * HWND hDlg : ウインドウハンドル
\r
2044 * UINT message : メッセージ番号
\r
2045 * WPARAM wParam : メッセージの WPARAM 引数
\r
2046 * LPARAM lParam : メッセージの LPARAM 引数
\r
2050 *----------------------------------------------------------------------------*/
\r
2052 static INT_PTR CALLBACK UpDownAsWithExtDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2056 case WM_INITDIALOG :
\r
2057 if(CurWin == WIN_LOCAL)
\r
2058 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN064);
\r
2060 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN065);
\r
2062 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, EM_LIMITTEXT, FMAX_PATH, 0);
\r
2063 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2064 SendDlgItemMessage(hDlg, UPDOWNAS_TEXT, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2065 SendDlgItemMessage(hDlg, UPDOWNAS_FILECODE, EM_LIMITTEXT, 4, 0);
\r
2066 SendDlgItemMessage(hDlg, UPDOWNAS_FILECODE, WM_SETTEXT, 0, (LPARAM)TmpFileCode);
\r
2071 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2074 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, WM_GETTEXT, FMAX_PATH, (LPARAM)TmpString);
\r
2075 SendDlgItemMessage(hDlg, UPDOWNAS_FILECODE, WM_GETTEXT, FMAX_PATH, (LPARAM)TmpFileCode);
\r
2076 EndDialog(hDlg, YES);
\r
2079 case UPDOWNAS_STOP :
\r
2080 EndDialog(hDlg, NO_ALL);
\r
2090 /*----- ファイル一覧で指定されたファイルを削除する ----------------------------
\r
2097 *----------------------------------------------------------------------------*/
\r
2099 void DeleteProc(void)
\r
2102 FILELIST *FileListBase;
\r
2106 char CurDir[FMAX_PATH+1];
\r
2107 char Tmp[FMAX_PATH+1];
\r
2115 AskRemoteCurDir(CurDir, FMAX_PATH);
\r
2116 FileListBase = NULL;
\r
2117 if(GetFocus() == GetLocalHwnd())
\r
2120 MakeSelectedFileList(Win, NO, NO, &FileListBase, &CancelFlg);
\r
2125 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2126 MakeSelectedFileList(Win, YES, NO, &FileListBase, &CancelFlg);
\r
2134 // DisableUserOpe();
\r
2138 Pos = FileListBase;
\r
2139 while(Pos != NULL)
\r
2141 if(Pos->Node == NODE_FILE)
\r
2143 DelNotifyAndDo(Pos, Win, &Sts, &DelFlg, CurDir);
\r
2151 DeleteAllDir(FileListBase, Win, &Sts, &DelFlg, CurDir);
\r
2153 if(Win == WIN_REMOTE)
\r
2155 AskRemoteCurDir(Tmp, FMAX_PATH);
\r
2156 if(strcmp(Tmp, CurDir) != 0)
\r
2157 DoCWD(Tmp, NO, NO, NO);
\r
2160 DeleteFileList(&FileListBase);
\r
2164 if(Win == WIN_LOCAL)
\r
2165 GetLocalDirForWnd();
\r
2167 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2171 // EnableUserOpe();
\r
2179 /*----- サブディレクトリ以下を全て削除する ------------------------------------
\r
2182 * FILELIST *Dt : 削除するファイルのリスト
\r
2183 * int Win : ウインドウ番号 (WIN_xxx)
\r
2184 * int *Sw : 操作方法 (YES/NO/YES_ALL/NO_ALL)
\r
2185 * int *Flg : ファイルを削除したかどうかのフラグ (YES/NO)
\r
2186 * char *CurDir : カレントディレクトリ
\r
2190 *----------------------------------------------------------------------------*/
\r
2192 static void DeleteAllDir(FILELIST *Dt, int Win, int *Sw, int *Flg, char *CurDir)
\r
2196 if(Dt->Node == NODE_DIR)
\r
2198 DeleteAllDir(Dt->Next, Win, Sw, Flg, CurDir);
\r
2202 DelNotifyAndDo(Dt, Win, Sw, Flg, CurDir);
\r
2211 /*----- 削除するかどうかの確認と削除実行 --------------------------------------
\r
2214 * FILELIST *Dt : 削除するファイルのリスト
\r
2215 * int Win : ウインドウ番号 (WIN_xxx)
\r
2216 * int *Sw : 操作方法 (YES/NO/YES_ALL/NO_ALL)
\r
2217 * int *Flg : ファイルを削除したかどうかのフラグ (YES/NO)
\r
2218 * char *CurDir : カレントディレクトリ
\r
2222 *----------------------------------------------------------------------------*/
\r
2224 static void DelNotifyAndDo(FILELIST *Dt, int Win, int *Sw, int *Flg, char *CurDir)
\r
2226 char Path[FMAX_PATH+1];
\r
2228 if(Win == WIN_LOCAL)
\r
2230 AskLocalCurDir(Path, FMAX_PATH);
\r
2232 strcat(Path, Dt->File);
\r
2233 ReplaceAll(Path, '/', '\\');
\r
2237 AskRemoteCurDir(Path, FMAX_PATH);
\r
2238 SetSlashTail(Path);
\r
2239 strcat(Path, Dt->File);
\r
2240 ReplaceAll(Path, '\\', '/');
\r
2243 if(*Sw != YES_ALL)
\r
2245 sprintf(TmpString, "%s", Path);
\r
2247 // ローカルのファイルのパスの最後の'\\'が消えるバグ修正
\r
2248 // if(AskHostType() == HTYPE_VMS)
\r
2249 if(Win == WIN_REMOTE && AskHostType() == HTYPE_VMS)
\r
2250 ReformToVMSstylePathName(TmpString);
\r
2253 *Sw = DialogBox(GetFtpInst(), MAKEINTRESOURCE(delete_dlg), GetMainHwnd(), DeleteDialogCallBack);
\r
2256 if((*Sw == YES) || (*Sw == YES_ALL))
\r
2258 if(Win == WIN_LOCAL)
\r
2260 if(Dt->Node == NODE_FILE)
\r
2261 DoLocalDELE(Path);
\r
2268 /* フルパスを使わない時のための処理 */
\r
2270 // if(ProcForNonFullpath(Path, CurDir, GetMainHwnd(), 0) == FFFTP_FAIL)
\r
2271 if(ProcForNonFullpath(AskCmdCtrlSkt(), Path, CurDir, GetMainHwnd(), &CancelFlg) == FFFTP_FAIL)
\r
2276 if(Dt->Node == NODE_FILE)
\r
2288 /*----- ファイル削除ダイアログのコールバック ----------------------------------
\r
2291 * HWND hDlg : ウインドウハンドル
\r
2292 * UINT message : メッセージ番号
\r
2293 * WPARAM wParam : メッセージの WPARAM 引数
\r
2294 * LPARAM lParam : メッセージの LPARAM 引数
\r
2298 *----------------------------------------------------------------------------*/
\r
2301 //static BOOL CALLBACK DeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2302 static INT_PTR CALLBACK DeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2306 case WM_INITDIALOG :
\r
2307 if(CurWin == WIN_LOCAL)
\r
2308 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN066);
\r
2310 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN067);
\r
2311 SendDlgItemMessage(hDlg, DELETE_TEXT, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2315 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2318 EndDialog(hDlg, YES);
\r
2322 EndDialog(hDlg, NO);
\r
2326 EndDialog(hDlg, YES_ALL);
\r
2330 EndDialog(hDlg, NO_ALL);
\r
2339 /*----- ファイル一覧で指定されたファイルの名前を変更する ----------------------
\r
2346 *----------------------------------------------------------------------------*/
\r
2348 void RenameProc(void)
\r
2351 FILELIST *FileListBase;
\r
2353 char New[FMAX_PATH+1];
\r
2360 Sts = FFFTP_SUCCESS;
\r
2361 if(GetFocus() == GetLocalHwnd())
\r
2366 Sts = CheckClosedAndReconnect();
\r
2369 if(Sts == FFFTP_SUCCESS)
\r
2373 FileListBase = NULL;
\r
2374 MakeSelectedFileList(Win, NO, NO, &FileListBase, &CancelFlg);
\r
2378 Pos = FileListBase;
\r
2379 while(Pos != NULL)
\r
2381 if((Pos->Node == NODE_FILE) || (Pos->Node == NODE_DIR))
\r
2383 strcpy(TmpString, Pos->File);
\r
2385 Sts = DialogBox(GetFtpInst(), MAKEINTRESOURCE(rename_dlg), GetMainHwnd(), RenameDialogCallBack);
\r
2390 if((Sts == YES) && (strlen(TmpString) != 0))
\r
2392 strcpy(New, TmpString);
\r
2393 if(Win == WIN_LOCAL)
\r
2394 DoLocalRENAME(Pos->File, New);
\r
2396 DoRENAME(Pos->File, New);
\r
2402 DeleteFileList(&FileListBase);
\r
2406 if(Win == WIN_LOCAL)
\r
2407 GetLocalDirForWnd();
\r
2409 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2419 // リモート側でのファイルの移動(リネーム)を行う
\r
2421 // RenameProc()をベースに改造。(2007.9.5 yutaka)
\r
2423 void MoveRemoteFileProc(int drop_index)
\r
2426 FILELIST *FileListBase;
\r
2429 char New[FMAX_PATH+1];
\r
2430 char Old[FMAX_PATH+1];
\r
2431 char HostDir[FMAX_PATH+1];
\r
2438 if(MoveMode == MOVE_DISABLE)
\r
2443 AskRemoteCurDir(HostDir, FMAX_PATH);
\r
2446 GetNodeName(WIN_REMOTE, drop_index, Pkt.File, FMAX_PATH);
\r
2448 if(MoveMode == MOVE_DLG)
\r
2450 if(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(move_notify_dlg), GetRemoteHwnd(), ExeEscTextDialogProc, (LPARAM)Pkt.File) == NO)
\r
2456 Sts = FFFTP_SUCCESS;
\r
2458 if(GetFocus() == GetLocalHwnd())
\r
2463 Sts = CheckClosedAndReconnect();
\r
2467 Sts = CheckClosedAndReconnect();
\r
2470 if(Sts == FFFTP_SUCCESS)
\r
2474 FileListBase = NULL;
\r
2475 MakeSelectedFileList(Win, NO, NO, &FileListBase, &CancelFlg);
\r
2479 Pos = FileListBase;
\r
2480 while(Pos != NULL)
\r
2482 if((Pos->Node == NODE_FILE) || (Pos->Node == NODE_DIR))
\r
2484 strcpy(TmpString, Pos->File);
\r
2487 Sts = DialogBox(GetFtpInst(), MAKEINTRESOURCE(rename_dlg), GetMainHwnd(), RenameDialogCallBack);
\r
2495 if((Sts == YES) && (strlen(TmpString) != 0))
\r
2498 strncpy_s(Old, sizeof(Old), HostDir, _TRUNCATE);
\r
2499 strncat_s(Old, sizeof(Old), "/", _TRUNCATE);
\r
2500 strncat_s(Old, sizeof(Old), Pos->File, _TRUNCATE);
\r
2503 strncpy_s(New, sizeof(New), HostDir, _TRUNCATE);
\r
2504 strncat_s(New, sizeof(New), "/", _TRUNCATE);
\r
2505 strncat_s(New, sizeof(New), Pkt.File, _TRUNCATE);
\r
2506 strncat_s(New, sizeof(New), "/", _TRUNCATE);
\r
2507 strncat_s(New, sizeof(New), Pos->File, _TRUNCATE);
\r
2509 if(Win == WIN_LOCAL)
\r
2510 DoLocalRENAME(Old, New);
\r
2512 DoRENAME(Old, New);
\r
2518 DeleteFileList(&FileListBase);
\r
2522 if(Win == WIN_LOCAL) {
\r
2523 GetLocalDirForWnd();
\r
2525 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2527 strncpy_s(New, sizeof(New), HostDir, _TRUNCATE);
\r
2528 strncat_s(New, sizeof(New), "/", _TRUNCATE);
\r
2529 strncat_s(New, sizeof(New), Pkt.File, _TRUNCATE);
\r
2530 DoCWD(New, YES, YES, YES);
\r
2531 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2542 /*----- 新ファイル名入力ダイアログのコールバック ------------------------------
\r
2545 * HWND hDlg : ウインドウハンドル
\r
2546 * UINT message : メッセージ番号
\r
2547 * WPARAM wParam : メッセージの WPARAM 引数
\r
2548 * LPARAM lParam : メッセージの LPARAM 引数
\r
2552 *----------------------------------------------------------------------------*/
\r
2555 //static BOOL CALLBACK RenameDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2556 static INT_PTR CALLBACK RenameDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2560 case WM_INITDIALOG :
\r
2561 if(CurWin == WIN_LOCAL)
\r
2562 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN068);
\r
2564 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN069);
\r
2565 SendDlgItemMessage(hDlg, RENAME_NEW, EM_LIMITTEXT, FMAX_PATH, 0);
\r
2566 SendDlgItemMessage(hDlg, RENAME_NEW, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2567 SendDlgItemMessage(hDlg, RENAME_TEXT, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2571 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2574 SendDlgItemMessage(hDlg, RENAME_NEW, WM_GETTEXT, FMAX_PATH, (LPARAM)TmpString);
\r
2575 EndDialog(hDlg, YES);
\r
2579 EndDialog(hDlg, NO);
\r
2582 case RENAME_STOP :
\r
2583 EndDialog(hDlg, NO_ALL);
\r
2592 /*----- 新しいディレクトリを作成する ------------------------------------------
\r
2599 *----------------------------------------------------------------------------*/
\r
2601 void MkdirProc(void)
\r
2605 char Path[FMAX_PATH+1];
\r
2612 if(GetFocus() == GetLocalHwnd())
\r
2615 Title = MSGJPN070;
\r
2620 Title = MSGJPN071;
\r
2624 Sts = InputDialogBox(mkdir_dlg, GetMainHwnd(), Title, Path, FMAX_PATH+1, &Tmp, IDH_HELP_TOPIC_0000001);
\r
2626 if((Sts == YES) && (strlen(Path) != 0))
\r
2628 if(Win == WIN_LOCAL)
\r
2632 GetLocalDirForWnd();
\r
2637 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2641 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2650 /*----- ヒストリリストを使ったディレクトリの移動 ------------------------------
\r
2653 * HWND hWnd : コンボボックスのウインドウハンドル
\r
2657 *----------------------------------------------------------------------------*/
\r
2659 void ChangeDirComboProc(HWND hWnd)
\r
2661 char Tmp[FMAX_PATH+1];
\r
2667 if((i = SendMessage(hWnd, CB_GETCURSEL, 0, 0)) != CB_ERR)
\r
2669 SendMessage(hWnd, CB_GETLBTEXT, i, (LPARAM)Tmp);
\r
2671 if(hWnd == GetLocalHistHwnd())
\r
2675 GetLocalDirForWnd();
\r
2680 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2683 if(DoCWD(Tmp, YES, NO, YES) < FTP_RETRY)
\r
2684 GetRemoteDirForWnd(CACHE_NORMAL, &CancelFlg);
\r
2693 /*----- ブックマークを使ったディレクトリの移動 --------------------------------
\r
2696 * int MarkID : ブックマークのメニューID
\r
2700 *----------------------------------------------------------------------------*/
\r
2702 void ChangeDirBmarkProc(int MarkID)
\r
2704 char Local[FMAX_PATH+1];
\r
2705 char Remote[FMAX_PATH+1];
\r
2711 Sts = AskBookMarkText(MarkID, Local, Remote, FMAX_PATH+1);
\r
2712 if((Sts == BMARK_TYPE_LOCAL) || (Sts == BMARK_TYPE_BOTH))
\r
2715 if(DoLocalCWD(Local) == FFFTP_SUCCESS)
\r
2716 GetLocalDirForWnd();
\r
2720 if((Sts == BMARK_TYPE_REMOTE) || (Sts == BMARK_TYPE_BOTH))
\r
2722 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2725 if(DoCWD(Remote, YES, NO, YES) < FTP_RETRY)
\r
2726 GetRemoteDirForWnd(CACHE_NORMAL, &CancelFlg);
\r
2734 /*----- ディレクトリ名を入力してディレクトリの移動 ----------------------------
\r
2737 * int Win : ウインドウ番号 (WIN_xxx)
\r
2741 *----------------------------------------------------------------------------*/
\r
2743 void ChangeDirDirectProc(int Win)
\r
2746 char Path[FMAX_PATH+1];
\r
2753 if(Win == WIN_LOCAL)
\r
2754 Title = MSGJPN072;
\r
2756 Title = MSGJPN073;
\r
2759 if(Win == WIN_LOCAL)
\r
2760 Sts = InputDialogBox(chdir_br_dlg, GetMainHwnd(), Title, Path, FMAX_PATH+1, &Tmp, IDH_HELP_TOPIC_0000001);
\r
2762 Sts = InputDialogBox(chdir_dlg, GetMainHwnd(), Title, Path, FMAX_PATH+1, &Tmp, IDH_HELP_TOPIC_0000001);
\r
2764 if((Sts == YES) && (strlen(Path) != 0))
\r
2766 if(Win == WIN_LOCAL)
\r
2770 GetLocalDirForWnd();
\r
2775 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2778 if(DoCWD(Path, YES, NO, YES) < FTP_RETRY)
\r
2779 GetRemoteDirForWnd(CACHE_NORMAL, &CancelFlg);
\r
2788 /*----- Dropされたファイルによるディレクトリの移動 ----------------------------
\r
2791 * WPARAM wParam : ドロップされたファイルの情報
\r
2795 *----------------------------------------------------------------------------*/
\r
2797 void ChangeDirDropFileProc(WPARAM wParam)
\r
2799 char Path[FMAX_PATH+1];
\r
2802 MakeDroppedDir(wParam, Path);
\r
2804 GetLocalDirForWnd();
\r
2810 /*----- ファイルの属性変更 ----------------------------------------------------
\r
2817 *----------------------------------------------------------------------------*/
\r
2819 void ChmodProc(void)
\r
2822 FILELIST *FileListBase;
\r
2832 if(GetFocus() == GetRemoteHwnd())
\r
2834 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2837 FileListBase = NULL;
\r
2838 MakeSelectedFileList(WIN_REMOTE, NO, NO, &FileListBase, &CancelFlg);
\r
2839 if(FileListBase != NULL)
\r
2841 sprintf(Tmp, "%03X", FileListBase->Attr);
\r
2842 if(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(chmod_dlg), GetMainHwnd(), ChmodDialogCallBack, (LPARAM)Tmp) == YES)
\r
2845 Pos = FileListBase;
\r
2846 while(Pos != NULL)
\r
2848 if((Pos->Node == NODE_FILE) || (Pos->Node == NODE_DIR))
\r
2850 DoCHMOD(Pos->File, Tmp);
\r
2855 if(ChmodFlg == YES)
\r
2856 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2859 DeleteFileList(&FileListBase);
\r
2863 else if(GetFocus() == GetLocalHwnd())
\r
2866 FileListBase = NULL;
\r
2867 MakeSelectedFileList(WIN_LOCAL, NO, NO, &FileListBase, &CancelFlg);
\r
2868 if(FileListBase != NULL)
\r
2870 if((Buf = malloc(1)) != NULL)
\r
2874 Pos = FileListBase;
\r
2875 while(Pos != NULL)
\r
2877 if((BufTmp = realloc(Buf, BufLen + strlen(Pos->File) + 2)) != NULL)
\r
2880 strcpy(Buf+BufLen, Pos->File);
\r
2881 BufLen += strlen(Pos->File) + 1;
\r
2886 memset(Buf+BufLen, NUL, 1);
\r
2887 DispFileProperty(Buf);
\r
2891 DeleteFileList(&FileListBase);
\r
2898 /*----- 属性変更ダイアログのコールバック --------------------------------------
\r
2901 * HWND hDlg : ウインドウハンドル
\r
2902 * UINT message : メッセージ番号
\r
2903 * WPARAM wParam : メッセージの WPARAM 引数
\r
2904 * LPARAM lParam : メッセージの LPARAM 引数
\r
2908 *----------------------------------------------------------------------------*/
\r
2911 //BOOL CALLBACK ChmodDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2912 INT_PTR CALLBACK ChmodDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2920 case WM_INITDIALOG :
\r
2921 Buf = (char *)lParam;
\r
2922 SendDlgItemMessage(hDlg, PERM_NOW, EM_LIMITTEXT, 4, 0);
\r
2923 SendDlgItemMessage(hDlg, PERM_NOW, WM_SETTEXT, 0, (LPARAM)Buf);
\r
2924 SetAttrToDialog(hDlg, xtoi(Buf));
\r
2928 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2931 SendDlgItemMessage(hDlg, PERM_NOW, WM_GETTEXT, 5, (LPARAM)Buf);
\r
2932 EndDialog(hDlg, YES);
\r
2936 EndDialog(hDlg, NO);
\r
2939 case PERM_O_READ :
\r
2940 case PERM_O_WRITE :
\r
2941 case PERM_O_EXEC :
\r
2942 case PERM_G_READ :
\r
2943 case PERM_G_WRITE :
\r
2944 case PERM_G_EXEC :
\r
2945 case PERM_A_READ :
\r
2946 case PERM_A_WRITE :
\r
2947 case PERM_A_EXEC :
\r
2948 Tmp = GetAttrFromDialog(hDlg);
\r
2949 sprintf(Str, "%03X", Tmp);
\r
2950 SendDlgItemMessage(hDlg, PERM_NOW, WM_SETTEXT, 0, (LPARAM)Str);
\r
2954 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000017);
\r
2963 /*----- 属性をダイアログボックスに設定 ----------------------------------------
\r
2966 * HWND hWnd : ダイアログボックスのウインドウハンドル
\r
2971 *----------------------------------------------------------------------------*/
\r
2973 static void SetAttrToDialog(HWND hDlg, int Attr)
\r
2976 SendDlgItemMessage(hDlg, PERM_O_READ, BM_SETCHECK, 1, 0);
\r
2978 SendDlgItemMessage(hDlg, PERM_O_WRITE, BM_SETCHECK, 1, 0);
\r
2980 SendDlgItemMessage(hDlg, PERM_O_EXEC, BM_SETCHECK, 1, 0);
\r
2983 SendDlgItemMessage(hDlg, PERM_G_READ, BM_SETCHECK, 1, 0);
\r
2985 SendDlgItemMessage(hDlg, PERM_G_WRITE, BM_SETCHECK, 1, 0);
\r
2987 SendDlgItemMessage(hDlg, PERM_G_EXEC, BM_SETCHECK, 1, 0);
\r
2990 SendDlgItemMessage(hDlg, PERM_A_READ, BM_SETCHECK, 1, 0);
\r
2992 SendDlgItemMessage(hDlg, PERM_A_WRITE, BM_SETCHECK, 1, 0);
\r
2994 SendDlgItemMessage(hDlg, PERM_A_EXEC, BM_SETCHECK, 1, 0);
\r
3000 /*----- ダイアログボックスの内容から属性を取得 --------------------------------
\r
3003 * HWND hWnd : ダイアログボックスのウインドウハンドル
\r
3007 *----------------------------------------------------------------------------*/
\r
3009 static int GetAttrFromDialog(HWND hDlg)
\r
3015 if(SendDlgItemMessage(hDlg, PERM_O_READ, BM_GETCHECK, 0, 0) == 1)
\r
3017 if(SendDlgItemMessage(hDlg, PERM_O_WRITE, BM_GETCHECK, 0, 0) == 1)
\r
3019 if(SendDlgItemMessage(hDlg, PERM_O_EXEC, BM_GETCHECK, 0, 0) == 1)
\r
3022 if(SendDlgItemMessage(hDlg, PERM_G_READ, BM_GETCHECK, 0, 0) == 1)
\r
3024 if(SendDlgItemMessage(hDlg, PERM_G_WRITE, BM_GETCHECK, 0, 0) == 1)
\r
3026 if(SendDlgItemMessage(hDlg, PERM_G_EXEC, BM_GETCHECK, 0, 0) == 1)
\r
3029 if(SendDlgItemMessage(hDlg, PERM_A_READ, BM_GETCHECK, 0, 0) == 1)
\r
3031 if(SendDlgItemMessage(hDlg, PERM_A_WRITE, BM_GETCHECK, 0, 0) == 1)
\r
3033 if(SendDlgItemMessage(hDlg, PERM_A_EXEC, BM_GETCHECK, 0, 0) == 1)
\r
3042 /*----- 任意のコマンドを送る --------------------------------------------------
\r
3049 *----------------------------------------------------------------------------*/
\r
3051 void SomeCmdProc(void)
\r
3055 FILELIST *FileListBase;
\r
3060 if(GetFocus() == GetRemoteHwnd())
\r
3062 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
3065 FileListBase = NULL;
\r
3066 MakeSelectedFileList(WIN_REMOTE, NO, NO, &FileListBase, &CancelFlg);
\r
3067 memset(Cmd, NUL, 81);
\r
3068 if(FileListBase != NULL)
\r
3070 strncpy(Cmd, FileListBase->File, 80);
\r
3072 DeleteFileList(&FileListBase);
\r
3074 if(InputDialogBox(somecmd_dlg, GetMainHwnd(), NULL, Cmd, 81, &Tmp, IDH_HELP_TOPIC_0000023) == YES)
\r
3078 DoQUOTE(AskCmdCtrlSkt(), Cmd);
\r
3089 /*----- ファイル総容量の計算を行う --------------------------------------------
\r
3096 *----------------------------------------------------------------------------*/
\r
3098 void CalcFileSizeProc(void)
\r
3100 FILELIST *ListBase;
\r
3109 if((All = DialogBox(GetFtpInst(), MAKEINTRESOURCE(filesize_notify_dlg), GetMainHwnd(), SizeNotifyDlgWndProc)) != NO_ALL)
\r
3111 Sts = FFFTP_SUCCESS;
\r
3112 if(GetFocus() == GetLocalHwnd())
\r
3117 Sts = CheckClosedAndReconnect();
\r
3120 if(Sts == FFFTP_SUCCESS)
\r
3123 MakeSelectedFileList(Win, YES, All, &ListBase, &CancelFlg);
\r
3127 while(Pos != NULL)
\r
3129 if(Pos->Node != NODE_DIR)
\r
3130 FileSize += Pos->Size;
\r
3133 DeleteFileList(&ListBase);
\r
3134 DialogBox(GetFtpInst(), MAKEINTRESOURCE(filesize_dlg), GetMainHwnd(), SizeDlgWndProc);
\r
3141 /*----- ファイル容量検索確認ダイアログのコールバック --------------------------
\r
3144 * HWND hDlg : ウインドウハンドル
\r
3145 * UINT message : メッセージ番号
\r
3146 * WPARAM wParam : メッセージの WPARAM 引数
\r
3147 * LPARAM lParam : メッセージの LPARAM 引数
\r
3151 *----------------------------------------------------------------------------*/
\r
3153 static LRESULT CALLBACK SizeNotifyDlgWndProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
\r
3157 case WM_INITDIALOG :
\r
3158 if(GetFocus() == GetLocalHwnd())
\r
3159 SendDlgItemMessage(hDlg, FSNOTIFY_TITLE, WM_SETTEXT, 0, (LPARAM)MSGJPN074);
\r
3161 SendDlgItemMessage(hDlg, FSNOTIFY_TITLE, WM_SETTEXT, 0, (LPARAM)MSGJPN075);
\r
3165 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
3168 if(SendDlgItemMessage(hDlg, FSNOTIFY_SEL_ONLY, BM_GETCHECK, 0, 0) == 1)
\r
3169 EndDialog(hDlg, NO);
\r
3171 EndDialog(hDlg, YES);
\r
3175 EndDialog(hDlg, NO_ALL);
\r
3184 /*----- ファイル容量検索ダイアログのコールバック ------------------------------
\r
3187 * HWND hDlg : ウインドウハンドル
\r
3188 * UINT message : メッセージ番号
\r
3189 * WPARAM wParam : メッセージの WPARAM 引数
\r
3190 * LPARAM lParam : メッセージの LPARAM 引数
\r
3194 *----------------------------------------------------------------------------*/
\r
3196 static LRESULT CALLBACK SizeDlgWndProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
\r
3198 char Tmp[FMAX_PATH+1];
\r
3202 case WM_INITDIALOG :
\r
3203 if(GetFocus() == GetLocalHwnd())
\r
3204 SendDlgItemMessage(hDlg, FSIZE_TITLE, WM_SETTEXT, 0, (LPARAM)MSGJPN076);
\r
3206 SendDlgItemMessage(hDlg, FSIZE_TITLE, WM_SETTEXT, 0, (LPARAM)MSGJPN077);
\r
3208 MakeSizeString(FileSize, Tmp);
\r
3209 SendDlgItemMessage(hDlg, FSIZE_SIZE, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
3213 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
3217 EndDialog(hDlg, YES);
\r
3227 /*----- ディレクトリ移動失敗時のエラーを表示 ----------------------------------
\r
3230 * HWND hDlg : ウインドウハンドル
\r
3234 *----------------------------------------------------------------------------*/
\r
3236 void DispCWDerror(HWND hWnd)
\r
3238 DialogBox(GetFtpInst(), MAKEINTRESOURCE(cwderr_dlg), hWnd, ExeEscDialogProc);
\r
3243 /*----- URLをクリップボードにコピー -------------------------------------------
\r
3250 *----------------------------------------------------------------------------*/
\r
3252 void CopyURLtoClipBoard(void)
\r
3254 FILELIST *FileListBase;
\r
3257 char Path[FMAX_PATH+1];
\r
3258 char Host[HOST_ADRS_LEN+1];
\r
3263 if(GetFocus() == GetRemoteHwnd())
\r
3265 FileListBase = NULL;
\r
3266 MakeSelectedFileList(WIN_REMOTE, NO, NO, &FileListBase, &CancelFlg);
\r
3267 if(FileListBase != NULL)
\r
3269 strcpy(Host, AskHostAdrs());
\r
3272 Pos = FileListBase;
\r
3273 while(Pos != NULL)
\r
3275 AskRemoteCurDir(Path, FMAX_PATH);
\r
3276 SetSlashTail(Path);
\r
3277 strcat(Path, Pos->File);
\r
3279 if(AskHostType() == HTYPE_VMS)
\r
3280 ReformToVMSstylePathName(Path);
\r
3283 if(AskHostPort() != PORT_NOR)
\r
3284 sprintf(Port, ":%d", AskHostPort());
\r
3287 Total += strlen(Path) + strlen(Host) + strlen(Port) + 8; /* 8は "ftp://\r\n" のぶん */
\r
3288 if(AskHostType() == HTYPE_VMS)
\r
3291 if((Buf = realloc(Buf, Total+1)) == NULL)
\r
3294 if(AskHostType() != HTYPE_VMS)
\r
3295 sprintf(Buf + Set, "ftp://%s%s%s\r\n", Host, Port, Path);
\r
3297 sprintf(Buf + Set, "ftp://%s%s/%s\r\n", Host, Port, Path);
\r
3304 CopyStrToClipBoard(Buf);
\r
3308 DeleteFileList(&FileListBase);
\r
3314 /*----- フルパスを使わないファイルアクセスの準備 ------------------------------
\r
3317 * char *Path : パス名
\r
3318 * char *CurDir : カレントディレクトリ
\r
3319 * HWND hWnd : エラーウインドウを表示する際の親ウインドウ
\r
3320 * int Type : 使用するソケットの種類
\r
3321 * 0=コマンドソケット, 1=転送ソケット
\r
3324 * int ステータス(FFFTP_SUCCESS/FFFTP_FAIL)
\r
3328 * このモジュール内で CWD を行ない、
\r
3329 * Path にファイル名のみ残す。(パス名は消す)
\r
3330 *----------------------------------------------------------------------------*/
\r
3333 //int ProcForNonFullpath(char *Path, char *CurDir, HWND hWnd, int Type)
\r
3334 int ProcForNonFullpath(SOCKET cSkt, char *Path, char *CurDir, HWND hWnd, int *CancelCheckWork)
\r
3338 char Tmp[FMAX_PATH+1];
\r
3340 Sts = FFFTP_SUCCESS;
\r
3341 if(AskNoFullPathMode() == YES)
\r
3343 strcpy(Tmp, Path);
\r
3344 if(AskHostType() == HTYPE_VMS)
\r
3346 GetUpperDirEraseTopSlash(Tmp);
\r
3347 ReformToVMSstyleDirName(Tmp);
\r
3349 else if(AskHostType() == HTYPE_STRATUS)
\r
3350 GetUpperDirEraseTopSlash(Tmp);
\r
3354 if(strcmp(Tmp, CurDir) != 0)
\r
3358 // Cmd = CommandProcCmd(NULL, "CWD %s", Tmp);
\r
3360 // Cmd = CommandProcTrn(NULL, "CWD %s", Tmp);
\r
3361 Cmd = CommandProcTrn(cSkt, NULL, CancelCheckWork, "CWD %s", Tmp);
\r
3363 if(Cmd/100 != FTP_COMPLETE)
\r
3365 DispCWDerror(hWnd);
\r
3369 strcpy(CurDir, Tmp);
\r
3371 strcpy(Path, GetFileName(Path));
\r
3377 /*----- ディレクトリ名をVAX VMSスタイルに変換する -----------------------------
\r
3380 * char *Path : パス名
\r
3386 * ddd:[xxx.yyy]/rrr/ppp --> ddd:[xxx.yyy.rrr.ppp]
\r
3387 *----------------------------------------------------------------------------*/
\r
3389 void ReformToVMSstyleDirName(char *Path)
\r
3394 if((Btm = strchr(Path, ']')) != NULL)
\r
3397 while((Pos = strchr(Pos, '/')) != NULL)
\r
3400 memmove(Btm, Btm+1, strlen(Btm+1)+1);
\r
3401 Pos = strchr(Path, NUL);
\r
3402 if(*(Pos-1) == '.')
\r
3413 /*----- ファイル名をVAX VMSスタイルに変換する ---------------------------------
\r
3416 * char *Path : パス名
\r
3422 * ddd:[xxx.yyy]/rrr/ppp --> ddd:[xxx.yyy.rrr]ppp
\r
3423 *----------------------------------------------------------------------------*/
\r
3425 void ReformToVMSstylePathName(char *Path)
\r
3427 char Fname[FMAX_PATH+1];
\r
3429 strcpy(Fname, GetFileName(Path));
\r
3431 GetUpperDirEraseTopSlash(Path);
\r
3432 ReformToVMSstyleDirName(Path);
\r
3434 strcat(Path, Fname);
\r
3440 #if defined(HAVE_OPENVMS)
\r
3441 /*----- VMSの"HOGE.DIR;?"というディレクトリ名から"HOGE"を取り出す ---------------
\r
3444 * char *DirName : "HOGE.DIR;?"形式のディレクトリ名
\r
3445 * int Flg : ";"のチェックをする(TRUE)かしない(FALSE)か
\r
3452 *----------------------------------------------------------------------------*/
\r
3454 void ReformVMSDirName(char *DirName, int Flg)
\r
3458 if (Flg == TRUE) {
\r
3459 /* ';'がない場合はVMS形式じゃなさそうなので何もしない */
\r
3460 if ((p = strrchr(DirName, ';')) == NULL)
\r
3464 /* ".DIR"があったらつぶす */
\r
3465 if ((p = strrchr(DirName, '.'))) {
\r
3466 if (memcmp(p + 1, "DIR", 3) == 0)
\r
3473 /*----- ファイル名に使えない文字がないかチェックし名前を変更する --------------
\r
3476 * char *Fname : ファイル名
\r
3480 * FFFTP_SUCCESS/FFFTP_FAIL=中止する
\r
3484 *----------------------------------------------------------------------------*/
\r
3486 static int RenameUnuseableName(char *Fname)
\r
3491 Ret = FFFTP_SUCCESS;
\r
3494 if((_mbschr(Fname, ':') != NULL) ||
\r
3495 (_mbschr(Fname, '*') != NULL) ||
\r
3496 (_mbschr(Fname, '?') != NULL) ||
\r
3497 (_mbschr(Fname, '<') != NULL) ||
\r
3498 (_mbschr(Fname, '>') != NULL) ||
\r
3499 (_mbschr(Fname, '|') != NULL) ||
\r
3500 (_mbschr(Fname, '\x22') != NULL) ||
\r
3501 (_mbschr(Fname, '\\') != NULL))
\r
3503 if(InputDialogBox(forcerename_dlg, GetMainHwnd(), NULL, Fname, FMAX_PATH+1, &Tmp, IDH_HELP_TOPIC_0000001) == NO)
\r
3517 // NOOPコマンドでは効果が無いホストが多いためLISTコマンドを使用
\r
3518 void NoopProc(void)
\r
3520 int CancelCheckWork;
\r
3521 CancelCheckWork = NO;
\r
3522 if(AskConnecting() == YES && AskUserOpeDisabled() == NO)
\r
3524 if(AskReuseCmdSkt() == NO || AskShareProh() == YES)
\r
3527 DoDirListCmdSkt("", "", 999, &CancelCheckWork);
\r