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
31 #include <windows.h>
\r
35 #include <mbstring.h>
\r
36 #include <windowsx.h>
\r
37 #include <commctrl.h>
\r
40 #include "resource.h"
\r
42 #include <htmlhelp.h>
\r
46 #undef __MBSWRAPPER_H__
\r
47 #include "mbswrapper.h"
\r
50 /*===== プロトタイプ =====*/
\r
52 static int CheckRemoteFile(TRANSPACKET *Pkt, FILELIST *ListList);
\r
53 static BOOL CALLBACK UpExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
55 static void DispMirrorFiles(FILELIST *Local, FILELIST *Remote);
\r
56 static void MirrorDeleteAllLocalDir(FILELIST *Local, TRANSPACKET *Pkt, TRANSPACKET **Base);
\r
57 static int CheckLocalFile(TRANSPACKET *Pkt);
\r
58 static BOOL CALLBACK DownExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
59 static void RemoveAfterSemicolon(char *Path);
\r
60 static void MirrorDeleteAllDir(FILELIST *Remote, TRANSPACKET *Pkt, TRANSPACKET **Base);
\r
61 static BOOL CALLBACK MirrorNotifyCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
62 static BOOL CALLBACK MirrorDispListCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
63 static void CountMirrorFiles(HWND hDlg, TRANSPACKET *Pkt);
\r
64 static int AskMirrorNoTrn(char *Fname, int Mode);
\r
65 static int AskUpLoadFileAttr(char *Fname);
\r
66 static BOOL CALLBACK UpDownAsDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
67 static void DeleteAllDir(FILELIST *Dt, int Win, int *Sw, int *Flg, char *CurDir);
\r
68 static void DelNotifyAndDo(FILELIST *Dt, int Win, int *Sw, int *Flg, char *CurDir);
\r
69 static BOOL CALLBACK DeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
70 static BOOL CALLBACK RenameDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
71 static void SetAttrToDialog(HWND hWnd, int Attr);
\r
72 static int GetAttrFromDialog(HWND hDlg);
\r
73 static LRESULT CALLBACK SizeNotifyDlgWndProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam);
\r
74 static LRESULT CALLBACK SizeDlgWndProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam);
\r
75 static int RenameUnuseableName(char *Fname);
\r
79 extern HWND hHelpWin;
\r
82 extern int FnameCnv;
\r
83 extern int RecvMode;
\r
84 extern int SendMode;
\r
85 extern int MoveMode;
\r
86 extern char MirrorNoTrn[MIRROR_LEN+1];
\r
87 extern char MirrorNoDel[MIRROR_LEN+1];
\r
88 extern int MirrorFnameCnv;
\r
89 extern char DefAttrList[DEFATTRLIST_LEN+1];
\r
90 extern SIZE MirrorDlgSize;
\r
91 extern int VaxSemicolon;
\r
92 extern int DebugConsole;
\r
93 extern int CancelFlg;
\r
95 /*===== ローカルなワーク =====*/
\r
97 static char TmpString[FMAX_PATH+80]; /* テンポラリ */
\r
98 static int CurWin; /* ウインドウ番号 */
\r
100 int UpExistMode = EXIST_OVW; /* アップロードで同じ名前のファイルがある時の扱い方 EXIST_xxx */
\r
101 int ExistMode = EXIST_OVW; /* 同じ名前のファイルがある時の扱い方 EXIST_xxx */
\r
102 static int ExistNotify; /* 確認ダイアログを出すかどうか YES/NO */
\r
104 static double FileSize; /* ファイル総容量 */
\r
108 /*----- ファイル一覧で指定されたファイルをダウンロードする --------------------
\r
111 * int ChName : 名前を変えるかどうか (YES/NO)
\r
112 * int ForceFile : ディレクトリをファイル見なすかどうか (YES/NO)
\r
113 * int All : 全てが選ばれている物として扱うかどうか (YES/NO)
\r
117 *----------------------------------------------------------------------------*/
\r
119 void DownLoadProc(int ChName, int ForceFile, int All)
\r
121 FILELIST *FileListBase;
\r
128 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
133 // KeepTransferDialog(YES);
\r
135 FileListBase = NULL;
\r
136 MakeSelectedFileList(WIN_REMOTE, (ForceFile == YES ? NO : YES), All, &FileListBase, &CancelFlg);
\r
138 if(AskNoFullPathMode() == YES)
\r
140 strcpy(Pkt.Cmd, "SETCUR");
\r
141 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
142 AddTransFileList(&Pkt);
\r
145 Pos = FileListBase;
\r
148 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
149 SetYenTail(Pkt.LocalFile);
\r
150 strcpy(TmpString, Pos->File);
\r
151 if((ChName == NO) || ((ForceFile == NO) && (Pos->Node == NODE_DIR)))
\r
153 if(FnameCnv == FNAME_LOWER)
\r
154 _mbslwr(TmpString);
\r
155 else if(FnameCnv == FNAME_UPPER)
\r
156 _mbsupr(TmpString);
\r
157 RemoveAfterSemicolon(TmpString);
\r
158 if(RenameUnuseableName(TmpString) == FFFTP_FAIL)
\r
163 CurWin = WIN_REMOTE;
\r
164 if(DialogBox(GetFtpInst(), MAKEINTRESOURCE(updown_as_dlg), GetMainHwnd(), UpDownAsDialogCallBack) == YES)
\r
166 if(RenameUnuseableName(TmpString) == FFFTP_FAIL)
\r
172 strcat(Pkt.LocalFile, TmpString);
\r
173 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
175 if((ForceFile == NO) && (Pos->Node == NODE_DIR))
\r
177 strcpy(Pkt.Cmd, "MKD ");
\r
178 strcpy(Pkt.RemoteFile, "");
\r
179 AddTransFileList(&Pkt);
\r
181 else if((Pos->Node == NODE_FILE) ||
\r
182 ((ForceFile == YES) && (Pos->Node == NODE_DIR)))
\r
184 if(AskHostType() == HTYPE_ACOS)
\r
186 strcpy(Pkt.RemoteFile, "'");
\r
187 strcat(Pkt.RemoteFile, AskHostLsName());
\r
188 strcat(Pkt.RemoteFile, "(");
\r
189 strcat(Pkt.RemoteFile, Pos->File);
\r
190 strcat(Pkt.RemoteFile, ")");
\r
191 strcat(Pkt.RemoteFile, "'");
\r
193 else if(AskHostType() == HTYPE_ACOS_4)
\r
195 strcpy(Pkt.RemoteFile, Pos->File);
\r
199 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
200 SetSlashTail(Pkt.RemoteFile);
\r
201 strcat(Pkt.RemoteFile, Pos->File);
\r
202 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
205 strcpy(Pkt.Cmd, "RETR ");
\r
206 Pkt.Type = AskTransferTypeAssoc(Pkt.RemoteFile, AskTransferType());
\r
207 Pkt.Size = Pos->Size;
\r
208 Pkt.Time = Pos->Time;
\r
209 Pkt.KanjiCode = AskHostKanjiCode();
\r
211 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
212 Pkt.KanaCnv = AskHostKanaCnv();
\r
214 Pkt.Mode = CheckLocalFile(&Pkt); /* Pkt.ExistSize がセットされる */
\r
215 if(Pkt.Mode == EXIST_ABORT)
\r
217 else if(Pkt.Mode != EXIST_IGNORE)
\r
218 AddTransFileList(&Pkt);
\r
223 if(AskNoFullPathMode() == YES)
\r
225 strcpy(Pkt.Cmd, "BACKCUR");
\r
226 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
227 AddTransFileList(&Pkt);
\r
229 DeleteFileList(&FileListBase);
\r
231 strcpy(Pkt.Cmd, "GOQUIT");
\r
232 AddTransFileList(&Pkt);
\r
234 GoForwardTransWindow();
\r
235 // KeepTransferDialog(NO);
\r
243 /*----- 指定されたファイルを一つダウンロードする ------------------------------
\r
246 * char *Fname : ファイル名
\r
250 *----------------------------------------------------------------------------*/
\r
252 void DirectDownLoadProc(char *Fname)
\r
259 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
264 // KeepTransferDialog(YES);
\r
266 if(AskNoFullPathMode() == YES)
\r
268 strcpy(Pkt.Cmd, "SETCUR");
\r
269 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
270 AddTransFileList(&Pkt);
\r
273 if(strlen(Fname) > 0)
\r
275 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
276 SetYenTail(Pkt.LocalFile);
\r
277 strcpy(TmpString, Fname);
\r
278 if(FnameCnv == FNAME_LOWER)
\r
279 _mbslwr(TmpString);
\r
280 else if(FnameCnv == FNAME_UPPER)
\r
281 _mbsupr(TmpString);
\r
282 RemoveAfterSemicolon(TmpString);
\r
284 if(RenameUnuseableName(TmpString) == FFFTP_SUCCESS)
\r
286 strcat(Pkt.LocalFile, TmpString);
\r
287 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
289 if(AskHostType() == HTYPE_ACOS)
\r
291 strcpy(Pkt.RemoteFile, "'");
\r
292 strcat(Pkt.RemoteFile, AskHostLsName());
\r
293 strcat(Pkt.RemoteFile, "(");
\r
294 strcat(Pkt.RemoteFile, Fname);
\r
295 strcat(Pkt.RemoteFile, ")");
\r
296 strcat(Pkt.RemoteFile, "'");
\r
298 else if(AskHostType() == HTYPE_ACOS_4)
\r
300 strcpy(Pkt.RemoteFile, Fname);
\r
304 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
305 SetSlashTail(Pkt.RemoteFile);
\r
306 strcat(Pkt.RemoteFile, Fname);
\r
307 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
310 strcpy(Pkt.Cmd, "RETR-S ");
\r
311 Pkt.Type = AskTransferTypeAssoc(Pkt.RemoteFile, AskTransferType());
\r
313 /* サイズと日付は転送側スレッドで取得し、セットする */
\r
315 Pkt.KanjiCode = AskHostKanjiCode();
\r
317 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
318 Pkt.KanaCnv = AskHostKanaCnv();
\r
320 Pkt.Mode = CheckLocalFile(&Pkt); /* Pkt.ExistSize がセットされる */
\r
321 if((Pkt.Mode != EXIST_ABORT) && (Pkt.Mode != EXIST_IGNORE))
\r
322 AddTransFileList(&Pkt);
\r
326 if(AskNoFullPathMode() == YES)
\r
328 strcpy(Pkt.Cmd, "BACKCUR");
\r
329 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
330 AddTransFileList(&Pkt);
\r
333 strcpy(Pkt.Cmd, "GOQUIT");
\r
334 AddTransFileList(&Pkt);
\r
336 GoForwardTransWindow();
\r
337 // KeepTransferDialog(NO);
\r
345 /*----- 入力されたファイル名のファイルを一つダウンロードする ------------------
\r
352 *----------------------------------------------------------------------------*/
\r
354 void InputDownLoadProc(void)
\r
356 char Path[FMAX_PATH+1];
\r
359 // DisableUserOpe();
\r
362 if(InputDialogBox(downname_dlg, GetMainHwnd(), NULL, Path, FMAX_PATH, &Tmp, IDH_HELP_TOPIC_0000001) == YES)
\r
364 DirectDownLoadProc(Path);
\r
367 // EnableUserOpe();
\r
373 /*----- ミラーリングダウンロードを行う ----------------------------------------
\r
376 * int Notify : 確認を行うかどうか (YES/NO)
\r
380 *----------------------------------------------------------------------------*/
\r
382 void MirrorDownloadProc(int Notify)
\r
384 FILELIST *LocalListBase;
\r
385 FILELIST *RemoteListBase;
\r
386 FILELIST *LocalPos;
\r
387 FILELIST *RemotePos;
\r
390 char Name[FMAX_PATH+1];
\r
398 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
405 Notify = DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(mirror_down_dlg), GetMainHwnd(), MirrorNotifyCallBack, 0);
\r
409 if((Notify == YES) || (Notify == YES_LIST))
\r
411 /*===== ファイルリスト取得 =====*/
\r
413 LocalListBase = NULL;
\r
414 MakeSelectedFileList(WIN_LOCAL, YES, YES, &LocalListBase, &CancelFlg);
\r
415 RemoteListBase = NULL;
\r
416 MakeSelectedFileList(WIN_REMOTE, YES, YES, &RemoteListBase, &CancelFlg);
\r
418 RemotePos = RemoteListBase;
\r
419 while(RemotePos != NULL)
\r
421 RemotePos->Attr = YES; /* RemotePos->Attrは転送するかどうかのフラグに使用 (YES/NO) */
\r
422 RemotePos = RemotePos->Next;
\r
425 LocalPos = LocalListBase;
\r
426 while(LocalPos != NULL)
\r
428 if(AskMirrorNoTrn(LocalPos->File, 1) == NO)
\r
430 LocalPos->Attr = YES;
\r
431 LocalPos = LocalPos->Next;
\r
435 LocalPos->Attr = NO; /* LocalPos->Attrは削除するかどうかのフラグに使用 (YES/NO) */
\r
437 if(LocalPos->Node == NODE_DIR)
\r
439 Level = AskDirLevel(LocalPos->File);
\r
440 LocalPos = LocalPos->Next;
\r
441 while(LocalPos != NULL)
\r
443 if((LocalPos->Node == NODE_DIR) &&
\r
444 (AskDirLevel(LocalPos->File) <= Level))
\r
448 LocalPos->Attr = NO;
\r
449 LocalPos = LocalPos->Next;
\r
453 LocalPos = LocalPos->Next;
\r
457 /*===== ファイルリスト比較 =====*/
\r
459 RemotePos = RemoteListBase;
\r
460 while(RemotePos != NULL)
\r
462 if(AskMirrorNoTrn(RemotePos->File, 0) == NO)
\r
464 strcpy(Name, RemotePos->File);
\r
465 // ReplaceAll(Name, '/', '\\');
\r
467 if(MirrorFnameCnv == YES)
\r
468 Mode = COMP_LOWERMATCH;
\r
470 Mode = COMP_STRICT;
\r
472 if((LocalPos = SearchFileList(Name, LocalListBase, Mode)) != NULL)
\r
474 if((RemotePos->Node == NODE_DIR) && (LocalPos->Node == NODE_DIR))
\r
476 LocalPos->Attr = NO;
\r
477 RemotePos->Attr = NO;
\r
479 else if((RemotePos->Node == NODE_FILE) && (LocalPos->Node == NODE_FILE))
\r
481 LocalPos->Attr = NO;
\r
482 if(CompareFileTime(&RemotePos->Time, &LocalPos->Time) <= 0)
\r
483 RemotePos->Attr = NO;
\r
486 RemotePos = RemotePos->Next;
\r
490 if(RemotePos->Node == NODE_FILE)
\r
492 RemotePos->Attr = NO;
\r
493 RemotePos = RemotePos->Next;
\r
497 RemotePos->Attr = NO;
\r
498 Level = AskDirLevel(RemotePos->File);
\r
499 RemotePos = RemotePos->Next;
\r
500 while(RemotePos != NULL)
\r
502 if((RemotePos->Node == NODE_DIR) &&
\r
503 (AskDirLevel(RemotePos->File) <= Level))
\r
507 RemotePos->Attr = NO;
\r
508 RemotePos = RemotePos->Next;
\r
514 DispMirrorFiles(LocalListBase, RemoteListBase);
\r
516 /*===== 削除/アップロード =====*/
\r
518 LocalPos = LocalListBase;
\r
519 while(LocalPos != NULL)
\r
521 if((LocalPos->Attr == YES) && (LocalPos->Node == NODE_FILE))
\r
523 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
524 SetYenTail(Pkt.LocalFile);
\r
525 strcat(Pkt.LocalFile, LocalPos->File);
\r
526 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
527 strcpy(Pkt.RemoteFile, "");
\r
528 strcpy(Pkt.Cmd, "L-DELE ");
\r
529 AddTmpTransFileList(&Pkt, &Base);
\r
531 LocalPos = LocalPos->Next;
\r
533 MirrorDeleteAllLocalDir(LocalListBase, &Pkt, &Base);
\r
536 RemotePos = RemoteListBase;
\r
537 while(RemotePos != NULL)
\r
539 if(RemotePos->Attr == YES)
\r
541 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
542 SetYenTail(Pkt.LocalFile);
\r
543 Cat = strchr(Pkt.LocalFile, NUL);
\r
544 strcat(Pkt.LocalFile, RemotePos->File);
\r
546 if(MirrorFnameCnv == YES)
\r
549 RemoveAfterSemicolon(Cat);
\r
550 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
552 if(RemotePos->Node == NODE_DIR)
\r
554 strcpy(Pkt.RemoteFile, "");
\r
555 strcpy(Pkt.Cmd, "L-MKD ");
\r
556 AddTmpTransFileList(&Pkt, &Base);
\r
558 else if(RemotePos->Node == NODE_FILE)
\r
560 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
561 SetSlashTail(Pkt.RemoteFile);
\r
562 strcat(Pkt.RemoteFile, RemotePos->File);
\r
563 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
565 strcpy(Pkt.Cmd, "RETR ");
\r
566 Pkt.Type = AskTransferTypeAssoc(Pkt.RemoteFile, AskTransferType());
\r
567 Pkt.Size = RemotePos->Size;
\r
568 Pkt.Time = RemotePos->Time;
\r
570 Pkt.KanjiCode = AskHostKanjiCode();
\r
572 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
573 Pkt.KanaCnv = AskHostKanaCnv();
\r
574 Pkt.Mode = EXIST_OVW;
\r
575 AddTmpTransFileList(&Pkt, &Base);
\r
578 RemotePos = RemotePos->Next;
\r
581 if((Notify == YES) ||
\r
582 (DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(mirrordown_notify_dlg), GetMainHwnd(), MirrorDispListCallBack, (LPARAM)&Base) == YES))
\r
584 if(AskNoFullPathMode() == YES)
\r
586 strcpy(Pkt.Cmd, "SETCUR");
\r
587 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
588 AddTransFileList(&Pkt);
\r
590 AppendTransFileList(Base);
\r
592 if(AskNoFullPathMode() == YES)
\r
594 strcpy(Pkt.Cmd, "BACKCUR");
\r
595 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
596 AddTransFileList(&Pkt);
\r
599 strcpy(Pkt.Cmd, "GOQUIT");
\r
600 AddTransFileList(&Pkt);
\r
603 EraseTmpTransFileList(&Base);
\r
605 DeleteFileList(&LocalListBase);
\r
606 DeleteFileList(&RemoteListBase);
\r
608 GoForwardTransWindow();
\r
617 /*----- ミラーリングのファイル一覧を表示 --------------------------------------
\r
620 * FILELIST *Local : ローカル側
\r
621 * FILELIST *Remote : リモート側
\r
625 *----------------------------------------------------------------------------*/
\r
627 static void DispMirrorFiles(FILELIST *Local, FILELIST *Remote)
\r
633 if(DebugConsole == YES)
\r
635 DoPrintf("---- MIRROR FILE LIST ----");
\r
636 while(Local != NULL)
\r
638 FileTimeToLocalFileTime(&Local->Time, &fTime);
\r
639 FileTimeToSystemTime(&fTime, &sTime);
\r
640 sprintf(Date, "%04d/%02d/%02d %02d:%02d:%02d.%04d",
\r
641 sTime.wYear, sTime.wMonth, sTime.wDay, sTime.wHour, sTime.wMinute, sTime.wSecond, sTime.wMilliseconds);
\r
642 DoPrintf("LOCAL : %s %s [%s] %s", Local->Attr==1?"YES":"NO ", Local->Node==NODE_DIR?"DIR ":"FILE", Date, Local->File);
\r
643 Local = Local->Next;
\r
645 while(Remote != NULL)
\r
647 FileTimeToLocalFileTime(&Remote->Time, &fTime);
\r
648 FileTimeToSystemTime(&fTime, &sTime);
\r
649 sprintf(Date, "%04d/%02d/%02d %02d:%02d:%02d.%04d",
\r
650 sTime.wYear, sTime.wMonth, sTime.wDay, sTime.wHour, sTime.wMinute, sTime.wSecond, sTime.wMilliseconds);
\r
651 DoPrintf("REMOTE : %s %s [%s] %s", Remote->Attr==1?"YES":"NO ", Remote->Node==NODE_DIR?"DIR ":"FILE", Date, Remote->File);
\r
652 Remote = Remote->Next;
\r
654 DoPrintf("---- END ----");
\r
660 /*----- ミラーリング時のローカル側のフォルダ削除 ------------------------------
\r
663 * FILELIST *Local : ファイルリスト
\r
664 * TRANSPACKET *Pkt :
\r
665 * TRANSPACKET **Base :
\r
669 *----------------------------------------------------------------------------*/
\r
671 static void MirrorDeleteAllLocalDir(FILELIST *Local, TRANSPACKET *Pkt, TRANSPACKET **Base)
\r
673 while(Local != NULL)
\r
675 if(Local->Node == NODE_DIR)
\r
677 MirrorDeleteAllLocalDir(Local->Next, Pkt, Base);
\r
679 if(Local->Attr == YES)
\r
681 AskLocalCurDir(Pkt->LocalFile, FMAX_PATH);
\r
682 SetYenTail(Pkt->LocalFile);
\r
683 strcat(Pkt->LocalFile, Local->File);
\r
684 ReplaceAll(Pkt->LocalFile, '/', '\\');
\r
685 strcpy(Pkt->RemoteFile, "");
\r
686 strcpy(Pkt->Cmd, "L-RMD ");
\r
687 AddTmpTransFileList(Pkt, Base);
\r
691 Local = Local->Next;
\r
697 /*----- ファイル名のセミコロン以降を取り除く ----------------------------------
\r
700 * char *Path : ファイル名
\r
707 * オプション設定によって処理を切替える
\r
708 *----------------------------------------------------------------------------*/
\r
710 static void RemoveAfterSemicolon(char *Path)
\r
714 if(VaxSemicolon == YES)
\r
716 if((Pos = strchr(Path, ';')) != NULL)
\r
723 /*----- ローカルに同じ名前のファイルがないかチェック --------------------------
\r
726 * TRANSPACKET *Pkt : 転送ファイル情報
\r
730 * EXIST_OVW/EXIST_RESUME/EXIST_IGNORE
\r
733 * Pkt.ExistSize, ExistMode、ExistNotify が変更される
\r
734 *----------------------------------------------------------------------------*/
\r
736 static int CheckLocalFile(TRANSPACKET *Pkt)
\r
739 WIN32_FIND_DATA Find;
\r
743 Pkt->ExistSize = 0;
\r
744 if(RecvMode != TRANS_OVW)
\r
746 if((fHnd = FindFirstFile(Pkt->LocalFile, &Find)) != INVALID_HANDLE_VALUE)
\r
750 Pkt->ExistSize = MakeLongLong(Find.nFileSizeHigh, Find.nFileSizeLow);
\r
752 if(ExistNotify == YES)
\r
754 SoundPlay(SND_ERROR);
\r
755 if(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(down_exist_dlg), GetMainHwnd(), DownExistDialogCallBack, (LPARAM)Pkt) == NO)
\r
763 if(Ret == EXIST_NEW)
\r
766 if(CompareFileTime(&Find.ftLastWriteTime, &Pkt->Time) < 0)
\r
769 Ret = EXIST_IGNORE;
\r
777 /*----- ローカルに同じ名前のファイルがある時の確認ダイアログのコールバック ----
\r
780 * HWND hDlg : ウインドウハンドル
\r
781 * UINT message : メッセージ番号
\r
782 * WPARAM wParam : メッセージの WPARAM 引数
\r
783 * LPARAM lParam : メッセージの LPARAM 引数
\r
787 *----------------------------------------------------------------------------*/
\r
789 static BOOL CALLBACK DownExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
791 static TRANSPACKET *Pkt;
\r
792 static const RADIOBUTTON DownExistButton[] = {
\r
793 { DOWN_EXIST_OVW, EXIST_OVW },
\r
794 { DOWN_EXIST_NEW, EXIST_NEW },
\r
795 { DOWN_EXIST_RESUME, EXIST_RESUME },
\r
796 { DOWN_EXIST_IGNORE, EXIST_IGNORE }
\r
798 #define DOWNEXISTBUTTONS (sizeof(DownExistButton)/sizeof(RADIOBUTTON))
\r
802 case WM_INITDIALOG :
\r
803 Pkt = (TRANSPACKET *)lParam;
\r
804 SendDlgItemMessage(hDlg, DOWN_EXIST_NAME, EM_LIMITTEXT, FMAX_PATH, 0);
\r
805 SendDlgItemMessage(hDlg, DOWN_EXIST_NAME, WM_SETTEXT, 0, (LPARAM)Pkt->LocalFile);
\r
807 if((Pkt->Type == TYPE_A) || (Pkt->ExistSize <= 0))
\r
808 EnableWindow(GetDlgItem(hDlg, DOWN_EXIST_RESUME), FALSE);
\r
810 SetRadioButtonByValue(hDlg, ExistMode, DownExistButton, DOWNEXISTBUTTONS);
\r
814 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
818 /* ここに break はない */
\r
821 ExistMode = AskRadioButtonValue(hDlg, DownExistButton, DOWNEXISTBUTTONS);
\r
822 SendDlgItemMessage(hDlg, DOWN_EXIST_NAME, WM_GETTEXT, FMAX_PATH, (LPARAM)Pkt->LocalFile);
\r
823 EndDialog(hDlg, YES);
\r
827 // ExistMode = EXIST_ABORT;
\r
828 EndDialog(hDlg, NO);
\r
832 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000009);
\r
845 /*----- ファイル一覧で指定されたファイルをアップロードする --------------------
\r
848 * int ChName : 名前を変えるかどうか (YES/NO)
\r
849 * int All : 全てが選ばれている物として扱うかどうか (YES/NO)
\r
853 *----------------------------------------------------------------------------*/
\r
855 void UpLoadListProc(int ChName, int All)
\r
857 FILELIST *FileListBase;
\r
862 FILELIST *RemoteList;
\r
863 char Tmp[FMAX_PATH+1];
\r
869 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
873 // ローカル側で選ばれているファイルをFileListBaseに登録
\r
874 FileListBase = NULL;
\r
875 MakeSelectedFileList(WIN_LOCAL, YES, All, &FileListBase, &CancelFlg);
\r
877 // 現在ホスト側のファイル一覧に表示されているものをRemoteListに登録
\r
880 AddRemoteTreeToFileList(AskCurrentFileListNum(), "", RDIR_NONE, &RemoteList);
\r
885 Pos = FileListBase;
\r
888 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
889 SetSlashTail(Pkt.RemoteFile);
\r
890 Cat = strchr(Pkt.RemoteFile, NUL);
\r
891 if((ChName == NO) || (Pos->Node == NODE_DIR))
\r
893 strcat(Pkt.RemoteFile, Pos->File);
\r
894 if(FnameCnv == FNAME_LOWER)
\r
896 else if(FnameCnv == FNAME_UPPER)
\r
902 strcpy(TmpString, Pos->File);
\r
903 CurWin = WIN_LOCAL;
\r
904 if(DialogBox(GetFtpInst(), MAKEINTRESOURCE(updown_as_dlg), GetMainHwnd(), UpDownAsDialogCallBack) == YES)
\r
905 strcat(Pkt.RemoteFile, TmpString);
\r
909 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
911 if(AskHostType() == HTYPE_ACOS)
\r
913 strcpy(Pkt.RemoteFile, "'");
\r
914 strcat(Pkt.RemoteFile, AskHostLsName());
\r
915 strcat(Pkt.RemoteFile, "(");
\r
916 strcat(Pkt.RemoteFile, Cat);
\r
917 strcat(Pkt.RemoteFile, ")");
\r
918 strcat(Pkt.RemoteFile, "'");
\r
920 else if(AskHostType() == HTYPE_ACOS_4)
\r
921 strcpy(Pkt.RemoteFile, Cat);
\r
923 if(Pos->Node == NODE_DIR)
\r
927 // ホスト側のファイル一覧をRemoteListに登録
\r
929 if(RemoteList != NULL)
\r
930 DeleteFileList(&RemoteList);
\r
933 AskRemoteCurDir(Tmp, FMAX_PATH);
\r
934 if(DoCWD(Pkt.RemoteFile, NO, NO, NO) == FTP_COMPLETE)
\r
936 if(DoDirListCmdSkt("", "", 998, &CancelFlg) == FTP_COMPLETE)
\r
937 AddRemoteTreeToFileList(998, "", RDIR_NONE, &RemoteList);
\r
938 DoCWD(Tmp, NO, NO, NO);
\r
943 if((FirstAdd == YES) && (AskNoFullPathMode() == YES))
\r
945 strcpy(Pkt1.Cmd, "SETCUR");
\r
946 AskRemoteCurDir(Pkt1.RemoteFile, FMAX_PATH);
\r
947 AddTransFileList(&Pkt1);
\r
950 strcpy(Pkt.Cmd, "MKD ");
\r
951 strcpy(Pkt.LocalFile, "");
\r
952 AddTransFileList(&Pkt);
\r
955 else if(Pos->Node == NODE_FILE)
\r
958 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
959 SetYenTail(Pkt.LocalFile);
\r
960 strcat(Pkt.LocalFile, Pos->File);
\r
961 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
963 strcpy(Pkt.Cmd, "STOR ");
\r
964 Pkt.Type = AskTransferTypeAssoc(Pkt.LocalFile, AskTransferType());
\r
966 Pkt.Time = Pos->Time;
\r
967 Pkt.Attr = AskUpLoadFileAttr(Pkt.RemoteFile);
\r
968 Pkt.KanjiCode = AskHostKanjiCode();
\r
970 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
971 Pkt.KanaCnv = AskHostKanaCnv();
\r
972 Pkt.Mode = CheckRemoteFile(&Pkt, RemoteList);
\r
973 if(Pkt.Mode == EXIST_ABORT)
\r
975 else if(Pkt.Mode != EXIST_IGNORE)
\r
977 if((FirstAdd == YES) && (AskNoFullPathMode() == YES))
\r
979 strcpy(Pkt1.Cmd, "SETCUR");
\r
980 AskRemoteCurDir(Pkt1.RemoteFile, FMAX_PATH);
\r
981 AddTransFileList(&Pkt1);
\r
984 AddTransFileList(&Pkt);
\r
990 if((FirstAdd == NO) && (AskNoFullPathMode() == YES))
\r
992 strcpy(Pkt.Cmd, "BACKCUR");
\r
993 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
994 AddTransFileList(&Pkt);
\r
997 if(RemoteList != NULL)
\r
998 DeleteFileList(&RemoteList);
\r
1000 DeleteFileList(&FileListBase);
\r
1002 strcpy(Pkt.Cmd, "GOQUIT");
\r
1003 AddTransFileList(&Pkt);
\r
1005 GoForwardTransWindow();
\r
1013 /*----- ドラッグ&ドロップで指定されたファイルをアップロードする --------------
\r
1016 * WPARAM wParam : ドロップされたファイルの情報
\r
1020 *----------------------------------------------------------------------------*/
\r
1022 void UpLoadDragProc(WPARAM wParam)
\r
1024 FILELIST *FileListBase;
\r
1029 FILELIST *RemoteList;
\r
1030 char Tmp[FMAX_PATH+1];
\r
1032 char Cur[FMAX_PATH+1];
\r
1037 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
1041 // ローカル側で選ばれているファイルをFileListBaseに登録
\r
1042 FileListBase = NULL;
\r
1043 MakeDroppedFileList(wParam, Cur, &FileListBase);
\r
1045 // 現在ホスト側のファイル一覧に表示されているものをRemoteListに登録
\r
1047 RemoteList = NULL;
\r
1048 AddRemoteTreeToFileList(AskCurrentFileListNum(), "", RDIR_NONE, &RemoteList);
\r
1051 ExistNotify = YES;
\r
1053 Pos = FileListBase;
\r
1054 while(Pos != NULL)
\r
1056 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1057 SetSlashTail(Pkt.RemoteFile);
\r
1058 Cat = strchr(Pkt.RemoteFile, NUL);
\r
1060 strcat(Pkt.RemoteFile, Pos->File);
\r
1061 if(FnameCnv == FNAME_LOWER)
\r
1063 else if(FnameCnv == FNAME_UPPER)
\r
1065 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
1067 if(AskHostType() == HTYPE_ACOS)
\r
1069 strcpy(Pkt.RemoteFile, "'");
\r
1070 strcat(Pkt.RemoteFile, AskHostLsName());
\r
1071 strcat(Pkt.RemoteFile, "(");
\r
1072 strcat(Pkt.RemoteFile, Cat);
\r
1073 strcat(Pkt.RemoteFile, ")");
\r
1074 strcat(Pkt.RemoteFile, "'");
\r
1076 else if(AskHostType() == HTYPE_ACOS_4)
\r
1077 strcpy(Pkt.RemoteFile, Cat);
\r
1079 if(Pos->Node == NODE_DIR)
\r
1083 // ホスト側のファイル一覧をRemoteListに登録
\r
1085 if(RemoteList != NULL)
\r
1086 DeleteFileList(&RemoteList);
\r
1087 RemoteList = NULL;
\r
1089 AskRemoteCurDir(Tmp, FMAX_PATH);
\r
1090 if(DoCWD(Pkt.RemoteFile, NO, NO, NO) == FTP_COMPLETE)
\r
1092 if(DoDirListCmdSkt("", "", 998, &CancelFlg) == FTP_COMPLETE)
\r
1093 AddRemoteTreeToFileList(998, "", RDIR_NONE, &RemoteList);
\r
1094 DoCWD(Tmp, NO, NO, NO);
\r
1098 if((FirstAdd == YES) && (AskNoFullPathMode() == YES))
\r
1100 strcpy(Pkt1.Cmd, "SETCUR");
\r
1101 AskRemoteCurDir(Pkt1.RemoteFile, FMAX_PATH);
\r
1102 AddTransFileList(&Pkt1);
\r
1105 strcpy(Pkt.Cmd, "MKD ");
\r
1106 strcpy(Pkt.LocalFile, "");
\r
1107 AddTransFileList(&Pkt);
\r
1110 else if(Pos->Node == NODE_FILE)
\r
1113 strcpy(Pkt.LocalFile, Cur);
\r
1114 SetYenTail(Pkt.LocalFile);
\r
1115 strcat(Pkt.LocalFile, Pos->File);
\r
1116 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
1118 strcpy(Pkt.Cmd, "STOR ");
\r
1119 Pkt.Type = AskTransferTypeAssoc(Pkt.LocalFile, AskTransferType());
\r
1121 Pkt.Time = Pos->Time;
\r
1122 Pkt.Attr = AskUpLoadFileAttr(Pkt.RemoteFile);
\r
1123 Pkt.KanjiCode = AskHostKanjiCode();
\r
1125 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
1126 Pkt.KanaCnv = AskHostKanaCnv();
\r
1127 Pkt.Mode = CheckRemoteFile(&Pkt, RemoteList);
\r
1128 if(Pkt.Mode == EXIST_ABORT)
\r
1130 else if(Pkt.Mode != EXIST_IGNORE)
\r
1132 if((FirstAdd == YES) && (AskNoFullPathMode() == YES))
\r
1134 strcpy(Pkt1.Cmd, "SETCUR");
\r
1135 AskRemoteCurDir(Pkt1.RemoteFile, FMAX_PATH);
\r
1136 AddTransFileList(&Pkt1);
\r
1139 AddTransFileList(&Pkt);
\r
1145 if((FirstAdd == NO) && (AskNoFullPathMode() == YES))
\r
1147 strcpy(Pkt.Cmd, "BACKCUR");
\r
1148 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1149 AddTransFileList(&Pkt);
\r
1152 if(RemoteList != NULL)
\r
1153 DeleteFileList(&RemoteList);
\r
1155 DeleteFileList(&FileListBase);
\r
1157 strcpy(Pkt.Cmd, "GOQUIT");
\r
1158 AddTransFileList(&Pkt);
\r
1160 GoForwardTransWindow();
\r
1168 /*----- ミラーリングアップロードを行う ----------------------------------------
\r
1171 * int Notify : 確認を行うかどうか (YES/NO)
\r
1175 *----------------------------------------------------------------------------*/
\r
1177 void MirrorUploadProc(int Notify)
\r
1179 FILELIST *LocalListBase;
\r
1180 FILELIST *RemoteListBase;
\r
1181 FILELIST *LocalPos;
\r
1182 FILELIST *RemotePos;
\r
1184 TRANSPACKET *Base;
\r
1185 char Name[FMAX_PATH+1];
\r
1189 SYSTEMTIME TmpStime;
\r
1190 FILETIME TmpFtimeL;
\r
1191 FILETIME TmpFtimeR;
\r
1196 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
1203 Notify = DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(mirror_up_dlg), GetMainHwnd(), MirrorNotifyCallBack, 1);
\r
1207 if((Notify == YES) || (Notify == YES_LIST))
\r
1209 /*===== ファイルリスト取得 =====*/
\r
1211 LocalListBase = NULL;
\r
1212 MakeSelectedFileList(WIN_LOCAL, YES, YES, &LocalListBase, &CancelFlg);
\r
1213 RemoteListBase = NULL;
\r
1214 MakeSelectedFileList(WIN_REMOTE, YES, YES, &RemoteListBase, &CancelFlg);
\r
1216 LocalPos = LocalListBase;
\r
1217 while(LocalPos != NULL)
\r
1219 LocalPos->Attr = YES; /* LocalPos->Attrは転送するかどうかのフラグに使用 (YES/NO) */
\r
1220 LocalPos = LocalPos->Next;
\r
1223 RemotePos = RemoteListBase;
\r
1224 while(RemotePos != NULL)
\r
1226 if(AskMirrorNoTrn(RemotePos->File, 1) == NO)
\r
1228 RemotePos->Attr = YES;
\r
1229 RemotePos = RemotePos->Next;
\r
1233 RemotePos->Attr = NO; /* RemotePos->Attrは削除するかどうかのフラグに使用 (YES/NO) */
\r
1235 if(RemotePos->Node == NODE_DIR)
\r
1237 Level = AskDirLevel(RemotePos->File);
\r
1238 RemotePos = RemotePos->Next;
\r
1239 while(RemotePos != NULL)
\r
1241 if((RemotePos->Node == NODE_DIR) &&
\r
1242 (AskDirLevel(RemotePos->File) <= Level))
\r
1246 RemotePos->Attr = NO;
\r
1247 RemotePos = RemotePos->Next;
\r
1251 RemotePos = RemotePos->Next;
\r
1255 /*===== ファイルリスト比較 =====*/
\r
1257 LocalPos = LocalListBase;
\r
1258 while(LocalPos != NULL)
\r
1260 if(AskMirrorNoTrn(LocalPos->File, 0) == NO)
\r
1262 strcpy(Name, LocalPos->File);
\r
1263 ReplaceAll(Name, '\\', '/');
\r
1265 if(MirrorFnameCnv == YES)
\r
1266 Mode = COMP_LOWERMATCH;
\r
1268 Mode = COMP_STRICT;
\r
1270 if(LocalPos->Node == NODE_DIR)
\r
1272 if((RemotePos = SearchFileList(Name, RemoteListBase, Mode)) != NULL)
\r
1274 if(RemotePos->Node == NODE_DIR)
\r
1276 RemotePos->Attr = NO;
\r
1277 LocalPos->Attr = NO;
\r
1281 else if(LocalPos->Node == NODE_FILE)
\r
1283 if((RemotePos = SearchFileList(Name, RemoteListBase, Mode)) != NULL)
\r
1285 if(RemotePos->Node == NODE_FILE)
\r
1287 FileTimeToLocalFileTime(&LocalPos->Time, &TmpFtimeL);
\r
1288 FileTimeToLocalFileTime(&RemotePos->Time, &TmpFtimeR);
\r
1289 if((RemotePos->InfoExist & FINFO_TIME) == 0)
\r
1291 FileTimeToSystemTime(&TmpFtimeL, &TmpStime);
\r
1292 TmpStime.wHour = 0;
\r
1293 TmpStime.wMinute = 0;
\r
1294 TmpStime.wSecond = 0;
\r
1295 TmpStime.wMilliseconds = 0;
\r
1296 SystemTimeToFileTime(&TmpStime, &TmpFtimeL);
\r
1298 FileTimeToSystemTime(&TmpFtimeR, &TmpStime);
\r
1299 TmpStime.wHour = 0;
\r
1300 TmpStime.wMinute = 0;
\r
1301 TmpStime.wSecond = 0;
\r
1302 TmpStime.wMilliseconds = 0;
\r
1303 SystemTimeToFileTime(&TmpStime, &TmpFtimeR);
\r
1305 RemotePos->Attr = NO;
\r
1306 if(CompareFileTime(&TmpFtimeL, &TmpFtimeR) <= 0)
\r
1307 LocalPos->Attr = NO;
\r
1312 LocalPos = LocalPos->Next;
\r
1316 if(LocalPos->Node == NODE_FILE)
\r
1318 LocalPos->Attr = NO;
\r
1319 LocalPos = LocalPos->Next;
\r
1323 LocalPos->Attr = NO;
\r
1324 Level = AskDirLevel(LocalPos->File);
\r
1325 LocalPos = LocalPos->Next;
\r
1326 while(LocalPos != NULL)
\r
1328 if((LocalPos->Node == NODE_DIR) &&
\r
1329 (AskDirLevel(LocalPos->File) <= Level))
\r
1333 LocalPos->Attr = NO;
\r
1334 LocalPos = LocalPos->Next;
\r
1340 DispMirrorFiles(LocalListBase, RemoteListBase);
\r
1342 /*===== 削除/アップロード =====*/
\r
1344 RemotePos = RemoteListBase;
\r
1345 while(RemotePos != NULL)
\r
1347 if((RemotePos->Attr == YES) && (RemotePos->Node == NODE_FILE))
\r
1349 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1350 SetSlashTail(Pkt.RemoteFile);
\r
1351 strcat(Pkt.RemoteFile, RemotePos->File);
\r
1352 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
1353 strcpy(Pkt.LocalFile, "");
\r
1354 strcpy(Pkt.Cmd, "R-DELE ");
\r
1355 AddTmpTransFileList(&Pkt, &Base);
\r
1357 RemotePos = RemotePos->Next;
\r
1359 MirrorDeleteAllDir(RemoteListBase, &Pkt, &Base);
\r
1361 LocalPos = LocalListBase;
\r
1362 while(LocalPos != NULL)
\r
1364 if(LocalPos->Attr == YES)
\r
1366 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1367 SetSlashTail(Pkt.RemoteFile);
\r
1368 Cat = strchr(Pkt.RemoteFile, NUL);
\r
1369 strcat(Pkt.RemoteFile, LocalPos->File);
\r
1371 if(MirrorFnameCnv == YES)
\r
1374 ReplaceAll(Pkt.RemoteFile, '\\', '/');
\r
1376 if(LocalPos->Node == NODE_DIR)
\r
1378 strcpy(Pkt.LocalFile, "");
\r
1379 strcpy(Pkt.Cmd, "R-MKD ");
\r
1380 AddTmpTransFileList(&Pkt, &Base);
\r
1382 else if(LocalPos->Node == NODE_FILE)
\r
1384 AskLocalCurDir(Pkt.LocalFile, FMAX_PATH);
\r
1385 SetYenTail(Pkt.LocalFile);
\r
1386 strcat(Pkt.LocalFile, LocalPos->File);
\r
1387 ReplaceAll(Pkt.LocalFile, '/', '\\');
\r
1389 strcpy(Pkt.Cmd, "STOR ");
\r
1390 Pkt.Type = AskTransferTypeAssoc(Pkt.LocalFile, AskTransferType());
\r
1392 Pkt.Time = LocalPos->Time;
\r
1393 Pkt.Attr = AskUpLoadFileAttr(Pkt.RemoteFile);
\r
1394 Pkt.KanjiCode = AskHostKanjiCode();
\r
1396 Pkt.KanjiCodeDesired = AskLocalKanjiCode();
\r
1397 Pkt.KanaCnv = AskHostKanaCnv();
\r
1398 Pkt.Mode = EXIST_OVW;
\r
1399 AddTmpTransFileList(&Pkt, &Base);
\r
1402 LocalPos = LocalPos->Next;
\r
1405 if((Notify == YES) ||
\r
1406 (DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(mirror_notify_dlg), GetMainHwnd(), MirrorDispListCallBack, (LPARAM)&Base) == YES))
\r
1408 if(AskNoFullPathMode() == YES)
\r
1410 strcpy(Pkt.Cmd, "SETCUR");
\r
1411 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1412 AddTransFileList(&Pkt);
\r
1414 AppendTransFileList(Base);
\r
1416 if(AskNoFullPathMode() == YES)
\r
1418 strcpy(Pkt.Cmd, "BACKCUR");
\r
1419 AskRemoteCurDir(Pkt.RemoteFile, FMAX_PATH);
\r
1420 AddTransFileList(&Pkt);
\r
1423 strcpy(Pkt.Cmd, "GOQUIT");
\r
1424 AddTransFileList(&Pkt);
\r
1427 EraseTmpTransFileList(&Base);
\r
1429 DeleteFileList(&LocalListBase);
\r
1430 DeleteFileList(&RemoteListBase);
\r
1432 GoForwardTransWindow();
\r
1441 /*----- ミラーリング時のホスト側のフォルダ削除 --------------------------------
\r
1444 * FILELIST *Base : ファイルリスト
\r
1445 * TRANSPACKET *Pkt :
\r
1446 * TRANSPACKET **Base :
\r
1450 *----------------------------------------------------------------------------*/
\r
1452 static void MirrorDeleteAllDir(FILELIST *Remote, TRANSPACKET *Pkt, TRANSPACKET **Base)
\r
1454 while(Remote != NULL)
\r
1456 if(Remote->Node == NODE_DIR)
\r
1458 MirrorDeleteAllDir(Remote->Next, Pkt, Base);
\r
1460 if(Remote->Attr == YES)
\r
1462 AskRemoteCurDir(Pkt->RemoteFile, FMAX_PATH);
\r
1463 SetSlashTail(Pkt->RemoteFile);
\r
1464 strcat(Pkt->RemoteFile, Remote->File);
\r
1465 ReplaceAll(Pkt->RemoteFile, '\\', '/');
\r
1466 strcpy(Pkt->LocalFile, "");
\r
1467 strcpy(Pkt->Cmd, "R-RMD ");
\r
1468 AddTmpTransFileList(Pkt, Base);
\r
1472 Remote = Remote->Next;
\r
1478 /*----- ミラーリングアップロード開始確認ウインドウのコールバック --------------
\r
1481 * HWND hDlg : ウインドウハンドル
\r
1482 * UINT message : メッセージ番号
\r
1483 * WPARAM wParam : メッセージの WPARAM 引数
\r
1484 * LPARAM lParam : メッセージの LPARAM 引数
\r
1488 *----------------------------------------------------------------------------*/
\r
1490 static BOOL CALLBACK MirrorNotifyCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
1496 case WM_INITDIALOG :
\r
1501 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
1504 EndDialog(hDlg, YES);
\r
1508 EndDialog(hDlg, NO);
\r
1511 case MIRRORUP_DISP :
\r
1512 EndDialog(hDlg, YES_LIST);
\r
1517 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000013);
\r
1519 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000012);
\r
1527 /*----- ミラーリングアップロード処理内容確認ウインドウのコールバック ----------
\r
1530 * HWND hDlg : ウインドウハンドル
\r
1531 * UINT message : メッセージ番号
\r
1532 * WPARAM wParam : メッセージの WPARAM 引数
\r
1533 * LPARAM lParam : メッセージの LPARAM 引数
\r
1537 *----------------------------------------------------------------------------*/
\r
1539 static BOOL CALLBACK MirrorDispListCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
1541 static DIALOGSIZE DlgSize = {
\r
1542 { MIRROR_DEL, MIRROR_SIZEGRIP, -1 },
\r
1543 { IDOK, IDCANCEL, IDHELP, MIRROR_DEL, MIRROR_COPYNUM, MIRROR_MAKENUM, MIRROR_DELNUM, MIRROR_SIZEGRIP, -1 },
\r
1544 { MIRROR_LIST, -1 },
\r
1549 static TRANSPACKET **Base;
\r
1551 char Tmp[FMAX_PATH+1+6];
\r
1557 case WM_INITDIALOG :
\r
1558 Base = (TRANSPACKET **)lParam;
\r
1560 while(Pos != NULL)
\r
1563 if((strncmp(Pos->Cmd, "R-DELE", 6) == 0) ||
\r
1564 (strncmp(Pos->Cmd, "R-RMD", 5) == 0))
\r
1565 sprintf(Tmp, MSGJPN052, Pos->RemoteFile);
\r
1566 else if(strncmp(Pos->Cmd, "R-MKD", 5) == 0)
\r
1567 sprintf(Tmp, MSGJPN053, Pos->RemoteFile);
\r
1568 else if(strncmp(Pos->Cmd, "STOR", 4) == 0)
\r
1569 sprintf(Tmp, MSGJPN054, Pos->RemoteFile);
\r
1570 else if((strncmp(Pos->Cmd, "L-DELE", 6) == 0) ||
\r
1571 (strncmp(Pos->Cmd, "L-RMD", 5) == 0))
\r
1572 sprintf(Tmp, MSGJPN055, Pos->LocalFile);
\r
1573 else if(strncmp(Pos->Cmd, "L-MKD", 5) == 0)
\r
1574 sprintf(Tmp, MSGJPN056, Pos->LocalFile);
\r
1575 else if(strncmp(Pos->Cmd, "RETR", 4) == 0)
\r
1576 sprintf(Tmp, MSGJPN057, Pos->LocalFile);
\r
1578 if(strlen(Tmp) > 0)
\r
1579 SendDlgItemMessage(hDlg, MIRROR_LIST, LB_ADDSTRING, 0, (LPARAM)Tmp);
\r
1582 CountMirrorFiles(hDlg, *Base);
\r
1583 DlgSizeInit(hDlg, &DlgSize, &MirrorDlgSize);
\r
1584 EnableWindow(GetDlgItem(hDlg, MIRROR_DEL), FALSE);
\r
1588 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
1591 AskDlgSize(hDlg, &DlgSize, &MirrorDlgSize);
\r
1592 EndDialog(hDlg, YES);
\r
1596 AskDlgSize(hDlg, &DlgSize, &MirrorDlgSize);
\r
1597 EndDialog(hDlg, NO);
\r
1601 Num = SendDlgItemMessage(hDlg, MIRROR_LIST, LB_GETSELCOUNT, 0, 0);
\r
1602 if((List = malloc(Num * sizeof(int))) != NULL)
\r
1604 Num = SendDlgItemMessage(hDlg, MIRROR_LIST, LB_GETSELITEMS, Num, (LPARAM)List);
\r
1605 for(Num--; Num >= 0; Num--)
\r
1607 if(RemoveTmpTransFileListItem(Base, List[Num]) == FFFTP_SUCCESS)
\r
1608 SendDlgItemMessage(hDlg, MIRROR_LIST, LB_DELETESTRING, List[Num], 0);
\r
1613 CountMirrorFiles(hDlg, *Base);
\r
1617 case MIRROR_LIST :
\r
1618 switch(GET_WM_COMMAND_CMD(wParam, lParam))
\r
1620 case LBN_SELCHANGE :
\r
1621 if(SendDlgItemMessage(hDlg, MIRROR_LIST, LB_GETSELCOUNT, 0, 0) > 0)
\r
1622 EnableWindow(GetDlgItem(hDlg, MIRROR_DEL), TRUE);
\r
1624 EnableWindow(GetDlgItem(hDlg, MIRROR_DEL), FALSE);
\r
1630 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000012);
\r
1635 DlgSizeChange(hDlg, &DlgSize, (RECT *)lParam, (int)wParam);
\r
1642 /*----- ミラーリングで転送/削除するファイルの数を数えダイアログに表示---------
\r
1646 * TRANSPACKET *Pkt :
\r
1650 *----------------------------------------------------------------------------*/
\r
1652 static void CountMirrorFiles(HWND hDlg, TRANSPACKET *Pkt)
\r
1662 while(Pkt != NULL)
\r
1664 if((strncmp(Pkt->Cmd, "R-DELE", 6) == 0) ||
\r
1665 (strncmp(Pkt->Cmd, "R-RMD", 5) == 0) ||
\r
1666 (strncmp(Pkt->Cmd, "L-DELE", 6) == 0) ||
\r
1667 (strncmp(Pkt->Cmd, "L-RMD", 5) == 0))
\r
1671 else if((strncmp(Pkt->Cmd, "R-MKD", 5) == 0) ||
\r
1672 (strncmp(Pkt->Cmd, "L-MKD", 5) == 0))
\r
1676 else if((strncmp(Pkt->Cmd, "STOR", 4) == 0) ||
\r
1677 (strncmp(Pkt->Cmd, "RETR", 4) == 0))
\r
1685 sprintf(Tmp, MSGJPN058, Copy);
\r
1687 sprintf(Tmp, MSGJPN059);
\r
1688 SendDlgItemMessage(hDlg, MIRROR_COPYNUM, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
1691 sprintf(Tmp, MSGJPN060, Make);
\r
1693 sprintf(Tmp, MSGJPN061);
\r
1694 SendDlgItemMessage(hDlg, MIRROR_MAKENUM, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
1697 sprintf(Tmp, MSGJPN062, Del);
\r
1699 sprintf(Tmp, MSGJPN063);
\r
1700 SendDlgItemMessage(hDlg, MIRROR_DELNUM, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
1708 /*----- ミラーリングで転送/削除しないファイルかどうかを返す ------------------
\r
1711 * char Fname : ファイル名
\r
1713 * 0=転送しないファイル, 1=削除しないファイル
\r
1718 *----------------------------------------------------------------------------*/
\r
1720 static int AskMirrorNoTrn(char *Fname, int Mode)
\r
1725 Tbl = MirrorNoTrn;
\r
1727 Tbl = MirrorNoDel;
\r
1730 if(StrMultiLen(Tbl) > 0)
\r
1732 Fname = GetFileName(Fname);
\r
1733 while(*Tbl != NUL)
\r
1735 if(CheckFname(Fname, Tbl) == FFFTP_SUCCESS)
\r
1740 Tbl += strlen(Tbl) + 1;
\r
1747 /*----- アップロードするファイルの属性を返す ----------------------------------
\r
1750 * char Fname : ファイル名
\r
1753 * int 属性 (-1=設定なし)
\r
1754 *----------------------------------------------------------------------------*/
\r
1756 static int AskUpLoadFileAttr(char *Fname)
\r
1762 Tbl = DefAttrList;
\r
1763 Fname = GetFileName(Fname);
\r
1765 while(*Tbl != NUL)
\r
1767 Sts = CheckFname(Fname, Tbl);
\r
1768 Tbl += strlen(Tbl) + 1;
\r
1770 if((Sts == FFFTP_SUCCESS) && (*Tbl != NUL))
\r
1775 Tbl += strlen(Tbl) + 1;
\r
1781 /*----- ホストに同じ名前のファイルがないかチェック- ---------------------------a
\r
1784 * TRANSPACKET *Pkt : 転送ファイル情報
\r
1785 * FILELIST *ListList :
\r
1789 * EXIST_OVW/EXIST_UNIQUE/EXIST_IGNORE
\r
1792 * Pkt.ExistSize, UpExistMode、ExistNotify が変更される
\r
1793 *----------------------------------------------------------------------------*/
\r
1795 static int CheckRemoteFile(TRANSPACKET *Pkt, FILELIST *ListList)
\r
1801 Pkt->ExistSize = 0;
\r
1802 if(SendMode != TRANS_OVW)
\r
1804 if((Exist = SearchFileList(GetFileName(Pkt->RemoteFile), ListList, COMP_STRICT)) != NULL)
\r
1806 Pkt->ExistSize = Exist->Size;
\r
1808 if(ExistNotify == YES)
\r
1810 SoundPlay(SND_ERROR);
\r
1811 if(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(up_exist_dlg), GetMainHwnd(), UpExistDialogCallBack, (LPARAM)Pkt) == NO)
\r
1812 Ret = EXIST_ABORT;
\r
1814 Ret = UpExistMode;
\r
1817 Ret = UpExistMode;
\r
1819 if(Ret == EXIST_NEW)
\r
1822 if(CompareFileTime(&Exist->Time, &Pkt->Time) < 0)
\r
1825 Ret = EXIST_IGNORE;
\r
1833 /*----- ホストに同じ名前のファイルがある時の確認ダイアログのコールバック ------
\r
1836 * HWND hDlg : ウインドウハンドル
\r
1837 * UINT message : メッセージ番号
\r
1838 * WPARAM wParam : メッセージの WPARAM 引数
\r
1839 * LPARAM lParam : メッセージの LPARAM 引数
\r
1843 *----------------------------------------------------------------------------*/
\r
1845 static BOOL CALLBACK UpExistDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
1847 static TRANSPACKET *Pkt;
\r
1848 static const RADIOBUTTON UpExistButton[] = {
\r
1849 { UP_EXIST_OVW, EXIST_OVW },
\r
1850 { UP_EXIST_NEW, EXIST_NEW },
\r
1851 { UP_EXIST_RESUME, EXIST_RESUME },
\r
1852 { UP_EXIST_UNIQUE, EXIST_UNIQUE },
\r
1853 { UP_EXIST_IGNORE, EXIST_IGNORE }
\r
1855 #define UPEXISTBUTTONS (sizeof(UpExistButton)/sizeof(RADIOBUTTON))
\r
1859 case WM_INITDIALOG :
\r
1860 Pkt = (TRANSPACKET *)lParam;
\r
1861 SendDlgItemMessage(hDlg, UP_EXIST_NAME, EM_LIMITTEXT, FMAX_PATH, 0);
\r
1862 SendDlgItemMessage(hDlg, UP_EXIST_NAME, WM_SETTEXT, 0, (LPARAM)Pkt->RemoteFile);
\r
1864 if((Pkt->Type == TYPE_A) || (Pkt->ExistSize <= 0))
\r
1865 EnableWindow(GetDlgItem(hDlg, UP_EXIST_RESUME), FALSE);
\r
1867 SetRadioButtonByValue(hDlg, UpExistMode, UpExistButton, UPEXISTBUTTONS);
\r
1871 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
1875 /* ここに break はない */
\r
1878 UpExistMode = AskRadioButtonValue(hDlg, UpExistButton, UPEXISTBUTTONS);
\r
1879 SendDlgItemMessage(hDlg, UP_EXIST_NAME, WM_GETTEXT, FMAX_PATH, (LPARAM)Pkt->RemoteFile);
\r
1880 EndDialog(hDlg, YES);
\r
1884 // Pkt->Abort = ABORT_USER;
\r
1885 // UpExistMode = EXIST_IGNORE;
\r
1886 EndDialog(hDlg, NO);
\r
1890 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000011);
\r
1899 /*----- アップロード/ダウンロードファイル名入力ダイアログのコールバック ------
\r
1902 * HWND hDlg : ウインドウハンドル
\r
1903 * UINT message : メッセージ番号
\r
1904 * WPARAM wParam : メッセージの WPARAM 引数
\r
1905 * LPARAM lParam : メッセージの LPARAM 引数
\r
1909 *----------------------------------------------------------------------------*/
\r
1911 static BOOL CALLBACK UpDownAsDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
1915 case WM_INITDIALOG :
\r
1916 if(CurWin == WIN_LOCAL)
\r
1917 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN064);
\r
1919 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN065);
\r
1921 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, EM_LIMITTEXT, FMAX_PATH, 0);
\r
1922 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
1923 SendDlgItemMessage(hDlg, UPDOWNAS_TEXT, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
1927 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
1930 SendDlgItemMessage(hDlg, UPDOWNAS_NEW, WM_GETTEXT, FMAX_PATH, (LPARAM)TmpString);
\r
1931 EndDialog(hDlg, YES);
\r
1934 case UPDOWNAS_STOP :
\r
1935 EndDialog(hDlg, NO_ALL);
\r
1944 /*----- ファイル一覧で指定されたファイルを削除する ----------------------------
\r
1951 *----------------------------------------------------------------------------*/
\r
1953 void DeleteProc(void)
\r
1956 FILELIST *FileListBase;
\r
1960 char CurDir[FMAX_PATH+1];
\r
1961 char Tmp[FMAX_PATH+1];
\r
1969 AskRemoteCurDir(CurDir, FMAX_PATH);
\r
1970 FileListBase = NULL;
\r
1971 if(GetFocus() == GetLocalHwnd())
\r
1974 MakeSelectedFileList(Win, NO, NO, &FileListBase, &CancelFlg);
\r
1979 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
1980 MakeSelectedFileList(Win, YES, NO, &FileListBase, &CancelFlg);
\r
1988 // DisableUserOpe();
\r
1992 Pos = FileListBase;
\r
1993 while(Pos != NULL)
\r
1995 if(Pos->Node == NODE_FILE)
\r
1997 DelNotifyAndDo(Pos, Win, &Sts, &DelFlg, CurDir);
\r
2005 DeleteAllDir(FileListBase, Win, &Sts, &DelFlg, CurDir);
\r
2007 if(Win == WIN_REMOTE)
\r
2009 AskRemoteCurDir(Tmp, FMAX_PATH);
\r
2010 if(strcmp(Tmp, CurDir) != 0)
\r
2011 DoCWD(Tmp, NO, NO, NO);
\r
2014 DeleteFileList(&FileListBase);
\r
2018 if(Win == WIN_LOCAL)
\r
2019 GetLocalDirForWnd();
\r
2021 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2025 // EnableUserOpe();
\r
2033 /*----- サブディレクトリ以下を全て削除する ------------------------------------
\r
2036 * FILELIST *Dt : 削除するファイルのリスト
\r
2037 * int Win : ウインドウ番号 (WIN_xxx)
\r
2038 * int *Sw : 操作方法 (YES/NO/YES_ALL/NO_ALL)
\r
2039 * int *Flg : ファイルを削除したかどうかのフラグ (YES/NO)
\r
2040 * char *CurDir : カレントディレクトリ
\r
2044 *----------------------------------------------------------------------------*/
\r
2046 static void DeleteAllDir(FILELIST *Dt, int Win, int *Sw, int *Flg, char *CurDir)
\r
2050 if(Dt->Node == NODE_DIR)
\r
2052 DeleteAllDir(Dt->Next, Win, Sw, Flg, CurDir);
\r
2056 DelNotifyAndDo(Dt, Win, Sw, Flg, CurDir);
\r
2065 /*----- 削除するかどうかの確認と削除実行 --------------------------------------
\r
2068 * FILELIST *Dt : 削除するファイルのリスト
\r
2069 * int Win : ウインドウ番号 (WIN_xxx)
\r
2070 * int *Sw : 操作方法 (YES/NO/YES_ALL/NO_ALL)
\r
2071 * int *Flg : ファイルを削除したかどうかのフラグ (YES/NO)
\r
2072 * char *CurDir : カレントディレクトリ
\r
2076 *----------------------------------------------------------------------------*/
\r
2078 static void DelNotifyAndDo(FILELIST *Dt, int Win, int *Sw, int *Flg, char *CurDir)
\r
2080 char Path[FMAX_PATH+1];
\r
2082 if(Win == WIN_LOCAL)
\r
2084 AskLocalCurDir(Path, FMAX_PATH);
\r
2086 strcat(Path, Dt->File);
\r
2087 ReplaceAll(Path, '/', '\\');
\r
2091 AskRemoteCurDir(Path, FMAX_PATH);
\r
2092 SetSlashTail(Path);
\r
2093 strcat(Path, Dt->File);
\r
2094 ReplaceAll(Path, '\\', '/');
\r
2097 if(*Sw != YES_ALL)
\r
2099 sprintf(TmpString, "%s", Path);
\r
2101 if(AskHostType() == HTYPE_VMS)
\r
2102 ReformToVMSstylePathName(TmpString);
\r
2105 *Sw = DialogBox(GetFtpInst(), MAKEINTRESOURCE(delete_dlg), GetMainHwnd(), DeleteDialogCallBack);
\r
2108 if((*Sw == YES) || (*Sw == YES_ALL))
\r
2110 if(Win == WIN_LOCAL)
\r
2112 if(Dt->Node == NODE_FILE)
\r
2113 DoLocalDELE(Path);
\r
2120 /* フルパスを使わない時のための処理 */
\r
2122 // if(ProcForNonFullpath(Path, CurDir, GetMainHwnd(), 0) == FFFTP_FAIL)
\r
2123 if(ProcForNonFullpath(AskCmdCtrlSkt(), Path, CurDir, GetMainHwnd(), &CancelFlg) == FFFTP_FAIL)
\r
2128 if(Dt->Node == NODE_FILE)
\r
2140 /*----- ファイル削除ダイアログのコールバック ----------------------------------
\r
2143 * HWND hDlg : ウインドウハンドル
\r
2144 * UINT message : メッセージ番号
\r
2145 * WPARAM wParam : メッセージの WPARAM 引数
\r
2146 * LPARAM lParam : メッセージの LPARAM 引数
\r
2150 *----------------------------------------------------------------------------*/
\r
2152 static BOOL CALLBACK DeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2156 case WM_INITDIALOG :
\r
2157 if(CurWin == WIN_LOCAL)
\r
2158 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN066);
\r
2160 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN067);
\r
2161 SendDlgItemMessage(hDlg, DELETE_TEXT, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2165 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2168 EndDialog(hDlg, YES);
\r
2172 EndDialog(hDlg, NO);
\r
2176 EndDialog(hDlg, YES_ALL);
\r
2180 EndDialog(hDlg, NO_ALL);
\r
2189 /*----- ファイル一覧で指定されたファイルの名前を変更する ----------------------
\r
2196 *----------------------------------------------------------------------------*/
\r
2198 void RenameProc(void)
\r
2201 FILELIST *FileListBase;
\r
2203 char New[FMAX_PATH+1];
\r
2210 Sts = FFFTP_SUCCESS;
\r
2211 if(GetFocus() == GetLocalHwnd())
\r
2216 Sts = CheckClosedAndReconnect();
\r
2219 if(Sts == FFFTP_SUCCESS)
\r
2223 FileListBase = NULL;
\r
2224 MakeSelectedFileList(Win, NO, NO, &FileListBase, &CancelFlg);
\r
2228 Pos = FileListBase;
\r
2229 while(Pos != NULL)
\r
2231 if((Pos->Node == NODE_FILE) || (Pos->Node == NODE_DIR))
\r
2233 strcpy(TmpString, Pos->File);
\r
2235 Sts = DialogBox(GetFtpInst(), MAKEINTRESOURCE(rename_dlg), GetMainHwnd(), RenameDialogCallBack);
\r
2240 if((Sts == YES) && (strlen(TmpString) != 0))
\r
2242 strcpy(New, TmpString);
\r
2243 if(Win == WIN_LOCAL)
\r
2244 DoLocalRENAME(Pos->File, New);
\r
2246 DoRENAME(Pos->File, New);
\r
2252 DeleteFileList(&FileListBase);
\r
2256 if(Win == WIN_LOCAL)
\r
2257 GetLocalDirForWnd();
\r
2259 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2269 // リモート側でのファイルの移動(リネーム)を行う
\r
2271 // RenameProc()をベースに改造。(2007.9.5 yutaka)
\r
2273 void MoveRemoteFileProc(int drop_index)
\r
2276 FILELIST *FileListBase;
\r
2279 char New[FMAX_PATH+1];
\r
2280 char Old[FMAX_PATH+1];
\r
2281 char HostDir[FMAX_PATH+1];
\r
2288 if(MoveMode == MOVE_DISABLE)
\r
2293 AskRemoteCurDir(HostDir, FMAX_PATH);
\r
2296 GetNodeName(WIN_REMOTE, drop_index, Pkt.File, FMAX_PATH);
\r
2298 if(MoveMode == MOVE_DLG)
\r
2300 if(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(move_notify_dlg), GetRemoteHwnd(), ExeEscTextDialogProc, (LPARAM)Pkt.File) == NO)
\r
2306 Sts = FFFTP_SUCCESS;
\r
2308 if(GetFocus() == GetLocalHwnd())
\r
2313 Sts = CheckClosedAndReconnect();
\r
2317 Sts = CheckClosedAndReconnect();
\r
2320 if(Sts == FFFTP_SUCCESS)
\r
2324 FileListBase = NULL;
\r
2325 MakeSelectedFileList(Win, NO, NO, &FileListBase, &CancelFlg);
\r
2329 Pos = FileListBase;
\r
2330 while(Pos != NULL)
\r
2332 if((Pos->Node == NODE_FILE) || (Pos->Node == NODE_DIR))
\r
2334 strcpy(TmpString, Pos->File);
\r
2337 Sts = DialogBox(GetFtpInst(), MAKEINTRESOURCE(rename_dlg), GetMainHwnd(), RenameDialogCallBack);
\r
2345 if((Sts == YES) && (strlen(TmpString) != 0))
\r
2348 strncpy_s(Old, sizeof(Old), HostDir, _TRUNCATE);
\r
2349 strncat_s(Old, sizeof(Old), "/", _TRUNCATE);
\r
2350 strncat_s(Old, sizeof(Old), Pos->File, _TRUNCATE);
\r
2353 strncpy_s(New, sizeof(New), HostDir, _TRUNCATE);
\r
2354 strncat_s(New, sizeof(New), "/", _TRUNCATE);
\r
2355 strncat_s(New, sizeof(New), Pkt.File, _TRUNCATE);
\r
2356 strncat_s(New, sizeof(New), "/", _TRUNCATE);
\r
2357 strncat_s(New, sizeof(New), Pos->File, _TRUNCATE);
\r
2359 if(Win == WIN_LOCAL)
\r
2360 DoLocalRENAME(Old, New);
\r
2362 DoRENAME(Old, New);
\r
2368 DeleteFileList(&FileListBase);
\r
2372 if(Win == WIN_LOCAL) {
\r
2373 GetLocalDirForWnd();
\r
2375 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2377 strncpy_s(New, sizeof(New), HostDir, _TRUNCATE);
\r
2378 strncat_s(New, sizeof(New), "/", _TRUNCATE);
\r
2379 strncat_s(New, sizeof(New), Pkt.File, _TRUNCATE);
\r
2380 DoCWD(New, YES, YES, YES);
\r
2381 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2392 /*----- 新ファイル名入力ダイアログのコールバック ------------------------------
\r
2395 * HWND hDlg : ウインドウハンドル
\r
2396 * UINT message : メッセージ番号
\r
2397 * WPARAM wParam : メッセージの WPARAM 引数
\r
2398 * LPARAM lParam : メッセージの LPARAM 引数
\r
2402 *----------------------------------------------------------------------------*/
\r
2404 static BOOL CALLBACK RenameDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2408 case WM_INITDIALOG :
\r
2409 if(CurWin == WIN_LOCAL)
\r
2410 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN068);
\r
2412 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN069);
\r
2413 SendDlgItemMessage(hDlg, RENAME_NEW, EM_LIMITTEXT, FMAX_PATH, 0);
\r
2414 SendDlgItemMessage(hDlg, RENAME_NEW, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2415 SendDlgItemMessage(hDlg, RENAME_TEXT, WM_SETTEXT, 0, (LPARAM)TmpString);
\r
2419 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2422 SendDlgItemMessage(hDlg, RENAME_NEW, WM_GETTEXT, FMAX_PATH, (LPARAM)TmpString);
\r
2423 EndDialog(hDlg, YES);
\r
2427 EndDialog(hDlg, NO);
\r
2430 case RENAME_STOP :
\r
2431 EndDialog(hDlg, NO_ALL);
\r
2440 /*----- 新しいディレクトリを作成する ------------------------------------------
\r
2447 *----------------------------------------------------------------------------*/
\r
2449 void MkdirProc(void)
\r
2453 char Path[FMAX_PATH+1];
\r
2460 if(GetFocus() == GetLocalHwnd())
\r
2463 Title = MSGJPN070;
\r
2468 Title = MSGJPN071;
\r
2472 Sts = InputDialogBox(mkdir_dlg, GetMainHwnd(), Title, Path, FMAX_PATH+1, &Tmp, IDH_HELP_TOPIC_0000001);
\r
2474 if((Sts == YES) && (strlen(Path) != 0))
\r
2476 if(Win == WIN_LOCAL)
\r
2480 GetLocalDirForWnd();
\r
2485 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2489 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2498 /*----- ヒストリリストを使ったディレクトリの移動 ------------------------------
\r
2501 * HWND hWnd : コンボボックスのウインドウハンドル
\r
2505 *----------------------------------------------------------------------------*/
\r
2507 void ChangeDirComboProc(HWND hWnd)
\r
2509 char Tmp[FMAX_PATH+1];
\r
2515 if((i = SendMessage(hWnd, CB_GETCURSEL, 0, 0)) != CB_ERR)
\r
2517 SendMessage(hWnd, CB_GETLBTEXT, i, (LPARAM)Tmp);
\r
2519 if(hWnd == GetLocalHistHwnd())
\r
2523 GetLocalDirForWnd();
\r
2528 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2531 if(DoCWD(Tmp, YES, NO, YES) < FTP_RETRY)
\r
2532 GetRemoteDirForWnd(CACHE_NORMAL, &CancelFlg);
\r
2541 /*----- ブックマークを使ったディレクトリの移動 --------------------------------
\r
2544 * int MarkID : ブックマークのメニューID
\r
2548 *----------------------------------------------------------------------------*/
\r
2550 void ChangeDirBmarkProc(int MarkID)
\r
2552 char Local[FMAX_PATH+1];
\r
2553 char Remote[FMAX_PATH+1];
\r
2559 Sts = AskBookMarkText(MarkID, Local, Remote, FMAX_PATH+1);
\r
2560 if((Sts == BMARK_TYPE_LOCAL) || (Sts == BMARK_TYPE_BOTH))
\r
2563 if(DoLocalCWD(Local) == FFFTP_SUCCESS)
\r
2564 GetLocalDirForWnd();
\r
2568 if((Sts == BMARK_TYPE_REMOTE) || (Sts == BMARK_TYPE_BOTH))
\r
2570 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2573 if(DoCWD(Remote, YES, NO, YES) < FTP_RETRY)
\r
2574 GetRemoteDirForWnd(CACHE_NORMAL, &CancelFlg);
\r
2582 /*----- ディレクトリ名を入力してディレクトリの移動 ----------------------------
\r
2585 * int Win : ウインドウ番号 (WIN_xxx)
\r
2589 *----------------------------------------------------------------------------*/
\r
2591 void ChangeDirDirectProc(int Win)
\r
2594 char Path[FMAX_PATH+1];
\r
2601 if(Win == WIN_LOCAL)
\r
2602 Title = MSGJPN072;
\r
2604 Title = MSGJPN073;
\r
2607 if(Win == WIN_LOCAL)
\r
2608 Sts = InputDialogBox(chdir_br_dlg, GetMainHwnd(), Title, Path, FMAX_PATH+1, &Tmp, IDH_HELP_TOPIC_0000001);
\r
2610 Sts = InputDialogBox(chdir_dlg, GetMainHwnd(), Title, Path, FMAX_PATH+1, &Tmp, IDH_HELP_TOPIC_0000001);
\r
2612 if((Sts == YES) && (strlen(Path) != 0))
\r
2614 if(Win == WIN_LOCAL)
\r
2618 GetLocalDirForWnd();
\r
2623 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2626 if(DoCWD(Path, YES, NO, YES) < FTP_RETRY)
\r
2627 GetRemoteDirForWnd(CACHE_NORMAL, &CancelFlg);
\r
2636 /*----- Dropされたファイルによるディレクトリの移動 ----------------------------
\r
2639 * WPARAM wParam : ドロップされたファイルの情報
\r
2643 *----------------------------------------------------------------------------*/
\r
2645 void ChangeDirDropFileProc(WPARAM wParam)
\r
2647 char Path[FMAX_PATH+1];
\r
2650 MakeDroppedDir(wParam, Path);
\r
2652 GetLocalDirForWnd();
\r
2658 /*----- ファイルの属性変更 ----------------------------------------------------
\r
2665 *----------------------------------------------------------------------------*/
\r
2667 void ChmodProc(void)
\r
2670 FILELIST *FileListBase;
\r
2680 if(GetFocus() == GetRemoteHwnd())
\r
2682 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2685 FileListBase = NULL;
\r
2686 MakeSelectedFileList(WIN_REMOTE, NO, NO, &FileListBase, &CancelFlg);
\r
2687 if(FileListBase != NULL)
\r
2689 sprintf(Tmp, "%03X", FileListBase->Attr);
\r
2690 if(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(chmod_dlg), GetMainHwnd(), ChmodDialogCallBack, (LPARAM)Tmp) == YES)
\r
2693 Pos = FileListBase;
\r
2694 while(Pos != NULL)
\r
2696 if((Pos->Node == NODE_FILE) || (Pos->Node == NODE_DIR))
\r
2698 DoCHMOD(Pos->File, Tmp);
\r
2703 if(ChmodFlg == YES)
\r
2704 GetRemoteDirForWnd(CACHE_REFRESH, &CancelFlg);
\r
2707 DeleteFileList(&FileListBase);
\r
2711 else if(GetFocus() == GetLocalHwnd())
\r
2714 FileListBase = NULL;
\r
2715 MakeSelectedFileList(WIN_LOCAL, NO, NO, &FileListBase, &CancelFlg);
\r
2716 if(FileListBase != NULL)
\r
2718 if((Buf = malloc(1)) != NULL)
\r
2722 Pos = FileListBase;
\r
2723 while(Pos != NULL)
\r
2725 if((BufTmp = realloc(Buf, BufLen + strlen(Pos->File) + 2)) != NULL)
\r
2728 strcpy(Buf+BufLen, Pos->File);
\r
2729 BufLen += strlen(Pos->File) + 1;
\r
2734 memset(Buf+BufLen, NUL, 1);
\r
2735 DispFileProperty(Buf);
\r
2739 DeleteFileList(&FileListBase);
\r
2746 /*----- 属性変更ダイアログのコールバック --------------------------------------
\r
2749 * HWND hDlg : ウインドウハンドル
\r
2750 * UINT message : メッセージ番号
\r
2751 * WPARAM wParam : メッセージの WPARAM 引数
\r
2752 * LPARAM lParam : メッセージの LPARAM 引数
\r
2756 *----------------------------------------------------------------------------*/
\r
2758 BOOL CALLBACK ChmodDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2766 case WM_INITDIALOG :
\r
2767 Buf = (char *)lParam;
\r
2768 SendDlgItemMessage(hDlg, PERM_NOW, EM_LIMITTEXT, 4, 0);
\r
2769 SendDlgItemMessage(hDlg, PERM_NOW, WM_SETTEXT, 0, (LPARAM)Buf);
\r
2770 SetAttrToDialog(hDlg, xtoi(Buf));
\r
2774 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2777 SendDlgItemMessage(hDlg, PERM_NOW, WM_GETTEXT, 5, (LPARAM)Buf);
\r
2778 EndDialog(hDlg, YES);
\r
2782 EndDialog(hDlg, NO);
\r
2785 case PERM_O_READ :
\r
2786 case PERM_O_WRITE :
\r
2787 case PERM_O_EXEC :
\r
2788 case PERM_G_READ :
\r
2789 case PERM_G_WRITE :
\r
2790 case PERM_G_EXEC :
\r
2791 case PERM_A_READ :
\r
2792 case PERM_A_WRITE :
\r
2793 case PERM_A_EXEC :
\r
2794 Tmp = GetAttrFromDialog(hDlg);
\r
2795 sprintf(Str, "%03X", Tmp);
\r
2796 SendDlgItemMessage(hDlg, PERM_NOW, WM_SETTEXT, 0, (LPARAM)Str);
\r
2800 hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000017);
\r
2809 /*----- 属性をダイアログボックスに設定 ----------------------------------------
\r
2812 * HWND hWnd : ダイアログボックスのウインドウハンドル
\r
2817 *----------------------------------------------------------------------------*/
\r
2819 static void SetAttrToDialog(HWND hDlg, int Attr)
\r
2822 SendDlgItemMessage(hDlg, PERM_O_READ, BM_SETCHECK, 1, 0);
\r
2824 SendDlgItemMessage(hDlg, PERM_O_WRITE, BM_SETCHECK, 1, 0);
\r
2826 SendDlgItemMessage(hDlg, PERM_O_EXEC, BM_SETCHECK, 1, 0);
\r
2829 SendDlgItemMessage(hDlg, PERM_G_READ, BM_SETCHECK, 1, 0);
\r
2831 SendDlgItemMessage(hDlg, PERM_G_WRITE, BM_SETCHECK, 1, 0);
\r
2833 SendDlgItemMessage(hDlg, PERM_G_EXEC, BM_SETCHECK, 1, 0);
\r
2836 SendDlgItemMessage(hDlg, PERM_A_READ, BM_SETCHECK, 1, 0);
\r
2838 SendDlgItemMessage(hDlg, PERM_A_WRITE, BM_SETCHECK, 1, 0);
\r
2840 SendDlgItemMessage(hDlg, PERM_A_EXEC, BM_SETCHECK, 1, 0);
\r
2846 /*----- ダイアログボックスの内容から属性を取得 --------------------------------
\r
2849 * HWND hWnd : ダイアログボックスのウインドウハンドル
\r
2853 *----------------------------------------------------------------------------*/
\r
2855 static int GetAttrFromDialog(HWND hDlg)
\r
2861 if(SendDlgItemMessage(hDlg, PERM_O_READ, BM_GETCHECK, 0, 0) == 1)
\r
2863 if(SendDlgItemMessage(hDlg, PERM_O_WRITE, BM_GETCHECK, 0, 0) == 1)
\r
2865 if(SendDlgItemMessage(hDlg, PERM_O_EXEC, BM_GETCHECK, 0, 0) == 1)
\r
2868 if(SendDlgItemMessage(hDlg, PERM_G_READ, BM_GETCHECK, 0, 0) == 1)
\r
2870 if(SendDlgItemMessage(hDlg, PERM_G_WRITE, BM_GETCHECK, 0, 0) == 1)
\r
2872 if(SendDlgItemMessage(hDlg, PERM_G_EXEC, BM_GETCHECK, 0, 0) == 1)
\r
2875 if(SendDlgItemMessage(hDlg, PERM_A_READ, BM_GETCHECK, 0, 0) == 1)
\r
2877 if(SendDlgItemMessage(hDlg, PERM_A_WRITE, BM_GETCHECK, 0, 0) == 1)
\r
2879 if(SendDlgItemMessage(hDlg, PERM_A_EXEC, BM_GETCHECK, 0, 0) == 1)
\r
2888 /*----- 任意のコマンドを送る --------------------------------------------------
\r
2895 *----------------------------------------------------------------------------*/
\r
2897 void SomeCmdProc(void)
\r
2901 FILELIST *FileListBase;
\r
2906 if(GetFocus() == GetRemoteHwnd())
\r
2908 if(CheckClosedAndReconnect() == FFFTP_SUCCESS)
\r
2911 FileListBase = NULL;
\r
2912 MakeSelectedFileList(WIN_REMOTE, NO, NO, &FileListBase, &CancelFlg);
\r
2913 memset(Cmd, NUL, 81);
\r
2914 if(FileListBase != NULL)
\r
2916 strncpy(Cmd, FileListBase->File, 80);
\r
2918 DeleteFileList(&FileListBase);
\r
2920 if(InputDialogBox(somecmd_dlg, GetMainHwnd(), NULL, Cmd, 81, &Tmp, IDH_HELP_TOPIC_0000023) == YES)
\r
2933 /*----- ファイル総容量の計算を行う --------------------------------------------
\r
2940 *----------------------------------------------------------------------------*/
\r
2942 void CalcFileSizeProc(void)
\r
2944 FILELIST *ListBase;
\r
2953 if((All = DialogBox(GetFtpInst(), MAKEINTRESOURCE(filesize_notify_dlg), GetMainHwnd(), SizeNotifyDlgWndProc)) != NO_ALL)
\r
2955 Sts = FFFTP_SUCCESS;
\r
2956 if(GetFocus() == GetLocalHwnd())
\r
2961 Sts = CheckClosedAndReconnect();
\r
2964 if(Sts == FFFTP_SUCCESS)
\r
2967 MakeSelectedFileList(Win, YES, All, &ListBase, &CancelFlg);
\r
2971 while(Pos != NULL)
\r
2973 if(Pos->Node != NODE_DIR)
\r
2974 FileSize += Pos->Size;
\r
2977 DeleteFileList(&ListBase);
\r
2978 DialogBox(GetFtpInst(), MAKEINTRESOURCE(filesize_dlg), GetMainHwnd(), SizeDlgWndProc);
\r
2985 /*----- ファイル容量検索確認ダイアログのコールバック --------------------------
\r
2988 * HWND hDlg : ウインドウハンドル
\r
2989 * UINT message : メッセージ番号
\r
2990 * WPARAM wParam : メッセージの WPARAM 引数
\r
2991 * LPARAM lParam : メッセージの LPARAM 引数
\r
2995 *----------------------------------------------------------------------------*/
\r
2997 static LRESULT CALLBACK SizeNotifyDlgWndProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
\r
3001 case WM_INITDIALOG :
\r
3002 if(GetFocus() == GetLocalHwnd())
\r
3003 SendDlgItemMessage(hDlg, FSNOTIFY_TITLE, WM_SETTEXT, 0, (LPARAM)MSGJPN074);
\r
3005 SendDlgItemMessage(hDlg, FSNOTIFY_TITLE, WM_SETTEXT, 0, (LPARAM)MSGJPN075);
\r
3009 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
3012 if(SendDlgItemMessage(hDlg, FSNOTIFY_SEL_ONLY, BM_GETCHECK, 0, 0) == 1)
\r
3013 EndDialog(hDlg, NO);
\r
3015 EndDialog(hDlg, YES);
\r
3019 EndDialog(hDlg, NO_ALL);
\r
3028 /*----- ファイル容量検索ダイアログのコールバック ------------------------------
\r
3031 * HWND hDlg : ウインドウハンドル
\r
3032 * UINT message : メッセージ番号
\r
3033 * WPARAM wParam : メッセージの WPARAM 引数
\r
3034 * LPARAM lParam : メッセージの LPARAM 引数
\r
3038 *----------------------------------------------------------------------------*/
\r
3040 static LRESULT CALLBACK SizeDlgWndProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
\r
3042 char Tmp[FMAX_PATH+1];
\r
3046 case WM_INITDIALOG :
\r
3047 if(GetFocus() == GetLocalHwnd())
\r
3048 SendDlgItemMessage(hDlg, FSIZE_TITLE, WM_SETTEXT, 0, (LPARAM)MSGJPN076);
\r
3050 SendDlgItemMessage(hDlg, FSIZE_TITLE, WM_SETTEXT, 0, (LPARAM)MSGJPN077);
\r
3052 MakeSizeString(FileSize, Tmp);
\r
3053 SendDlgItemMessage(hDlg, FSIZE_SIZE, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
3057 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
3061 EndDialog(hDlg, YES);
\r
3071 /*----- ディレクトリ移動失敗時のエラーを表示 ----------------------------------
\r
3074 * HWND hDlg : ウインドウハンドル
\r
3078 *----------------------------------------------------------------------------*/
\r
3080 void DispCWDerror(HWND hWnd)
\r
3082 DialogBox(GetFtpInst(), MAKEINTRESOURCE(cwderr_dlg), hWnd, ExeEscDialogProc);
\r
3087 /*----- URLをクリップボードにコピー -------------------------------------------
\r
3094 *----------------------------------------------------------------------------*/
\r
3096 void CopyURLtoClipBoard(void)
\r
3098 FILELIST *FileListBase;
\r
3101 char Path[FMAX_PATH+1];
\r
3102 char Host[HOST_ADRS_LEN+1];
\r
3107 if(GetFocus() == GetRemoteHwnd())
\r
3109 FileListBase = NULL;
\r
3110 MakeSelectedFileList(WIN_REMOTE, NO, NO, &FileListBase, &CancelFlg);
\r
3111 if(FileListBase != NULL)
\r
3113 strcpy(Host, AskHostAdrs());
\r
3116 Pos = FileListBase;
\r
3117 while(Pos != NULL)
\r
3119 AskRemoteCurDir(Path, FMAX_PATH);
\r
3120 SetSlashTail(Path);
\r
3121 strcat(Path, Pos->File);
\r
3123 if(AskHostType() == HTYPE_VMS)
\r
3124 ReformToVMSstylePathName(Path);
\r
3127 if(AskHostPort() != PORT_NOR)
\r
3128 sprintf(Port, ":%d", AskHostPort());
\r
3131 Total += strlen(Path) + strlen(Host) + strlen(Port) + 8; /* 8は "ftp://\r\n" のぶん */
\r
3132 if(AskHostType() == HTYPE_VMS)
\r
3135 if((Buf = realloc(Buf, Total+1)) == NULL)
\r
3138 if(AskHostType() != HTYPE_VMS)
\r
3139 sprintf(Buf + Set, "ftp://%s%s%s\r\n", Host, Port, Path);
\r
3141 sprintf(Buf + Set, "ftp://%s%s/%s\r\n", Host, Port, Path);
\r
3148 CopyStrToClipBoard(Buf);
\r
3152 DeleteFileList(&FileListBase);
\r
3158 /*----- フルパスを使わないファイルアクセスの準備 ------------------------------
\r
3161 * char *Path : パス名
\r
3162 * char *CurDir : カレントディレクトリ
\r
3163 * HWND hWnd : エラーウインドウを表示する際の親ウインドウ
\r
3164 * int Type : 使用するソケットの種類
\r
3165 * 0=コマンドソケット, 1=転送ソケット
\r
3168 * int ステータス(FFFTP_SUCCESS/FFFTP_FAIL)
\r
3172 * このモジュール内で CWD を行ない、
\r
3173 * Path にファイル名のみ残す。(パス名は消す)
\r
3174 *----------------------------------------------------------------------------*/
\r
3177 //int ProcForNonFullpath(char *Path, char *CurDir, HWND hWnd, int Type)
\r
3178 int ProcForNonFullpath(SOCKET cSkt, char *Path, char *CurDir, HWND hWnd, int *CancelCheckWork)
\r
3182 char Tmp[FMAX_PATH+1];
\r
3184 Sts = FFFTP_SUCCESS;
\r
3185 if(AskNoFullPathMode() == YES)
\r
3187 strcpy(Tmp, Path);
\r
3188 if(AskHostType() == HTYPE_VMS)
\r
3190 GetUpperDirEraseTopSlash(Tmp);
\r
3191 ReformToVMSstyleDirName(Tmp);
\r
3193 else if(AskHostType() == HTYPE_STRATUS)
\r
3194 GetUpperDirEraseTopSlash(Tmp);
\r
3198 if(strcmp(Tmp, CurDir) != 0)
\r
3202 // Cmd = CommandProcCmd(NULL, "CWD %s", Tmp);
\r
3204 // Cmd = CommandProcTrn(NULL, "CWD %s", Tmp);
\r
3205 Cmd = CommandProcTrn(cSkt, NULL, CancelCheckWork, "CWD %s", Tmp);
\r
3207 if(Cmd/100 != FTP_COMPLETE)
\r
3209 DispCWDerror(hWnd);
\r
3213 strcpy(CurDir, Tmp);
\r
3215 strcpy(Path, GetFileName(Path));
\r
3221 /*----- ディレクトリ名をVAX VMSスタイルに変換する -----------------------------
\r
3224 * char *Path : パス名
\r
3230 * ddd:[xxx.yyy]/rrr/ppp --> ddd:[xxx.yyy.rrr.ppp]
\r
3231 *----------------------------------------------------------------------------*/
\r
3233 void ReformToVMSstyleDirName(char *Path)
\r
3238 if((Btm = strchr(Path, ']')) != NULL)
\r
3241 while((Pos = strchr(Pos, '/')) != NULL)
\r
3244 memmove(Btm, Btm+1, strlen(Btm+1)+1);
\r
3245 Pos = strchr(Path, NUL);
\r
3246 if(*(Pos-1) == '.')
\r
3257 /*----- ファイル名をVAX VMSスタイルに変換する ---------------------------------
\r
3260 * char *Path : パス名
\r
3266 * ddd:[xxx.yyy]/rrr/ppp --> ddd:[xxx.yyy.rrr]ppp
\r
3267 *----------------------------------------------------------------------------*/
\r
3269 void ReformToVMSstylePathName(char *Path)
\r
3271 char Fname[FMAX_PATH+1];
\r
3273 strcpy(Fname, GetFileName(Path));
\r
3275 GetUpperDirEraseTopSlash(Path);
\r
3276 ReformToVMSstyleDirName(Path);
\r
3278 strcat(Path, Fname);
\r
3284 #if defined(HAVE_OPENVMS)
\r
3285 /*----- VMSの"HOGE.DIR;?"というディレクトリ名から"HOGE"を取り出す ---------------
\r
3288 * char *DirName : "HOGE.DIR;?"形式のディレクトリ名
\r
3289 * int Flg : ";"のチェックをする(TRUE)かしない(FALSE)か
\r
3296 *----------------------------------------------------------------------------*/
\r
3298 void ReformVMSDirName(char *DirName, int Flg)
\r
3302 if (Flg == TRUE) {
\r
3303 /* ';'がない場合はVMS形式じゃなさそうなので何もしない */
\r
3304 if ((p = strrchr(DirName, ';')) == NULL)
\r
3308 /* ".DIR"があったらつぶす */
\r
3309 if ((p = strrchr(DirName, '.'))) {
\r
3310 if (memcmp(p + 1, "DIR", 3) == 0)
\r
3317 /*----- ファイル名に使えない文字がないかチェックし名前を変更する --------------
\r
3320 * char *Fname : ファイル名
\r
3324 * FFFTP_SUCCESS/FFFTP_FAIL=中止する
\r
3328 *----------------------------------------------------------------------------*/
\r
3330 static int RenameUnuseableName(char *Fname)
\r
3335 Ret = FFFTP_SUCCESS;
\r
3338 if((_mbschr(Fname, ':') != NULL) ||
\r
3339 (_mbschr(Fname, '*') != NULL) ||
\r
3340 (_mbschr(Fname, '?') != NULL) ||
\r
3341 (_mbschr(Fname, '<') != NULL) ||
\r
3342 (_mbschr(Fname, '>') != NULL) ||
\r
3343 (_mbschr(Fname, '|') != NULL) ||
\r
3344 (_mbschr(Fname, '\x22') != NULL) ||
\r
3345 (_mbschr(Fname, '\\') != NULL))
\r
3347 if(InputDialogBox(forcerename_dlg, GetMainHwnd(), NULL, Fname, FMAX_PATH+1, &Tmp, IDH_HELP_TOPIC_0000001) == NO)
\r