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
30 /* このソースは一部、WS_FTP Version 93.12.05 のソースを参考にしました。 */
\r
31 /* スレッドの作成/終了に関して、樋口殿作成のパッチを組み込みました。 */
\r
34 一部、高速化のためのコード追加 by H.Shirouzu at 2002/10/02
\r
42 #include <mbstring.h>
\r
44 #include <winsock.h>
\r
45 #include <windowsx.h>
\r
46 #include <commctrl.h>
\r
47 #include <process.h>
\r
50 #include "resource.h"
\r
52 #define SET_BUFFER_SIZE
\r
54 /* Add by H.Shirouzu at 2002/10/02 */
\r
56 #define BUFSIZE (32 * 1024)
\r
57 #define SOCKBUF_SIZE (256 * 1024)
\r
60 #ifdef DISABLE_TRANSFER_NETWORK_BUFFERS
\r
62 #define BUFSIZE (64 * 1024) // RWIN値以下で充分な大きさが望ましいと思われる。
\r
63 #undef SET_BUFFER_SIZE
\r
66 #define TIMER_DISPLAY 1 /* 表示更新用タイマのID */
\r
67 #define DISPLAY_TIMING 500 /* 表示更新時間 0.5秒 */
\r
69 #define ERR_MSG_LEN 1024
\r
79 /*===== プロトタイプ =====*/
\r
81 static void DispTransPacket(TRANSPACKET *Pkt);
\r
82 static void EraseTransFileList(void);
\r
83 static ULONG WINAPI TransferThread(void *Dummy);
\r
84 static int MakeNonFullPath(TRANSPACKET *Pkt, char *CurDir, char *Tmp);
\r
85 static int DownLoadNonPassive(TRANSPACKET *Pkt, int *CancelCheckWork);
\r
86 static int DownLoadPassive(TRANSPACKET *Pkt, int *CancelCheckWork);
\r
87 static int DownLoadFile(TRANSPACKET *Pkt, SOCKET dSkt, int CreateMode, int *CancelCheckWork);
\r
88 static void DispDownloadFinishMsg(TRANSPACKET *Pkt, int iRetCode);
\r
89 static int DispUpDownErrDialog(int ResID, HWND hWnd, char *Fname);
\r
90 static BOOL CALLBACK UpDownErrorDialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam);
\r
91 static int SetDownloadResume(TRANSPACKET *Pkt, int ProcMode, LONGLONG Size, int *Mode, int *CancelCheckWork);
\r
92 static BOOL CALLBACK NoResumeWndProc(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
93 static int DoUpLoad(SOCKET cSkt, TRANSPACKET *Pkt);
\r
94 static int UpLoadNonPassive(TRANSPACKET *Pkt);
\r
95 static int UpLoadPassive(TRANSPACKET *Pkt);
\r
96 static int UpLoadFile(TRANSPACKET *Pkt, SOCKET dSkt);
\r
98 //static int TermCodeConvAndSend(TERMCODECONVINFO *tInfo, SOCKET Skt, char *Data, int Size, int Ascii);
\r
99 static int TermCodeConvAndSend(int ThreadCount, TERMCODECONVINFO *tInfo, SOCKET Skt, char *Data, int Size, int Ascii);
\r
100 static void DispUploadFinishMsg(TRANSPACKET *Pkt, int iRetCode);
\r
101 static int SetUploadResume(TRANSPACKET *Pkt, int ProcMode, LONGLONG Size, int *Mode);
\r
102 static LRESULT CALLBACK TransDlgProc(HWND hDlg, UINT Msg, WPARAM wParam, LPARAM lParam);
\r
103 static void DispTransferStatus(HWND hWnd, int End, TRANSPACKET *Pkt);
\r
104 static void DispTransFileInfo(TRANSPACKET *Pkt, char *Title, int SkipButton, int Info);
\r
105 static int GetAdrsAndPort(char *Str, char *Adrs, int *Port, int Max);
\r
106 static int IsSpecialDevice(char *Fname);
\r
107 static int MirrorDelNotify(int Cur, int Notify, TRANSPACKET *Pkt);
\r
108 static BOOL CALLBACK MirrorDeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
109 static void SetErrorMsg(char *fmt, ...);
\r
111 /*===== ローカルなワーク =====*/
\r
114 //static HANDLE hTransferThread;
\r
115 static HANDLE hTransferThread[MAX_DATA_CONNECTION];
\r
116 static int fTransferThreadExit = FALSE;
\r
118 static HANDLE hRunMutex; /* 転送スレッド実行ミューテックス */
\r
119 static HANDLE hListAccMutex; /* 転送ファイルアクセス用ミューテックス */
\r
121 static int TransFiles = 0; /* 転送待ちファイル数 */
\r
122 static TRANSPACKET *TransPacketBase = NULL; /* 転送ファイルリスト */
\r
125 //static int Canceled; /* 中止フラグ YES/NO */
\r
126 static int Canceled[MAX_DATA_CONNECTION]; /* 中止フラグ YES/NO */
\r
127 static int ClearAll; /* 全て中止フラグ YES/NO */
\r
129 static int ForceAbort; /* 転送中止フラグ */
\r
130 /* このフラグはスレッドを終了させるときに使う */
\r
133 //static LONGLONG AllTransSizeNow; /* 今回の転送で転送したサイズ */
\r
134 //static time_t TimeStart; /* 転送開始時間 */
\r
135 static LONGLONG AllTransSizeNow[MAX_DATA_CONNECTION]; /* 今回の転送で転送したサイズ */
\r
136 static time_t TimeStart[MAX_DATA_CONNECTION]; /* 転送開始時間 */
\r
138 static int KeepDlg = NO; /* 転送中ダイアログを消さないかどうか (YES/NO) */
\r
139 static int MoveToForeground = NO; /* ウインドウを前面に移動するかどうか (YES/NO) */
\r
141 static char CurDir[FMAX_PATH+1] = { "" };
\r
142 static char ErrMsg[ERR_MSG_LEN+7];
\r
144 /*===== 外部参照 =====*/
\r
147 extern int SaveTimeStamp;
\r
149 // extern int TimeOut;
\r
150 extern int FwallType;
\r
151 extern int MirUpDelNotify;
\r
152 extern int MirDownDelNotify;
\r
153 extern int FolderAttr;
\r
154 extern int FolderAttrNum;
\r
157 /*----- ファイル転送スレッドを起動する ----------------------------------------
\r
164 *----------------------------------------------------------------------------*/
\r
166 int MakeTransferThread(void)
\r
171 hListAccMutex = CreateMutex( NULL, FALSE, NULL );
\r
172 hRunMutex = CreateMutex( NULL, TRUE, NULL );
\r
177 fTransferThreadExit = FALSE;
\r
179 // hTransferThread = (HANDLE)_beginthreadex(NULL, 0, TransferThread, 0, 0, &dwID);
\r
180 // if (hTransferThread == NULL)
\r
181 // return(FFFTP_FAIL); /* XXX */
\r
182 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
184 hTransferThread[i] = (HANDLE)_beginthreadex(NULL, 0, TransferThread, (void*)i, 0, &dwID);
\r
185 if(hTransferThread[i] == NULL)
\r
189 return(FFFTP_SUCCESS);
\r
193 /*----- ファイル転送スレッドを終了する ----------------------------------------
\r
200 *----------------------------------------------------------------------------*/
\r
202 void CloseTransferThread(void)
\r
207 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
212 fTransferThreadExit = TRUE;
\r
214 // while(WaitForSingleObject(hTransferThread, 10) == WAIT_TIMEOUT)
\r
216 // BackgrndMessageProc();
\r
219 // CloseHandle(hTransferThread);
\r
220 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
222 while(WaitForSingleObject(hTransferThread[i], 10) == WAIT_TIMEOUT)
\r
224 BackgrndMessageProc();
\r
227 CloseHandle(hTransferThread[i]);
\r
230 ReleaseMutex( hRunMutex );
\r
232 CloseHandle( hListAccMutex );
\r
233 CloseHandle( hRunMutex );
\r
238 /*----- 転送するファイル情報をリストに追加する --------------------------------
\r
241 * TRANSPACKET *Pkt : 転送ファイル情報
\r
242 * TRANSPACKET **Base : リストの先頭
\r
246 * FFFTP_SUCCESS/FFFTP_FAIL
\r
247 *----------------------------------------------------------------------------*/
\r
249 int AddTmpTransFileList(TRANSPACKET *Pkt, TRANSPACKET **Base)
\r
256 if((Pos = malloc(sizeof(TRANSPACKET))) != NULL)
\r
258 memcpy(Pos, Pkt, sizeof(TRANSPACKET));
\r
266 while(Prev->Next != NULL)
\r
270 Sts = FFFTP_SUCCESS;
\r
276 /*----- 転送するファイル情報リストをクリアする --------------------------------
\r
279 * TRANSPACKET **Base : リストの先頭
\r
283 *----------------------------------------------------------------------------*/
\r
285 void EraseTmpTransFileList(TRANSPACKET **Base)
\r
302 /*----- 転送するファイル情報リストから1つの情報を取り除く --------------------
\r
305 * TRANSPACKET *Pkt : 転送ファイル情報
\r
306 * TRANSPACKET **Base : リストの先頭
\r
310 * FFFTP_SUCCESS/FFFTP_FAIL
\r
311 *----------------------------------------------------------------------------*/
\r
313 int RemoveTmpTransFileListItem(TRANSPACKET **Base, int Num)
\r
325 Sts = FFFTP_SUCCESS;
\r
335 Prev->Next = Pos->Next;
\r
337 Sts = FFFTP_SUCCESS;
\r
346 /*----- 転送するファイル情報を転送ファイルリストに登録する --------------------
\r
349 * TRANSPACKET *Pkt : 転送ファイル情報
\r
353 *----------------------------------------------------------------------------*/
\r
355 void AddTransFileList(TRANSPACKET *Pkt)
\r
357 DispTransPacket(Pkt);
\r
359 WaitForSingleObject(hListAccMutex, INFINITE);
\r
361 if(AddTmpTransFileList(Pkt, &TransPacketBase) == FFFTP_SUCCESS)
\r
363 if((strncmp(Pkt->Cmd, "RETR", 4) == 0) ||
\r
364 (strncmp(Pkt->Cmd, "STOR", 4) == 0))
\r
367 PostMessage(GetMainHwnd(), WM_CHANGE_COND, 0, 0);
\r
370 ReleaseMutex(hListAccMutex);
\r
376 /*----- 転送ファイル情報を転送ファイルリストに追加する ------------------------
\r
379 * TRANSPACKET *Pkt : 転送ファイル情報
\r
380 * TRANSPACKET **Base : リストの先頭
\r
387 *----------------------------------------------------------------------------*/
\r
389 void AppendTransFileList(TRANSPACKET *Pkt)
\r
393 WaitForSingleObject(hListAccMutex, INFINITE);
\r
395 if(TransPacketBase == NULL)
\r
396 TransPacketBase = Pkt;
\r
399 Pos = TransPacketBase;
\r
400 while(Pos->Next != NULL)
\r
407 DispTransPacket(Pkt);
\r
409 if((strncmp(Pkt->Cmd, "RETR", 4) == 0) ||
\r
410 (strncmp(Pkt->Cmd, "STOR", 4) == 0))
\r
413 PostMessage(GetMainHwnd(), WM_CHANGE_COND, 0, 0);
\r
418 ReleaseMutex(hListAccMutex);
\r
423 /*----- 転送ファイル情報を表示する --------------------------------------------
\r
426 * TRANSPACKET *Pkt : 転送ファイル情報
\r
430 *----------------------------------------------------------------------------*/
\r
432 static void DispTransPacket(TRANSPACKET *Pkt)
\r
434 if((strncmp(Pkt->Cmd, "RETR", 4) == 0) || (strncmp(Pkt->Cmd, "STOR", 4) == 0))
\r
435 DoPrintf("TransList Cmd=%s : %s : %s", Pkt->Cmd, Pkt->RemoteFile, Pkt->LocalFile);
\r
436 else if(strncmp(Pkt->Cmd, "R-", 2) == 0)
\r
437 DoPrintf("TransList Cmd=%s : %s", Pkt->Cmd, Pkt->RemoteFile);
\r
438 else if(strncmp(Pkt->Cmd, "L-", 2) == 0)
\r
439 DoPrintf("TransList Cmd=%s : %s", Pkt->Cmd, Pkt->LocalFile);
\r
440 else if(strncmp(Pkt->Cmd, "MKD", 3) == 0)
\r
442 if(strlen(Pkt->LocalFile) > 0)
\r
443 DoPrintf("TransList Cmd=%s : %s", Pkt->Cmd, Pkt->LocalFile);
\r
445 DoPrintf("TransList Cmd=%s : %s", Pkt->Cmd, Pkt->RemoteFile);
\r
448 DoPrintf("TransList Cmd=%s", Pkt->Cmd);
\r
453 /*----- 転送ファイルリストをクリアする ----------------------------------------
\r
460 *----------------------------------------------------------------------------*/
\r
462 static void EraseTransFileList(void)
\r
466 TRANSPACKET *NotDel;
\r
471 WaitForSingleObject(hListAccMutex, INFINITE);
\r
472 New = TransPacketBase;
\r
475 /* 最後の"BACKCUR"は必要なので消さない */
\r
476 if(strcmp(New->Cmd, "BACKCUR") == 0)
\r
482 NotDel->Next = NULL;
\r
491 TransPacketBase = NotDel;
\r
493 PostMessage(GetMainHwnd(), WM_CHANGE_COND, 0, 0);
\r
494 ReleaseMutex(hListAccMutex);
\r
496 strcpy(Pkt.Cmd, "GOQUIT");
\r
497 AddTransFileList(&Pkt);
\r
502 /*----- 転送中ダイアログを消さないようにするかどうかを設定 --------------------
\r
505 * int Sw : 転送中ダイアログを消さないかどうか (YES/NO)
\r
509 *----------------------------------------------------------------------------*/
\r
511 void KeepTransferDialog(int Sw)
\r
518 /*----- 現在転送中かどうかを返す ----------------------------------------------
\r
524 * int ステータス (YES/NO=転送中ではない)
\r
525 *----------------------------------------------------------------------------*/
\r
527 int AskTransferNow(void)
\r
529 return(TransPacketBase != NULL ? YES : NO);
\r
533 /*----- 転送するファイルの数を返す --------------------------------------------
\r
540 *----------------------------------------------------------------------------*/
\r
542 int AskTransferFileNum(void)
\r
544 return(TransFiles);
\r
548 /*----- 転送中ウインドウを前面に出す ------------------------------------------
\r
555 *----------------------------------------------------------------------------*/
\r
557 void GoForwardTransWindow(void)
\r
559 MoveToForeground = YES;
\r
564 /*----- 転送ソケットのカレントディレクトリ情報を初期化 ------------------------
\r
571 *----------------------------------------------------------------------------*/
\r
573 void InitTransCurDir(void)
\r
575 strcpy(CurDir, "");
\r
580 /*----- ファイル転送スレッドのメインループ ------------------------------------
\r
583 * void *Dummy : 使わない
\r
587 *----------------------------------------------------------------------------*/
\r
589 static ULONG WINAPI TransferThread(void *Dummy)
\r
593 char Tmp[FMAX_PATH+1];
\r
613 ThreadCount = (int)Dummy;
\r
614 CmdSkt = INVALID_SOCKET;
\r
615 NewCmdSkt = INVALID_SOCKET;
\r
616 TrnSkt = INVALID_SOCKET;
\r
618 while((TransPacketBase != NULL) ||
\r
619 (WaitForSingleObject(hRunMutex, 200) == WAIT_TIMEOUT))
\r
621 if(fTransferThreadExit == TRUE)
\r
624 WaitForSingleObject(hListAccMutex, INFINITE);
\r
625 memset(ErrMsg, NUL, ERR_MSG_LEN+7);
\r
628 Canceled[ThreadCount] = NO;
\r
630 NewCmdSkt = AskCmdCtrlSkt();
\r
631 if(TransPacketBase && NewCmdSkt != INVALID_SOCKET && ThreadCount < AskMaxThreadCount())
\r
633 if(TrnSkt == INVALID_SOCKET || NewCmdSkt != CmdSkt)
\r
635 ReleaseMutex(hListAccMutex);
\r
636 ReConnectTrnSkt(&TrnSkt);
\r
637 WaitForSingleObject(hListAccMutex, INFINITE);
\r
642 if(TrnSkt != INVALID_SOCKET)
\r
644 ReleaseMutex(hListAccMutex);
\r
646 TrnSkt = INVALID_SOCKET;
\r
647 WaitForSingleObject(hListAccMutex, INFINITE);
\r
650 CmdSkt = NewCmdSkt;
\r
651 // if(TransPacketBase != NULL)
\r
652 if(TrnSkt != INVALID_SOCKET && TransPacketBase != NULL)
\r
654 Pos = TransPacketBase;
\r
655 TransPacketBase = TransPacketBase->Next;
\r
656 // ディレクトリ操作は非同期で行わない
\r
657 // ReleaseMutex(hListAccMutex);
\r
658 if(hWndTrans == NULL)
\r
660 // if((strncmp(TransPacketBase->Cmd, "RETR", 4) == 0) ||
\r
661 // (strncmp(TransPacketBase->Cmd, "STOR", 4) == 0) ||
\r
662 // (strncmp(TransPacketBase->Cmd, "MKD", 3) == 0) ||
\r
663 // (strncmp(TransPacketBase->Cmd, "L-", 2) == 0) ||
\r
664 // (strncmp(TransPacketBase->Cmd, "R-", 2) == 0))
\r
665 if((strncmp(Pos->Cmd, "RETR", 4) == 0) ||
\r
666 (strncmp(Pos->Cmd, "STOR", 4) == 0) ||
\r
667 (strncmp(Pos->Cmd, "MKD", 3) == 0) ||
\r
668 (strncmp(Pos->Cmd, "L-", 2) == 0) ||
\r
669 (strncmp(Pos->Cmd, "R-", 2) == 0))
\r
671 hWndTrans = CreateDialog(GetFtpInst(), MAKEINTRESOURCE(transfer_dlg), HWND_DESKTOP, (DLGPROC)TransDlgProc);
\r
672 if(MoveToForeground == YES)
\r
673 SetForegroundWindow(hWndTrans);
\r
674 ShowWindow(hWndTrans, SW_SHOWNOACTIVATE);
\r
675 GetWindowRect(hWndTrans, &WndRect);
\r
676 SetWindowPos(hWndTrans, NULL, WndRect.left, WndRect.top + (WndRect.bottom - WndRect.top) * ThreadCount - (WndRect.bottom - WndRect.top) * (AskMaxThreadCount() - 1) / 2, 0, 0, SWP_NOSIZE | SWP_NOZORDER);
\r
679 // TransPacketBase->hWndTrans = hWndTrans;
\r
680 Pos->hWndTrans = hWndTrans;
\r
681 Pos->ctrl_skt = TrnSkt;
\r
682 Pos->ThreadCount = ThreadCount;
\r
684 if(hWndTrans != NULL)
\r
686 if(MoveToForeground == YES)
\r
688 SetForegroundWindow(hWndTrans);
\r
689 MoveToForeground = NO;
\r
693 if(hWndTrans != NULL)
\r
694 // SendMessage(hWndTrans, WM_SET_PACKET, 0, (LPARAM)TransPacketBase);
\r
695 SendMessage(hWndTrans, WM_SET_PACKET, 0, (LPARAM)Pos);
\r
698 // if(strncmp(TransPacketBase->Cmd, "RETR", 4) == 0)
\r
699 if(strncmp(Pos->Cmd, "RETR", 4) == 0)
\r
701 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
702 // ReleaseMutex(hListAccMutex);
\r
704 // if(CheckPathViolation(TransPacketBase) == NO)
\r
705 if(CheckPathViolation(Pos) == NO)
\r
707 /* フルパスを使わないための処理 */
\r
708 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
709 if(MakeNonFullPath(Pos, CurDir, Tmp) == FFFTP_SUCCESS)
\r
711 // if(strncmp(TransPacketBase->Cmd, "RETR-S", 6) == 0)
\r
712 if(strncmp(Pos->Cmd, "RETR-S", 6) == 0)
\r
715 // DoSIZE(TransPacketBase->RemoteFile, &TransPacketBase->Size);
\r
716 // DoMDTM(TransPacketBase->RemoteFile, &TransPacketBase->Time);
\r
717 // strcpy(TransPacketBase->Cmd, "RETR ");
\r
718 DoSIZE(TrnSkt, Pos->RemoteFile, &Pos->Size);
\r
719 DoMDTM(TrnSkt, Pos->RemoteFile, &Pos->Time);
\r
720 strcpy(Pos->Cmd, "RETR ");
\r
724 // if(DoDownLoad(AskTrnCtrlSkt(), TransPacketBase, NO) == 429)
\r
726 // if(ReConnectTrnSkt() == FFFTP_SUCCESS)
\r
727 // DoDownLoad(AskTrnCtrlSkt(), TransPacketBase, NO, &Canceled);
\r
728 DoDownLoad(TrnSkt, Pos, NO, &Canceled[Pos->ThreadCount]);
\r
732 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
733 ReleaseMutex(hListAccMutex);
\r
736 // else if(strncmp(TransPacketBase->Cmd, "STOR", 4) == 0)
\r
737 else if(strncmp(Pos->Cmd, "STOR", 4) == 0)
\r
739 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
740 // ReleaseMutex(hListAccMutex);
\r
741 /* フルパスを使わないための処理 */
\r
742 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
743 if(MakeNonFullPath(Pos, CurDir, Tmp) == FFFTP_SUCCESS)
\r
746 // if(DoUpLoad(AskTrnCtrlSkt(), TransPacketBase) == 429)
\r
748 // if(ReConnectTrnSkt() == FFFTP_SUCCESS)
\r
749 // DoUpLoad(AskTrnCtrlSkt(), TransPacketBase);
\r
750 DoUpLoad(TrnSkt, Pos);
\r
753 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
754 ReleaseMutex(hListAccMutex);
\r
756 /* フォルダ作成(ローカルまたはホスト) */
\r
757 // else if(strncmp(TransPacketBase->Cmd, "MKD", 3) == 0)
\r
758 else if(strncmp(Pos->Cmd, "MKD", 3) == 0)
\r
760 // DispTransFileInfo(TransPacketBase, MSGJPN078, FALSE, YES);
\r
761 DispTransFileInfo(Pos, MSGJPN078, FALSE, YES);
\r
763 // if(strlen(TransPacketBase->RemoteFile) > 0)
\r
764 if(strlen(Pos->RemoteFile) > 0)
\r
766 /* フルパスを使わないための処理 */
\r
767 CwdSts = FTP_COMPLETE;
\r
769 // strcpy(Tmp, TransPacketBase->RemoteFile);
\r
770 strcpy(Tmp, Pos->RemoteFile);
\r
771 // if(ProcForNonFullpath(Tmp, CurDir, hWndTrans, 1) == FFFTP_FAIL)
\r
772 if(ProcForNonFullpath(Tmp, CurDir, hWndTrans, (int)TrnSkt + 1) == FFFTP_FAIL)
\r
775 CwdSts = FTP_ERROR;
\r
778 if(CwdSts == FTP_COMPLETE)
\r
781 // CommandProcTrn(NULL, "MKD %s", Tmp);
\r
782 CommandProcTrn(TrnSkt, NULL, "MKD %s", Tmp);
\r
783 /* すでにフォルダがある場合もあるので、 */
\r
784 /* ここではエラーチェックはしない */
\r
787 // CommandProcTrn(NULL, "%s %03d %s", AskHostChmodCmd(), FolderAttrNum, Tmp);
\r
788 CommandProcTrn(TrnSkt, NULL, "%s %03d %s", AskHostChmodCmd(), FolderAttrNum, Tmp);
\r
791 // else if(strlen(TransPacketBase->LocalFile) > 0)
\r
792 else if(strlen(Pos->LocalFile) > 0)
\r
795 // DoLocalMKD(TransPacketBase->LocalFile);
\r
796 DoLocalMKD(Pos->LocalFile);
\r
798 ReleaseMutex(hListAccMutex);
\r
800 /* ディレクトリ作成(常にホスト側) */
\r
801 // else if(strncmp(TransPacketBase->Cmd, "R-MKD", 5) == 0)
\r
802 else if(strncmp(Pos->Cmd, "R-MKD", 5) == 0)
\r
804 // DispTransFileInfo(TransPacketBase, MSGJPN079, FALSE, YES);
\r
805 DispTransFileInfo(Pos, MSGJPN079, FALSE, YES);
\r
807 /* フルパスを使わないための処理 */
\r
808 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
809 if(MakeNonFullPath(Pos, CurDir, Tmp) == FFFTP_SUCCESS)
\r
812 // CommandProcTrn(NULL, "%s%s", TransPacketBase->Cmd+2, TransPacketBase->RemoteFile);
\r
813 CommandProcTrn(TrnSkt, NULL, "%s%s", Pos->Cmd+2, Pos->RemoteFile);
\r
816 // CommandProcTrn(NULL, "%s %03d %s", AskHostChmodCmd(), FolderAttrNum, TransPacketBase->RemoteFile);
\r
817 CommandProcTrn(TrnSkt, NULL, "%s %03d %s", AskHostChmodCmd(), FolderAttrNum, Pos->RemoteFile);
\r
819 ReleaseMutex(hListAccMutex);
\r
821 /* ディレクトリ削除(常にホスト側) */
\r
822 // else if(strncmp(TransPacketBase->Cmd, "R-RMD", 5) == 0)
\r
823 else if(strncmp(Pos->Cmd, "R-RMD", 5) == 0)
\r
825 // DispTransFileInfo(TransPacketBase, MSGJPN080, FALSE, YES);
\r
826 DispTransFileInfo(Pos, MSGJPN080, FALSE, YES);
\r
828 // DelNotify = MirrorDelNotify(WIN_REMOTE, DelNotify, TransPacketBase);
\r
829 DelNotify = MirrorDelNotify(WIN_REMOTE, DelNotify, Pos);
\r
830 if((DelNotify == YES) || (DelNotify == YES_ALL))
\r
832 /* フルパスを使わないための処理 */
\r
833 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
834 if(MakeNonFullPath(Pos, CurDir, Tmp) == FFFTP_SUCCESS)
\r
837 // CommandProcTrn(NULL, "%s%s", TransPacketBase->Cmd+2, TransPacketBase->RemoteFile);
\r
838 CommandProcTrn(TrnSkt, NULL, "%s%s", Pos->Cmd+2, Pos->RemoteFile);
\r
841 ReleaseMutex(hListAccMutex);
\r
843 /* ファイル削除(常にホスト側) */
\r
844 // else if(strncmp(TransPacketBase->Cmd, "R-DELE", 6) == 0)
\r
845 else if(strncmp(Pos->Cmd, "R-DELE", 6) == 0)
\r
847 ReleaseMutex(hListAccMutex);
\r
848 // DispTransFileInfo(TransPacketBase, MSGJPN081, FALSE, YES);
\r
849 DispTransFileInfo(Pos, MSGJPN081, FALSE, YES);
\r
851 // DelNotify = MirrorDelNotify(WIN_REMOTE, DelNotify, TransPacketBase);
\r
852 DelNotify = MirrorDelNotify(WIN_REMOTE, DelNotify, Pos);
\r
853 if((DelNotify == YES) || (DelNotify == YES_ALL))
\r
855 /* フルパスを使わないための処理 */
\r
856 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
857 if(MakeNonFullPath(Pos, CurDir, Tmp) == FFFTP_SUCCESS)
\r
860 // CommandProcTrn(NULL, "%s%s", TransPacketBase->Cmd+2, TransPacketBase->RemoteFile);
\r
861 CommandProcTrn(TrnSkt, NULL, "%s%s", Pos->Cmd+2, Pos->RemoteFile);
\r
865 /* ディレクトリ作成(常にローカル側) */
\r
866 // else if(strncmp(TransPacketBase->Cmd, "L-MKD", 5) == 0)
\r
867 else if(strncmp(Pos->Cmd, "L-MKD", 5) == 0)
\r
869 // DispTransFileInfo(TransPacketBase, MSGJPN082, FALSE, YES);
\r
870 DispTransFileInfo(Pos, MSGJPN082, FALSE, YES);
\r
873 // DoLocalMKD(TransPacketBase->LocalFile);
\r
874 DoLocalMKD(Pos->LocalFile);
\r
875 ReleaseMutex(hListAccMutex);
\r
877 /* ディレクトリ削除(常にローカル側) */
\r
878 // else if(strncmp(TransPacketBase->Cmd, "L-RMD", 5) == 0)
\r
879 else if(strncmp(Pos->Cmd, "L-RMD", 5) == 0)
\r
881 // DispTransFileInfo(TransPacketBase, MSGJPN083, FALSE, YES);
\r
882 DispTransFileInfo(Pos, MSGJPN083, FALSE, YES);
\r
884 // DelNotify = MirrorDelNotify(WIN_LOCAL, DelNotify, TransPacketBase);
\r
885 DelNotify = MirrorDelNotify(WIN_LOCAL, DelNotify, Pos);
\r
886 if((DelNotify == YES) || (DelNotify == YES_ALL))
\r
889 // DoLocalRMD(TransPacketBase->LocalFile);
\r
890 DoLocalRMD(Pos->LocalFile);
\r
892 ReleaseMutex(hListAccMutex);
\r
894 /* ファイル削除(常にローカル側) */
\r
895 // else if(strncmp(TransPacketBase->Cmd, "L-DELE", 6) == 0)
\r
896 else if(strncmp(Pos->Cmd, "L-DELE", 6) == 0)
\r
898 // DispTransFileInfo(TransPacketBase, MSGJPN084, FALSE, YES);
\r
899 DispTransFileInfo(Pos, MSGJPN084, FALSE, YES);
\r
901 // DelNotify = MirrorDelNotify(WIN_LOCAL, DelNotify, TransPacketBase);
\r
902 DelNotify = MirrorDelNotify(WIN_LOCAL, DelNotify, Pos);
\r
903 if((DelNotify == YES) || (DelNotify == YES_ALL))
\r
906 // DoLocalDELE(TransPacketBase->LocalFile);
\r
907 DoLocalDELE(Pos->LocalFile);
\r
909 ReleaseMutex(hListAccMutex);
\r
911 /* カレントディレクトリを設定 */
\r
912 // else if(strcmp(TransPacketBase->Cmd, "SETCUR") == 0)
\r
913 else if(strcmp(Pos->Cmd, "SETCUR") == 0)
\r
915 if(AskShareProh() == YES)
\r
917 // if(strcmp(CurDir, TransPacketBase->RemoteFile) != 0)
\r
918 if(strcmp(CurDir, Pos->RemoteFile) != 0)
\r
920 // if(CommandProcTrn(NULL, "CWD %s", TransPacketBase->RemoteFile)/100 != FTP_COMPLETE)
\r
921 if(CommandProcTrn(TrnSkt, NULL, "CWD %s", Pos->RemoteFile)/100 != FTP_COMPLETE)
\r
923 DispCWDerror(hWndTrans);
\r
928 // strcpy(CurDir, TransPacketBase->RemoteFile);
\r
929 strcpy(CurDir, Pos->RemoteFile);
\r
930 ReleaseMutex(hListAccMutex);
\r
932 /* カレントディレクトリを戻す */
\r
933 // else if(strcmp(TransPacketBase->Cmd, "BACKCUR") == 0)
\r
934 else if(strcmp(Pos->Cmd, "BACKCUR") == 0)
\r
936 if(AskShareProh() == NO)
\r
938 // if(strcmp(CurDir, TransPacketBase->RemoteFile) != 0)
\r
939 // CommandProcTrn(NULL, "CWD %s", TransPacketBase->RemoteFile);
\r
940 // strcpy(CurDir, TransPacketBase->RemoteFile);
\r
941 if(strcmp(CurDir, Pos->RemoteFile) != 0)
\r
942 CommandProcTrn(TrnSkt, NULL, "CWD %s", Pos->RemoteFile);
\r
943 strcpy(CurDir, Pos->RemoteFile);
\r
945 ReleaseMutex(hListAccMutex);
\r
948 // else if(strcmp(TransPacketBase->Cmd, "GOQUIT") == 0)
\r
949 else if(strcmp(Pos->Cmd, "GOQUIT") == 0)
\r
951 ReleaseMutex(hListAccMutex);
\r
955 ReleaseMutex(hListAccMutex);
\r
957 /*===== 1つの処理終わり =====*/
\r
959 if(ForceAbort == NO)
\r
961 WaitForSingleObject(hListAccMutex, INFINITE);
\r
962 if(ClearAll == YES)
\r
963 // EraseTransFileList();
\r
965 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
967 EraseTransFileList();
\r
971 // if((strncmp(TransPacketBase->Cmd, "RETR", 4) == 0) ||
\r
972 // (strncmp(TransPacketBase->Cmd, "STOR", 4) == 0))
\r
973 if((strncmp(Pos->Cmd, "RETR", 4) == 0) ||
\r
974 (strncmp(Pos->Cmd, "STOR", 4) == 0))
\r
979 PostMessage(GetMainHwnd(), WM_CHANGE_COND, 0, 0);
\r
981 // Pos = TransPacketBase;
\r
982 // TransPacketBase = TransPacketBase->Next;
\r
986 ReleaseMutex(hListAccMutex);
\r
988 if(BackgrndMessageProc() == YES)
\r
990 WaitForSingleObject(hListAccMutex, INFINITE);
\r
991 EraseTransFileList();
\r
992 ReleaseMutex(hListAccMutex);
\r
995 if(hWndTrans != NULL)
\r
996 SendMessage(hWndTrans, WM_SET_PACKET, 0, 0);
\r
1000 else if(TransPacketBase == NULL)
\r
1004 ReleaseMutex(hListAccMutex);
\r
1007 if(hWndTrans != NULL)
\r
1009 DestroyWindow(hWndTrans);
\r
1014 SoundPlay(SND_TRANS);
\r
1016 if(AskAutoExit() == NO)
\r
1019 PostMessage(GetMainHwnd(), WM_REFRESH_LOCAL_FLG, 0, 0);
\r
1021 PostMessage(GetMainHwnd(), WM_REFRESH_REMOTE_FLG, 0, 0);
\r
1028 BackgrndMessageProc();
\r
1033 PostMessage(GetMainHwnd(), WM_COMMAND, MAKEWPARAM(MENU_AUTO_EXIT, 0), 0);
\r
1039 ReleaseMutex(hListAccMutex);
\r
1040 if(hWndTrans != NULL)
\r
1042 DestroyWindow(hWndTrans);
\r
1045 BackgrndMessageProc();
\r
1049 if(TrnSkt != INVALID_SOCKET)
\r
1055 /*----- フルパスを使わないファイルアクセスの準備 ------------------------------
\r
1058 * TRANSPACKET *Pkt : 転送パケット
\r
1059 * char *Cur : カレントディレクトリ
\r
1060 * char *Tmp : 作業用エリア
\r
1063 * int ステータス(FFFTP_SUCCESS/FFFTP_FAIL)
\r
1067 * このモジュール内で CWD を行ない、
\r
1068 * Pkt->RemoteFile にファイル名のみ残す。(パス名は消す)
\r
1069 *----------------------------------------------------------------------------*/
\r
1072 static int MakeNonFullPath(TRANSPACKET *Pkt, char *Cur, char *Tmp)
\r
1076 // Sts = ProcForNonFullpath(Pkt->RemoteFile, Cur, Pkt->hWndTrans, 1);
\r
1077 Sts = ProcForNonFullpath(Pkt->RemoteFile, Cur, Pkt->hWndTrans, (int)Pkt->ctrl_skt + 1);
\r
1078 if(Sts == FFFTP_FAIL)
\r
1087 /*----- ダウンロードを行なう --------------------------------------------------
\r
1090 * SOCKET cSkt : コントロールソケット
\r
1091 * TRANSPACKET *Pkt : 転送ファイル情報
\r
1092 * int DirList : ディレクトリリストのダウンロード(YES/NO)
\r
1098 * このモジュールは、ファイル一覧の取得などを行なう際にメインのスレッド
\r
1099 * からも呼ばれる。メインのスレッドから呼ばれる時は Pkt->hWndTrans == NULL。
\r
1100 *----------------------------------------------------------------------------*/
\r
1102 int DoDownLoad(SOCKET cSkt, TRANSPACKET *Pkt, int DirList, int *CancelCheckWork)
\r
1105 char Reply[ERR_MSG_LEN+7];
\r
1107 Pkt->ctrl_skt = cSkt;
\r
1108 if(IsSpecialDevice(GetFileName(Pkt->LocalFile)) == YES)
\r
1111 SetTaskMsg(MSGJPN085, GetFileName(Pkt->LocalFile));
\r
1112 DispDownloadFinishMsg(Pkt, iRetCode);
\r
1114 else if(Pkt->Mode != EXIST_IGNORE)
\r
1116 if(Pkt->Type == TYPE_I)
\r
1117 Pkt->KanjiCode = KANJI_NOCNV;
\r
1119 iRetCode = command(Pkt->ctrl_skt, Reply, CancelCheckWork, "TYPE %c", Pkt->Type);
\r
1120 if(iRetCode/100 < FTP_RETRY)
\r
1122 if(Pkt->hWndTrans != NULL)
\r
1125 // AllTransSizeNow = 0;
\r
1126 AllTransSizeNow[Pkt->ThreadCount] = 0;
\r
1129 DispTransFileInfo(Pkt, MSGJPN086, TRUE, YES);
\r
1131 DispTransFileInfo(Pkt, MSGJPN087, FALSE, NO);
\r
1134 if(BackgrndMessageProc() == NO)
\r
1136 if(AskPasvMode() != YES)
\r
1137 iRetCode = DownLoadNonPassive(Pkt, CancelCheckWork);
\r
1139 iRetCode = DownLoadPassive(Pkt, CancelCheckWork);
\r
1145 SetErrorMsg(Reply);
\r
1149 DispTransFileInfo(Pkt, MSGJPN088, TRUE, YES);
\r
1150 SetTaskMsg(MSGJPN089, Pkt->RemoteFile);
\r
1157 /*----- 通常モードでファイルをダウンロード ------------------------------------
\r
1160 * TRANSPACKET *Pkt : 転送ファイル情報
\r
1164 *----------------------------------------------------------------------------*/
\r
1166 static int DownLoadNonPassive(TRANSPACKET *Pkt, int *CancelCheckWork)
\r
1170 SOCKET data_socket = INVALID_SOCKET; // data channel socket
\r
1171 SOCKET listen_socket = INVALID_SOCKET; // data listen socket
\r
1174 struct sockaddr_in saSockAddr1;
\r
1175 char Reply[ERR_MSG_LEN+7];
\r
1177 if((listen_socket = GetFTPListenSocket(Pkt->ctrl_skt, CancelCheckWork)) != INVALID_SOCKET)
\r
1179 if(SetDownloadResume(Pkt, Pkt->Mode, Pkt->ExistSize, &CreateMode, CancelCheckWork) == YES)
\r
1181 sprintf(Buf, "%s%s", Pkt->Cmd, Pkt->RemoteFile);
\r
1182 iRetCode = command(Pkt->ctrl_skt, Reply, CancelCheckWork, "%s", Buf);
\r
1183 if(iRetCode/100 == FTP_PRELIM)
\r
1185 if(SocksGet2ndBindReply(listen_socket, &data_socket) == FFFTP_FAIL)
\r
1187 iLength = sizeof(saSockAddr1);
\r
1188 data_socket = do_accept(listen_socket, (struct sockaddr *)&saSockAddr1, (int *)&iLength);
\r
1190 if(shutdown(listen_socket, 1) != 0)
\r
1191 ReportWSError("shutdown listen", WSAGetLastError());
\r
1192 listen_socket = DoClose(listen_socket);
\r
1194 if(data_socket == INVALID_SOCKET)
\r
1196 SetErrorMsg(MSGJPN280);
\r
1197 ReportWSError("accept", WSAGetLastError());
\r
1201 DoPrintf("Skt=%u : accept from %s port %u", data_socket, inet_ntoa(saSockAddr1.sin_addr), ntohs(saSockAddr1.sin_port));
\r
1204 if(data_socket != INVALID_SOCKET)
\r
1206 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
1207 ReleaseMutex(hListAccMutex);
\r
1209 // iRetCode = DownLoadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1210 if(AskCryptMode() == CRYPT_FTPES || AskCryptMode() == CRYPT_FTPIS)
\r
1212 if(AttachSSL(data_socket))
\r
1213 iRetCode = DownLoadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1215 iRetCode = FTP_ERROR;
\r
1218 iRetCode = DownLoadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1219 // data_socket = DoClose(data_socket);
\r
1224 SetErrorMsg(Reply);
\r
1225 SetTaskMsg(MSGJPN090);
\r
1226 listen_socket = DoClose(listen_socket);
\r
1236 SetErrorMsg(MSGJPN279);
\r
1238 DispDownloadFinishMsg(Pkt, iRetCode);
\r
1244 /*----- Passiveモードでファイルをダウンロード ---------------------------------
\r
1247 * TRANSPACKET *Pkt : 転送ファイル情報
\r
1251 *----------------------------------------------------------------------------*/
\r
1253 static int DownLoadPassive(TRANSPACKET *Pkt, int *CancelCheckWork)
\r
1256 SOCKET data_socket = INVALID_SOCKET; // data channel socket
\r
1262 char Reply[ERR_MSG_LEN+7];
\r
1264 iRetCode = command(Pkt->ctrl_skt, Buf, CancelCheckWork, "PASV");
\r
1265 if(iRetCode/100 == FTP_COMPLETE)
\r
1267 if(GetAdrsAndPort(Buf, Adrs, &Port, 19) == FFFTP_SUCCESS)
\r
1269 if((data_socket = connectsock(Adrs, Port, MSGJPN091, CancelCheckWork)) != INVALID_SOCKET)
\r
1273 if(setsockopt(data_socket, IPPROTO_TCP, TCP_NODELAY, (LPSTR)&Flg, sizeof(Flg)) == SOCKET_ERROR)
\r
1274 ReportWSError("setsockopt", WSAGetLastError());
\r
1276 if(SetDownloadResume(Pkt, Pkt->Mode, Pkt->ExistSize, &CreateMode, CancelCheckWork) == YES)
\r
1278 sprintf(Buf, "%s%s", Pkt->Cmd, Pkt->RemoteFile);
\r
1279 iRetCode = command(Pkt->ctrl_skt, Reply, CancelCheckWork, "%s", Buf);
\r
1280 if(iRetCode/100 == FTP_PRELIM)
\r
1282 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
1283 ReleaseMutex(hListAccMutex);
\r
1285 // iRetCode = DownLoadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1286 if(AskCryptMode() == CRYPT_FTPES || AskCryptMode() == CRYPT_FTPIS)
\r
1288 if(AttachSSL(data_socket))
\r
1289 iRetCode = DownLoadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1291 iRetCode = FTP_ERROR;
\r
1294 iRetCode = DownLoadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1295 // data_socket = DoClose(data_socket);
\r
1299 SetErrorMsg(Reply);
\r
1300 SetTaskMsg(MSGJPN092);
\r
1301 data_socket = DoClose(data_socket);
\r
1313 SetErrorMsg(MSGJPN093);
\r
1314 SetTaskMsg(MSGJPN093);
\r
1321 DispDownloadFinishMsg(Pkt, iRetCode);
\r
1327 /*----- ダウンロードの実行 ----------------------------------------------------
\r
1330 * TRANSPACKET *Pkt : 転送ファイル情報
\r
1331 * SOCKET dSkt : データソケット
\r
1332 * int CreateMode : ファイル作成モード (CREATE_ALWAYS/OPEN_ALWAYS)
\r
1339 * ダイアログを出す(Pkt->hWndTrans!=NULL)場合、インターバルタイマで経過を表示する
\r
1340 * ダイアログを出さない場合、このルーチンからDispDownloadSize()を呼ぶ
\r
1341 *----------------------------------------------------------------------------*/
\r
1343 static int DownLoadFile(TRANSPACKET *Pkt, SOCKET dSkt, int CreateMode, int *CancelCheckWork)
\r
1346 char Buf[BUFSIZE];
\r
1347 char Buf2[BUFSIZE+3];
\r
1348 HANDLE iFileHandle;
\r
1349 SECURITY_ATTRIBUTES Sec;
\r
1351 CODECONVINFO cInfo;
\r
1353 // fd_set ReadFds;
\r
1354 // struct timeval Tout;
\r
1355 // struct timeval *ToutPtr;
\r
1358 char TmpBuf[ONELINE_BUF_SIZE];
\r
1359 DWORD dwFileAttributes;
\r
1361 #ifdef SET_BUFFER_SIZE
\r
1362 /* Add by H.Shirouzu at 2002/10/02 */
\r
1363 int buf_size = SOCKBUF_SIZE;
\r
1364 for ( ; buf_size > 0; buf_size /= 2)
\r
1365 if (setsockopt(dSkt, SOL_SOCKET, SO_RCVBUF, (char *)&buf_size, sizeof(buf_size)) == 0)
\r
1370 // 念のため受信バッファを無効にする
\r
1371 #ifdef DISABLE_TRANSFER_NETWORK_BUFFERS
\r
1373 setsockopt(dSkt, SOL_SOCKET, SO_RCVBUF, (char *)&buf_size, sizeof(buf_size));
\r
1376 Pkt->Abort = ABORT_NONE;
\r
1378 Sec.nLength = sizeof(SECURITY_ATTRIBUTES);
\r
1379 Sec.lpSecurityDescriptor = NULL;
\r
1380 Sec.bInheritHandle = FALSE;
\r
1382 dwFileAttributes = GetFileAttributes(Pkt->LocalFile);
\r
1383 if (dwFileAttributes != INVALID_FILE_ATTRIBUTES && (dwFileAttributes & FILE_ATTRIBUTE_READONLY)) {
\r
1385 if (MessageBox(GetMainHwnd(), MSGJPN296, MSGJPN086, MB_YESNO) == IDYES) {
\r
1387 SetFileAttributes(Pkt->LocalFile, dwFileAttributes ^ FILE_ATTRIBUTE_READONLY);
\r
1391 if((iFileHandle = CreateFile(Pkt->LocalFile, GENERIC_READ | GENERIC_WRITE, FILE_SHARE_READ | FILE_SHARE_WRITE, &Sec, CreateMode, FILE_ATTRIBUTE_NORMAL, NULL)) != INVALID_HANDLE_VALUE)
\r
1394 char Buf3[(BUFSIZE + 3) * 4];
\r
1395 CODECONVINFO cInfo2;
\r
1396 int ProcessedBOM = NO;
\r
1397 if(CreateMode == OPEN_ALWAYS)
\r
1398 SetFilePointer(iFileHandle, 0, 0, FILE_END);
\r
1400 if(Pkt->hWndTrans != NULL)
\r
1403 // TimeStart = time(NULL);
\r
1404 TimeStart[Pkt->ThreadCount] = time(NULL);
\r
1405 SetTimer(Pkt->hWndTrans, TIMER_DISPLAY, DISPLAY_TIMING, NULL);
\r
1408 InitCodeConvInfo(&cInfo);
\r
1409 cInfo.KanaCnv = Pkt->KanaCnv;
\r
1411 InitCodeConvInfo(&cInfo2);
\r
1412 cInfo2.KanaCnv = Pkt->KanaCnv;
\r
1414 /*===== ファイルを受信するループ =====*/
\r
1415 while((Pkt->Abort == ABORT_NONE) && (ForceAbort == NO))
\r
1417 // FD_ZERO(&ReadFds);
\r
1418 // FD_SET(dSkt, &ReadFds);
\r
1419 // ToutPtr = NULL;
\r
1420 // if(TimeOut != 0)
\r
1422 // Tout.tv_sec = TimeOut;
\r
1423 // Tout.tv_usec = 0;
\r
1424 // ToutPtr = &Tout;
\r
1426 // iNumBytes = select(0, &ReadFds, NULL, NULL, ToutPtr);
\r
1427 // if(iNumBytes == SOCKET_ERROR)
\r
1429 // ReportWSError("select", WSAGetLastError());
\r
1430 // if(Pkt->Abort == ABORT_NONE)
\r
1431 // Pkt->Abort = ABORT_ERROR;
\r
1434 // else if(iNumBytes == 0)
\r
1436 // SetErrorMsg(MSGJPN094);
\r
1437 // SetTaskMsg(MSGJPN094);
\r
1438 // Pkt->Abort = ABORT_ERROR;
\r
1442 if((iNumBytes = do_recv(dSkt, Buf, BUFSIZE, 0, &TimeOutErr, CancelCheckWork)) <= 0)
\r
1444 if(TimeOutErr == YES)
\r
1446 SetErrorMsg(MSGJPN094);
\r
1447 SetTaskMsg(MSGJPN094);
\r
1448 if(Pkt->hWndTrans != NULL)
\r
1450 if(Pkt->Abort == ABORT_NONE)
\r
1451 Pkt->Abort = ABORT_ERROR;
\r
1453 else if(iNumBytes == SOCKET_ERROR)
\r
1455 if(Pkt->Abort == ABORT_NONE)
\r
1456 Pkt->Abort = ABORT_ERROR;
\r
1462 if(Pkt->KanjiCode != KANJI_NOCNV)
\r
1465 cInfo.StrLen = iNumBytes;
\r
1467 cInfo.BufSize = BUFSIZE+3;
\r
1470 // ここで全てUTF-8へ変換する
\r
1471 // TODO: SJIS以外も直接UTF-8へ変換
\r
1472 // if(Pkt->KanjiCode == KANJI_JIS)
\r
1473 // Continue = ConvJIStoSJIS(&cInfo);
\r
1475 // Continue = ConvEUCtoSJIS(&cInfo);
\r
1476 char Buf3[(BUFSIZE + 3) * 4];
\r
1477 CODECONVINFO cInfo2;
\r
1478 switch(Pkt->KanjiCode)
\r
1481 switch(Pkt->KanjiCodeDesired)
\r
1484 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1485 // cInfo2.OutLen = cInfo.StrLen;
\r
1488 Continue = ConvSJIStoJIS(&cInfo);
\r
1489 cInfo2.Str = cInfo.Buf;
\r
1490 cInfo2.StrLen = cInfo.OutLen;
\r
1491 cInfo2.Buf = Buf3;
\r
1492 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1493 ConvJIStoSJIS(&cInfo2);
\r
1496 Continue = ConvSJIStoJIS(&cInfo);
\r
1497 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1498 cInfo2.OutLen = cInfo.OutLen;
\r
1501 Continue = ConvSJIStoEUC(&cInfo);
\r
1502 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1503 cInfo2.OutLen = cInfo.OutLen;
\r
1506 if(ProcessedBOM == NO)
\r
1508 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
1509 cInfo2.OutLen = 3;
\r
1511 ProcessedBOM = YES;
\r
1514 Continue = ConvSJIStoUTF8N(&cInfo);
\r
1515 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1516 cInfo2.OutLen = cInfo.OutLen;
\r
1521 switch(Pkt->KanjiCodeDesired)
\r
1524 Continue = ConvJIStoSJIS(&cInfo);
\r
1525 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1526 cInfo2.OutLen = cInfo.OutLen;
\r
1529 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1530 // cInfo2.OutLen = cInfo.StrLen;
\r
1533 Continue = ConvJIStoSJIS(&cInfo);
\r
1534 cInfo2.Str = cInfo.Buf;
\r
1535 cInfo2.StrLen = cInfo.OutLen;
\r
1536 cInfo2.Buf = Buf3;
\r
1537 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1538 ConvSJIStoJIS(&cInfo2);
\r
1541 Continue = ConvJIStoSJIS(&cInfo);
\r
1542 cInfo2.Str = cInfo.Buf;
\r
1543 cInfo2.StrLen = cInfo.OutLen;
\r
1544 cInfo2.Buf = Buf3;
\r
1545 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1546 ConvSJIStoEUC(&cInfo2);
\r
1549 if(ProcessedBOM == NO)
\r
1551 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
1552 cInfo2.OutLen = 3;
\r
1554 ProcessedBOM = YES;
\r
1557 Continue = ConvJIStoSJIS(&cInfo);
\r
1558 cInfo2.Str = cInfo.Buf;
\r
1559 cInfo2.StrLen = cInfo.OutLen;
\r
1560 cInfo2.Buf = Buf3;
\r
1561 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1562 ConvSJIStoUTF8N(&cInfo2);
\r
1567 switch(Pkt->KanjiCodeDesired)
\r
1570 Continue = ConvEUCtoSJIS(&cInfo);
\r
1571 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1572 cInfo2.OutLen = cInfo.OutLen;
\r
1575 Continue = ConvEUCtoSJIS(&cInfo);
\r
1576 cInfo2.Str = cInfo.Buf;
\r
1577 cInfo2.StrLen = cInfo.OutLen;
\r
1578 cInfo2.Buf = Buf3;
\r
1579 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1580 ConvSJIStoJIS(&cInfo2);
\r
1583 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1584 // cInfo2.OutLen = cInfo.StrLen;
\r
1587 Continue = ConvEUCtoSJIS(&cInfo);
\r
1588 cInfo2.Str = cInfo.Buf;
\r
1589 cInfo2.StrLen = cInfo.OutLen;
\r
1590 cInfo2.Buf = Buf3;
\r
1591 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1592 ConvSJIStoEUC(&cInfo2);
\r
1595 if(ProcessedBOM == NO)
\r
1597 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
1598 cInfo2.OutLen = 3;
\r
1600 ProcessedBOM = YES;
\r
1603 Continue = ConvEUCtoSJIS(&cInfo);
\r
1604 cInfo2.Str = cInfo.Buf;
\r
1605 cInfo2.StrLen = cInfo.OutLen;
\r
1606 cInfo2.Buf = Buf3;
\r
1607 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1608 ConvSJIStoUTF8N(&cInfo2);
\r
1613 if(ProcessedBOM == NO)
\r
1615 if(memcmp(Buf, "\xEF\xBB\xBF", 3) == 0)
\r
1618 cInfo.StrLen -= 3;
\r
1620 cInfo2.OutLen = 0;
\r
1621 switch(Pkt->KanjiCodeDesired)
\r
1624 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
1625 cInfo2.OutLen = 3;
\r
1629 ProcessedBOM = YES;
\r
1632 switch(Pkt->KanjiCodeDesired)
\r
1635 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1636 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1637 cInfo2.OutLen = cInfo.OutLen;
\r
1640 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1641 cInfo2.Str = cInfo.Buf;
\r
1642 cInfo2.StrLen = cInfo.OutLen;
\r
1643 cInfo2.Buf = Buf3;
\r
1644 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1645 ConvSJIStoJIS(&cInfo2);
\r
1648 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1649 cInfo2.Str = cInfo.Buf;
\r
1650 cInfo2.StrLen = cInfo.OutLen;
\r
1651 cInfo2.Buf = Buf3;
\r
1652 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1653 ConvSJIStoEUC(&cInfo2);
\r
1656 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1657 cInfo2.OutLen = cInfo.StrLen;
\r
1663 // if(WriteFile(iFileHandle, Buf2, cInfo.OutLen, &Writed, NULL) == FALSE)
\r
1664 if(WriteFile(iFileHandle, Buf3, cInfo2.OutLen, &Writed, NULL) == FALSE)
\r
1665 Pkt->Abort = ABORT_DISKFULL;
\r
1667 while((Continue == YES) && (Pkt->Abort == ABORT_NONE));
\r
1671 if(WriteFile(iFileHandle, Buf, iNumBytes, &Writed, NULL) == FALSE)
\r
1672 Pkt->Abort = ABORT_DISKFULL;
\r
1675 Pkt->ExistSize += iNumBytes;
\r
1676 if(Pkt->hWndTrans != NULL)
\r
1678 // AllTransSizeNow += iNumBytes;
\r
1679 AllTransSizeNow[Pkt->ThreadCount] += iNumBytes;
\r
1682 /* 転送ダイアログを出さない時の経過表示 */
\r
1683 DispDownloadSize(Pkt->ExistSize);
\r
1686 if(BackgrndMessageProc() == YES)
\r
1690 /* 書き残したデータを書き込む */
\r
1691 if(Pkt->KanjiCode != KANJI_NOCNV)
\r
1694 cInfo.BufSize = BUFSIZE+3;
\r
1695 FlushRestData(&cInfo);
\r
1696 switch(Pkt->KanjiCode)
\r
1699 switch(Pkt->KanjiCodeDesired)
\r
1703 cInfo2.Str = cInfo.Buf;
\r
1704 cInfo2.StrLen = cInfo.OutLen;
\r
1705 cInfo2.Buf = Buf3;
\r
1706 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1707 ConvJIStoSJIS(&cInfo2);
\r
1710 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1711 cInfo2.OutLen = cInfo.OutLen;
\r
1714 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1715 cInfo2.OutLen = cInfo.OutLen;
\r
1718 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1719 cInfo2.OutLen = cInfo.OutLen;
\r
1724 switch(Pkt->KanjiCodeDesired)
\r
1727 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1728 cInfo2.OutLen = cInfo.OutLen;
\r
1732 cInfo2.Str = cInfo.Buf;
\r
1733 cInfo2.StrLen = cInfo.OutLen;
\r
1734 cInfo2.Buf = Buf3;
\r
1735 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1736 ConvSJIStoJIS(&cInfo2);
\r
1739 cInfo2.Str = cInfo.Buf;
\r
1740 cInfo2.StrLen = cInfo.OutLen;
\r
1741 cInfo2.Buf = Buf3;
\r
1742 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1743 ConvSJIStoEUC(&cInfo2);
\r
1746 cInfo2.Str = cInfo.Buf;
\r
1747 cInfo2.StrLen = cInfo.OutLen;
\r
1748 cInfo2.Buf = Buf3;
\r
1749 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1750 ConvSJIStoUTF8N(&cInfo2);
\r
1755 switch(Pkt->KanjiCodeDesired)
\r
1758 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1759 cInfo2.OutLen = cInfo.OutLen;
\r
1762 cInfo2.Str = cInfo.Buf;
\r
1763 cInfo2.StrLen = cInfo.OutLen;
\r
1764 cInfo2.Buf = Buf3;
\r
1765 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1766 ConvSJIStoJIS(&cInfo2);
\r
1770 cInfo2.Str = cInfo.Buf;
\r
1771 cInfo2.StrLen = cInfo.OutLen;
\r
1772 cInfo2.Buf = Buf3;
\r
1773 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1774 ConvSJIStoEUC(&cInfo2);
\r
1777 cInfo2.Str = cInfo.Buf;
\r
1778 cInfo2.StrLen = cInfo.OutLen;
\r
1779 cInfo2.Buf = Buf3;
\r
1780 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1781 ConvSJIStoUTF8N(&cInfo2);
\r
1786 switch(Pkt->KanjiCodeDesired)
\r
1789 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1790 cInfo2.OutLen = cInfo.OutLen;
\r
1793 cInfo2.Str = cInfo.Buf;
\r
1794 cInfo2.StrLen = cInfo.OutLen;
\r
1795 cInfo2.Buf = Buf3;
\r
1796 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1797 ConvSJIStoJIS(&cInfo2);
\r
1800 cInfo2.Str = cInfo.Buf;
\r
1801 cInfo2.StrLen = cInfo.OutLen;
\r
1802 cInfo2.Buf = Buf3;
\r
1803 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1804 ConvSJIStoEUC(&cInfo2);
\r
1807 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1808 cInfo2.OutLen = cInfo.OutLen;
\r
1813 // if(WriteFile(iFileHandle, Buf2, cInfo.OutLen, &Writed, NULL) == FALSE)
\r
1814 if(WriteFile(iFileHandle, Buf3, cInfo2.OutLen, &Writed, NULL) == FALSE)
\r
1815 Pkt->Abort = ABORT_DISKFULL;
\r
1816 cInfo2.Buf = Buf3;
\r
1817 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1818 FlushRestData(&cInfo2);
\r
1819 if(WriteFile(iFileHandle, Buf3, cInfo2.OutLen, &Writed, NULL) == FALSE)
\r
1820 Pkt->Abort = ABORT_DISKFULL;
\r
1824 if(Pkt->hWndTrans != NULL)
\r
1826 KillTimer(Pkt->hWndTrans, TIMER_DISPLAY);
\r
1827 DispTransferStatus(Pkt->hWndTrans, YES, Pkt);
\r
1829 // TimeStart = time(NULL) - TimeStart + 1;
\r
1830 TimeStart[Pkt->ThreadCount] = time(NULL) - TimeStart[Pkt->ThreadCount] + 1;
\r
1834 /* 転送ダイアログを出さない時の経過表示を消す */
\r
1835 DispDownloadSize(-1);
\r
1838 /* ファイルのタイムスタンプを合わせる */
\r
1839 if((SaveTimeStamp == YES) &&
\r
1840 ((Pkt->Time.dwLowDateTime != 0) || (Pkt->Time.dwHighDateTime != 0)))
\r
1842 SetFileTime(iFileHandle, &Pkt->Time, &Pkt->Time, &Pkt->Time);
\r
1845 CloseHandle(iFileHandle);
\r
1847 if(iNumBytes == SOCKET_ERROR)
\r
1848 ReportWSError("recv",WSAGetLastError());
\r
1852 SetErrorMsg(MSGJPN095, Pkt->LocalFile);
\r
1853 SetTaskMsg(MSGJPN095, Pkt->LocalFile);
\r
1854 Pkt->Abort = ABORT_ERROR;
\r
1858 if(shutdown(dSkt, 1) != 0)
\r
1859 ReportWSError("shutdown", WSAGetLastError());
\r
1863 if(ForceAbort == NO)
\r
1865 /* Abortをホストに伝える */
\r
1866 if(Pkt->Abort != ABORT_NONE && iFileHandle != INVALID_HANDLE_VALUE)
\r
1868 SendData(Pkt->ctrl_skt, "\xFF\xF4\xFF", 3, MSG_OOB, CancelCheckWork); /* MSG_OOBに注意 */
\r
1869 SendData(Pkt->ctrl_skt, "\xF2", 1, 0, CancelCheckWork);
\r
1870 command(Pkt->ctrl_skt, NULL, CancelCheckWork, "ABOR");
\r
1874 iRetCode = ReadReplyMessage(Pkt->ctrl_skt, Buf, 1024, CancelCheckWork, TmpBuf);
\r
1877 //DoPrintf("##DOWN REPLY : %s", Buf);
\r
1879 if(Pkt->Abort == ABORT_DISKFULL)
\r
1881 SetErrorMsg(MSGJPN096);
\r
1882 SetTaskMsg(MSGJPN096);
\r
1884 if(iRetCode >= FTP_RETRY)
\r
1886 if(Pkt->Abort != ABORT_NONE)
\r
1893 /*----- ダウンロード終了/中止時のメッセージを表示 ----------------------------
\r
1896 * TRANSPACKET *Pkt : 転送ファイル情報
\r
1897 * int iRetCode : 応答コード
\r
1901 *----------------------------------------------------------------------------*/
\r
1903 static void DispDownloadFinishMsg(TRANSPACKET *Pkt, int iRetCode)
\r
1905 char Fname[FMAX_PATH+1];
\r
1907 if(ForceAbort == NO)
\r
1909 if((iRetCode/100) >= FTP_CONTINUE)
\r
1911 strcpy(Fname, Pkt->RemoteFile);
\r
1913 #if defined(HAVE_OPENVMS)
\r
1914 /* OpenVMSの場合、空ディレクトリへ移動すると550 File not foundになって
\r
1915 * エラーダイアログやエラーメッセージが出るので何もしない */
\r
1916 if (AskHostType() == HTYPE_VMS)
\r
1920 if((strncmp(Pkt->Cmd, "NLST", 4) == 0) || (strncmp(Pkt->Cmd, "LIST", 4) == 0))
\r
1922 SetTaskMsg(MSGJPN097);
\r
1923 strcpy(Fname, MSGJPN098);
\r
1926 // else if((Pkt->hWndTrans != NULL) && (TimeStart != 0))
\r
1927 // SetTaskMsg(MSGJPN099, TimeStart, Pkt->ExistSize/TimeStart);
\r
1928 else if((Pkt->hWndTrans != NULL) && (TimeStart[Pkt->ThreadCount] != 0))
\r
1929 SetTaskMsg(MSGJPN099, TimeStart[Pkt->ThreadCount], Pkt->ExistSize/TimeStart[Pkt->ThreadCount]);
\r
1931 SetTaskMsg(MSGJPN100);
\r
1933 if(Pkt->Abort != ABORT_USER)
\r
1935 // 全て中止を選択後にダイアログが表示されるバグ対策
\r
1936 // if(DispUpDownErrDialog(downerr_dlg, Pkt->hWndTrans, Fname) == NO)
\r
1937 if(Canceled[Pkt->ThreadCount] == NO && ClearAll == NO && DispUpDownErrDialog(downerr_dlg, Pkt->hWndTrans, Fname) == NO)
\r
1943 if((strncmp(Pkt->Cmd, "NLST", 4) == 0) || (strncmp(Pkt->Cmd, "LIST", 4) == 0))
\r
1944 SetTaskMsg(MSGJPN101, Pkt->ExistSize);
\r
1946 // else if((Pkt->hWndTrans != NULL) && (TimeStart != 0))
\r
1947 // SetTaskMsg(MSGJPN102, TimeStart, Pkt->ExistSize/TimeStart);
\r
1948 else if((Pkt->hWndTrans != NULL) && (TimeStart[Pkt->ThreadCount] != 0))
\r
1949 SetTaskMsg(MSGJPN102, TimeStart[Pkt->ThreadCount], Pkt->ExistSize/TimeStart[Pkt->ThreadCount]);
\r
1951 SetTaskMsg(MSGJPN103, Pkt->ExistSize);
\r
1958 /*----- ダウンロード/アップロードエラーのダイアログを表示 --------------------
\r
1961 * int RedID : ダイアログボックスのリソースID
\r
1962 * HWND hWnd : 書き込み中ダイアログのウインドウ
\r
1963 * char *Fname : ファイル名
\r
1966 * int ステータス (YES=中止/NO=全て中止)
\r
1967 *----------------------------------------------------------------------------*/
\r
1969 static int DispUpDownErrDialog(int ResID, HWND hWnd, char *Fname)
\r
1972 hWnd = GetMainHwnd();
\r
1974 SoundPlay(SND_ERROR);
\r
1975 return(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(ResID), hWnd, UpDownErrorDialogProc, (LPARAM)Fname));
\r
1979 /*----- ダウンロードエラー/アップロードエラーダイアログのコールバック --------
\r
1982 * HWND hDlg : ウインドウハンドル
\r
1983 * UINT message : メッセージ番号
\r
1984 * WPARAM wParam : メッセージの WPARAM 引数
\r
1985 * LPARAM lParam : メッセージの LPARAM 引数
\r
1989 *----------------------------------------------------------------------------*/
\r
1991 static BOOL CALLBACK UpDownErrorDialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
\r
1995 case WM_INITDIALOG :
\r
1996 SendDlgItemMessage(hDlg, UPDOWN_ERR_FNAME, WM_SETTEXT, 0, (LPARAM)lParam);
\r
1997 SendDlgItemMessage(hDlg, UPDOWN_ERR_MSG, WM_SETTEXT, 0, (LPARAM)ErrMsg);
\r
2001 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2004 EndDialog(hDlg, YES);
\r
2008 EndDialog(hDlg, NO);
\r
2017 /*----- ダウンロードのリジュームの準備を行う ----------------------------------
\r
2020 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2021 * iont ProcMode : 処理モード(EXIST_xxx)
\r
2022 * LONGLONG Size : ロード済みのファイルのサイズ
\r
2023 * int *Mode : ファイル作成モード (CREATE_xxxx)
\r
2026 * int 転送を行うかどうか(YES/NO=このファイルを中止/NO_ALL=全て中止)
\r
2029 * Pkt->ExistSizeのセットを行なう
\r
2030 *----------------------------------------------------------------------------*/
\r
2032 static int SetDownloadResume(TRANSPACKET *Pkt, int ProcMode, LONGLONG Size, int *Mode, int *CancelCheckWork)
\r
2036 char Reply[ERR_MSG_LEN+7];
\r
2041 Pkt->ExistSize = 0;
\r
2042 *Mode = CREATE_ALWAYS;
\r
2044 if(ProcMode == EXIST_RESUME)
\r
2046 iRetCode = command(Pkt->ctrl_skt, Reply, CancelCheckWork, "REST %s", MakeNumString(Size, Tmp, FALSE));
\r
2047 if(iRetCode/100 < FTP_RETRY)
\r
2050 if(Pkt->hWndTrans != NULL)
\r
2051 Pkt->ExistSize = Size;
\r
2052 *Mode = OPEN_ALWAYS;
\r
2056 Com = DialogBox(GetFtpInst(), MAKEINTRESOURCE(noresume_dlg), Pkt->hWndTrans, NoResumeWndProc);
\r
2059 if(Com == NO_ALL) /* 全て中止 */
\r
2061 Pkt->Abort = ABORT_USER;
\r
2069 /*----- resumeエラーダイアログのコールバック ----------------------------------
\r
2072 * HWND hDlg : ウインドウハンドル
\r
2073 * UINT message : メッセージ番号
\r
2074 * WPARAM wParam : メッセージの WPARAM 引数
\r
2075 * LPARAM lParam : メッセージの LPARAM 引数
\r
2079 *----------------------------------------------------------------------------*/
\r
2081 static BOOL CALLBACK NoResumeWndProc(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2085 case WM_INITDIALOG :
\r
2089 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2092 EndDialog(hDlg, YES);
\r
2096 EndDialog(hDlg, NO);
\r
2099 case RESUME_CANCEL_ALL :
\r
2100 EndDialog(hDlg, NO_ALL);
\r
2110 /*----- アップロードを行なう --------------------------------------------------
\r
2113 * SOCKET cSkt : コントロールソケット
\r
2114 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2118 *----------------------------------------------------------------------------*/
\r
2120 static int DoUpLoad(SOCKET cSkt, TRANSPACKET *Pkt)
\r
2123 char Reply[ERR_MSG_LEN+7];
\r
2125 Pkt->ctrl_skt = cSkt;
\r
2127 if(Pkt->Mode != EXIST_IGNORE)
\r
2129 if(CheckFileReadable(Pkt->LocalFile) == FFFTP_SUCCESS)
\r
2131 if(Pkt->Type == TYPE_I)
\r
2132 Pkt->KanjiCode = KANJI_NOCNV;
\r
2135 // iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled, "TYPE %c", Pkt->Type);
\r
2136 iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled[Pkt->ThreadCount], "TYPE %c", Pkt->Type);
\r
2137 if(iRetCode/100 < FTP_RETRY)
\r
2139 if(Pkt->Mode == EXIST_UNIQUE)
\r
2140 strcpy(Pkt->Cmd, "STOU ");
\r
2142 if(Pkt->hWndTrans != NULL)
\r
2143 DispTransFileInfo(Pkt, MSGJPN104, TRUE, YES);
\r
2145 if(BackgrndMessageProc() == NO)
\r
2147 if(AskPasvMode() != YES)
\r
2148 iRetCode = UpLoadNonPassive(Pkt);
\r
2150 iRetCode = UpLoadPassive(Pkt);
\r
2156 SetErrorMsg(Reply);
\r
2159 if((Pkt->Attr != -1) && ((iRetCode/100) == FTP_COMPLETE))
\r
2161 // command(Pkt->ctrl_skt, Reply, &Canceled, "%s %03X %s", AskHostChmodCmd(), Pkt->Attr, Pkt->RemoteFile);
\r
2162 command(Pkt->ctrl_skt, Reply, &Canceled[Pkt->ThreadCount], "%s %03X %s", AskHostChmodCmd(), Pkt->Attr, Pkt->RemoteFile);
\r
2166 SetErrorMsg(MSGJPN105, Pkt->LocalFile);
\r
2167 SetTaskMsg(MSGJPN105, Pkt->LocalFile);
\r
2169 Pkt->Abort = ABORT_ERROR;
\r
2170 DispUploadFinishMsg(Pkt, iRetCode);
\r
2175 DispTransFileInfo(Pkt, MSGJPN106, TRUE, YES);
\r
2176 SetTaskMsg(MSGJPN107, Pkt->LocalFile);
\r
2183 /*----- 通常モードでファイルをアップロード ------------------------------------
\r
2186 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2190 *----------------------------------------------------------------------------*/
\r
2192 static int UpLoadNonPassive(TRANSPACKET *Pkt)
\r
2196 SOCKET data_socket = INVALID_SOCKET; // data channel socket
\r
2197 SOCKET listen_socket = INVALID_SOCKET; // data listen socket
\r
2199 struct sockaddr_in saSockAddr1;
\r
2201 char Reply[ERR_MSG_LEN+7];
\r
2204 // if((listen_socket = GetFTPListenSocket(Pkt->ctrl_skt, &Canceled)) != INVALID_SOCKET)
\r
2205 if((listen_socket = GetFTPListenSocket(Pkt->ctrl_skt, &Canceled[Pkt->ThreadCount])) != INVALID_SOCKET)
\r
2207 SetUploadResume(Pkt, Pkt->Mode, Pkt->ExistSize, &Resume);
\r
2209 sprintf(Buf, "%s%s", Pkt->Cmd, Pkt->RemoteFile);
\r
2211 sprintf(Buf, "%s%s", "APPE ", Pkt->RemoteFile);
\r
2214 // iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled, "%s", Buf);
\r
2215 iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled[Pkt->ThreadCount], "%s", Buf);
\r
2216 if((iRetCode/100) == FTP_PRELIM)
\r
2218 if(SocksGet2ndBindReply(listen_socket, &data_socket) == FFFTP_FAIL)
\r
2220 iLength=sizeof(saSockAddr1);
\r
2221 data_socket = do_accept(listen_socket,(struct sockaddr *)&saSockAddr1, (int *)&iLength);
\r
2223 if(shutdown(listen_socket, 1) != 0)
\r
2224 ReportWSError("shutdown listen", WSAGetLastError());
\r
2225 listen_socket = DoClose(listen_socket);
\r
2227 if(data_socket == INVALID_SOCKET)
\r
2229 SetErrorMsg(MSGJPN280);
\r
2230 ReportWSError("accept", WSAGetLastError());
\r
2234 DoPrintf("Skt=%u : accept from %s port %u", data_socket, inet_ntoa(saSockAddr1.sin_addr), ntohs(saSockAddr1.sin_port));
\r
2237 if(data_socket != INVALID_SOCKET)
\r
2239 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
2240 ReleaseMutex(hListAccMutex);
\r
2242 // iRetCode = UpLoadFile(Pkt, data_socket);
\r
2243 if(AskCryptMode() == CRYPT_FTPES || AskCryptMode() == CRYPT_FTPIS)
\r
2245 if(AttachSSL(data_socket))
\r
2246 iRetCode = UpLoadFile(Pkt, data_socket);
\r
2248 iRetCode = FTP_ERROR;
\r
2251 iRetCode = UpLoadFile(Pkt, data_socket);
\r
2252 data_socket = DoClose(data_socket);
\r
2257 SetErrorMsg(Reply);
\r
2258 SetTaskMsg(MSGJPN108);
\r
2259 listen_socket = DoClose(listen_socket);
\r
2265 SetErrorMsg(MSGJPN279);
\r
2268 DispUploadFinishMsg(Pkt, iRetCode);
\r
2274 /*----- Passiveモードでファイルをアップロード ---------------------------------
\r
2277 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2281 *----------------------------------------------------------------------------*/
\r
2283 static int UpLoadPassive(TRANSPACKET *Pkt)
\r
2286 SOCKET data_socket = INVALID_SOCKET; // data channel socket
\r
2292 char Reply[ERR_MSG_LEN+7];
\r
2295 // iRetCode = command(Pkt->ctrl_skt, Buf, &Canceled, "PASV");
\r
2296 iRetCode = command(Pkt->ctrl_skt, Buf, &Canceled[Pkt->ThreadCount], "PASV");
\r
2297 if(iRetCode/100 == FTP_COMPLETE)
\r
2299 if(GetAdrsAndPort(Buf, Adrs, &Port, 19) == FFFTP_SUCCESS)
\r
2302 // if((data_socket = connectsock(Adrs, Port, MSGJPN109, &Canceled)) != INVALID_SOCKET)
\r
2303 if((data_socket = connectsock(Adrs, Port, MSGJPN109, &Canceled[Pkt->ThreadCount])) != INVALID_SOCKET)
\r
2307 if(setsockopt(data_socket, IPPROTO_TCP, TCP_NODELAY, (LPSTR)&Flg, sizeof(Flg)) == SOCKET_ERROR)
\r
2308 ReportWSError("setsockopt", WSAGetLastError());
\r
2310 SetUploadResume(Pkt, Pkt->Mode, Pkt->ExistSize, &Resume);
\r
2312 sprintf(Buf, "%s%s", Pkt->Cmd, Pkt->RemoteFile);
\r
2314 sprintf(Buf, "%s%s", "APPE ", Pkt->RemoteFile);
\r
2317 // iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled, "%s", Buf);
\r
2318 iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled[Pkt->ThreadCount], "%s", Buf);
\r
2319 if(iRetCode/100 == FTP_PRELIM)
\r
2321 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
2322 ReleaseMutex(hListAccMutex);
\r
2324 // iRetCode = UpLoadFile(Pkt, data_socket);
\r
2325 if(AskCryptMode() == CRYPT_FTPES || AskCryptMode() == CRYPT_FTPIS)
\r
2327 if(AttachSSL(data_socket))
\r
2328 iRetCode = UpLoadFile(Pkt, data_socket);
\r
2330 iRetCode = FTP_ERROR;
\r
2333 iRetCode = UpLoadFile(Pkt, data_socket);
\r
2335 data_socket = DoClose(data_socket);
\r
2339 SetErrorMsg(Reply);
\r
2340 SetTaskMsg(MSGJPN110);
\r
2341 data_socket = DoClose(data_socket);
\r
2347 SetErrorMsg(MSGJPN281);
\r
2354 SetTaskMsg(MSGJPN111);
\r
2361 DispUploadFinishMsg(Pkt, iRetCode);
\r
2367 /*----- アップロードの実行 ----------------------------------------------------
\r
2370 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2371 * SOCKET dSkt : データソケット
\r
2377 * 転送の経過表示は、インターバルタイマで経過を表示する
\r
2378 * 転送ダイアログを出さないでアップロードすることはない
\r
2379 *----------------------------------------------------------------------------*/
\r
2381 static int UpLoadFile(TRANSPACKET *Pkt, SOCKET dSkt)
\r
2384 HANDLE iFileHandle;
\r
2385 SECURITY_ATTRIBUTES Sec;
\r
2386 char Buf[BUFSIZE];
\r
2387 char Buf2[BUFSIZE+3];
\r
2388 CODECONVINFO cInfo;
\r
2389 TERMCODECONVINFO tInfo;
\r
2396 char TmpBuf[ONELINE_BUF_SIZE];
\r
2400 #ifdef SET_BUFFER_SIZE
\r
2401 /* Add by H.Shirouzu at 2002/10/02 */
\r
2402 int buf_size = SOCKBUF_SIZE;
\r
2403 for ( ; buf_size > 0; buf_size /= 2)
\r
2404 if (setsockopt(dSkt, SOL_SOCKET, SO_SNDBUF, (char *)&buf_size, sizeof(buf_size)) == 0)
\r
2409 // 念のため送信バッファを無効にする
\r
2410 #ifdef DISABLE_TRANSFER_NETWORK_BUFFERS
\r
2412 setsockopt(dSkt, SOL_SOCKET, SO_SNDBUF, (char *)&buf_size, sizeof(buf_size));
\r
2415 Pkt->Abort = ABORT_NONE;
\r
2417 Sec.nLength = sizeof(SECURITY_ATTRIBUTES);
\r
2418 Sec.lpSecurityDescriptor = NULL;
\r
2419 Sec.bInheritHandle = FALSE;
\r
2421 if((iFileHandle = CreateFile(Pkt->LocalFile, GENERIC_READ,
\r
2422 FILE_SHARE_READ|FILE_SHARE_WRITE, &Sec, OPEN_EXISTING, 0, NULL)) != INVALID_HANDLE_VALUE)
\r
2425 char Buf3[(BUFSIZE + 3) * 4];
\r
2426 CODECONVINFO cInfo2;
\r
2427 int ProcessedBOM = NO;
\r
2428 if(Pkt->hWndTrans != NULL)
\r
2430 Low = GetFileSize(iFileHandle, &High);
\r
2431 Pkt->Size = MakeLongLong(High, Low);
\r
2433 High = (DWORD)HIGH32(Pkt->ExistSize);
\r
2434 Low = (DWORD)LOW32(Pkt->ExistSize);
\r
2435 SetFilePointer(iFileHandle, Low, &High, FILE_BEGIN);
\r
2438 // AllTransSizeNow = 0;
\r
2439 // TimeStart = time(NULL);
\r
2440 AllTransSizeNow[Pkt->ThreadCount] = 0;
\r
2441 TimeStart[Pkt->ThreadCount] = time(NULL);
\r
2442 SetTimer(Pkt->hWndTrans, TIMER_DISPLAY, DISPLAY_TIMING, NULL);
\r
2445 InitCodeConvInfo(&cInfo);
\r
2446 cInfo.KanaCnv = Pkt->KanaCnv;
\r
2447 InitTermCodeConvInfo(&tInfo);
\r
2449 InitCodeConvInfo(&cInfo2);
\r
2450 cInfo2.KanaCnv = Pkt->KanaCnv;
\r
2452 /*===== ファイルを送信するループ =====*/
\r
2453 while((Pkt->Abort == ABORT_NONE) &&
\r
2454 (ForceAbort == NO) &&
\r
2455 (ReadFile(iFileHandle, Buf, BUFSIZE, &iNumBytes, NULL) == TRUE))
\r
2457 if(iNumBytes == 0)
\r
2462 if((RmEOF == YES) && (Pkt->Type == TYPE_A))
\r
2464 if((EofPos = memchr(Buf, 0x1A, iNumBytes)) != NULL)
\r
2465 iNumBytes = EofPos - Buf;
\r
2469 if(Pkt->KanjiCode != KANJI_NOCNV)
\r
2472 cInfo.StrLen = iNumBytes;
\r
2474 cInfo.BufSize = BUFSIZE+3;
\r
2477 // ここで全てUTF-8へ変換する
\r
2478 // TODO: SJIS以外も直接UTF-8へ変換
\r
2479 // if(Pkt->KanjiCode == KANJI_JIS)
\r
2480 // Continue = ConvSJIStoJIS(&cInfo);
\r
2482 // Continue = ConvSJIStoEUC(&cInfo);
\r
2483 switch(Pkt->KanjiCodeDesired)
\r
2486 switch(Pkt->KanjiCode)
\r
2489 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
2490 // cInfo2.OutLen = cInfo.StrLen;
\r
2493 Continue = ConvSJIStoJIS(&cInfo);
\r
2494 cInfo2.Str = cInfo.Buf;
\r
2495 cInfo2.StrLen = cInfo.OutLen;
\r
2496 cInfo2.Buf = Buf3;
\r
2497 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2498 ConvJIStoSJIS(&cInfo2);
\r
2501 Continue = ConvSJIStoJIS(&cInfo);
\r
2502 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2503 cInfo2.OutLen = cInfo.OutLen;
\r
2506 Continue = ConvSJIStoEUC(&cInfo);
\r
2507 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2508 cInfo2.OutLen = cInfo.OutLen;
\r
2511 if(ProcessedBOM == NO)
\r
2513 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
2514 cInfo2.OutLen = 3;
\r
2516 ProcessedBOM = YES;
\r
2519 Continue = ConvSJIStoUTF8N(&cInfo);
\r
2520 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2521 cInfo2.OutLen = cInfo.OutLen;
\r
2526 switch(Pkt->KanjiCode)
\r
2529 Continue = ConvJIStoSJIS(&cInfo);
\r
2530 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2531 cInfo2.OutLen = cInfo.OutLen;
\r
2534 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
2535 // cInfo2.OutLen = cInfo.StrLen;
\r
2538 Continue = ConvJIStoSJIS(&cInfo);
\r
2539 cInfo2.Str = cInfo.Buf;
\r
2540 cInfo2.StrLen = cInfo.OutLen;
\r
2541 cInfo2.Buf = Buf3;
\r
2542 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2543 ConvSJIStoJIS(&cInfo2);
\r
2546 Continue = ConvJIStoSJIS(&cInfo);
\r
2547 cInfo2.Str = cInfo.Buf;
\r
2548 cInfo2.StrLen = cInfo.OutLen;
\r
2549 cInfo2.Buf = Buf3;
\r
2550 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2551 ConvSJIStoEUC(&cInfo2);
\r
2554 if(ProcessedBOM == NO)
\r
2556 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
2557 cInfo2.OutLen = 3;
\r
2559 ProcessedBOM = YES;
\r
2562 Continue = ConvJIStoSJIS(&cInfo);
\r
2563 cInfo2.Str = cInfo.Buf;
\r
2564 cInfo2.StrLen = cInfo.OutLen;
\r
2565 cInfo2.Buf = Buf3;
\r
2566 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2567 ConvSJIStoUTF8N(&cInfo2);
\r
2572 switch(Pkt->KanjiCode)
\r
2575 Continue = ConvEUCtoSJIS(&cInfo);
\r
2576 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2577 cInfo2.OutLen = cInfo.OutLen;
\r
2580 Continue = ConvEUCtoSJIS(&cInfo);
\r
2581 cInfo2.Str = cInfo.Buf;
\r
2582 cInfo2.StrLen = cInfo.OutLen;
\r
2583 cInfo2.Buf = Buf3;
\r
2584 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2585 ConvSJIStoJIS(&cInfo2);
\r
2588 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
2589 // cInfo2.OutLen = cInfo.StrLen;
\r
2592 Continue = ConvEUCtoSJIS(&cInfo);
\r
2593 cInfo2.Str = cInfo.Buf;
\r
2594 cInfo2.StrLen = cInfo.OutLen;
\r
2595 cInfo2.Buf = Buf3;
\r
2596 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2597 ConvSJIStoEUC(&cInfo2);
\r
2600 if(ProcessedBOM == NO)
\r
2602 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
2603 cInfo2.OutLen = 3;
\r
2605 ProcessedBOM = YES;
\r
2608 Continue = ConvEUCtoSJIS(&cInfo);
\r
2609 cInfo2.Str = cInfo.Buf;
\r
2610 cInfo2.StrLen = cInfo.OutLen;
\r
2611 cInfo2.Buf = Buf3;
\r
2612 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2613 ConvSJIStoUTF8N(&cInfo2);
\r
2618 if(ProcessedBOM == NO)
\r
2620 if(memcmp(Buf, "\xEF\xBB\xBF", 3) == 0)
\r
2623 cInfo.StrLen -= 3;
\r
2625 cInfo2.OutLen = 0;
\r
2626 switch(Pkt->KanjiCode)
\r
2629 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
2630 cInfo2.OutLen = 3;
\r
2634 ProcessedBOM = YES;
\r
2637 switch(Pkt->KanjiCode)
\r
2640 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
2641 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2642 cInfo2.OutLen = cInfo.OutLen;
\r
2645 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
2646 cInfo2.Str = cInfo.Buf;
\r
2647 cInfo2.StrLen = cInfo.OutLen;
\r
2648 cInfo2.Buf = Buf3;
\r
2649 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2650 ConvSJIStoJIS(&cInfo2);
\r
2653 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
2654 cInfo2.Str = cInfo.Buf;
\r
2655 cInfo2.StrLen = cInfo.OutLen;
\r
2656 cInfo2.Buf = Buf3;
\r
2657 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2658 ConvSJIStoEUC(&cInfo2);
\r
2661 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
2662 cInfo2.OutLen = cInfo.StrLen;
\r
2669 // if(TermCodeConvAndSend(&tInfo, dSkt, Buf2, cInfo.OutLen, Pkt->Type) == FFFTP_FAIL)
\r
2670 if(TermCodeConvAndSend(Pkt->ThreadCount, &tInfo, dSkt, Buf3, cInfo2.OutLen, Pkt->Type) == FFFTP_FAIL)
\r
2672 Pkt->Abort = ABORT_ERROR;
\r
2676 while(Continue == YES);
\r
2681 // if(TermCodeConvAndSend(&tInfo, dSkt, Buf, iNumBytes, Pkt->Type) == FFFTP_FAIL)
\r
2682 if(TermCodeConvAndSend(Pkt->ThreadCount, &tInfo, dSkt, Buf, iNumBytes, Pkt->Type) == FFFTP_FAIL)
\r
2683 Pkt->Abort = ABORT_ERROR;
\r
2686 Pkt->ExistSize += iNumBytes;
\r
2687 if(Pkt->hWndTrans != NULL)
\r
2689 // AllTransSizeNow += iNumBytes;
\r
2690 AllTransSizeNow[Pkt->ThreadCount] += iNumBytes;
\r
2692 if(BackgrndMessageProc() == YES)
\r
2695 if(EofPos != NULL)
\r
2699 if((ForceAbort == NO) && (Pkt->Abort == ABORT_NONE))
\r
2702 if(Pkt->KanjiCode != KANJI_NOCNV)
\r
2705 cInfo.BufSize = BUFSIZE+3;
\r
2706 FlushRestData(&cInfo);
\r
2707 switch(Pkt->KanjiCodeDesired)
\r
2710 switch(Pkt->KanjiCode)
\r
2714 cInfo2.Str = cInfo.Buf;
\r
2715 cInfo2.StrLen = cInfo.OutLen;
\r
2716 cInfo2.Buf = Buf3;
\r
2717 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2718 ConvJIStoSJIS(&cInfo2);
\r
2721 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2722 cInfo2.OutLen = cInfo.OutLen;
\r
2725 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2726 cInfo2.OutLen = cInfo.OutLen;
\r
2729 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2730 cInfo2.OutLen = cInfo.OutLen;
\r
2735 switch(Pkt->KanjiCode)
\r
2738 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2739 cInfo2.OutLen = cInfo.OutLen;
\r
2743 cInfo2.Str = cInfo.Buf;
\r
2744 cInfo2.StrLen = cInfo.OutLen;
\r
2745 cInfo2.Buf = Buf3;
\r
2746 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2747 ConvSJIStoJIS(&cInfo2);
\r
2750 cInfo2.Str = cInfo.Buf;
\r
2751 cInfo2.StrLen = cInfo.OutLen;
\r
2752 cInfo2.Buf = Buf3;
\r
2753 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2754 ConvSJIStoEUC(&cInfo2);
\r
2757 cInfo2.Str = cInfo.Buf;
\r
2758 cInfo2.StrLen = cInfo.OutLen;
\r
2759 cInfo2.Buf = Buf3;
\r
2760 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2761 ConvSJIStoUTF8N(&cInfo2);
\r
2766 switch(Pkt->KanjiCode)
\r
2769 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2770 cInfo2.OutLen = cInfo.OutLen;
\r
2773 cInfo2.Str = cInfo.Buf;
\r
2774 cInfo2.StrLen = cInfo.OutLen;
\r
2775 cInfo2.Buf = Buf3;
\r
2776 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2777 ConvSJIStoJIS(&cInfo2);
\r
2781 cInfo2.Str = cInfo.Buf;
\r
2782 cInfo2.StrLen = cInfo.OutLen;
\r
2783 cInfo2.Buf = Buf3;
\r
2784 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2785 ConvSJIStoEUC(&cInfo2);
\r
2788 cInfo2.Str = cInfo.Buf;
\r
2789 cInfo2.StrLen = cInfo.OutLen;
\r
2790 cInfo2.Buf = Buf3;
\r
2791 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2792 ConvSJIStoUTF8N(&cInfo2);
\r
2797 switch(Pkt->KanjiCode)
\r
2800 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2801 cInfo2.OutLen = cInfo.OutLen;
\r
2804 cInfo2.Str = cInfo.Buf;
\r
2805 cInfo2.StrLen = cInfo.OutLen;
\r
2806 cInfo2.Buf = Buf3;
\r
2807 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2808 ConvSJIStoJIS(&cInfo2);
\r
2811 cInfo2.Str = cInfo.Buf;
\r
2812 cInfo2.StrLen = cInfo.OutLen;
\r
2813 cInfo2.Buf = Buf3;
\r
2814 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2815 ConvSJIStoEUC(&cInfo2);
\r
2818 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2819 cInfo2.OutLen = cInfo.OutLen;
\r
2825 // if(TermCodeConvAndSend(&tInfo, dSkt, Buf2, cInfo.OutLen, Pkt->Type) == FFFTP_FAIL)
\r
2826 if(TermCodeConvAndSend(Pkt->ThreadCount, &tInfo, dSkt, Buf3, cInfo2.OutLen, Pkt->Type) == FFFTP_FAIL)
\r
2827 Pkt->Abort = ABORT_ERROR;
\r
2828 cInfo2.Buf = Buf3;
\r
2829 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2830 FlushRestData(&cInfo2);
\r
2831 if(TermCodeConvAndSend(Pkt->ThreadCount, &tInfo, dSkt, Buf3, cInfo2.OutLen, Pkt->Type) == FFFTP_FAIL)
\r
2832 Pkt->Abort = ABORT_ERROR;
\r
2836 tInfo.BufSize = BUFSIZE+3;
\r
2837 FlushRestTermCodeConvData(&tInfo);
\r
2839 // if(SendData(dSkt, Buf2, tInfo.OutLen, 0, &Canceled) == FFFTP_FAIL)
\r
2840 if(SendData(dSkt, Buf2, tInfo.OutLen, 0, &Canceled[Pkt->ThreadCount]) == FFFTP_FAIL)
\r
2841 Pkt->Abort = ABORT_ERROR;
\r
2845 if(Pkt->hWndTrans != NULL)
\r
2847 KillTimer(Pkt->hWndTrans, TIMER_DISPLAY);
\r
2848 DispTransferStatus(Pkt->hWndTrans, YES, Pkt);
\r
2850 // TimeStart = time(NULL) - TimeStart + 1;
\r
2851 TimeStart[Pkt->ThreadCount] = time(NULL) - TimeStart[Pkt->ThreadCount] + 1;
\r
2853 CloseHandle(iFileHandle);
\r
2857 SetErrorMsg(MSGJPN112, Pkt->LocalFile);
\r
2858 SetTaskMsg(MSGJPN112, Pkt->LocalFile);
\r
2859 Pkt->Abort = ABORT_ERROR;
\r
2862 if(shutdown(dSkt, 1) != 0)
\r
2863 ReportWSError("shutdown", WSAGetLastError());
\r
2867 while(do_recv(dSkt, Buf, BUFSIZE, 0, &TimeOutErr, &Canceled) > 0)
\r
2872 // iRetCode = ReadReplyMessage(Pkt->ctrl_skt, Buf, 1024, &Canceled, TmpBuf);
\r
2873 iRetCode = ReadReplyMessage(Pkt->ctrl_skt, Buf, 1024, &Canceled[Pkt->ThreadCount], TmpBuf);
\r
2876 //DoPrintf("##UP REPLY : %s", Buf);
\r
2878 if(iRetCode >= FTP_RETRY)
\r
2881 if(Pkt->Abort != ABORT_NONE)
\r
2888 /*----- バッファの内容を改行コード変換して送信 --------------------------------
\r
2891 * TERMCODECONVINFO *tInfo : 改行コード変換パケット
\r
2892 * SOCKET Skt : ソケット
\r
2893 * char *Data : データ
\r
2894 * int Size : データのサイズ
\r
2895 * int Ascii : モード (TYPE_xx)
\r
2899 *----------------------------------------------------------------------------*/
\r
2902 //static int TermCodeConvAndSend(TERMCODECONVINFO *tInfo, SOCKET Skt, char *Data, int Size, int Ascii)
\r
2903 static int TermCodeConvAndSend(int ThreadCount, TERMCODECONVINFO *tInfo, SOCKET Skt, char *Data, int Size, int Ascii)
\r
2905 char Buf3[BUFSIZE*2];
\r
2909 Ret = FFFTP_SUCCESS;
\r
2911 // CR-LF以外の改行コードを変換しないモードはここへ追加
\r
2912 if(Ascii == TYPE_A)
\r
2914 tInfo->Str = Data;
\r
2915 tInfo->StrLen = Size;
\r
2916 tInfo->Buf = Buf3;
\r
2917 tInfo->BufSize = BUFSIZE*2;
\r
2920 Continue = ConvTermCodeToCRLF(tInfo);
\r
2922 // if((Ret = SendData(Skt, Buf3, tInfo->OutLen, 0, &Canceled)) == FFFTP_FAIL)
\r
2923 if((Ret = SendData(Skt, Buf3, tInfo->OutLen, 0, &Canceled[ThreadCount])) == FFFTP_FAIL)
\r
2926 while(Continue == YES);
\r
2930 // Ret = SendData(Skt, Data, Size, 0, &Canceled);
\r
2931 Ret = SendData(Skt, Data, Size, 0, &Canceled[ThreadCount]);
\r
2937 /*----- アップロード終了/中止時のメッセージを表示 ----------------------------
\r
2940 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2941 * int iRetCode : 応答コード
\r
2945 *----------------------------------------------------------------------------*/
\r
2947 static void DispUploadFinishMsg(TRANSPACKET *Pkt, int iRetCode)
\r
2949 if(ForceAbort == NO)
\r
2951 if((iRetCode/100) >= FTP_CONTINUE)
\r
2954 // if((Pkt->hWndTrans != NULL) && (TimeStart != 0))
\r
2955 // SetTaskMsg(MSGJPN113, TimeStart, Pkt->ExistSize/TimeStart);
\r
2956 if((Pkt->hWndTrans != NULL) && (TimeStart[Pkt->ThreadCount] != 0))
\r
2957 SetTaskMsg(MSGJPN113, TimeStart[Pkt->ThreadCount], Pkt->ExistSize/TimeStart[Pkt->ThreadCount]);
\r
2959 SetTaskMsg(MSGJPN114);
\r
2961 if(Pkt->Abort != ABORT_USER)
\r
2963 // 全て中止を選択後にダイアログが表示されるバグ対策
\r
2964 // if(DispUpDownErrDialog(uperr_dlg, Pkt->hWndTrans, Pkt->LocalFile) == NO)
\r
2965 if(Canceled[Pkt->ThreadCount] == NO && ClearAll == NO && DispUpDownErrDialog(uperr_dlg, Pkt->hWndTrans, Pkt->LocalFile) == NO)
\r
2972 // if((Pkt->hWndTrans != NULL) && (TimeStart != 0))
\r
2973 // SetTaskMsg(MSGJPN115, TimeStart, Pkt->ExistSize/TimeStart);
\r
2974 if((Pkt->hWndTrans != NULL) && (TimeStart[Pkt->ThreadCount] != 0))
\r
2975 SetTaskMsg(MSGJPN115, TimeStart[Pkt->ThreadCount], Pkt->ExistSize/TimeStart[Pkt->ThreadCount]);
\r
2977 SetTaskMsg(MSGJPN116);
\r
2984 /*----- アップロードのリジュームの準備を行う ----------------------------------
\r
2987 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2988 * iont ProcMode : 処理モード(EXIST_xxx)
\r
2989 * LONGLONG Size : ホストにあるファイルのサイズ
\r
2990 * int *Mode : リジュームを行うかどうか (YES/NO)
\r
2996 * Pkt->ExistSizeのセットを行なう
\r
2997 *----------------------------------------------------------------------------*/
\r
2999 static int SetUploadResume(TRANSPACKET *Pkt, int ProcMode, LONGLONG Size, int *Mode)
\r
3001 Pkt->ExistSize = 0;
\r
3003 if(ProcMode == EXIST_RESUME)
\r
3005 if(Pkt->hWndTrans != NULL)
\r
3007 Pkt->ExistSize = Size;
\r
3015 /*----- 転送中ダイアログボックスのコールバック --------------------------------
\r
3018 * HWND hDlg : ウインドウハンドル
\r
3019 * UINT message : メッセージ番号
\r
3020 * WPARAM wParam : メッセージの WPARAM 引数
\r
3021 * LPARAM lParam : メッセージの LPARAM 引数
\r
3025 *----------------------------------------------------------------------------*/
\r
3027 static LRESULT CALLBACK TransDlgProc(HWND hDlg, UINT Msg, WPARAM wParam, LPARAM lParam)
\r
3033 // static TRANSPACKET *Pkt;
\r
3039 case WM_INITDIALOG :
\r
3040 GetWindowRect(hDlg, &RectDlg);
\r
3041 RectDlg.right -= RectDlg.left;
\r
3042 RectDlg.bottom -= RectDlg.top;
\r
3043 GetWindowRect(GetMainHwnd(), &RectPar);
\r
3045 ((RectPar.right + RectPar.left) / 2) - (RectDlg.right / 2),
\r
3046 ((RectPar.bottom + RectPar.top) / 2) - (RectDlg.bottom / 2),
\r
3051 hMenu = GetSystemMenu(hDlg, FALSE);
\r
3052 EnableMenuItem(hMenu, SC_CLOSE, MF_GRAYED);
\r
3056 switch(LOWORD(wParam))
\r
3058 case TRANS_STOP_NEXT :
\r
3062 case TRANS_STOP_ALL :
\r
3064 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
3065 Canceled[i] = YES;
\r
3066 /* ここに break はない */
\r
3069 if(!(Pkt = (TRANSPACKET*)GetWindowLong(hDlg, GWL_USERDATA)))
\r
3071 Pkt->Abort = ABORT_USER;
\r
3072 // Canceled = YES;
\r
3073 Canceled[Pkt->ThreadCount] = YES;
\r
3079 if(wParam == TIMER_DISPLAY)
\r
3081 if(MoveToForeground == YES)
\r
3082 SetForegroundWindow(hDlg);
\r
3083 MoveToForeground = NO;
\r
3084 KillTimer(hDlg, TIMER_DISPLAY);
\r
3085 if(!(Pkt = (TRANSPACKET*)GetWindowLong(hDlg, GWL_USERDATA)))
\r
3087 if(Canceled[Pkt->ThreadCount] == YES)
\r
3088 Pkt->Abort = ABORT_USER;
\r
3089 DispTransferStatus(hDlg, NO, Pkt);
\r
3090 SetTimer(hDlg, TIMER_DISPLAY, DISPLAY_TIMING, NULL);
\r
3094 case WM_SET_PACKET :
\r
3095 // Pkt = (TRANSPACKET *)lParam;
\r
3096 SetWindowLong(hDlg, GWL_USERDATA, (LONG)lParam);
\r
3103 /*----- 転送ステータスを表示 --------------------------------------------------
\r
3106 * HWND hWnd : ウインドウハンドル
\r
3107 * int End : 転送が完了したかどうか (YES/NO)
\r
3111 *----------------------------------------------------------------------------*/
\r
3113 static void DispTransferStatus(HWND hWnd, int End, TRANSPACKET *Pkt)
\r
3127 SendMessage(hWnd, WM_GETTEXT, 79, (LPARAM)Str);
\r
3128 if((Pos = strchr(Str, ')')) != NULL)
\r
3132 sprintf(Tmp, "(%d)%s", AskTransferFileNum(), Pos);
\r
3133 SendMessage(hWnd, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
3135 if(Pkt->Abort == ABORT_NONE)
\r
3140 // TotalLap = time(NULL) - TimeStart + 1;
\r
3141 TotalLap = time(NULL) - TimeStart[Pkt->ThreadCount] + 1;
\r
3146 // Bps = AllTransSizeNow / TotalLap;
\r
3147 Bps = AllTransSizeNow[Pkt->ThreadCount] / TotalLap;
\r
3148 Transed = Pkt->Size - Pkt->ExistSize;
\r
3150 if(Pkt->Size <= 0)
\r
3151 sprintf(Tmp, "%d ", Pkt->ExistSize);
\r
3152 else if(Pkt->Size < 1024)
\r
3153 sprintf(Tmp, "%s / %s ", MakeNumString(Pkt->ExistSize, Num1, TRUE), MakeNumString(Pkt->Size, Num2, TRUE));
\r
3155 sprintf(Tmp, "%sk / %sk ", MakeNumString(Pkt->ExistSize/1024, Num1, TRUE), MakeNumString(Pkt->Size/1024, Num2, TRUE));
\r
3159 sprintf(Tmp, "( 0 B/S )");
\r
3160 else if(Bps < 1000)
\r
3161 sprintf(Tmp, "( %s B/S )", MakeNumString(Bps, Num1, TRUE));
\r
3163 sprintf(Tmp, "( %s.%02d KB/S )", MakeNumString(Bps/1000, Num1, TRUE), (int)((Bps%1000)/10));
\r
3166 if((Bps > 0) && (Pkt->Size > 0) && (Transed >= 0))
\r
3168 sprintf(Tmp, " %d:%02d", (int)((Transed/Bps)/60), (int)((Transed/Bps)%60));
\r
3172 strcat(Str, " ??:??");
\r
3175 strcpy(Str, MSGJPN117);
\r
3178 strcpy(Str, MSGJPN118);
\r
3180 SendDlgItemMessage(hWnd, TRANS_STATUS, WM_SETTEXT, 0, (LPARAM)Str);
\r
3182 if(Pkt->Size <= 0)
\r
3184 else if(Pkt->Size < 1024*1024)
\r
3185 Per = (int)(Pkt->ExistSize * 100 / Pkt->Size);
\r
3187 Per = (int)((Pkt->ExistSize/1024) * 100 / (Pkt->Size/1024));
\r
3188 SendDlgItemMessage(hWnd, TRANS_TIME_BAR, PBM_SETPOS, Per, 0);
\r
3194 /*----- 転送するファイルの情報を表示 ------------------------------------------
\r
3197 * TRANSPACKET *Pkt : 転送ファイル情報
\r
3198 * char *Title : ウインドウのタイトル
\r
3199 * int SkipButton : 「このファイルを中止」ボタンの有無 (TRUE/FALSE)
\r
3200 * int Info : ファイル情報を表示するかどうか (YES/NO)
\r
3204 *----------------------------------------------------------------------------*/
\r
3206 static void DispTransFileInfo(TRANSPACKET *Pkt, char *Title, int SkipButton, int Info)
\r
3210 if(Pkt->hWndTrans != NULL)
\r
3212 EnableWindow(GetDlgItem(Pkt->hWndTrans, IDCANCEL), SkipButton);
\r
3214 sprintf(Tmp, "(%d)%s", AskTransferFileNum(), Title);
\r
3215 SendMessage(Pkt->hWndTrans, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
3216 SendDlgItemMessage(Pkt->hWndTrans, TRANS_STATUS, WM_SETTEXT, 0, (LPARAM)"");
\r
3218 SendDlgItemMessage(Pkt->hWndTrans, TRANS_TIME_BAR, PBM_SETRANGE, 0, MAKELPARAM(0, 100));
\r
3219 SendDlgItemMessage(Pkt->hWndTrans, TRANS_TIME_BAR, PBM_SETSTEP, 1, 0);
\r
3220 SendDlgItemMessage(Pkt->hWndTrans, TRANS_TIME_BAR, PBM_SETPOS, 0, 0);
\r
3224 DispStaticText(GetDlgItem(Pkt->hWndTrans, TRANS_REMOTE), Pkt->RemoteFile);
\r
3225 DispStaticText(GetDlgItem(Pkt->hWndTrans, TRANS_LOCAL), Pkt->LocalFile);
\r
3227 if(Pkt->Type == TYPE_I)
\r
3228 SendDlgItemMessage(Pkt->hWndTrans, TRANS_MODE, WM_SETTEXT, 0, (LPARAM)MSGJPN119);
\r
3229 else if(Pkt->Type == TYPE_A)
\r
3230 SendDlgItemMessage(Pkt->hWndTrans, TRANS_MODE, WM_SETTEXT, 0, (LPARAM)MSGJPN120);
\r
3233 if(Pkt->KanjiCode == KANJI_NOCNV)
\r
3234 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN121);
\r
3235 else if(Pkt->KanjiCode == KANJI_SJIS)
\r
3236 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN305);
\r
3237 else if(Pkt->KanjiCode == KANJI_JIS)
\r
3238 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN122);
\r
3239 else if(Pkt->KanjiCode == KANJI_EUC)
\r
3240 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN123);
\r
3241 else if(Pkt->KanjiCode == KANJI_UTF8N)
\r
3242 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN306);
\r
3246 SendDlgItemMessage(Pkt->hWndTrans, TRANS_REMOTE, WM_SETTEXT, 0, (LPARAM)"");
\r
3247 SendDlgItemMessage(Pkt->hWndTrans, TRANS_LOCAL, WM_SETTEXT, 0, (LPARAM)"");
\r
3248 SendDlgItemMessage(Pkt->hWndTrans, TRANS_MODE, WM_SETTEXT, 0, (LPARAM)"");
\r
3249 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)"");
\r
3256 /*----- PASVコマンドの戻り値からアドレスとポート番号を抽出 --------------------
\r
3259 * char *Str : PASVコマンドのリプライ
\r
3260 * char *Adrs : アドレスのコピー先 ("www.xxx.yyy.zzz")
\r
3261 * int *Port : ポート番号をセットするワーク
\r
3262 * int Max : アドレス文字列の最大長
\r
3266 * FFFTP_SUCCESS/FFFTP_FAIL
\r
3267 *----------------------------------------------------------------------------*/
\r
3269 static int GetAdrsAndPort(char *Str, char *Adrs, int *Port, int Max)
\r
3277 Pos = strchr(Str, '(');
\r
3281 Btm = strchr(Pos, ',');
\r
3285 Btm = strchr(Btm, ',');
\r
3289 Btm = strchr(Btm, ',');
\r
3293 Btm = strchr(Btm, ',');
\r
3296 if((Btm - Pos) <= Max)
\r
3298 strncpy(Adrs, Pos, Btm - Pos);
\r
3299 *(Adrs + (Btm - Pos)) = NUL;
\r
3300 ReplaceAll(Adrs, ',', '.');
\r
3303 Btm = strchr(Pos, ',');
\r
3307 *Port = (atoi(Pos) * 0x100) + atoi(Btm);
\r
3308 Sts = FFFTP_SUCCESS;
\r
3320 /*----- Windowsのスペシャルデバイスかどうかを返す -----------------------------
\r
3323 * char *Fname : ファイル名
\r
3326 * int ステータス (YES/NO)
\r
3327 *----------------------------------------------------------------------------*/
\r
3329 static int IsSpecialDevice(char *Fname)
\r
3335 // if((_stricmp(Fname, "CON") == 0) ||
\r
3336 // (_stricmp(Fname, "PRN") == 0) ||
\r
3337 // (_stricmp(Fname, "AUX") == 0) ||
\r
3338 // (_strnicmp(Fname, "CON.", 4) == 0) ||
\r
3339 // (_strnicmp(Fname, "PRN.", 4) == 0) ||
\r
3340 // (_strnicmp(Fname, "AUX.", 4) == 0))
\r
3344 if(_strnicmp(Fname, "AUX", 3) == 0|| _strnicmp(Fname, "CON", 3) == 0 || _strnicmp(Fname, "NUL", 3) == 0 || _strnicmp(Fname, "PRN", 3) == 0)
\r
3346 if(*(Fname + 3) == '\0' || *(Fname + 3) == '.')
\r
3349 else if(_strnicmp(Fname, "COM", 3) == 0 || _strnicmp(Fname, "LPT", 3) == 0)
\r
3351 if(isdigit(*(Fname + 3)) != 0)
\r
3353 if(*(Fname + 4) == '\0' || *(Fname + 4) == '.')
\r
3361 /*----- ミラーリングでのファイル削除確認 --------------------------------------
\r
3366 * TRANSPACKET *Pkt
\r
3370 *----------------------------------------------------------------------------*/
\r
3372 static int MirrorDelNotify(int Cur, int Notify, TRANSPACKET *Pkt)
\r
3374 MIRRORDELETEINFO DelInfo;
\r
3377 if(((Cur == WIN_LOCAL) && (MirDownDelNotify == NO)) ||
\r
3378 ((Cur == WIN_REMOTE) && (MirUpDelNotify == NO)))
\r
3383 if(Notify != YES_ALL)
\r
3385 DelInfo.Cur = Cur;
\r
3386 DelInfo.Pkt = Pkt;
\r
3387 hWnd = Pkt->hWndTrans;
\r
3389 hWnd = GetMainHwnd();
\r
3390 Notify = DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(delete_dlg), hWnd, MirrorDeleteDialogCallBack, (LPARAM)&DelInfo);
\r
3396 /*----- ミラーリングでのファイル削除ダイアログのコールバック ------------------
\r
3399 * HWND hDlg : ウインドウハンドル
\r
3400 * UINT message : メッセージ番号
\r
3401 * WPARAM wParam : メッセージの WPARAM 引数
\r
3402 * LPARAM lParam : メッセージの LPARAM 引数
\r
3406 *----------------------------------------------------------------------------*/
\r
3408 static BOOL CALLBACK MirrorDeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
3410 static MIRRORDELETEINFO *DelInfo;
\r
3413 case WM_INITDIALOG :
\r
3414 DelInfo = (MIRRORDELETEINFO *)lParam;
\r
3416 if(DelInfo->Cur == WIN_LOCAL)
\r
3418 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN124);
\r
3419 SendDlgItemMessage(hDlg, DELETE_TEXT, WM_SETTEXT, 0, (LPARAM)DelInfo->Pkt->LocalFile);
\r
3423 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN125);
\r
3424 SendDlgItemMessage(hDlg, DELETE_TEXT, WM_SETTEXT, 0, (LPARAM)DelInfo->Pkt->RemoteFile);
\r
3429 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
3432 EndDialog(hDlg, YES);
\r
3436 EndDialog(hDlg, NO);
\r
3440 EndDialog(hDlg, YES_ALL);
\r
3445 EndDialog(hDlg, NO_ALL);
\r
3457 static void SetErrorMsg(char *fmt, ...)
\r
3461 if(strlen(ErrMsg) == 0)
\r
3463 va_start(Args, fmt);
\r
3464 wvsprintf(ErrMsg, fmt, Args);
\r
3475 /*----- ダウンロード時の不正なパスをチェック ----------------------------------
\r
3478 * TRANSPACKET *packet : ダウンロード情報
\r
3481 * int YES=不正なパス/NO=問題ないパス
\r
3482 *----------------------------------------------------------------------------*/
\r
3483 int CheckPathViolation(TRANSPACKET *packet)
\r
3488 if((strncmp(packet->RemoteFile, "..\\", 3) == 0) ||
\r
3489 (strncmp(packet->RemoteFile, "../", 3) == 0) ||
\r
3490 (strstr(packet->RemoteFile, "\\..\\") != NULL) ||
\r
3491 (strstr(packet->RemoteFile, "/../") != NULL))
\r
3493 msg = malloc(strlen(MSGJPN297) + strlen(packet->RemoteFile) + 1);
\r
3496 sprintf(msg, MSGJPN297, packet->RemoteFile);
\r
3497 MessageBox(GetMainHwnd(), msg, MSGJPN086, MB_OK);
\r