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
45 //#include <winsock.h>
\r
46 #include <winsock2.h>
\r
47 #include <windowsx.h>
\r
48 #include <commctrl.h>
\r
49 #include <process.h>
\r
52 #include "resource.h"
\r
54 #define SET_BUFFER_SIZE
\r
56 /* Add by H.Shirouzu at 2002/10/02 */
\r
58 #define BUFSIZE (32 * 1024)
\r
59 #define SOCKBUF_SIZE (256 * 1024)
\r
62 #ifdef DISABLE_TRANSFER_NETWORK_BUFFERS
\r
64 #define BUFSIZE (64 * 1024) // RWIN値以下で充分な大きさが望ましいと思われる。
\r
65 #undef SET_BUFFER_SIZE
\r
68 #define TIMER_DISPLAY 1 /* 表示更新用タイマのID */
\r
69 #define DISPLAY_TIMING 500 /* 表示更新時間 0.5秒 */
\r
71 #define ERR_MSG_LEN 1024
\r
81 /*===== プロトタイプ =====*/
\r
83 static void DispTransPacket(TRANSPACKET *Pkt);
\r
84 static void EraseTransFileList(void);
\r
85 static ULONG WINAPI TransferThread(void *Dummy);
\r
86 static int MakeNonFullPath(TRANSPACKET *Pkt, char *CurDir, char *Tmp);
\r
87 static int DownLoadNonPassive(TRANSPACKET *Pkt, int *CancelCheckWork);
\r
88 static int DownLoadPassive(TRANSPACKET *Pkt, int *CancelCheckWork);
\r
89 static int DownLoadFile(TRANSPACKET *Pkt, SOCKET dSkt, int CreateMode, int *CancelCheckWork);
\r
90 static void DispDownloadFinishMsg(TRANSPACKET *Pkt, int iRetCode);
\r
92 //static int DispUpDownErrDialog(int ResID, HWND hWnd, char *Fname);
\r
93 static int DispUpDownErrDialog(int ResID, HWND hWnd, TRANSPACKET *Pkt);
\r
94 static BOOL CALLBACK UpDownErrorDialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam);
\r
95 static int SetDownloadResume(TRANSPACKET *Pkt, int ProcMode, LONGLONG Size, int *Mode, int *CancelCheckWork);
\r
96 static BOOL CALLBACK NoResumeWndProc(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
97 static int DoUpLoad(SOCKET cSkt, TRANSPACKET *Pkt);
\r
98 static int UpLoadNonPassive(TRANSPACKET *Pkt);
\r
99 static int UpLoadPassive(TRANSPACKET *Pkt);
\r
100 static int UpLoadFile(TRANSPACKET *Pkt, SOCKET dSkt);
\r
102 //static int TermCodeConvAndSend(TERMCODECONVINFO *tInfo, SOCKET Skt, char *Data, int Size, int Ascii);
\r
103 static int TermCodeConvAndSend(TERMCODECONVINFO *tInfo, SOCKET Skt, char *Data, int Size, int Ascii, int *CancelCheckWork);
\r
104 static void DispUploadFinishMsg(TRANSPACKET *Pkt, int iRetCode);
\r
105 static int SetUploadResume(TRANSPACKET *Pkt, int ProcMode, LONGLONG Size, int *Mode);
\r
106 static LRESULT CALLBACK TransDlgProc(HWND hDlg, UINT Msg, WPARAM wParam, LPARAM lParam);
\r
107 static void DispTransferStatus(HWND hWnd, int End, TRANSPACKET *Pkt);
\r
108 static void DispTransFileInfo(TRANSPACKET *Pkt, char *Title, int SkipButton, int Info);
\r
110 //static int GetAdrsAndPort(char *Str, char *Adrs, int *Port, int Max);
\r
111 static int GetAdrsAndPort(SOCKET Skt, char *Str, char *Adrs, int *Port, int Max);
\r
112 static int GetAdrsAndPortIPv4(SOCKET Skt, char *Str, char *Adrs, int *Port, int Max);
\r
113 static int GetAdrsAndPortIPv6(SOCKET Skt, char *Str, char *Adrs, int *Port, int Max);
\r
114 static int IsSpecialDevice(char *Fname);
\r
115 static int MirrorDelNotify(int Cur, int Notify, TRANSPACKET *Pkt);
\r
116 static BOOL CALLBACK MirrorDeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
117 static void SetErrorMsg(char *fmt, ...);
\r
119 static char* GetErrMsg();
\r
121 /*===== ローカルなワーク =====*/
\r
124 //static HANDLE hTransferThread;
\r
125 static HANDLE hTransferThread[MAX_DATA_CONNECTION];
\r
126 static int fTransferThreadExit = FALSE;
\r
128 static HANDLE hRunMutex; /* 転送スレッド実行ミューテックス */
\r
129 static HANDLE hListAccMutex; /* 転送ファイルアクセス用ミューテックス */
\r
131 static int TransFiles = 0; /* 転送待ちファイル数 */
\r
132 static TRANSPACKET *TransPacketBase = NULL; /* 転送ファイルリスト */
\r
134 static TRANSPACKET *NextTransPacketBase = NULL;
\r
137 //static int Canceled; /* 中止フラグ YES/NO */
\r
138 static int Canceled[MAX_DATA_CONNECTION]; /* 中止フラグ YES/NO */
\r
139 static int ClearAll; /* 全て中止フラグ YES/NO */
\r
141 static int ForceAbort; /* 転送中止フラグ */
\r
142 /* このフラグはスレッドを終了させるときに使う */
\r
145 //static LONGLONG AllTransSizeNow; /* 今回の転送で転送したサイズ */
\r
146 //static time_t TimeStart; /* 転送開始時間 */
\r
147 static LONGLONG AllTransSizeNow[MAX_DATA_CONNECTION]; /* 今回の転送で転送したサイズ */
\r
148 static time_t TimeStart[MAX_DATA_CONNECTION]; /* 転送開始時間 */
\r
150 static int KeepDlg = NO; /* 転送中ダイアログを消さないかどうか (YES/NO) */
\r
151 static int MoveToForeground = NO; /* ウインドウを前面に移動するかどうか (YES/NO) */
\r
154 //static char CurDir[FMAX_PATH+1] = { "" };
\r
155 static char CurDir[MAX_DATA_CONNECTION][FMAX_PATH+1];
\r
157 //static char ErrMsg[ERR_MSG_LEN+7];
\r
158 static char ErrMsg[MAX_DATA_CONNECTION+1][ERR_MSG_LEN+7];
\r
159 static DWORD ErrMsgThreadId[MAX_DATA_CONNECTION+1];
\r
160 static HANDLE hErrMsgMutex;
\r
163 static int WaitForMainThread = NO;
\r
165 static int TransferErrorMode = EXIST_OVW;
\r
166 static int TransferErrorNotify = NO;
\r
168 /*===== 外部参照 =====*/
\r
171 extern int SaveTimeStamp;
\r
173 // extern int TimeOut;
\r
174 extern int FwallType;
\r
175 extern int MirUpDelNotify;
\r
176 extern int MirDownDelNotify;
\r
177 extern int FolderAttr;
\r
178 extern int FolderAttrNum;
\r
181 /*----- ファイル転送スレッドを起動する ----------------------------------------
\r
188 *----------------------------------------------------------------------------*/
\r
190 int MakeTransferThread(void)
\r
195 hListAccMutex = CreateMutex( NULL, FALSE, NULL );
\r
196 hRunMutex = CreateMutex( NULL, TRUE, NULL );
\r
198 hErrMsgMutex = CreateMutex( NULL, FALSE, NULL );
\r
203 fTransferThreadExit = FALSE;
\r
205 // hTransferThread = (HANDLE)_beginthreadex(NULL, 0, TransferThread, 0, 0, &dwID);
\r
206 // if (hTransferThread == NULL)
\r
207 // return(FFFTP_FAIL); /* XXX */
\r
208 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
210 hTransferThread[i] = (HANDLE)_beginthreadex(NULL, 0, TransferThread, (void*)i, 0, &dwID);
\r
211 if(hTransferThread[i] == NULL)
\r
215 return(FFFTP_SUCCESS);
\r
219 /*----- ファイル転送スレッドを終了する ----------------------------------------
\r
226 *----------------------------------------------------------------------------*/
\r
228 void CloseTransferThread(void)
\r
233 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
238 fTransferThreadExit = TRUE;
\r
240 // while(WaitForSingleObject(hTransferThread, 10) == WAIT_TIMEOUT)
\r
242 // BackgrndMessageProc();
\r
245 // CloseHandle(hTransferThread);
\r
246 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
248 while(WaitForSingleObject(hTransferThread[i], 10) == WAIT_TIMEOUT)
\r
250 BackgrndMessageProc();
\r
253 CloseHandle(hTransferThread[i]);
\r
256 ReleaseMutex( hRunMutex );
\r
258 CloseHandle( hListAccMutex );
\r
259 CloseHandle( hRunMutex );
\r
261 CloseHandle( hErrMsgMutex );
\r
266 /*----- 転送するファイル情報をリストに追加する --------------------------------
\r
269 * TRANSPACKET *Pkt : 転送ファイル情報
\r
270 * TRANSPACKET **Base : リストの先頭
\r
274 * FFFTP_SUCCESS/FFFTP_FAIL
\r
275 *----------------------------------------------------------------------------*/
\r
277 int AddTmpTransFileList(TRANSPACKET *Pkt, TRANSPACKET **Base)
\r
284 if((Pos = malloc(sizeof(TRANSPACKET))) != NULL)
\r
286 memcpy(Pos, Pkt, sizeof(TRANSPACKET));
\r
294 while(Prev->Next != NULL)
\r
298 Sts = FFFTP_SUCCESS;
\r
304 /*----- 転送するファイル情報リストをクリアする --------------------------------
\r
307 * TRANSPACKET **Base : リストの先頭
\r
311 *----------------------------------------------------------------------------*/
\r
313 void EraseTmpTransFileList(TRANSPACKET **Base)
\r
330 /*----- 転送するファイル情報リストから1つの情報を取り除く --------------------
\r
333 * TRANSPACKET *Pkt : 転送ファイル情報
\r
334 * TRANSPACKET **Base : リストの先頭
\r
338 * FFFTP_SUCCESS/FFFTP_FAIL
\r
339 *----------------------------------------------------------------------------*/
\r
341 int RemoveTmpTransFileListItem(TRANSPACKET **Base, int Num)
\r
353 Sts = FFFTP_SUCCESS;
\r
363 Prev->Next = Pos->Next;
\r
365 Sts = FFFTP_SUCCESS;
\r
374 /*----- 転送するファイル情報を転送ファイルリストに登録する --------------------
\r
377 * TRANSPACKET *Pkt : 転送ファイル情報
\r
381 *----------------------------------------------------------------------------*/
\r
383 void AddTransFileList(TRANSPACKET *Pkt)
\r
388 DispTransPacket(Pkt);
\r
391 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
392 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
394 WaitForMainThread = YES;
\r
395 BackgrndMessageProc();
\r
400 Pos = TransPacketBase;
\r
403 while(Pos->Next != NULL)
\r
406 if(AddTmpTransFileList(Pkt, &TransPacketBase) == FFFTP_SUCCESS)
\r
408 if((strncmp(Pkt->Cmd, "RETR", 4) == 0) ||
\r
409 (strncmp(Pkt->Cmd, "STOR", 4) == 0))
\r
412 PostMessage(GetMainHwnd(), WM_CHANGE_COND, 0, 0);
\r
416 if(NextTransPacketBase == NULL)
\r
419 NextTransPacketBase = Pos->Next;
\r
421 NextTransPacketBase = TransPacketBase;
\r
423 ReleaseMutex(hListAccMutex);
\r
425 WaitForMainThread = NO;
\r
431 /*----- 転送ファイル情報を転送ファイルリストに追加する ------------------------
\r
434 * TRANSPACKET *Pkt : 転送ファイル情報
\r
435 * TRANSPACKET **Base : リストの先頭
\r
442 *----------------------------------------------------------------------------*/
\r
444 void AppendTransFileList(TRANSPACKET *Pkt)
\r
449 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
450 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
452 WaitForMainThread = YES;
\r
453 BackgrndMessageProc();
\r
457 if(TransPacketBase == NULL)
\r
458 TransPacketBase = Pkt;
\r
461 Pos = TransPacketBase;
\r
462 while(Pos->Next != NULL)
\r
467 if(NextTransPacketBase == NULL)
\r
468 NextTransPacketBase = Pkt;
\r
472 DispTransPacket(Pkt);
\r
474 if((strncmp(Pkt->Cmd, "RETR", 4) == 0) ||
\r
475 (strncmp(Pkt->Cmd, "STOR", 4) == 0))
\r
478 PostMessage(GetMainHwnd(), WM_CHANGE_COND, 0, 0);
\r
483 ReleaseMutex(hListAccMutex);
\r
485 WaitForMainThread = NO;
\r
490 /*----- 転送ファイル情報を表示する --------------------------------------------
\r
493 * TRANSPACKET *Pkt : 転送ファイル情報
\r
497 *----------------------------------------------------------------------------*/
\r
499 static void DispTransPacket(TRANSPACKET *Pkt)
\r
501 if((strncmp(Pkt->Cmd, "RETR", 4) == 0) || (strncmp(Pkt->Cmd, "STOR", 4) == 0))
\r
502 DoPrintf("TransList Cmd=%s : %s : %s", Pkt->Cmd, Pkt->RemoteFile, Pkt->LocalFile);
\r
503 else if(strncmp(Pkt->Cmd, "R-", 2) == 0)
\r
504 DoPrintf("TransList Cmd=%s : %s", Pkt->Cmd, Pkt->RemoteFile);
\r
505 else if(strncmp(Pkt->Cmd, "L-", 2) == 0)
\r
506 DoPrintf("TransList Cmd=%s : %s", Pkt->Cmd, Pkt->LocalFile);
\r
507 else if(strncmp(Pkt->Cmd, "MKD", 3) == 0)
\r
509 if(strlen(Pkt->LocalFile) > 0)
\r
510 DoPrintf("TransList Cmd=%s : %s", Pkt->Cmd, Pkt->LocalFile);
\r
512 DoPrintf("TransList Cmd=%s : %s", Pkt->Cmd, Pkt->RemoteFile);
\r
515 DoPrintf("TransList Cmd=%s", Pkt->Cmd);
\r
520 /*----- 転送ファイルリストをクリアする ----------------------------------------
\r
527 *----------------------------------------------------------------------------*/
\r
529 static void EraseTransFileList(void)
\r
533 TRANSPACKET *NotDel;
\r
539 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
540 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
542 WaitForMainThread = YES;
\r
543 BackgrndMessageProc();
\r
546 New = TransPacketBase;
\r
549 /* 最後の"BACKCUR"は必要なので消さない */
\r
550 if(strcmp(New->Cmd, "BACKCUR") == 0)
\r
555 strcpy(NotDel->Cmd, "");
\r
559 // NotDel->Next = NULL;
\r
566 strcpy(New->Cmd, "");
\r
570 TransPacketBase = NotDel;
\r
572 NextTransPacketBase = NotDel;
\r
574 PostMessage(GetMainHwnd(), WM_CHANGE_COND, 0, 0);
\r
575 ReleaseMutex(hListAccMutex);
\r
577 WaitForMainThread = NO;
\r
579 strcpy(Pkt.Cmd, "GOQUIT");
\r
580 AddTransFileList(&Pkt);
\r
585 /*----- 転送中ダイアログを消さないようにするかどうかを設定 --------------------
\r
588 * int Sw : 転送中ダイアログを消さないかどうか (YES/NO)
\r
592 *----------------------------------------------------------------------------*/
\r
594 void KeepTransferDialog(int Sw)
\r
601 /*----- 現在転送中かどうかを返す ----------------------------------------------
\r
607 * int ステータス (YES/NO=転送中ではない)
\r
608 *----------------------------------------------------------------------------*/
\r
610 int AskTransferNow(void)
\r
612 return(TransPacketBase != NULL ? YES : NO);
\r
616 /*----- 転送するファイルの数を返す --------------------------------------------
\r
623 *----------------------------------------------------------------------------*/
\r
625 int AskTransferFileNum(void)
\r
627 return(TransFiles);
\r
631 /*----- 転送中ウインドウを前面に出す ------------------------------------------
\r
638 *----------------------------------------------------------------------------*/
\r
640 void GoForwardTransWindow(void)
\r
642 MoveToForeground = YES;
\r
647 /*----- 転送ソケットのカレントディレクトリ情報を初期化 ------------------------
\r
654 *----------------------------------------------------------------------------*/
\r
656 void InitTransCurDir(void)
\r
659 // strcpy(CurDir, "");
\r
661 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
662 strcpy(CurDir[i], "");
\r
667 /*----- ファイル転送スレッドのメインループ ------------------------------------
\r
670 * void *Dummy : 使わない
\r
674 *----------------------------------------------------------------------------*/
\r
676 static ULONG WINAPI TransferThread(void *Dummy)
\r
680 char Tmp[FMAX_PATH+1];
\r
702 ThreadCount = (int)Dummy;
\r
703 CmdSkt = INVALID_SOCKET;
\r
704 NewCmdSkt = INVALID_SOCKET;
\r
705 TrnSkt = INVALID_SOCKET;
\r
706 SetThreadPriority(GetCurrentThread(), THREAD_PRIORITY_LOWEST);
\r
708 while((TransPacketBase != NULL) ||
\r
709 (WaitForSingleObject(hRunMutex, 200) == WAIT_TIMEOUT))
\r
711 if(fTransferThreadExit == TRUE)
\r
714 if(WaitForMainThread == YES)
\r
716 BackgrndMessageProc();
\r
721 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
722 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
724 BackgrndMessageProc();
\r
727 // memset(ErrMsg, NUL, ERR_MSG_LEN+7);
\r
728 memset(GetErrMsg(), NUL, ERR_MSG_LEN+7);
\r
731 Canceled[ThreadCount] = NO;
\r
733 while(TransPacketBase != NULL && strcmp(TransPacketBase->Cmd, "") == 0)
\r
735 Pos = TransPacketBase;
\r
736 TransPacketBase = TransPacketBase->Next;
\r
739 NewCmdSkt = AskCmdCtrlSkt();
\r
740 if(AskReuseCmdSkt() == YES && ThreadCount == 0)
\r
742 if(TransPacketBase && ThreadCount < AskMaxThreadCount())
\r
743 TrnSkt = AskTrnCtrlSkt();
\r
747 if(TransPacketBase && NewCmdSkt != INVALID_SOCKET && ThreadCount < AskMaxThreadCount())
\r
749 if(TrnSkt == INVALID_SOCKET || NewCmdSkt != CmdSkt)
\r
751 ReleaseMutex(hListAccMutex);
\r
752 ReConnectTrnSkt(&TrnSkt, &Canceled[ThreadCount]);
\r
753 // 同時ログイン数制限に引っかかった可能性あり
\r
755 if(TrnSkt == INVALID_SOCKET)
\r
758 while(NewCmdSkt != CmdSkt && i > 0)
\r
760 BackgrndMessageProc();
\r
765 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
766 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
768 BackgrndMessageProc();
\r
775 if(TrnSkt != INVALID_SOCKET)
\r
777 ReleaseMutex(hListAccMutex);
\r
778 SendData(TrnSkt, "QUIT\r\n", 6, 0, &Canceled[ThreadCount]);
\r
780 TrnSkt = INVALID_SOCKET;
\r
781 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
782 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
784 BackgrndMessageProc();
\r
790 CmdSkt = NewCmdSkt;
\r
791 // if(TransPacketBase != NULL)
\r
792 if(TrnSkt != INVALID_SOCKET && NextTransPacketBase != NULL)
\r
794 Pos = NextTransPacketBase;
\r
795 NextTransPacketBase = NextTransPacketBase->Next;
\r
796 // ディレクトリ操作は非同期で行わない
\r
797 // ReleaseMutex(hListAccMutex);
\r
798 if(hWndTrans == NULL)
\r
800 // if((strncmp(TransPacketBase->Cmd, "RETR", 4) == 0) ||
\r
801 // (strncmp(TransPacketBase->Cmd, "STOR", 4) == 0) ||
\r
802 // (strncmp(TransPacketBase->Cmd, "MKD", 3) == 0) ||
\r
803 // (strncmp(TransPacketBase->Cmd, "L-", 2) == 0) ||
\r
804 // (strncmp(TransPacketBase->Cmd, "R-", 2) == 0))
\r
805 if((strncmp(Pos->Cmd, "RETR", 4) == 0) ||
\r
806 (strncmp(Pos->Cmd, "STOR", 4) == 0) ||
\r
807 (strncmp(Pos->Cmd, "MKD", 3) == 0) ||
\r
808 (strncmp(Pos->Cmd, "L-", 2) == 0) ||
\r
809 (strncmp(Pos->Cmd, "R-", 2) == 0))
\r
811 hWndTrans = CreateDialog(GetFtpInst(), MAKEINTRESOURCE(transfer_dlg), HWND_DESKTOP, (DLGPROC)TransDlgProc);
\r
812 if(MoveToForeground == YES)
\r
813 SetForegroundWindow(hWndTrans);
\r
814 ShowWindow(hWndTrans, SW_SHOWNOACTIVATE);
\r
815 GetWindowRect(hWndTrans, &WndRect);
\r
816 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
819 // TransPacketBase->hWndTrans = hWndTrans;
\r
820 Pos->hWndTrans = hWndTrans;
\r
821 Pos->ctrl_skt = TrnSkt;
\r
822 Pos->ThreadCount = ThreadCount;
\r
824 if(hWndTrans != NULL)
\r
826 if(MoveToForeground == YES)
\r
828 SetForegroundWindow(hWndTrans);
\r
829 MoveToForeground = NO;
\r
833 if(hWndTrans != NULL)
\r
834 // SendMessage(hWndTrans, WM_SET_PACKET, 0, (LPARAM)TransPacketBase);
\r
835 SendMessage(hWndTrans, WM_SET_PACKET, 0, (LPARAM)Pos);
\r
838 // if(strncmp(TransPacketBase->Cmd, "RETR", 4) == 0)
\r
839 if(strncmp(Pos->Cmd, "RETR", 4) == 0)
\r
841 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
842 // ReleaseMutex(hListAccMutex);
\r
844 // if(CheckPathViolation(TransPacketBase) == NO)
\r
845 if(CheckPathViolation(Pos) == NO)
\r
847 /* フルパスを使わないための処理 */
\r
848 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
849 if(MakeNonFullPath(Pos, CurDir[Pos->ThreadCount], Tmp) == FFFTP_SUCCESS)
\r
851 // if(strncmp(TransPacketBase->Cmd, "RETR-S", 6) == 0)
\r
852 if(strncmp(Pos->Cmd, "RETR-S", 6) == 0)
\r
855 // DoSIZE(TransPacketBase->RemoteFile, &TransPacketBase->Size);
\r
856 // DoMDTM(TransPacketBase->RemoteFile, &TransPacketBase->Time);
\r
857 // strcpy(TransPacketBase->Cmd, "RETR ");
\r
858 DoSIZE(TrnSkt, Pos->RemoteFile, &Pos->Size, &Canceled[Pos->ThreadCount]);
\r
859 DoMDTM(TrnSkt, Pos->RemoteFile, &Pos->Time, &Canceled[Pos->ThreadCount]);
\r
860 strcpy(Pos->Cmd, "RETR ");
\r
864 // if(DoDownLoad(AskTrnCtrlSkt(), TransPacketBase, NO) == 429)
\r
866 // if(ReConnectTrnSkt() == FFFTP_SUCCESS)
\r
867 // DoDownLoad(AskTrnCtrlSkt(), TransPacketBase, NO, &Canceled);
\r
868 DoDownLoad(TrnSkt, Pos, NO, &Canceled[Pos->ThreadCount]);
\r
872 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
873 ReleaseMutex(hListAccMutex);
\r
876 // else if(strncmp(TransPacketBase->Cmd, "STOR", 4) == 0)
\r
877 else if(strncmp(Pos->Cmd, "STOR", 4) == 0)
\r
879 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
880 // ReleaseMutex(hListAccMutex);
\r
881 /* フルパスを使わないための処理 */
\r
882 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
883 if(MakeNonFullPath(Pos, CurDir[Pos->ThreadCount], Tmp) == FFFTP_SUCCESS)
\r
886 // if(DoUpLoad(AskTrnCtrlSkt(), TransPacketBase) == 429)
\r
888 // if(ReConnectTrnSkt() == FFFTP_SUCCESS)
\r
889 // DoUpLoad(AskTrnCtrlSkt(), TransPacketBase);
\r
890 DoUpLoad(TrnSkt, Pos);
\r
893 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
894 ReleaseMutex(hListAccMutex);
\r
896 /* フォルダ作成(ローカルまたはホスト) */
\r
897 // else if(strncmp(TransPacketBase->Cmd, "MKD", 3) == 0)
\r
898 else if(strncmp(Pos->Cmd, "MKD", 3) == 0)
\r
900 // DispTransFileInfo(TransPacketBase, MSGJPN078, FALSE, YES);
\r
901 DispTransFileInfo(Pos, MSGJPN078, FALSE, YES);
\r
903 // if(strlen(TransPacketBase->RemoteFile) > 0)
\r
904 if(strlen(Pos->RemoteFile) > 0)
\r
906 /* フルパスを使わないための処理 */
\r
907 CwdSts = FTP_COMPLETE;
\r
909 // strcpy(Tmp, TransPacketBase->RemoteFile);
\r
910 strcpy(Tmp, Pos->RemoteFile);
\r
911 // if(ProcForNonFullpath(Tmp, CurDir, hWndTrans, 1) == FFFTP_FAIL)
\r
912 if(ProcForNonFullpath(TrnSkt, Tmp, CurDir[Pos->ThreadCount], hWndTrans, &Canceled[Pos->ThreadCount]) == FFFTP_FAIL)
\r
915 CwdSts = FTP_ERROR;
\r
918 if(CwdSts == FTP_COMPLETE)
\r
921 // CommandProcTrn(NULL, "MKD %s", Tmp);
\r
922 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "MKD %s", Tmp);
\r
923 /* すでにフォルダがある場合もあるので、 */
\r
924 /* ここではエラーチェックはしない */
\r
927 // CommandProcTrn(NULL, "%s %03d %s", AskHostChmodCmd(), FolderAttrNum, Tmp);
\r
928 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "%s %03d %s", AskHostChmodCmd(), FolderAttrNum, Tmp);
\r
931 // else if(strlen(TransPacketBase->LocalFile) > 0)
\r
932 else if(strlen(Pos->LocalFile) > 0)
\r
935 // DoLocalMKD(TransPacketBase->LocalFile);
\r
936 DoLocalMKD(Pos->LocalFile);
\r
938 ReleaseMutex(hListAccMutex);
\r
940 /* ディレクトリ作成(常にホスト側) */
\r
941 // else if(strncmp(TransPacketBase->Cmd, "R-MKD", 5) == 0)
\r
942 else if(strncmp(Pos->Cmd, "R-MKD", 5) == 0)
\r
944 // DispTransFileInfo(TransPacketBase, MSGJPN079, FALSE, YES);
\r
945 DispTransFileInfo(Pos, MSGJPN079, FALSE, YES);
\r
947 /* フルパスを使わないための処理 */
\r
948 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
949 if(MakeNonFullPath(Pos, CurDir[Pos->ThreadCount], Tmp) == FFFTP_SUCCESS)
\r
952 // CommandProcTrn(NULL, "%s%s", TransPacketBase->Cmd+2, TransPacketBase->RemoteFile);
\r
953 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "%s%s", Pos->Cmd+2, Pos->RemoteFile);
\r
956 // CommandProcTrn(NULL, "%s %03d %s", AskHostChmodCmd(), FolderAttrNum, TransPacketBase->RemoteFile);
\r
957 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "%s %03d %s", AskHostChmodCmd(), FolderAttrNum, Pos->RemoteFile);
\r
959 ReleaseMutex(hListAccMutex);
\r
961 /* ディレクトリ削除(常にホスト側) */
\r
962 // else if(strncmp(TransPacketBase->Cmd, "R-RMD", 5) == 0)
\r
963 else if(strncmp(Pos->Cmd, "R-RMD", 5) == 0)
\r
965 // DispTransFileInfo(TransPacketBase, MSGJPN080, FALSE, YES);
\r
966 DispTransFileInfo(Pos, MSGJPN080, FALSE, YES);
\r
968 // DelNotify = MirrorDelNotify(WIN_REMOTE, DelNotify, TransPacketBase);
\r
969 DelNotify = MirrorDelNotify(WIN_REMOTE, DelNotify, Pos);
\r
970 if((DelNotify == YES) || (DelNotify == YES_ALL))
\r
972 /* フルパスを使わないための処理 */
\r
973 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
974 if(MakeNonFullPath(Pos, CurDir[Pos->ThreadCount], Tmp) == FFFTP_SUCCESS)
\r
977 // CommandProcTrn(NULL, "%s%s", TransPacketBase->Cmd+2, TransPacketBase->RemoteFile);
\r
978 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "%s%s", Pos->Cmd+2, Pos->RemoteFile);
\r
981 ReleaseMutex(hListAccMutex);
\r
983 /* ファイル削除(常にホスト側) */
\r
984 // else if(strncmp(TransPacketBase->Cmd, "R-DELE", 6) == 0)
\r
985 else if(strncmp(Pos->Cmd, "R-DELE", 6) == 0)
\r
987 // DispTransFileInfo(TransPacketBase, MSGJPN081, FALSE, YES);
\r
988 DispTransFileInfo(Pos, MSGJPN081, FALSE, YES);
\r
990 // DelNotify = MirrorDelNotify(WIN_REMOTE, DelNotify, TransPacketBase);
\r
991 DelNotify = MirrorDelNotify(WIN_REMOTE, DelNotify, Pos);
\r
992 if((DelNotify == YES) || (DelNotify == YES_ALL))
\r
994 /* フルパスを使わないための処理 */
\r
995 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
996 if(MakeNonFullPath(Pos, CurDir[Pos->ThreadCount], Tmp) == FFFTP_SUCCESS)
\r
999 // CommandProcTrn(NULL, "%s%s", TransPacketBase->Cmd+2, TransPacketBase->RemoteFile);
\r
1000 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "%s%s", Pos->Cmd+2, Pos->RemoteFile);
\r
1003 ReleaseMutex(hListAccMutex);
\r
1005 /* ディレクトリ作成(常にローカル側) */
\r
1006 // else if(strncmp(TransPacketBase->Cmd, "L-MKD", 5) == 0)
\r
1007 else if(strncmp(Pos->Cmd, "L-MKD", 5) == 0)
\r
1009 // DispTransFileInfo(TransPacketBase, MSGJPN082, FALSE, YES);
\r
1010 DispTransFileInfo(Pos, MSGJPN082, FALSE, YES);
\r
1013 // DoLocalMKD(TransPacketBase->LocalFile);
\r
1014 DoLocalMKD(Pos->LocalFile);
\r
1015 ReleaseMutex(hListAccMutex);
\r
1017 /* ディレクトリ削除(常にローカル側) */
\r
1018 // else if(strncmp(TransPacketBase->Cmd, "L-RMD", 5) == 0)
\r
1019 else if(strncmp(Pos->Cmd, "L-RMD", 5) == 0)
\r
1021 // DispTransFileInfo(TransPacketBase, MSGJPN083, FALSE, YES);
\r
1022 DispTransFileInfo(Pos, MSGJPN083, FALSE, YES);
\r
1024 // DelNotify = MirrorDelNotify(WIN_LOCAL, DelNotify, TransPacketBase);
\r
1025 DelNotify = MirrorDelNotify(WIN_LOCAL, DelNotify, Pos);
\r
1026 if((DelNotify == YES) || (DelNotify == YES_ALL))
\r
1029 // DoLocalRMD(TransPacketBase->LocalFile);
\r
1030 DoLocalRMD(Pos->LocalFile);
\r
1032 ReleaseMutex(hListAccMutex);
\r
1034 /* ファイル削除(常にローカル側) */
\r
1035 // else if(strncmp(TransPacketBase->Cmd, "L-DELE", 6) == 0)
\r
1036 else if(strncmp(Pos->Cmd, "L-DELE", 6) == 0)
\r
1038 // DispTransFileInfo(TransPacketBase, MSGJPN084, FALSE, YES);
\r
1039 DispTransFileInfo(Pos, MSGJPN084, FALSE, YES);
\r
1041 // DelNotify = MirrorDelNotify(WIN_LOCAL, DelNotify, TransPacketBase);
\r
1042 DelNotify = MirrorDelNotify(WIN_LOCAL, DelNotify, Pos);
\r
1043 if((DelNotify == YES) || (DelNotify == YES_ALL))
\r
1046 // DoLocalDELE(TransPacketBase->LocalFile);
\r
1047 DoLocalDELE(Pos->LocalFile);
\r
1049 ReleaseMutex(hListAccMutex);
\r
1051 /* カレントディレクトリを設定 */
\r
1052 // else if(strcmp(TransPacketBase->Cmd, "SETCUR") == 0)
\r
1053 else if(strcmp(Pos->Cmd, "SETCUR") == 0)
\r
1055 // if(AskShareProh() == YES)
\r
1056 if(AskReuseCmdSkt() == NO || AskShareProh() == YES)
\r
1058 // if(strcmp(CurDir, TransPacketBase->RemoteFile) != 0)
\r
1059 if(strcmp(CurDir[Pos->ThreadCount], Pos->RemoteFile) != 0)
\r
1061 // if(CommandProcTrn(NULL, "CWD %s", TransPacketBase->RemoteFile)/100 != FTP_COMPLETE)
\r
1062 if(CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "CWD %s", Pos->RemoteFile)/100 != FTP_COMPLETE)
\r
1064 DispCWDerror(hWndTrans);
\r
1069 // strcpy(CurDir, TransPacketBase->RemoteFile);
\r
1070 strcpy(CurDir[Pos->ThreadCount], Pos->RemoteFile);
\r
1071 ReleaseMutex(hListAccMutex);
\r
1073 /* カレントディレクトリを戻す */
\r
1074 // else if(strcmp(TransPacketBase->Cmd, "BACKCUR") == 0)
\r
1075 else if(strcmp(Pos->Cmd, "BACKCUR") == 0)
\r
1077 // if(AskShareProh() == NO)
\r
1078 if(AskReuseCmdSkt() == YES && AskShareProh() == NO)
\r
1080 // if(strcmp(CurDir, TransPacketBase->RemoteFile) != 0)
\r
1081 // CommandProcTrn(NULL, "CWD %s", TransPacketBase->RemoteFile);
\r
1082 // strcpy(CurDir, TransPacketBase->RemoteFile);
\r
1083 if(strcmp(CurDir[Pos->ThreadCount], Pos->RemoteFile) != 0)
\r
1084 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "CWD %s", Pos->RemoteFile);
\r
1085 strcpy(CurDir[Pos->ThreadCount], Pos->RemoteFile);
\r
1087 ReleaseMutex(hListAccMutex);
\r
1090 // else if(strcmp(TransPacketBase->Cmd, "GOQUIT") == 0)
\r
1091 else if(strcmp(Pos->Cmd, "GOQUIT") == 0)
\r
1093 ReleaseMutex(hListAccMutex);
\r
1097 ReleaseMutex(hListAccMutex);
\r
1099 /*===== 1つの処理終わり =====*/
\r
1101 if(ForceAbort == NO)
\r
1103 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
1104 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
1106 BackgrndMessageProc();
\r
1109 if(ClearAll == YES)
\r
1110 // EraseTransFileList();
\r
1112 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
1113 Canceled[i] = YES;
\r
1114 EraseTransFileList();
\r
1119 // if((strncmp(TransPacketBase->Cmd, "RETR", 4) == 0) ||
\r
1120 // (strncmp(TransPacketBase->Cmd, "STOR", 4) == 0))
\r
1121 if((strncmp(Pos->Cmd, "RETR", 4) == 0) ||
\r
1122 (strncmp(Pos->Cmd, "STOR", 4) == 0))
\r
1125 if(TransFiles > 0)
\r
1127 PostMessage(GetMainHwnd(), WM_CHANGE_COND, 0, 0);
\r
1129 // Pos = TransPacketBase;
\r
1130 // TransPacketBase = TransPacketBase->Next;
\r
1134 ReleaseMutex(hListAccMutex);
\r
1136 if(BackgrndMessageProc() == YES)
\r
1138 WaitForSingleObject(hListAccMutex, INFINITE);
\r
1139 EraseTransFileList();
\r
1140 ReleaseMutex(hListAccMutex);
\r
1143 if(hWndTrans != NULL)
\r
1144 SendMessage(hWndTrans, WM_SET_PACKET, 0, 0);
\r
1146 strcpy(Pos->Cmd, "");
\r
1149 else if(TransPacketBase == NULL)
\r
1153 ReleaseMutex(hListAccMutex);
\r
1156 if(hWndTrans != NULL)
\r
1158 DestroyWindow(hWndTrans);
\r
1161 // if(GoExit == YES)
\r
1163 // SoundPlay(SND_TRANS);
\r
1165 // if(AskAutoExit() == NO)
\r
1167 // if(Down == YES)
\r
1168 // PostMessage(GetMainHwnd(), WM_REFRESH_LOCAL_FLG, 0, 0);
\r
1170 // PostMessage(GetMainHwnd(), WM_REFRESH_REMOTE_FLG, 0, 0);
\r
1177 BackgrndMessageProc();
\r
1183 SoundPlay(SND_TRANS);
\r
1184 if(AskAutoExit() == NO)
\r
1187 PostMessage(GetMainHwnd(), WM_REFRESH_LOCAL_FLG, 0, 0);
\r
1189 PostMessage(GetMainHwnd(), WM_REFRESH_REMOTE_FLG, 0, 0);
\r
1193 PostMessage(GetMainHwnd(), WM_COMMAND, MAKEWPARAM(MENU_AUTO_EXIT, 0), 0);
\r
1198 TransferErrorMode = AskTransferErrorMode();
\r
1199 TransferErrorNotify = AskTransferErrorNotify();
\r
1203 ReleaseMutex(hListAccMutex);
\r
1204 if(hWndTrans != NULL)
\r
1206 DestroyWindow(hWndTrans);
\r
1209 BackgrndMessageProc();
\r
1210 if(ThreadCount < AskMaxThreadCount())
\r
1216 if(AskReuseCmdSkt() == NO || ThreadCount > 0)
\r
1218 if(TrnSkt != INVALID_SOCKET)
\r
1220 SendData(TrnSkt, "QUIT\r\n", 6, 0, &Canceled[ThreadCount]);
\r
1228 /*----- フルパスを使わないファイルアクセスの準備 ------------------------------
\r
1231 * TRANSPACKET *Pkt : 転送パケット
\r
1232 * char *Cur : カレントディレクトリ
\r
1233 * char *Tmp : 作業用エリア
\r
1236 * int ステータス(FFFTP_SUCCESS/FFFTP_FAIL)
\r
1240 * このモジュール内で CWD を行ない、
\r
1241 * Pkt->RemoteFile にファイル名のみ残す。(パス名は消す)
\r
1242 *----------------------------------------------------------------------------*/
\r
1245 static int MakeNonFullPath(TRANSPACKET *Pkt, char *Cur, char *Tmp)
\r
1249 // Sts = ProcForNonFullpath(Pkt->RemoteFile, Cur, Pkt->hWndTrans, 1);
\r
1250 Sts = ProcForNonFullpath(Pkt->ctrl_skt, Pkt->RemoteFile, Cur, Pkt->hWndTrans, &Canceled[Pkt->ThreadCount]);
\r
1251 if(Sts == FFFTP_FAIL)
\r
1260 /*----- ダウンロードを行なう --------------------------------------------------
\r
1263 * SOCKET cSkt : コントロールソケット
\r
1264 * TRANSPACKET *Pkt : 転送ファイル情報
\r
1265 * int DirList : ディレクトリリストのダウンロード(YES/NO)
\r
1271 * このモジュールは、ファイル一覧の取得などを行なう際にメインのスレッド
\r
1272 * からも呼ばれる。メインのスレッドから呼ばれる時は Pkt->hWndTrans == NULL。
\r
1273 *----------------------------------------------------------------------------*/
\r
1275 int DoDownLoad(SOCKET cSkt, TRANSPACKET *Pkt, int DirList, int *CancelCheckWork)
\r
1278 char Reply[ERR_MSG_LEN+7];
\r
1280 Pkt->ctrl_skt = cSkt;
\r
1281 if(IsSpecialDevice(GetFileName(Pkt->LocalFile)) == YES)
\r
1284 SetTaskMsg(MSGJPN085, GetFileName(Pkt->LocalFile));
\r
1285 DispDownloadFinishMsg(Pkt, iRetCode);
\r
1287 else if(Pkt->Mode != EXIST_IGNORE)
\r
1289 if(Pkt->Type == TYPE_I)
\r
1290 Pkt->KanjiCode = KANJI_NOCNV;
\r
1292 iRetCode = command(Pkt->ctrl_skt, Reply, CancelCheckWork, "TYPE %c", Pkt->Type);
\r
1293 if(iRetCode/100 < FTP_RETRY)
\r
1295 if(Pkt->hWndTrans != NULL)
\r
1298 // AllTransSizeNow = 0;
\r
1299 AllTransSizeNow[Pkt->ThreadCount] = 0;
\r
1302 DispTransFileInfo(Pkt, MSGJPN086, TRUE, YES);
\r
1304 DispTransFileInfo(Pkt, MSGJPN087, FALSE, NO);
\r
1307 if(BackgrndMessageProc() == NO)
\r
1309 if(AskPasvMode() != YES)
\r
1310 iRetCode = DownLoadNonPassive(Pkt, CancelCheckWork);
\r
1312 iRetCode = DownLoadPassive(Pkt, CancelCheckWork);
\r
1318 SetErrorMsg(Reply);
\r
1322 DispTransFileInfo(Pkt, MSGJPN088, TRUE, YES);
\r
1323 SetTaskMsg(MSGJPN089, Pkt->RemoteFile);
\r
1330 /*----- 通常モードでファイルをダウンロード ------------------------------------
\r
1333 * TRANSPACKET *Pkt : 転送ファイル情報
\r
1337 *----------------------------------------------------------------------------*/
\r
1339 static int DownLoadNonPassive(TRANSPACKET *Pkt, int *CancelCheckWork)
\r
1343 SOCKET data_socket = INVALID_SOCKET; // data channel socket
\r
1344 SOCKET listen_socket = INVALID_SOCKET; // data listen socket
\r
1348 // struct sockaddr_in saSockAddr1;
\r
1349 struct sockaddr_in saSockAddrIPv4;
\r
1350 struct sockaddr_in6 saSockAddrIPv6;
\r
1351 char Reply[ERR_MSG_LEN+7];
\r
1353 if((listen_socket = GetFTPListenSocket(Pkt->ctrl_skt, CancelCheckWork)) != INVALID_SOCKET)
\r
1355 if(SetDownloadResume(Pkt, Pkt->Mode, Pkt->ExistSize, &CreateMode, CancelCheckWork) == YES)
\r
1357 sprintf(Buf, "%s%s", Pkt->Cmd, Pkt->RemoteFile);
\r
1358 iRetCode = command(Pkt->ctrl_skt, Reply, CancelCheckWork, "%s", Buf);
\r
1359 if(iRetCode/100 == FTP_PRELIM)
\r
1362 // if(SocksGet2ndBindReply(listen_socket, &data_socket) == FFFTP_FAIL)
\r
1363 if(SocksGet2ndBindReply(listen_socket, &data_socket, CancelCheckWork) == FFFTP_FAIL)
\r
1366 // iLength = sizeof(saSockAddr1);
\r
1367 // data_socket = do_accept(listen_socket, (struct sockaddr *)&saSockAddr1, (int *)&iLength);
\r
1368 switch(AskCurNetType())
\r
1371 iLength=sizeof(saSockAddrIPv4);
\r
1372 data_socket = do_accept(listen_socket,(struct sockaddr *)&saSockAddrIPv4, (int *)&iLength);
\r
1375 iLength=sizeof(saSockAddrIPv6);
\r
1376 data_socket = do_accept(listen_socket,(struct sockaddr *)&saSockAddrIPv6, (int *)&iLength);
\r
1380 if(shutdown(listen_socket, 1) != 0)
\r
1381 ReportWSError("shutdown listen", WSAGetLastError());
\r
1382 listen_socket = DoClose(listen_socket);
\r
1384 if(data_socket == INVALID_SOCKET)
\r
1386 SetErrorMsg(MSGJPN280);
\r
1387 ReportWSError("accept", WSAGetLastError());
\r
1392 // DoPrintf("Skt=%u : accept from %s port %u", data_socket, inet_ntoa(saSockAddr1.sin_addr), ntohs(saSockAddr1.sin_port));
\r
1394 switch(AskCurNetType())
\r
1397 DoPrintf("Skt=%u : accept from %s port %u", data_socket, inet_ntoa(saSockAddrIPv4.sin_addr), ntohs(saSockAddrIPv4.sin_port));
\r
1400 DoPrintf("Skt=%u : accept from %s port %u", data_socket, inet6_ntoa(saSockAddrIPv6.sin6_addr), ntohs(saSockAddrIPv6.sin6_port));
\r
1406 if(data_socket != INVALID_SOCKET)
\r
1408 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
1409 ReleaseMutex(hListAccMutex);
\r
1411 // iRetCode = DownLoadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1412 if(IsSSLAttached(Pkt->ctrl_skt))
\r
1414 if(AttachSSL(data_socket, Pkt->ctrl_skt, CancelCheckWork))
\r
1415 iRetCode = DownLoadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1420 iRetCode = DownLoadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1421 // data_socket = DoClose(data_socket);
\r
1426 SetErrorMsg(Reply);
\r
1427 SetTaskMsg(MSGJPN090);
\r
1428 listen_socket = DoClose(listen_socket);
\r
1438 SetErrorMsg(MSGJPN279);
\r
1440 DispDownloadFinishMsg(Pkt, iRetCode);
\r
1446 /*----- Passiveモードでファイルをダウンロード ---------------------------------
\r
1449 * TRANSPACKET *Pkt : 転送ファイル情報
\r
1453 *----------------------------------------------------------------------------*/
\r
1455 static int DownLoadPassive(TRANSPACKET *Pkt, int *CancelCheckWork)
\r
1458 SOCKET data_socket = INVALID_SOCKET; // data channel socket
\r
1466 char Reply[ERR_MSG_LEN+7];
\r
1469 // iRetCode = command(Pkt->ctrl_skt, Buf, CancelCheckWork, "PASV");
\r
1470 switch(AskCurNetType())
\r
1473 iRetCode = command(Pkt->ctrl_skt, Buf, CancelCheckWork, "PASV");
\r
1476 iRetCode = command(Pkt->ctrl_skt, Buf, CancelCheckWork, "EPSV");
\r
1479 if(iRetCode/100 == FTP_COMPLETE)
\r
1482 // if(GetAdrsAndPort(Buf, Adrs, &Port, 19) == FFFTP_SUCCESS)
\r
1483 if(GetAdrsAndPort(Pkt->ctrl_skt, Buf, Adrs, &Port, 39) == FFFTP_SUCCESS)
\r
1485 if((data_socket = connectsock(Adrs, Port, MSGJPN091, CancelCheckWork)) != INVALID_SOCKET)
\r
1489 if(setsockopt(data_socket, IPPROTO_TCP, TCP_NODELAY, (LPSTR)&Flg, sizeof(Flg)) == SOCKET_ERROR)
\r
1490 ReportWSError("setsockopt", WSAGetLastError());
\r
1492 if(SetDownloadResume(Pkt, Pkt->Mode, Pkt->ExistSize, &CreateMode, CancelCheckWork) == YES)
\r
1494 sprintf(Buf, "%s%s", Pkt->Cmd, Pkt->RemoteFile);
\r
1495 iRetCode = command(Pkt->ctrl_skt, Reply, CancelCheckWork, "%s", Buf);
\r
1496 if(iRetCode/100 == FTP_PRELIM)
\r
1498 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
1499 ReleaseMutex(hListAccMutex);
\r
1501 // iRetCode = DownLoadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1502 if(IsSSLAttached(Pkt->ctrl_skt))
\r
1504 if(AttachSSL(data_socket, Pkt->ctrl_skt, CancelCheckWork))
\r
1505 iRetCode = DownLoadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1510 iRetCode = DownLoadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1511 // data_socket = DoClose(data_socket);
\r
1515 SetErrorMsg(Reply);
\r
1516 SetTaskMsg(MSGJPN092);
\r
1517 data_socket = DoClose(data_socket);
\r
1529 SetErrorMsg(MSGJPN093);
\r
1530 SetTaskMsg(MSGJPN093);
\r
1537 DispDownloadFinishMsg(Pkt, iRetCode);
\r
1543 /*----- ダウンロードの実行 ----------------------------------------------------
\r
1546 * TRANSPACKET *Pkt : 転送ファイル情報
\r
1547 * SOCKET dSkt : データソケット
\r
1548 * int CreateMode : ファイル作成モード (CREATE_ALWAYS/OPEN_ALWAYS)
\r
1555 * ダイアログを出す(Pkt->hWndTrans!=NULL)場合、インターバルタイマで経過を表示する
\r
1556 * ダイアログを出さない場合、このルーチンからDispDownloadSize()を呼ぶ
\r
1557 *----------------------------------------------------------------------------*/
\r
1559 static int DownLoadFile(TRANSPACKET *Pkt, SOCKET dSkt, int CreateMode, int *CancelCheckWork)
\r
1562 char Buf[BUFSIZE];
\r
1563 char Buf2[BUFSIZE+3];
\r
1564 HANDLE iFileHandle;
\r
1565 SECURITY_ATTRIBUTES Sec;
\r
1567 CODECONVINFO cInfo;
\r
1569 // fd_set ReadFds;
\r
1570 // struct timeval Tout;
\r
1571 // struct timeval *ToutPtr;
\r
1574 char TmpBuf[ONELINE_BUF_SIZE];
\r
1575 DWORD dwFileAttributes;
\r
1577 #ifdef SET_BUFFER_SIZE
\r
1578 /* Add by H.Shirouzu at 2002/10/02 */
\r
1579 int buf_size = SOCKBUF_SIZE;
\r
1580 for ( ; buf_size > 0; buf_size /= 2)
\r
1581 if (setsockopt(dSkt, SOL_SOCKET, SO_RCVBUF, (char *)&buf_size, sizeof(buf_size)) == 0)
\r
1586 // 念のため受信バッファを無効にする
\r
1587 #ifdef DISABLE_TRANSFER_NETWORK_BUFFERS
\r
1589 setsockopt(dSkt, SOL_SOCKET, SO_RCVBUF, (char *)&buf_size, sizeof(buf_size));
\r
1592 Pkt->Abort = ABORT_NONE;
\r
1594 Sec.nLength = sizeof(SECURITY_ATTRIBUTES);
\r
1595 Sec.lpSecurityDescriptor = NULL;
\r
1596 Sec.bInheritHandle = FALSE;
\r
1598 dwFileAttributes = GetFileAttributes(Pkt->LocalFile);
\r
1599 if (dwFileAttributes != INVALID_FILE_ATTRIBUTES && (dwFileAttributes & FILE_ATTRIBUTE_READONLY)) {
\r
1601 if (MessageBox(GetMainHwnd(), MSGJPN296, MSGJPN086, MB_YESNO) == IDYES) {
\r
1603 SetFileAttributes(Pkt->LocalFile, dwFileAttributes ^ FILE_ATTRIBUTE_READONLY);
\r
1607 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
1610 char Buf3[(BUFSIZE + 3) * 4];
\r
1611 CODECONVINFO cInfo2;
\r
1612 int ProcessedBOM = NO;
\r
1613 // 4GB超対応(kaokunさん提供)
\r
1615 if(CreateMode == OPEN_ALWAYS)
\r
1616 // 4GB超対応(kaokunさん提供)
\r
1617 // SetFilePointer(iFileHandle, 0, 0, FILE_END);
\r
1618 SetFilePointer(iFileHandle, 0, &High, FILE_END);
\r
1620 if(Pkt->hWndTrans != NULL)
\r
1623 // TimeStart = time(NULL);
\r
1624 TimeStart[Pkt->ThreadCount] = time(NULL);
\r
1625 SetTimer(Pkt->hWndTrans, TIMER_DISPLAY, DISPLAY_TIMING, NULL);
\r
1628 InitCodeConvInfo(&cInfo);
\r
1629 cInfo.KanaCnv = Pkt->KanaCnv;
\r
1631 InitCodeConvInfo(&cInfo2);
\r
1632 cInfo2.KanaCnv = Pkt->KanaCnv;
\r
1634 /*===== ファイルを受信するループ =====*/
\r
1635 while((Pkt->Abort == ABORT_NONE) && (ForceAbort == NO))
\r
1637 // FD_ZERO(&ReadFds);
\r
1638 // FD_SET(dSkt, &ReadFds);
\r
1639 // ToutPtr = NULL;
\r
1640 // if(TimeOut != 0)
\r
1642 // Tout.tv_sec = TimeOut;
\r
1643 // Tout.tv_usec = 0;
\r
1644 // ToutPtr = &Tout;
\r
1646 // iNumBytes = select(0, &ReadFds, NULL, NULL, ToutPtr);
\r
1647 // if(iNumBytes == SOCKET_ERROR)
\r
1649 // ReportWSError("select", WSAGetLastError());
\r
1650 // if(Pkt->Abort == ABORT_NONE)
\r
1651 // Pkt->Abort = ABORT_ERROR;
\r
1654 // else if(iNumBytes == 0)
\r
1656 // SetErrorMsg(MSGJPN094);
\r
1657 // SetTaskMsg(MSGJPN094);
\r
1658 // Pkt->Abort = ABORT_ERROR;
\r
1662 if((iNumBytes = do_recv(dSkt, Buf, BUFSIZE, 0, &TimeOutErr, CancelCheckWork)) <= 0)
\r
1664 if(TimeOutErr == YES)
\r
1666 SetErrorMsg(MSGJPN094);
\r
1667 SetTaskMsg(MSGJPN094);
\r
1668 if(Pkt->hWndTrans != NULL)
\r
1670 if(Pkt->Abort == ABORT_NONE)
\r
1671 Pkt->Abort = ABORT_ERROR;
\r
1673 else if(iNumBytes == SOCKET_ERROR)
\r
1675 if(Pkt->Abort == ABORT_NONE)
\r
1676 Pkt->Abort = ABORT_ERROR;
\r
1682 if(Pkt->KanjiCode != KANJI_NOCNV)
\r
1685 cInfo.StrLen = iNumBytes;
\r
1687 cInfo.BufSize = BUFSIZE+3;
\r
1690 // ここで全てUTF-8へ変換する
\r
1691 // TODO: SJIS以外も直接UTF-8へ変換
\r
1692 // if(Pkt->KanjiCode == KANJI_JIS)
\r
1693 // Continue = ConvJIStoSJIS(&cInfo);
\r
1695 // Continue = ConvEUCtoSJIS(&cInfo);
\r
1696 char Buf3[(BUFSIZE + 3) * 4];
\r
1697 CODECONVINFO cInfo2;
\r
1698 switch(Pkt->KanjiCode)
\r
1701 switch(Pkt->KanjiCodeDesired)
\r
1704 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1705 // cInfo2.OutLen = cInfo.StrLen;
\r
1708 Continue = ConvSJIStoJIS(&cInfo);
\r
1709 cInfo2.Str = cInfo.Buf;
\r
1710 cInfo2.StrLen = cInfo.OutLen;
\r
1711 cInfo2.Buf = Buf3;
\r
1712 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1713 ConvJIStoSJIS(&cInfo2);
\r
1716 Continue = ConvSJIStoJIS(&cInfo);
\r
1717 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1718 cInfo2.OutLen = cInfo.OutLen;
\r
1721 Continue = ConvSJIStoEUC(&cInfo);
\r
1722 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1723 cInfo2.OutLen = cInfo.OutLen;
\r
1726 Continue = ConvSJIStoUTF8N(&cInfo);
\r
1727 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1728 cInfo2.OutLen = cInfo.OutLen;
\r
1730 case KANJI_UTF8BOM:
\r
1731 if(ProcessedBOM == NO)
\r
1733 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
1734 cInfo2.OutLen = 3;
\r
1736 ProcessedBOM = YES;
\r
1739 Continue = ConvSJIStoUTF8N(&cInfo);
\r
1740 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1741 cInfo2.OutLen = cInfo.OutLen;
\r
1746 switch(Pkt->KanjiCodeDesired)
\r
1749 Continue = ConvJIStoSJIS(&cInfo);
\r
1750 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1751 cInfo2.OutLen = cInfo.OutLen;
\r
1754 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1755 // cInfo2.OutLen = cInfo.StrLen;
\r
1758 Continue = ConvJIStoSJIS(&cInfo);
\r
1759 cInfo2.Str = cInfo.Buf;
\r
1760 cInfo2.StrLen = cInfo.OutLen;
\r
1761 cInfo2.Buf = Buf3;
\r
1762 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1763 ConvSJIStoJIS(&cInfo2);
\r
1766 Continue = ConvJIStoSJIS(&cInfo);
\r
1767 cInfo2.Str = cInfo.Buf;
\r
1768 cInfo2.StrLen = cInfo.OutLen;
\r
1769 cInfo2.Buf = Buf3;
\r
1770 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1771 ConvSJIStoEUC(&cInfo2);
\r
1774 Continue = ConvJIStoSJIS(&cInfo);
\r
1775 cInfo2.Str = cInfo.Buf;
\r
1776 cInfo2.StrLen = cInfo.OutLen;
\r
1777 cInfo2.Buf = Buf3;
\r
1778 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1779 ConvSJIStoUTF8N(&cInfo2);
\r
1781 case KANJI_UTF8BOM:
\r
1782 if(ProcessedBOM == NO)
\r
1784 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
1785 cInfo2.OutLen = 3;
\r
1787 ProcessedBOM = YES;
\r
1790 Continue = ConvJIStoSJIS(&cInfo);
\r
1791 cInfo2.Str = cInfo.Buf;
\r
1792 cInfo2.StrLen = cInfo.OutLen;
\r
1793 cInfo2.Buf = Buf3;
\r
1794 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1795 ConvSJIStoUTF8N(&cInfo2);
\r
1800 switch(Pkt->KanjiCodeDesired)
\r
1803 Continue = ConvEUCtoSJIS(&cInfo);
\r
1804 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1805 cInfo2.OutLen = cInfo.OutLen;
\r
1808 Continue = ConvEUCtoSJIS(&cInfo);
\r
1809 cInfo2.Str = cInfo.Buf;
\r
1810 cInfo2.StrLen = cInfo.OutLen;
\r
1811 cInfo2.Buf = Buf3;
\r
1812 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1813 ConvSJIStoJIS(&cInfo2);
\r
1816 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1817 // cInfo2.OutLen = cInfo.StrLen;
\r
1820 Continue = ConvEUCtoSJIS(&cInfo);
\r
1821 cInfo2.Str = cInfo.Buf;
\r
1822 cInfo2.StrLen = cInfo.OutLen;
\r
1823 cInfo2.Buf = Buf3;
\r
1824 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1825 ConvSJIStoEUC(&cInfo2);
\r
1828 Continue = ConvEUCtoSJIS(&cInfo);
\r
1829 cInfo2.Str = cInfo.Buf;
\r
1830 cInfo2.StrLen = cInfo.OutLen;
\r
1831 cInfo2.Buf = Buf3;
\r
1832 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1833 ConvSJIStoUTF8N(&cInfo2);
\r
1835 case KANJI_UTF8BOM:
\r
1836 if(ProcessedBOM == NO)
\r
1838 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
1839 cInfo2.OutLen = 3;
\r
1841 ProcessedBOM = YES;
\r
1844 Continue = ConvEUCtoSJIS(&cInfo);
\r
1845 cInfo2.Str = cInfo.Buf;
\r
1846 cInfo2.StrLen = cInfo.OutLen;
\r
1847 cInfo2.Buf = Buf3;
\r
1848 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1849 ConvSJIStoUTF8N(&cInfo2);
\r
1854 switch(Pkt->KanjiCodeDesired)
\r
1857 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1858 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1859 cInfo2.OutLen = cInfo.OutLen;
\r
1862 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1863 cInfo2.Str = cInfo.Buf;
\r
1864 cInfo2.StrLen = cInfo.OutLen;
\r
1865 cInfo2.Buf = Buf3;
\r
1866 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1867 ConvSJIStoJIS(&cInfo2);
\r
1870 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1871 cInfo2.Str = cInfo.Buf;
\r
1872 cInfo2.StrLen = cInfo.OutLen;
\r
1873 cInfo2.Buf = Buf3;
\r
1874 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1875 ConvSJIStoEUC(&cInfo2);
\r
1878 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1879 cInfo2.OutLen = cInfo.StrLen;
\r
1882 case KANJI_UTF8BOM:
\r
1883 if(ProcessedBOM == NO)
\r
1885 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
1886 cInfo2.OutLen = 3;
\r
1888 ProcessedBOM = YES;
\r
1891 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1892 cInfo2.OutLen = cInfo.StrLen;
\r
1897 case KANJI_UTF8BOM:
\r
1898 if(ProcessedBOM == NO)
\r
1900 if(memcmp(Buf, "\xEF\xBB\xBF", 3) == 0)
\r
1903 cInfo.StrLen -= 3;
\r
1905 cInfo2.OutLen = 0;
\r
1906 switch(Pkt->KanjiCodeDesired)
\r
1908 case KANJI_UTF8BOM:
\r
1909 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
1910 cInfo2.OutLen = 3;
\r
1914 ProcessedBOM = YES;
\r
1917 switch(Pkt->KanjiCodeDesired)
\r
1920 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1921 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1922 cInfo2.OutLen = cInfo.OutLen;
\r
1925 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1926 cInfo2.Str = cInfo.Buf;
\r
1927 cInfo2.StrLen = cInfo.OutLen;
\r
1928 cInfo2.Buf = Buf3;
\r
1929 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1930 ConvSJIStoJIS(&cInfo2);
\r
1933 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1934 cInfo2.Str = cInfo.Buf;
\r
1935 cInfo2.StrLen = cInfo.OutLen;
\r
1936 cInfo2.Buf = Buf3;
\r
1937 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1938 ConvSJIStoEUC(&cInfo2);
\r
1941 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1942 cInfo2.OutLen = cInfo.StrLen;
\r
1945 case KANJI_UTF8BOM:
\r
1946 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1947 cInfo2.OutLen = cInfo.StrLen;
\r
1953 // if(WriteFile(iFileHandle, Buf2, cInfo.OutLen, &Writed, NULL) == FALSE)
\r
1954 if(WriteFile(iFileHandle, Buf3, cInfo2.OutLen, &Writed, NULL) == FALSE)
\r
1955 Pkt->Abort = ABORT_DISKFULL;
\r
1957 while((Continue == YES) && (Pkt->Abort == ABORT_NONE));
\r
1961 if(WriteFile(iFileHandle, Buf, iNumBytes, &Writed, NULL) == FALSE)
\r
1962 Pkt->Abort = ABORT_DISKFULL;
\r
1965 Pkt->ExistSize += iNumBytes;
\r
1966 if(Pkt->hWndTrans != NULL)
\r
1968 // AllTransSizeNow += iNumBytes;
\r
1969 AllTransSizeNow[Pkt->ThreadCount] += iNumBytes;
\r
1972 /* 転送ダイアログを出さない時の経過表示 */
\r
1973 DispDownloadSize(Pkt->ExistSize);
\r
1976 if(BackgrndMessageProc() == YES)
\r
1980 /* 書き残したデータを書き込む */
\r
1981 if(Pkt->KanjiCode != KANJI_NOCNV)
\r
1984 cInfo.BufSize = BUFSIZE+3;
\r
1985 FlushRestData(&cInfo);
\r
1986 switch(Pkt->KanjiCode)
\r
1989 switch(Pkt->KanjiCodeDesired)
\r
1993 cInfo2.Str = cInfo.Buf;
\r
1994 cInfo2.StrLen = cInfo.OutLen;
\r
1995 cInfo2.Buf = Buf3;
\r
1996 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1997 ConvJIStoSJIS(&cInfo2);
\r
2000 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2001 cInfo2.OutLen = cInfo.OutLen;
\r
2004 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2005 cInfo2.OutLen = cInfo.OutLen;
\r
2008 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2009 cInfo2.OutLen = cInfo.OutLen;
\r
2011 case KANJI_UTF8BOM:
\r
2012 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2013 cInfo2.OutLen = cInfo.OutLen;
\r
2018 switch(Pkt->KanjiCodeDesired)
\r
2021 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2022 cInfo2.OutLen = cInfo.OutLen;
\r
2026 cInfo2.Str = cInfo.Buf;
\r
2027 cInfo2.StrLen = cInfo.OutLen;
\r
2028 cInfo2.Buf = Buf3;
\r
2029 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2030 ConvSJIStoJIS(&cInfo2);
\r
2033 cInfo2.Str = cInfo.Buf;
\r
2034 cInfo2.StrLen = cInfo.OutLen;
\r
2035 cInfo2.Buf = Buf3;
\r
2036 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2037 ConvSJIStoEUC(&cInfo2);
\r
2040 cInfo2.Str = cInfo.Buf;
\r
2041 cInfo2.StrLen = cInfo.OutLen;
\r
2042 cInfo2.Buf = Buf3;
\r
2043 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2044 ConvSJIStoUTF8N(&cInfo2);
\r
2046 case KANJI_UTF8BOM:
\r
2047 cInfo2.Str = cInfo.Buf;
\r
2048 cInfo2.StrLen = cInfo.OutLen;
\r
2049 cInfo2.Buf = Buf3;
\r
2050 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2051 ConvSJIStoUTF8N(&cInfo2);
\r
2056 switch(Pkt->KanjiCodeDesired)
\r
2059 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2060 cInfo2.OutLen = cInfo.OutLen;
\r
2063 cInfo2.Str = cInfo.Buf;
\r
2064 cInfo2.StrLen = cInfo.OutLen;
\r
2065 cInfo2.Buf = Buf3;
\r
2066 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2067 ConvSJIStoJIS(&cInfo2);
\r
2071 cInfo2.Str = cInfo.Buf;
\r
2072 cInfo2.StrLen = cInfo.OutLen;
\r
2073 cInfo2.Buf = Buf3;
\r
2074 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2075 ConvSJIStoEUC(&cInfo2);
\r
2078 cInfo2.Str = cInfo.Buf;
\r
2079 cInfo2.StrLen = cInfo.OutLen;
\r
2080 cInfo2.Buf = Buf3;
\r
2081 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2082 ConvSJIStoUTF8N(&cInfo2);
\r
2084 case KANJI_UTF8BOM:
\r
2085 cInfo2.Str = cInfo.Buf;
\r
2086 cInfo2.StrLen = cInfo.OutLen;
\r
2087 cInfo2.Buf = Buf3;
\r
2088 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2089 ConvSJIStoUTF8N(&cInfo2);
\r
2094 switch(Pkt->KanjiCodeDesired)
\r
2097 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2098 cInfo2.OutLen = cInfo.OutLen;
\r
2101 cInfo2.Str = cInfo.Buf;
\r
2102 cInfo2.StrLen = cInfo.OutLen;
\r
2103 cInfo2.Buf = Buf3;
\r
2104 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2105 ConvSJIStoJIS(&cInfo2);
\r
2108 cInfo2.Str = cInfo.Buf;
\r
2109 cInfo2.StrLen = cInfo.OutLen;
\r
2110 cInfo2.Buf = Buf3;
\r
2111 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2112 ConvSJIStoEUC(&cInfo2);
\r
2115 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2116 cInfo2.OutLen = cInfo.OutLen;
\r
2118 case KANJI_UTF8BOM:
\r
2119 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2120 cInfo2.OutLen = cInfo.OutLen;
\r
2124 case KANJI_UTF8BOM:
\r
2125 switch(Pkt->KanjiCodeDesired)
\r
2128 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2129 cInfo2.OutLen = cInfo.OutLen;
\r
2132 cInfo2.Str = cInfo.Buf;
\r
2133 cInfo2.StrLen = cInfo.OutLen;
\r
2134 cInfo2.Buf = Buf3;
\r
2135 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2136 ConvSJIStoJIS(&cInfo2);
\r
2139 cInfo2.Str = cInfo.Buf;
\r
2140 cInfo2.StrLen = cInfo.OutLen;
\r
2141 cInfo2.Buf = Buf3;
\r
2142 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2143 ConvSJIStoEUC(&cInfo2);
\r
2146 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2147 cInfo2.OutLen = cInfo.OutLen;
\r
2149 case KANJI_UTF8BOM:
\r
2150 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2151 cInfo2.OutLen = cInfo.OutLen;
\r
2156 // if(WriteFile(iFileHandle, Buf2, cInfo.OutLen, &Writed, NULL) == FALSE)
\r
2157 if(WriteFile(iFileHandle, Buf3, cInfo2.OutLen, &Writed, NULL) == FALSE)
\r
2158 Pkt->Abort = ABORT_DISKFULL;
\r
2159 cInfo2.Buf = Buf3;
\r
2160 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2161 FlushRestData(&cInfo2);
\r
2162 if(WriteFile(iFileHandle, Buf3, cInfo2.OutLen, &Writed, NULL) == FALSE)
\r
2163 Pkt->Abort = ABORT_DISKFULL;
\r
2167 if(Pkt->hWndTrans != NULL)
\r
2169 KillTimer(Pkt->hWndTrans, TIMER_DISPLAY);
\r
2170 DispTransferStatus(Pkt->hWndTrans, YES, Pkt);
\r
2172 // TimeStart = time(NULL) - TimeStart + 1;
\r
2173 TimeStart[Pkt->ThreadCount] = time(NULL) - TimeStart[Pkt->ThreadCount] + 1;
\r
2177 /* 転送ダイアログを出さない時の経過表示を消す */
\r
2178 DispDownloadSize(-1);
\r
2181 /* ファイルのタイムスタンプを合わせる */
\r
2182 if((SaveTimeStamp == YES) &&
\r
2183 ((Pkt->Time.dwLowDateTime != 0) || (Pkt->Time.dwHighDateTime != 0)))
\r
2185 SetFileTime(iFileHandle, &Pkt->Time, &Pkt->Time, &Pkt->Time);
\r
2188 CloseHandle(iFileHandle);
\r
2190 if(iNumBytes == SOCKET_ERROR)
\r
2191 ReportWSError("recv",WSAGetLastError());
\r
2195 SetErrorMsg(MSGJPN095, Pkt->LocalFile);
\r
2196 SetTaskMsg(MSGJPN095, Pkt->LocalFile);
\r
2197 Pkt->Abort = ABORT_ERROR;
\r
2201 if(shutdown(dSkt, 1) != 0)
\r
2202 ReportWSError("shutdown", WSAGetLastError());
\r
2206 if(ForceAbort == NO)
\r
2208 /* Abortをホストに伝える */
\r
2209 if(Pkt->Abort != ABORT_NONE && iFileHandle != INVALID_HANDLE_VALUE)
\r
2211 SendData(Pkt->ctrl_skt, "\xFF\xF4\xFF", 3, MSG_OOB, CancelCheckWork); /* MSG_OOBに注意 */
\r
2212 SendData(Pkt->ctrl_skt, "\xF2", 1, 0, CancelCheckWork);
\r
2213 command(Pkt->ctrl_skt, NULL, CancelCheckWork, "ABOR");
\r
2217 iRetCode = ReadReplyMessage(Pkt->ctrl_skt, Buf, 1024, CancelCheckWork, TmpBuf);
\r
2220 //DoPrintf("##DOWN REPLY : %s", Buf);
\r
2222 if(Pkt->Abort == ABORT_DISKFULL)
\r
2224 SetErrorMsg(MSGJPN096);
\r
2225 SetTaskMsg(MSGJPN096);
\r
2227 if(iRetCode >= FTP_RETRY)
\r
2229 if(Pkt->Abort != ABORT_NONE)
\r
2236 /*----- ダウンロード終了/中止時のメッセージを表示 ----------------------------
\r
2239 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2240 * int iRetCode : 応答コード
\r
2244 *----------------------------------------------------------------------------*/
\r
2246 static void DispDownloadFinishMsg(TRANSPACKET *Pkt, int iRetCode)
\r
2248 char Fname[FMAX_PATH+1];
\r
2250 if(ForceAbort == NO)
\r
2252 if((iRetCode/100) >= FTP_CONTINUE)
\r
2254 strcpy(Fname, Pkt->RemoteFile);
\r
2256 #if defined(HAVE_OPENVMS)
\r
2257 /* OpenVMSの場合、空ディレクトリへ移動すると550 File not foundになって
\r
2258 * エラーダイアログやエラーメッセージが出るので何もしない */
\r
2259 if (AskHostType() == HTYPE_VMS)
\r
2263 if((strncmp(Pkt->Cmd, "NLST", 4) == 0) || (strncmp(Pkt->Cmd, "LIST", 4) == 0))
\r
2265 SetTaskMsg(MSGJPN097);
\r
2266 strcpy(Fname, MSGJPN098);
\r
2269 // else if((Pkt->hWndTrans != NULL) && (TimeStart != 0))
\r
2270 // SetTaskMsg(MSGJPN099, TimeStart, Pkt->ExistSize/TimeStart);
\r
2271 else if((Pkt->hWndTrans != NULL) && (TimeStart[Pkt->ThreadCount] != 0))
\r
2272 SetTaskMsg(MSGJPN099, TimeStart[Pkt->ThreadCount], Pkt->ExistSize/TimeStart[Pkt->ThreadCount]);
\r
2274 SetTaskMsg(MSGJPN100);
\r
2276 if(Pkt->Abort != ABORT_USER)
\r
2278 // 全て中止を選択後にダイアログが表示されるバグ対策
\r
2279 // if(DispUpDownErrDialog(downerr_dlg, Pkt->hWndTrans, Fname) == NO)
\r
2281 // if(Canceled[Pkt->ThreadCount] == NO && ClearAll == NO && DispUpDownErrDialog(downerr_dlg, Pkt->hWndTrans, Fname) == NO)
\r
2282 // ClearAll = YES;
\r
2283 if(Canceled[Pkt->ThreadCount] == NO && ClearAll == NO)
\r
2285 if(TransferErrorNotify == YES && DispUpDownErrDialog(downerr_dlg, Pkt->hWndTrans, Pkt) == NO)
\r
2289 Pkt->Mode = TransferErrorMode;
\r
2290 AddTransFileList(Pkt);
\r
2297 if((strncmp(Pkt->Cmd, "NLST", 4) == 0) || (strncmp(Pkt->Cmd, "LIST", 4) == 0))
\r
2298 SetTaskMsg(MSGJPN101, Pkt->ExistSize);
\r
2300 // else if((Pkt->hWndTrans != NULL) && (TimeStart != 0))
\r
2301 // SetTaskMsg(MSGJPN102, TimeStart, Pkt->ExistSize/TimeStart);
\r
2302 else if((Pkt->hWndTrans != NULL) && (TimeStart[Pkt->ThreadCount] != 0))
\r
2303 // "0 B/S"と表示されるバグを修正
\r
2304 // 原因は%dにあたる部分に64ビット値が渡されているため
\r
2305 // SetTaskMsg(MSGJPN102, TimeStart[Pkt->ThreadCount], Pkt->ExistSize/TimeStart[Pkt->ThreadCount]);
\r
2306 SetTaskMsg(MSGJPN102, (LONG)TimeStart[Pkt->ThreadCount], (LONG)(Pkt->ExistSize/TimeStart[Pkt->ThreadCount]));
\r
2308 SetTaskMsg(MSGJPN103, Pkt->ExistSize);
\r
2315 /*----- ダウンロード/アップロードエラーのダイアログを表示 --------------------
\r
2318 * int RedID : ダイアログボックスのリソースID
\r
2319 * HWND hWnd : 書き込み中ダイアログのウインドウ
\r
2320 * char *Fname : ファイル名
\r
2323 * int ステータス (YES=中止/NO=全て中止)
\r
2324 *----------------------------------------------------------------------------*/
\r
2327 //static int DispUpDownErrDialog(int ResID, HWND hWnd, char *Fname)
\r
2328 static int DispUpDownErrDialog(int ResID, HWND hWnd, TRANSPACKET *Pkt)
\r
2331 hWnd = GetMainHwnd();
\r
2333 SoundPlay(SND_ERROR);
\r
2335 // return(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(ResID), hWnd, UpDownErrorDialogProc, (LPARAM)Fname));
\r
2336 return(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(ResID), hWnd, UpDownErrorDialogProc, (LPARAM)Pkt));
\r
2340 /*----- ダウンロードエラー/アップロードエラーダイアログのコールバック --------
\r
2343 * HWND hDlg : ウインドウハンドル
\r
2344 * UINT message : メッセージ番号
\r
2345 * WPARAM wParam : メッセージの WPARAM 引数
\r
2346 * LPARAM lParam : メッセージの LPARAM 引数
\r
2350 *----------------------------------------------------------------------------*/
\r
2352 static BOOL CALLBACK UpDownErrorDialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
\r
2354 static TRANSPACKET *Pkt;
\r
2355 static const RADIOBUTTON DownExistButton[] = {
\r
2356 { DOWN_EXIST_OVW, EXIST_OVW },
\r
2357 { DOWN_EXIST_RESUME, EXIST_RESUME },
\r
2358 { DOWN_EXIST_IGNORE, EXIST_IGNORE }
\r
2360 #define DOWNEXISTBUTTONS (sizeof(DownExistButton)/sizeof(RADIOBUTTON))
\r
2364 case WM_INITDIALOG :
\r
2365 Pkt = (TRANSPACKET *)lParam;
\r
2366 // SendDlgItemMessage(hDlg, UPDOWN_ERR_FNAME, WM_SETTEXT, 0, (LPARAM)lParam);
\r
2367 SendDlgItemMessage(hDlg, UPDOWN_ERR_FNAME, WM_SETTEXT, 0, (LPARAM)Pkt->RemoteFile);
\r
2369 // SendDlgItemMessage(hDlg, UPDOWN_ERR_MSG, WM_SETTEXT, 0, (LPARAM)ErrMsg);
\r
2370 SendDlgItemMessage(hDlg, UPDOWN_ERR_MSG, WM_SETTEXT, 0, (LPARAM)GetErrMsg());
\r
2372 if((Pkt->Type == TYPE_A) || (Pkt->ExistSize <= 0))
\r
2373 EnableWindow(GetDlgItem(hDlg, DOWN_EXIST_RESUME), FALSE);
\r
2375 SetRadioButtonByValue(hDlg, TransferErrorMode, DownExistButton, DOWNEXISTBUTTONS);
\r
2379 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2382 TransferErrorNotify = NO;
\r
2383 /* ここに break はない */
\r
2386 TransferErrorMode = AskRadioButtonValue(hDlg, DownExistButton, DOWNEXISTBUTTONS);
\r
2387 EndDialog(hDlg, YES);
\r
2391 EndDialog(hDlg, NO);
\r
2395 // hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000009);
\r
2404 /*----- ダウンロードのリジュームの準備を行う ----------------------------------
\r
2407 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2408 * iont ProcMode : 処理モード(EXIST_xxx)
\r
2409 * LONGLONG Size : ロード済みのファイルのサイズ
\r
2410 * int *Mode : ファイル作成モード (CREATE_xxxx)
\r
2413 * int 転送を行うかどうか(YES/NO=このファイルを中止/NO_ALL=全て中止)
\r
2416 * Pkt->ExistSizeのセットを行なう
\r
2417 *----------------------------------------------------------------------------*/
\r
2419 static int SetDownloadResume(TRANSPACKET *Pkt, int ProcMode, LONGLONG Size, int *Mode, int *CancelCheckWork)
\r
2423 char Reply[ERR_MSG_LEN+7];
\r
2428 Pkt->ExistSize = 0;
\r
2429 *Mode = CREATE_ALWAYS;
\r
2431 if(ProcMode == EXIST_RESUME)
\r
2433 iRetCode = command(Pkt->ctrl_skt, Reply, CancelCheckWork, "REST %s", MakeNumString(Size, Tmp, FALSE));
\r
2434 if(iRetCode/100 < FTP_RETRY)
\r
2437 if(Pkt->hWndTrans != NULL)
\r
2438 Pkt->ExistSize = Size;
\r
2439 *Mode = OPEN_ALWAYS;
\r
2443 Com = DialogBox(GetFtpInst(), MAKEINTRESOURCE(noresume_dlg), Pkt->hWndTrans, NoResumeWndProc);
\r
2446 if(Com == NO_ALL) /* 全て中止 */
\r
2448 Pkt->Abort = ABORT_USER;
\r
2456 /*----- resumeエラーダイアログのコールバック ----------------------------------
\r
2459 * HWND hDlg : ウインドウハンドル
\r
2460 * UINT message : メッセージ番号
\r
2461 * WPARAM wParam : メッセージの WPARAM 引数
\r
2462 * LPARAM lParam : メッセージの LPARAM 引数
\r
2466 *----------------------------------------------------------------------------*/
\r
2468 static BOOL CALLBACK NoResumeWndProc(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2472 case WM_INITDIALOG :
\r
2476 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2479 EndDialog(hDlg, YES);
\r
2483 EndDialog(hDlg, NO);
\r
2486 case RESUME_CANCEL_ALL :
\r
2487 EndDialog(hDlg, NO_ALL);
\r
2497 /*----- アップロードを行なう --------------------------------------------------
\r
2500 * SOCKET cSkt : コントロールソケット
\r
2501 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2505 *----------------------------------------------------------------------------*/
\r
2507 static int DoUpLoad(SOCKET cSkt, TRANSPACKET *Pkt)
\r
2510 char Reply[ERR_MSG_LEN+7];
\r
2512 Pkt->ctrl_skt = cSkt;
\r
2514 if(Pkt->Mode != EXIST_IGNORE)
\r
2516 if(CheckFileReadable(Pkt->LocalFile) == FFFTP_SUCCESS)
\r
2518 if(Pkt->Type == TYPE_I)
\r
2519 Pkt->KanjiCode = KANJI_NOCNV;
\r
2522 // iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled, "TYPE %c", Pkt->Type);
\r
2523 iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled[Pkt->ThreadCount], "TYPE %c", Pkt->Type);
\r
2524 if(iRetCode/100 < FTP_RETRY)
\r
2526 if(Pkt->Mode == EXIST_UNIQUE)
\r
2527 strcpy(Pkt->Cmd, "STOU ");
\r
2529 if(Pkt->hWndTrans != NULL)
\r
2530 DispTransFileInfo(Pkt, MSGJPN104, TRUE, YES);
\r
2532 if(BackgrndMessageProc() == NO)
\r
2534 if(AskPasvMode() != YES)
\r
2535 iRetCode = UpLoadNonPassive(Pkt);
\r
2537 iRetCode = UpLoadPassive(Pkt);
\r
2543 SetErrorMsg(Reply);
\r
2546 if((Pkt->Attr != -1) && ((iRetCode/100) == FTP_COMPLETE))
\r
2548 // command(Pkt->ctrl_skt, Reply, &Canceled, "%s %03X %s", AskHostChmodCmd(), Pkt->Attr, Pkt->RemoteFile);
\r
2549 command(Pkt->ctrl_skt, Reply, &Canceled[Pkt->ThreadCount], "%s %03X %s", AskHostChmodCmd(), Pkt->Attr, Pkt->RemoteFile);
\r
2553 SetErrorMsg(MSGJPN105, Pkt->LocalFile);
\r
2554 SetTaskMsg(MSGJPN105, Pkt->LocalFile);
\r
2556 Pkt->Abort = ABORT_ERROR;
\r
2557 DispUploadFinishMsg(Pkt, iRetCode);
\r
2562 DispTransFileInfo(Pkt, MSGJPN106, TRUE, YES);
\r
2563 SetTaskMsg(MSGJPN107, Pkt->LocalFile);
\r
2570 /*----- 通常モードでファイルをアップロード ------------------------------------
\r
2573 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2577 *----------------------------------------------------------------------------*/
\r
2579 static int UpLoadNonPassive(TRANSPACKET *Pkt)
\r
2583 SOCKET data_socket = INVALID_SOCKET; // data channel socket
\r
2584 SOCKET listen_socket = INVALID_SOCKET; // data listen socket
\r
2587 // struct sockaddr_in saSockAddr1;
\r
2588 struct sockaddr_in saSockAddrIPv4;
\r
2589 struct sockaddr_in6 saSockAddrIPv6;
\r
2591 char Reply[ERR_MSG_LEN+7];
\r
2594 // if((listen_socket = GetFTPListenSocket(Pkt->ctrl_skt, &Canceled)) != INVALID_SOCKET)
\r
2595 if((listen_socket = GetFTPListenSocket(Pkt->ctrl_skt, &Canceled[Pkt->ThreadCount])) != INVALID_SOCKET)
\r
2597 SetUploadResume(Pkt, Pkt->Mode, Pkt->ExistSize, &Resume);
\r
2599 sprintf(Buf, "%s%s", Pkt->Cmd, Pkt->RemoteFile);
\r
2601 sprintf(Buf, "%s%s", "APPE ", Pkt->RemoteFile);
\r
2604 // iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled, "%s", Buf);
\r
2605 iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled[Pkt->ThreadCount], "%s", Buf);
\r
2606 if((iRetCode/100) == FTP_PRELIM)
\r
2609 // if(SocksGet2ndBindReply(listen_socket, &data_socket) == FFFTP_FAIL)
\r
2610 if(SocksGet2ndBindReply(listen_socket, &data_socket, &Canceled[Pkt->ThreadCount]) == FFFTP_FAIL)
\r
2613 // iLength=sizeof(saSockAddr1);
\r
2614 // data_socket = do_accept(listen_socket,(struct sockaddr *)&saSockAddr1, (int *)&iLength);
\r
2615 switch(AskCurNetType())
\r
2618 iLength=sizeof(saSockAddrIPv4);
\r
2619 data_socket = do_accept(listen_socket,(struct sockaddr *)&saSockAddrIPv4, (int *)&iLength);
\r
2622 iLength=sizeof(saSockAddrIPv6);
\r
2623 data_socket = do_accept(listen_socket,(struct sockaddr *)&saSockAddrIPv6, (int *)&iLength);
\r
2627 if(shutdown(listen_socket, 1) != 0)
\r
2628 ReportWSError("shutdown listen", WSAGetLastError());
\r
2629 listen_socket = DoClose(listen_socket);
\r
2631 if(data_socket == INVALID_SOCKET)
\r
2633 SetErrorMsg(MSGJPN280);
\r
2634 ReportWSError("accept", WSAGetLastError());
\r
2639 // DoPrintf("Skt=%u : accept from %s port %u", data_socket, inet_ntoa(saSockAddr1.sin_addr), ntohs(saSockAddr1.sin_port));
\r
2641 switch(AskCurNetType())
\r
2644 DoPrintf("Skt=%u : accept from %s port %u", data_socket, inet_ntoa(saSockAddrIPv4.sin_addr), ntohs(saSockAddrIPv4.sin_port));
\r
2647 DoPrintf("Skt=%u : accept from %s port %u", data_socket, inet6_ntoa(saSockAddrIPv6.sin6_addr), ntohs(saSockAddrIPv6.sin6_port));
\r
2653 if(data_socket != INVALID_SOCKET)
\r
2655 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
2656 ReleaseMutex(hListAccMutex);
\r
2658 // iRetCode = UpLoadFile(Pkt, data_socket);
\r
2659 if(IsSSLAttached(Pkt->ctrl_skt))
\r
2661 if(AttachSSL(data_socket, Pkt->ctrl_skt, &Canceled[Pkt->ThreadCount]))
\r
2662 iRetCode = UpLoadFile(Pkt, data_socket);
\r
2667 iRetCode = UpLoadFile(Pkt, data_socket);
\r
2668 data_socket = DoClose(data_socket);
\r
2673 SetErrorMsg(Reply);
\r
2674 SetTaskMsg(MSGJPN108);
\r
2675 listen_socket = DoClose(listen_socket);
\r
2681 SetErrorMsg(MSGJPN279);
\r
2684 DispUploadFinishMsg(Pkt, iRetCode);
\r
2690 /*----- Passiveモードでファイルをアップロード ---------------------------------
\r
2693 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2697 *----------------------------------------------------------------------------*/
\r
2699 static int UpLoadPassive(TRANSPACKET *Pkt)
\r
2702 SOCKET data_socket = INVALID_SOCKET; // data channel socket
\r
2710 char Reply[ERR_MSG_LEN+7];
\r
2713 // iRetCode = command(Pkt->ctrl_skt, Buf, &Canceled, "PASV");
\r
2715 // iRetCode = command(Pkt->ctrl_skt, Buf, &Canceled[Pkt->ThreadCount], "PASV");
\r
2716 switch(AskCurNetType())
\r
2719 iRetCode = command(Pkt->ctrl_skt, Buf, &Canceled[Pkt->ThreadCount], "PASV");
\r
2722 iRetCode = command(Pkt->ctrl_skt, Buf, &Canceled[Pkt->ThreadCount], "EPSV");
\r
2725 if(iRetCode/100 == FTP_COMPLETE)
\r
2728 // if(GetAdrsAndPort(Buf, Adrs, &Port, 19) == FFFTP_SUCCESS)
\r
2729 if(GetAdrsAndPort(Pkt->ctrl_skt, Buf, Adrs, &Port, 39) == FFFTP_SUCCESS)
\r
2732 // if((data_socket = connectsock(Adrs, Port, MSGJPN109, &Canceled)) != INVALID_SOCKET)
\r
2733 if((data_socket = connectsock(Adrs, Port, MSGJPN109, &Canceled[Pkt->ThreadCount])) != INVALID_SOCKET)
\r
2737 if(setsockopt(data_socket, IPPROTO_TCP, TCP_NODELAY, (LPSTR)&Flg, sizeof(Flg)) == SOCKET_ERROR)
\r
2738 ReportWSError("setsockopt", WSAGetLastError());
\r
2740 SetUploadResume(Pkt, Pkt->Mode, Pkt->ExistSize, &Resume);
\r
2742 sprintf(Buf, "%s%s", Pkt->Cmd, Pkt->RemoteFile);
\r
2744 sprintf(Buf, "%s%s", "APPE ", Pkt->RemoteFile);
\r
2747 // iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled, "%s", Buf);
\r
2748 iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled[Pkt->ThreadCount], "%s", Buf);
\r
2749 if(iRetCode/100 == FTP_PRELIM)
\r
2751 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
2752 ReleaseMutex(hListAccMutex);
\r
2754 // iRetCode = UpLoadFile(Pkt, data_socket);
\r
2755 if(IsSSLAttached(Pkt->ctrl_skt))
\r
2757 if(AttachSSL(data_socket, Pkt->ctrl_skt, &Canceled[Pkt->ThreadCount]))
\r
2758 iRetCode = UpLoadFile(Pkt, data_socket);
\r
2763 iRetCode = UpLoadFile(Pkt, data_socket);
\r
2765 data_socket = DoClose(data_socket);
\r
2769 SetErrorMsg(Reply);
\r
2770 SetTaskMsg(MSGJPN110);
\r
2771 data_socket = DoClose(data_socket);
\r
2777 SetErrorMsg(MSGJPN281);
\r
2784 SetTaskMsg(MSGJPN111);
\r
2791 DispUploadFinishMsg(Pkt, iRetCode);
\r
2797 /*----- アップロードの実行 ----------------------------------------------------
\r
2800 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2801 * SOCKET dSkt : データソケット
\r
2807 * 転送の経過表示は、インターバルタイマで経過を表示する
\r
2808 * 転送ダイアログを出さないでアップロードすることはない
\r
2809 *----------------------------------------------------------------------------*/
\r
2811 static int UpLoadFile(TRANSPACKET *Pkt, SOCKET dSkt)
\r
2814 HANDLE iFileHandle;
\r
2815 SECURITY_ATTRIBUTES Sec;
\r
2816 char Buf[BUFSIZE];
\r
2817 char Buf2[BUFSIZE+3];
\r
2818 CODECONVINFO cInfo;
\r
2819 TERMCODECONVINFO tInfo;
\r
2826 char TmpBuf[ONELINE_BUF_SIZE];
\r
2830 #ifdef SET_BUFFER_SIZE
\r
2831 /* Add by H.Shirouzu at 2002/10/02 */
\r
2832 int buf_size = SOCKBUF_SIZE;
\r
2833 for ( ; buf_size > 0; buf_size /= 2)
\r
2834 if (setsockopt(dSkt, SOL_SOCKET, SO_SNDBUF, (char *)&buf_size, sizeof(buf_size)) == 0)
\r
2839 // 念のため送信バッファを無効にする
\r
2840 #ifdef DISABLE_TRANSFER_NETWORK_BUFFERS
\r
2842 setsockopt(dSkt, SOL_SOCKET, SO_SNDBUF, (char *)&buf_size, sizeof(buf_size));
\r
2845 Pkt->Abort = ABORT_NONE;
\r
2847 Sec.nLength = sizeof(SECURITY_ATTRIBUTES);
\r
2848 Sec.lpSecurityDescriptor = NULL;
\r
2849 Sec.bInheritHandle = FALSE;
\r
2851 if((iFileHandle = CreateFile(Pkt->LocalFile, GENERIC_READ,
\r
2852 FILE_SHARE_READ|FILE_SHARE_WRITE, &Sec, OPEN_EXISTING, 0, NULL)) != INVALID_HANDLE_VALUE)
\r
2855 char Buf3[(BUFSIZE + 3) * 4];
\r
2856 CODECONVINFO cInfo2;
\r
2857 int ProcessedBOM = NO;
\r
2858 if(Pkt->hWndTrans != NULL)
\r
2860 Low = GetFileSize(iFileHandle, &High);
\r
2861 Pkt->Size = MakeLongLong(High, Low);
\r
2863 High = (DWORD)HIGH32(Pkt->ExistSize);
\r
2864 Low = (DWORD)LOW32(Pkt->ExistSize);
\r
2865 SetFilePointer(iFileHandle, Low, &High, FILE_BEGIN);
\r
2868 // AllTransSizeNow = 0;
\r
2869 // TimeStart = time(NULL);
\r
2870 AllTransSizeNow[Pkt->ThreadCount] = 0;
\r
2871 TimeStart[Pkt->ThreadCount] = time(NULL);
\r
2872 SetTimer(Pkt->hWndTrans, TIMER_DISPLAY, DISPLAY_TIMING, NULL);
\r
2875 InitCodeConvInfo(&cInfo);
\r
2876 cInfo.KanaCnv = Pkt->KanaCnv;
\r
2877 InitTermCodeConvInfo(&tInfo);
\r
2879 InitCodeConvInfo(&cInfo2);
\r
2880 cInfo2.KanaCnv = Pkt->KanaCnv;
\r
2882 /*===== ファイルを送信するループ =====*/
\r
2883 while((Pkt->Abort == ABORT_NONE) &&
\r
2884 (ForceAbort == NO) &&
\r
2885 (ReadFile(iFileHandle, Buf, BUFSIZE, &iNumBytes, NULL) == TRUE))
\r
2887 if(iNumBytes == 0)
\r
2892 if((RmEOF == YES) && (Pkt->Type == TYPE_A))
\r
2894 if((EofPos = memchr(Buf, 0x1A, iNumBytes)) != NULL)
\r
2895 iNumBytes = EofPos - Buf;
\r
2899 if(Pkt->KanjiCode != KANJI_NOCNV)
\r
2902 cInfo.StrLen = iNumBytes;
\r
2904 cInfo.BufSize = BUFSIZE+3;
\r
2907 // ここで全てUTF-8へ変換する
\r
2908 // TODO: SJIS以外も直接UTF-8へ変換
\r
2909 // if(Pkt->KanjiCode == KANJI_JIS)
\r
2910 // Continue = ConvSJIStoJIS(&cInfo);
\r
2912 // Continue = ConvSJIStoEUC(&cInfo);
\r
2913 switch(Pkt->KanjiCodeDesired)
\r
2916 switch(Pkt->KanjiCode)
\r
2919 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
2920 // cInfo2.OutLen = cInfo.StrLen;
\r
2923 Continue = ConvSJIStoJIS(&cInfo);
\r
2924 cInfo2.Str = cInfo.Buf;
\r
2925 cInfo2.StrLen = cInfo.OutLen;
\r
2926 cInfo2.Buf = Buf3;
\r
2927 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2928 ConvJIStoSJIS(&cInfo2);
\r
2931 Continue = ConvSJIStoJIS(&cInfo);
\r
2932 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2933 cInfo2.OutLen = cInfo.OutLen;
\r
2936 Continue = ConvSJIStoEUC(&cInfo);
\r
2937 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2938 cInfo2.OutLen = cInfo.OutLen;
\r
2941 Continue = ConvSJIStoUTF8N(&cInfo);
\r
2942 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2943 cInfo2.OutLen = cInfo.OutLen;
\r
2945 case KANJI_UTF8BOM:
\r
2946 if(ProcessedBOM == NO)
\r
2948 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
2949 cInfo2.OutLen = 3;
\r
2951 ProcessedBOM = YES;
\r
2954 Continue = ConvSJIStoUTF8N(&cInfo);
\r
2955 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2956 cInfo2.OutLen = cInfo.OutLen;
\r
2961 switch(Pkt->KanjiCode)
\r
2964 Continue = ConvJIStoSJIS(&cInfo);
\r
2965 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2966 cInfo2.OutLen = cInfo.OutLen;
\r
2969 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
2970 // cInfo2.OutLen = cInfo.StrLen;
\r
2973 Continue = ConvJIStoSJIS(&cInfo);
\r
2974 cInfo2.Str = cInfo.Buf;
\r
2975 cInfo2.StrLen = cInfo.OutLen;
\r
2976 cInfo2.Buf = Buf3;
\r
2977 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2978 ConvSJIStoJIS(&cInfo2);
\r
2981 Continue = ConvJIStoSJIS(&cInfo);
\r
2982 cInfo2.Str = cInfo.Buf;
\r
2983 cInfo2.StrLen = cInfo.OutLen;
\r
2984 cInfo2.Buf = Buf3;
\r
2985 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2986 ConvSJIStoEUC(&cInfo2);
\r
2989 Continue = ConvJIStoSJIS(&cInfo);
\r
2990 cInfo2.Str = cInfo.Buf;
\r
2991 cInfo2.StrLen = cInfo.OutLen;
\r
2992 cInfo2.Buf = Buf3;
\r
2993 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2994 ConvSJIStoUTF8N(&cInfo2);
\r
2996 case KANJI_UTF8BOM:
\r
2997 if(ProcessedBOM == NO)
\r
2999 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
3000 cInfo2.OutLen = 3;
\r
3002 ProcessedBOM = YES;
\r
3005 Continue = ConvJIStoSJIS(&cInfo);
\r
3006 cInfo2.Str = cInfo.Buf;
\r
3007 cInfo2.StrLen = cInfo.OutLen;
\r
3008 cInfo2.Buf = Buf3;
\r
3009 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3010 ConvSJIStoUTF8N(&cInfo2);
\r
3015 switch(Pkt->KanjiCode)
\r
3018 Continue = ConvEUCtoSJIS(&cInfo);
\r
3019 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3020 cInfo2.OutLen = cInfo.OutLen;
\r
3023 Continue = ConvEUCtoSJIS(&cInfo);
\r
3024 cInfo2.Str = cInfo.Buf;
\r
3025 cInfo2.StrLen = cInfo.OutLen;
\r
3026 cInfo2.Buf = Buf3;
\r
3027 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3028 ConvSJIStoJIS(&cInfo2);
\r
3031 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
3032 // cInfo2.OutLen = cInfo.StrLen;
\r
3035 Continue = ConvEUCtoSJIS(&cInfo);
\r
3036 cInfo2.Str = cInfo.Buf;
\r
3037 cInfo2.StrLen = cInfo.OutLen;
\r
3038 cInfo2.Buf = Buf3;
\r
3039 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3040 ConvSJIStoEUC(&cInfo2);
\r
3043 Continue = ConvEUCtoSJIS(&cInfo);
\r
3044 cInfo2.Str = cInfo.Buf;
\r
3045 cInfo2.StrLen = cInfo.OutLen;
\r
3046 cInfo2.Buf = Buf3;
\r
3047 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3048 ConvSJIStoUTF8N(&cInfo2);
\r
3050 case KANJI_UTF8BOM:
\r
3051 if(ProcessedBOM == NO)
\r
3053 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
3054 cInfo2.OutLen = 3;
\r
3056 ProcessedBOM = YES;
\r
3059 Continue = ConvEUCtoSJIS(&cInfo);
\r
3060 cInfo2.Str = cInfo.Buf;
\r
3061 cInfo2.StrLen = cInfo.OutLen;
\r
3062 cInfo2.Buf = Buf3;
\r
3063 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3064 ConvSJIStoUTF8N(&cInfo2);
\r
3069 switch(Pkt->KanjiCode)
\r
3072 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
3073 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3074 cInfo2.OutLen = cInfo.OutLen;
\r
3077 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
3078 cInfo2.Str = cInfo.Buf;
\r
3079 cInfo2.StrLen = cInfo.OutLen;
\r
3080 cInfo2.Buf = Buf3;
\r
3081 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3082 ConvSJIStoJIS(&cInfo2);
\r
3085 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
3086 cInfo2.Str = cInfo.Buf;
\r
3087 cInfo2.StrLen = cInfo.OutLen;
\r
3088 cInfo2.Buf = Buf3;
\r
3089 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3090 ConvSJIStoEUC(&cInfo2);
\r
3093 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
3094 cInfo2.OutLen = cInfo.StrLen;
\r
3097 case KANJI_UTF8BOM:
\r
3098 if(ProcessedBOM == NO)
\r
3100 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
3101 cInfo2.OutLen = 3;
\r
3103 ProcessedBOM = YES;
\r
3106 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
3107 cInfo2.OutLen = cInfo.StrLen;
\r
3112 case KANJI_UTF8BOM:
\r
3113 if(ProcessedBOM == NO)
\r
3115 if(memcmp(Buf, "\xEF\xBB\xBF", 3) == 0)
\r
3118 cInfo.StrLen -= 3;
\r
3120 cInfo2.OutLen = 0;
\r
3121 switch(Pkt->KanjiCode)
\r
3123 case KANJI_UTF8BOM:
\r
3124 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
3125 cInfo2.OutLen = 3;
\r
3129 ProcessedBOM = YES;
\r
3132 switch(Pkt->KanjiCode)
\r
3135 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
3136 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3137 cInfo2.OutLen = cInfo.OutLen;
\r
3140 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
3141 cInfo2.Str = cInfo.Buf;
\r
3142 cInfo2.StrLen = cInfo.OutLen;
\r
3143 cInfo2.Buf = Buf3;
\r
3144 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3145 ConvSJIStoJIS(&cInfo2);
\r
3148 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
3149 cInfo2.Str = cInfo.Buf;
\r
3150 cInfo2.StrLen = cInfo.OutLen;
\r
3151 cInfo2.Buf = Buf3;
\r
3152 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3153 ConvSJIStoEUC(&cInfo2);
\r
3156 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
3157 cInfo2.OutLen = cInfo.StrLen;
\r
3160 case KANJI_UTF8BOM:
\r
3161 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
3162 cInfo2.OutLen = cInfo.StrLen;
\r
3169 // if(TermCodeConvAndSend(&tInfo, dSkt, Buf2, cInfo.OutLen, Pkt->Type) == FFFTP_FAIL)
\r
3170 if(TermCodeConvAndSend(&tInfo, dSkt, Buf3, cInfo2.OutLen, Pkt->Type, &Canceled[Pkt->ThreadCount]) == FFFTP_FAIL)
\r
3172 Pkt->Abort = ABORT_ERROR;
\r
3176 while(Continue == YES);
\r
3181 // if(TermCodeConvAndSend(&tInfo, dSkt, Buf, iNumBytes, Pkt->Type) == FFFTP_FAIL)
\r
3182 if(TermCodeConvAndSend(&tInfo, dSkt, Buf, iNumBytes, Pkt->Type, &Canceled[Pkt->ThreadCount]) == FFFTP_FAIL)
\r
3183 Pkt->Abort = ABORT_ERROR;
\r
3186 Pkt->ExistSize += iNumBytes;
\r
3187 if(Pkt->hWndTrans != NULL)
\r
3189 // AllTransSizeNow += iNumBytes;
\r
3190 AllTransSizeNow[Pkt->ThreadCount] += iNumBytes;
\r
3192 if(BackgrndMessageProc() == YES)
\r
3195 if(EofPos != NULL)
\r
3199 if((ForceAbort == NO) && (Pkt->Abort == ABORT_NONE))
\r
3202 if(Pkt->KanjiCode != KANJI_NOCNV)
\r
3205 cInfo.BufSize = BUFSIZE+3;
\r
3206 FlushRestData(&cInfo);
\r
3207 switch(Pkt->KanjiCodeDesired)
\r
3210 switch(Pkt->KanjiCode)
\r
3214 cInfo2.Str = cInfo.Buf;
\r
3215 cInfo2.StrLen = cInfo.OutLen;
\r
3216 cInfo2.Buf = Buf3;
\r
3217 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3218 ConvJIStoSJIS(&cInfo2);
\r
3221 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3222 cInfo2.OutLen = cInfo.OutLen;
\r
3225 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3226 cInfo2.OutLen = cInfo.OutLen;
\r
3229 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3230 cInfo2.OutLen = cInfo.OutLen;
\r
3232 case KANJI_UTF8BOM:
\r
3233 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3234 cInfo2.OutLen = cInfo.OutLen;
\r
3239 switch(Pkt->KanjiCode)
\r
3242 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3243 cInfo2.OutLen = cInfo.OutLen;
\r
3247 cInfo2.Str = cInfo.Buf;
\r
3248 cInfo2.StrLen = cInfo.OutLen;
\r
3249 cInfo2.Buf = Buf3;
\r
3250 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3251 ConvSJIStoJIS(&cInfo2);
\r
3254 cInfo2.Str = cInfo.Buf;
\r
3255 cInfo2.StrLen = cInfo.OutLen;
\r
3256 cInfo2.Buf = Buf3;
\r
3257 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3258 ConvSJIStoEUC(&cInfo2);
\r
3261 cInfo2.Str = cInfo.Buf;
\r
3262 cInfo2.StrLen = cInfo.OutLen;
\r
3263 cInfo2.Buf = Buf3;
\r
3264 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3265 ConvSJIStoUTF8N(&cInfo2);
\r
3267 case KANJI_UTF8BOM:
\r
3268 cInfo2.Str = cInfo.Buf;
\r
3269 cInfo2.StrLen = cInfo.OutLen;
\r
3270 cInfo2.Buf = Buf3;
\r
3271 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3272 ConvSJIStoUTF8N(&cInfo2);
\r
3277 switch(Pkt->KanjiCode)
\r
3280 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3281 cInfo2.OutLen = cInfo.OutLen;
\r
3284 cInfo2.Str = cInfo.Buf;
\r
3285 cInfo2.StrLen = cInfo.OutLen;
\r
3286 cInfo2.Buf = Buf3;
\r
3287 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3288 ConvSJIStoJIS(&cInfo2);
\r
3292 cInfo2.Str = cInfo.Buf;
\r
3293 cInfo2.StrLen = cInfo.OutLen;
\r
3294 cInfo2.Buf = Buf3;
\r
3295 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3296 ConvSJIStoEUC(&cInfo2);
\r
3299 cInfo2.Str = cInfo.Buf;
\r
3300 cInfo2.StrLen = cInfo.OutLen;
\r
3301 cInfo2.Buf = Buf3;
\r
3302 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3303 ConvSJIStoUTF8N(&cInfo2);
\r
3305 case KANJI_UTF8BOM:
\r
3306 cInfo2.Str = cInfo.Buf;
\r
3307 cInfo2.StrLen = cInfo.OutLen;
\r
3308 cInfo2.Buf = Buf3;
\r
3309 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3310 ConvSJIStoUTF8N(&cInfo2);
\r
3315 switch(Pkt->KanjiCode)
\r
3318 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3319 cInfo2.OutLen = cInfo.OutLen;
\r
3322 cInfo2.Str = cInfo.Buf;
\r
3323 cInfo2.StrLen = cInfo.OutLen;
\r
3324 cInfo2.Buf = Buf3;
\r
3325 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3326 ConvSJIStoJIS(&cInfo2);
\r
3329 cInfo2.Str = cInfo.Buf;
\r
3330 cInfo2.StrLen = cInfo.OutLen;
\r
3331 cInfo2.Buf = Buf3;
\r
3332 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3333 ConvSJIStoEUC(&cInfo2);
\r
3336 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3337 cInfo2.OutLen = cInfo.OutLen;
\r
3339 case KANJI_UTF8BOM:
\r
3340 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3341 cInfo2.OutLen = cInfo.OutLen;
\r
3345 case KANJI_UTF8BOM:
\r
3346 switch(Pkt->KanjiCode)
\r
3349 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3350 cInfo2.OutLen = cInfo.OutLen;
\r
3353 cInfo2.Str = cInfo.Buf;
\r
3354 cInfo2.StrLen = cInfo.OutLen;
\r
3355 cInfo2.Buf = Buf3;
\r
3356 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3357 ConvSJIStoJIS(&cInfo2);
\r
3360 cInfo2.Str = cInfo.Buf;
\r
3361 cInfo2.StrLen = cInfo.OutLen;
\r
3362 cInfo2.Buf = Buf3;
\r
3363 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3364 ConvSJIStoEUC(&cInfo2);
\r
3367 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3368 cInfo2.OutLen = cInfo.OutLen;
\r
3370 case KANJI_UTF8BOM:
\r
3371 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3372 cInfo2.OutLen = cInfo.OutLen;
\r
3378 // if(TermCodeConvAndSend(&tInfo, dSkt, Buf2, cInfo.OutLen, Pkt->Type) == FFFTP_FAIL)
\r
3379 if(TermCodeConvAndSend(&tInfo, dSkt, Buf3, cInfo2.OutLen, Pkt->Type, &Canceled[Pkt->ThreadCount]) == FFFTP_FAIL)
\r
3380 Pkt->Abort = ABORT_ERROR;
\r
3381 cInfo2.Buf = Buf3;
\r
3382 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3383 FlushRestData(&cInfo2);
\r
3384 if(TermCodeConvAndSend(&tInfo, dSkt, Buf3, cInfo2.OutLen, Pkt->Type, &Canceled[Pkt->ThreadCount]) == FFFTP_FAIL)
\r
3385 Pkt->Abort = ABORT_ERROR;
\r
3389 tInfo.BufSize = BUFSIZE+3;
\r
3390 FlushRestTermCodeConvData(&tInfo);
\r
3392 // if(SendData(dSkt, Buf2, tInfo.OutLen, 0, &Canceled) == FFFTP_FAIL)
\r
3393 if(SendData(dSkt, Buf2, tInfo.OutLen, 0, &Canceled[Pkt->ThreadCount]) == FFFTP_FAIL)
\r
3394 Pkt->Abort = ABORT_ERROR;
\r
3398 if(Pkt->hWndTrans != NULL)
\r
3400 KillTimer(Pkt->hWndTrans, TIMER_DISPLAY);
\r
3401 DispTransferStatus(Pkt->hWndTrans, YES, Pkt);
\r
3403 // TimeStart = time(NULL) - TimeStart + 1;
\r
3404 TimeStart[Pkt->ThreadCount] = time(NULL) - TimeStart[Pkt->ThreadCount] + 1;
\r
3406 CloseHandle(iFileHandle);
\r
3410 SetErrorMsg(MSGJPN112, Pkt->LocalFile);
\r
3411 SetTaskMsg(MSGJPN112, Pkt->LocalFile);
\r
3412 Pkt->Abort = ABORT_ERROR;
\r
3415 if(shutdown(dSkt, 1) != 0)
\r
3416 ReportWSError("shutdown", WSAGetLastError());
\r
3420 while(do_recv(dSkt, Buf, BUFSIZE, 0, &TimeOutErr, &Canceled) > 0)
\r
3425 // iRetCode = ReadReplyMessage(Pkt->ctrl_skt, Buf, 1024, &Canceled, TmpBuf);
\r
3426 iRetCode = ReadReplyMessage(Pkt->ctrl_skt, Buf, 1024, &Canceled[Pkt->ThreadCount], TmpBuf);
\r
3429 //DoPrintf("##UP REPLY : %s", Buf);
\r
3431 if(iRetCode >= FTP_RETRY)
\r
3434 if(Pkt->Abort != ABORT_NONE)
\r
3441 /*----- バッファの内容を改行コード変換して送信 --------------------------------
\r
3444 * TERMCODECONVINFO *tInfo : 改行コード変換パケット
\r
3445 * SOCKET Skt : ソケット
\r
3446 * char *Data : データ
\r
3447 * int Size : データのサイズ
\r
3448 * int Ascii : モード (TYPE_xx)
\r
3452 *----------------------------------------------------------------------------*/
\r
3455 //static int TermCodeConvAndSend(TERMCODECONVINFO *tInfo, SOCKET Skt, char *Data, int Size, int Ascii)
\r
3456 static int TermCodeConvAndSend(TERMCODECONVINFO *tInfo, SOCKET Skt, char *Data, int Size, int Ascii, int *CancelCheckWork)
\r
3458 char Buf3[BUFSIZE*2];
\r
3462 Ret = FFFTP_SUCCESS;
\r
3464 // CR-LF以外の改行コードを変換しないモードはここへ追加
\r
3465 if(Ascii == TYPE_A)
\r
3467 tInfo->Str = Data;
\r
3468 tInfo->StrLen = Size;
\r
3469 tInfo->Buf = Buf3;
\r
3470 tInfo->BufSize = BUFSIZE*2;
\r
3473 Continue = ConvTermCodeToCRLF(tInfo);
\r
3475 // if((Ret = SendData(Skt, Buf3, tInfo->OutLen, 0, &Canceled)) == FFFTP_FAIL)
\r
3476 if((Ret = SendData(Skt, Buf3, tInfo->OutLen, 0, CancelCheckWork)) == FFFTP_FAIL)
\r
3479 while(Continue == YES);
\r
3483 // Ret = SendData(Skt, Data, Size, 0, &Canceled);
\r
3484 Ret = SendData(Skt, Data, Size, 0, CancelCheckWork);
\r
3490 /*----- アップロード終了/中止時のメッセージを表示 ----------------------------
\r
3493 * TRANSPACKET *Pkt : 転送ファイル情報
\r
3494 * int iRetCode : 応答コード
\r
3498 *----------------------------------------------------------------------------*/
\r
3500 static void DispUploadFinishMsg(TRANSPACKET *Pkt, int iRetCode)
\r
3502 if(ForceAbort == NO)
\r
3504 if((iRetCode/100) >= FTP_CONTINUE)
\r
3507 // if((Pkt->hWndTrans != NULL) && (TimeStart != 0))
\r
3508 // SetTaskMsg(MSGJPN113, TimeStart, Pkt->ExistSize/TimeStart);
\r
3509 if((Pkt->hWndTrans != NULL) && (TimeStart[Pkt->ThreadCount] != 0))
\r
3510 SetTaskMsg(MSGJPN113, TimeStart[Pkt->ThreadCount], Pkt->ExistSize/TimeStart[Pkt->ThreadCount]);
\r
3512 SetTaskMsg(MSGJPN114);
\r
3514 if(Pkt->Abort != ABORT_USER)
\r
3516 // 全て中止を選択後にダイアログが表示されるバグ対策
\r
3517 // if(DispUpDownErrDialog(uperr_dlg, Pkt->hWndTrans, Pkt->LocalFile) == NO)
\r
3519 // if(Canceled[Pkt->ThreadCount] == NO && ClearAll == NO && DispUpDownErrDialog(uperr_dlg, Pkt->hWndTrans, Pkt->LocalFile) == NO)
\r
3520 // ClearAll = YES;
\r
3521 if(Canceled[Pkt->ThreadCount] == NO && ClearAll == NO)
\r
3523 if(TransferErrorNotify == YES && DispUpDownErrDialog(uperr_dlg, Pkt->hWndTrans, Pkt) == NO)
\r
3527 Pkt->Mode = TransferErrorMode;
\r
3528 AddTransFileList(Pkt);
\r
3536 // if((Pkt->hWndTrans != NULL) && (TimeStart != 0))
\r
3537 // SetTaskMsg(MSGJPN115, TimeStart, Pkt->ExistSize/TimeStart);
\r
3538 if((Pkt->hWndTrans != NULL) && (TimeStart[Pkt->ThreadCount] != 0))
\r
3539 // "0 B/S"と表示されるバグを修正
\r
3540 // 原因は%dにあたる部分に64ビット値が渡されているため
\r
3541 // SetTaskMsg(MSGJPN115, TimeStart[Pkt->ThreadCount], Pkt->ExistSize/TimeStart[Pkt->ThreadCount]);
\r
3542 SetTaskMsg(MSGJPN115, (LONG)TimeStart[Pkt->ThreadCount], (LONG)(Pkt->ExistSize/TimeStart[Pkt->ThreadCount]));
\r
3544 SetTaskMsg(MSGJPN116);
\r
3551 /*----- アップロードのリジュームの準備を行う ----------------------------------
\r
3554 * TRANSPACKET *Pkt : 転送ファイル情報
\r
3555 * iont ProcMode : 処理モード(EXIST_xxx)
\r
3556 * LONGLONG Size : ホストにあるファイルのサイズ
\r
3557 * int *Mode : リジュームを行うかどうか (YES/NO)
\r
3563 * Pkt->ExistSizeのセットを行なう
\r
3564 *----------------------------------------------------------------------------*/
\r
3566 static int SetUploadResume(TRANSPACKET *Pkt, int ProcMode, LONGLONG Size, int *Mode)
\r
3568 Pkt->ExistSize = 0;
\r
3570 if(ProcMode == EXIST_RESUME)
\r
3572 if(Pkt->hWndTrans != NULL)
\r
3574 Pkt->ExistSize = Size;
\r
3582 /*----- 転送中ダイアログボックスのコールバック --------------------------------
\r
3585 * HWND hDlg : ウインドウハンドル
\r
3586 * UINT message : メッセージ番号
\r
3587 * WPARAM wParam : メッセージの WPARAM 引数
\r
3588 * LPARAM lParam : メッセージの LPARAM 引数
\r
3592 *----------------------------------------------------------------------------*/
\r
3594 static LRESULT CALLBACK TransDlgProc(HWND hDlg, UINT Msg, WPARAM wParam, LPARAM lParam)
\r
3600 // static TRANSPACKET *Pkt;
\r
3606 case WM_INITDIALOG :
\r
3607 GetWindowRect(hDlg, &RectDlg);
\r
3608 RectDlg.right -= RectDlg.left;
\r
3609 RectDlg.bottom -= RectDlg.top;
\r
3610 GetWindowRect(GetMainHwnd(), &RectPar);
\r
3612 ((RectPar.right + RectPar.left) / 2) - (RectDlg.right / 2),
\r
3613 ((RectPar.bottom + RectPar.top) / 2) - (RectDlg.bottom / 2),
\r
3618 hMenu = GetSystemMenu(hDlg, FALSE);
\r
3619 EnableMenuItem(hMenu, SC_CLOSE, MF_GRAYED);
\r
3623 switch(LOWORD(wParam))
\r
3625 case TRANS_STOP_NEXT :
\r
3629 case TRANS_STOP_ALL :
\r
3631 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
3632 Canceled[i] = YES;
\r
3633 /* ここに break はない */
\r
3636 if(!(Pkt = (TRANSPACKET*)GetWindowLong(hDlg, GWL_USERDATA)))
\r
3638 Pkt->Abort = ABORT_USER;
\r
3639 // Canceled = YES;
\r
3640 Canceled[Pkt->ThreadCount] = YES;
\r
3646 if(wParam == TIMER_DISPLAY)
\r
3648 if(MoveToForeground == YES)
\r
3649 SetForegroundWindow(hDlg);
\r
3650 MoveToForeground = NO;
\r
3651 KillTimer(hDlg, TIMER_DISPLAY);
\r
3652 if(!(Pkt = (TRANSPACKET*)GetWindowLong(hDlg, GWL_USERDATA)))
\r
3654 if(Canceled[Pkt->ThreadCount] == YES)
\r
3655 Pkt->Abort = ABORT_USER;
\r
3656 DispTransferStatus(hDlg, NO, Pkt);
\r
3657 SetTimer(hDlg, TIMER_DISPLAY, DISPLAY_TIMING, NULL);
\r
3661 case WM_SET_PACKET :
\r
3662 // Pkt = (TRANSPACKET *)lParam;
\r
3663 SetWindowLong(hDlg, GWL_USERDATA, (LONG)lParam);
\r
3670 /*----- 転送ステータスを表示 --------------------------------------------------
\r
3673 * HWND hWnd : ウインドウハンドル
\r
3674 * int End : 転送が完了したかどうか (YES/NO)
\r
3678 *----------------------------------------------------------------------------*/
\r
3680 static void DispTransferStatus(HWND hWnd, int End, TRANSPACKET *Pkt)
\r
3694 SendMessage(hWnd, WM_GETTEXT, 79, (LPARAM)Str);
\r
3695 if((Pos = strchr(Str, ')')) != NULL)
\r
3699 sprintf(Tmp, "(%d)%s", AskTransferFileNum(), Pos);
\r
3700 SendMessage(hWnd, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
3702 if(Pkt->Abort == ABORT_NONE)
\r
3707 // TotalLap = time(NULL) - TimeStart + 1;
\r
3708 TotalLap = time(NULL) - TimeStart[Pkt->ThreadCount] + 1;
\r
3713 // Bps = AllTransSizeNow / TotalLap;
\r
3714 Bps = AllTransSizeNow[Pkt->ThreadCount] / TotalLap;
\r
3715 Transed = Pkt->Size - Pkt->ExistSize;
\r
3717 if(Pkt->Size <= 0)
\r
3718 sprintf(Tmp, "%d ", Pkt->ExistSize);
\r
3719 else if(Pkt->Size < 1024)
\r
3720 sprintf(Tmp, "%s / %s ", MakeNumString(Pkt->ExistSize, Num1, TRUE), MakeNumString(Pkt->Size, Num2, TRUE));
\r
3722 sprintf(Tmp, "%sk / %sk ", MakeNumString(Pkt->ExistSize/1024, Num1, TRUE), MakeNumString(Pkt->Size/1024, Num2, TRUE));
\r
3726 sprintf(Tmp, "( 0 B/S )");
\r
3727 else if(Bps < 1000)
\r
3728 sprintf(Tmp, "( %s B/S )", MakeNumString(Bps, Num1, TRUE));
\r
3730 sprintf(Tmp, "( %s.%02d KB/S )", MakeNumString(Bps/1000, Num1, TRUE), (int)((Bps%1000)/10));
\r
3733 if((Bps > 0) && (Pkt->Size > 0) && (Transed >= 0))
\r
3735 sprintf(Tmp, " %d:%02d", (int)((Transed/Bps)/60), (int)((Transed/Bps)%60));
\r
3739 strcat(Str, " ??:??");
\r
3742 strcpy(Str, MSGJPN117);
\r
3745 strcpy(Str, MSGJPN118);
\r
3747 SendDlgItemMessage(hWnd, TRANS_STATUS, WM_SETTEXT, 0, (LPARAM)Str);
\r
3749 if(Pkt->Size <= 0)
\r
3751 else if(Pkt->Size < 1024*1024)
\r
3752 Per = (int)(Pkt->ExistSize * 100 / Pkt->Size);
\r
3754 Per = (int)((Pkt->ExistSize/1024) * 100 / (Pkt->Size/1024));
\r
3755 SendDlgItemMessage(hWnd, TRANS_TIME_BAR, PBM_SETPOS, Per, 0);
\r
3761 /*----- 転送するファイルの情報を表示 ------------------------------------------
\r
3764 * TRANSPACKET *Pkt : 転送ファイル情報
\r
3765 * char *Title : ウインドウのタイトル
\r
3766 * int SkipButton : 「このファイルを中止」ボタンの有無 (TRUE/FALSE)
\r
3767 * int Info : ファイル情報を表示するかどうか (YES/NO)
\r
3771 *----------------------------------------------------------------------------*/
\r
3773 static void DispTransFileInfo(TRANSPACKET *Pkt, char *Title, int SkipButton, int Info)
\r
3777 if(Pkt->hWndTrans != NULL)
\r
3779 EnableWindow(GetDlgItem(Pkt->hWndTrans, IDCANCEL), SkipButton);
\r
3781 sprintf(Tmp, "(%d)%s", AskTransferFileNum(), Title);
\r
3782 SendMessage(Pkt->hWndTrans, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
3783 SendDlgItemMessage(Pkt->hWndTrans, TRANS_STATUS, WM_SETTEXT, 0, (LPARAM)"");
\r
3785 SendDlgItemMessage(Pkt->hWndTrans, TRANS_TIME_BAR, PBM_SETRANGE, 0, MAKELPARAM(0, 100));
\r
3786 SendDlgItemMessage(Pkt->hWndTrans, TRANS_TIME_BAR, PBM_SETSTEP, 1, 0);
\r
3787 SendDlgItemMessage(Pkt->hWndTrans, TRANS_TIME_BAR, PBM_SETPOS, 0, 0);
\r
3791 DispStaticText(GetDlgItem(Pkt->hWndTrans, TRANS_REMOTE), Pkt->RemoteFile);
\r
3792 DispStaticText(GetDlgItem(Pkt->hWndTrans, TRANS_LOCAL), Pkt->LocalFile);
\r
3794 if(Pkt->Type == TYPE_I)
\r
3795 SendDlgItemMessage(Pkt->hWndTrans, TRANS_MODE, WM_SETTEXT, 0, (LPARAM)MSGJPN119);
\r
3796 else if(Pkt->Type == TYPE_A)
\r
3797 SendDlgItemMessage(Pkt->hWndTrans, TRANS_MODE, WM_SETTEXT, 0, (LPARAM)MSGJPN120);
\r
3800 if(Pkt->KanjiCode == KANJI_NOCNV)
\r
3801 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN121);
\r
3802 else if(Pkt->KanjiCode == KANJI_SJIS)
\r
3803 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN305);
\r
3804 else if(Pkt->KanjiCode == KANJI_JIS)
\r
3805 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN122);
\r
3806 else if(Pkt->KanjiCode == KANJI_EUC)
\r
3807 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN123);
\r
3808 else if(Pkt->KanjiCode == KANJI_UTF8N)
\r
3809 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN306);
\r
3810 else if(Pkt->KanjiCode == KANJI_UTF8BOM)
\r
3811 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN329);
\r
3815 SendDlgItemMessage(Pkt->hWndTrans, TRANS_REMOTE, WM_SETTEXT, 0, (LPARAM)"");
\r
3816 SendDlgItemMessage(Pkt->hWndTrans, TRANS_LOCAL, WM_SETTEXT, 0, (LPARAM)"");
\r
3817 SendDlgItemMessage(Pkt->hWndTrans, TRANS_MODE, WM_SETTEXT, 0, (LPARAM)"");
\r
3818 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)"");
\r
3825 /*----- PASVコマンドの戻り値からアドレスとポート番号を抽出 --------------------
\r
3828 * char *Str : PASVコマンドのリプライ
\r
3829 * char *Adrs : アドレスのコピー先 ("www.xxx.yyy.zzz")
\r
3830 * int *Port : ポート番号をセットするワーク
\r
3831 * int Max : アドレス文字列の最大長
\r
3835 * FFFTP_SUCCESS/FFFTP_FAIL
\r
3836 *----------------------------------------------------------------------------*/
\r
3838 static int GetAdrsAndPort(SOCKET Skt, char *Str, char *Adrs, int *Port, int Max)
\r
3841 Result = FFFTP_FAIL;
\r
3842 switch(AskCurNetType())
\r
3845 Result = GetAdrsAndPortIPv4(Skt, Str, Adrs, Port, Max);
\r
3848 Result = GetAdrsAndPortIPv6(Skt, Str, Adrs, Port, Max);
\r
3856 //static int GetAdrsAndPort(char *Str, char *Adrs, int *Port, int Max)
\r
3857 static int GetAdrsAndPortIPv4(SOCKET Skt, char *Str, char *Adrs, int *Port, int Max)
\r
3861 // コンマではなくドットを返すホストがあるため
\r
3867 Pos = strchr(Str, '(');
\r
3871 Btm = strchr(Pos, ',');
\r
3872 // コンマではなくドットを返すホストがあるため
\r
3874 Btm = strchr(Pos, '.');
\r
3878 // コンマではなくドットを返すホストがあるため
\r
3879 // Btm = strchr(Btm, ',');
\r
3881 Btm = strchr(OldBtm, ',');
\r
3883 Btm = strchr(OldBtm, '.');
\r
3887 // コンマではなくドットを返すホストがあるため
\r
3888 // Btm = strchr(Btm, ',');
\r
3890 Btm = strchr(OldBtm, ',');
\r
3892 Btm = strchr(OldBtm, '.');
\r
3896 // コンマではなくドットを返すホストがあるため
\r
3897 // Btm = strchr(Btm, ',');
\r
3899 Btm = strchr(OldBtm, ',');
\r
3901 Btm = strchr(OldBtm, '.');
\r
3904 if((Btm - Pos) <= Max)
\r
3906 strncpy(Adrs, Pos, Btm - Pos);
\r
3907 *(Adrs + (Btm - Pos)) = NUL;
\r
3908 ReplaceAll(Adrs, ',', '.');
\r
3911 Btm = strchr(Pos, ',');
\r
3912 // コンマではなくドットを返すホストがあるため
\r
3914 Btm = strchr(Pos, '.');
\r
3918 *Port = (atoi(Pos) * 0x100) + atoi(Btm);
\r
3919 Sts = FFFTP_SUCCESS;
\r
3932 static int GetAdrsAndPortIPv6(SOCKET Skt, char *Str, char *Adrs, int *Port, int Max)
\r
3938 struct sockaddr_in6 SockAddr;
\r
3942 Btm = strchr(Str, '(');
\r
3946 Btm = strchr(Btm, '|');
\r
3950 Btm = strchr(Pos, '|');
\r
3954 Btm = strchr(Pos, '|');
\r
3957 if((Btm - Pos) <= Max)
\r
3959 if((Btm - Pos) > 0)
\r
3961 strncpy(Adrs, Pos, Btm - Pos);
\r
3962 *(Adrs + (Btm - Pos)) = NUL;
\r
3966 i = sizeof(SockAddr);
\r
3967 if(getpeername(Skt, (struct sockaddr*)&SockAddr, &i) != SOCKET_ERROR)
\r
3968 AddressToStringIPv6(Adrs, &SockAddr.sin6_addr);
\r
3972 Btm = strchr(Pos, '|');
\r
3976 *Port = atoi(Pos);
\r
3977 Btm = strchr(Btm, ')');
\r
3979 Sts = FFFTP_SUCCESS;
\r
3990 /*----- Windowsのスペシャルデバイスかどうかを返す -----------------------------
\r
3993 * char *Fname : ファイル名
\r
3996 * int ステータス (YES/NO)
\r
3997 *----------------------------------------------------------------------------*/
\r
3999 static int IsSpecialDevice(char *Fname)
\r
4005 // if((_stricmp(Fname, "CON") == 0) ||
\r
4006 // (_stricmp(Fname, "PRN") == 0) ||
\r
4007 // (_stricmp(Fname, "AUX") == 0) ||
\r
4008 // (_strnicmp(Fname, "CON.", 4) == 0) ||
\r
4009 // (_strnicmp(Fname, "PRN.", 4) == 0) ||
\r
4010 // (_strnicmp(Fname, "AUX.", 4) == 0))
\r
4014 if(_strnicmp(Fname, "AUX", 3) == 0|| _strnicmp(Fname, "CON", 3) == 0 || _strnicmp(Fname, "NUL", 3) == 0 || _strnicmp(Fname, "PRN", 3) == 0)
\r
4016 if(*(Fname + 3) == '\0' || *(Fname + 3) == '.')
\r
4019 else if(_strnicmp(Fname, "COM", 3) == 0 || _strnicmp(Fname, "LPT", 3) == 0)
\r
4021 if(isdigit(*(Fname + 3)) != 0)
\r
4023 if(*(Fname + 4) == '\0' || *(Fname + 4) == '.')
\r
4031 /*----- ミラーリングでのファイル削除確認 --------------------------------------
\r
4036 * TRANSPACKET *Pkt
\r
4040 *----------------------------------------------------------------------------*/
\r
4042 static int MirrorDelNotify(int Cur, int Notify, TRANSPACKET *Pkt)
\r
4044 MIRRORDELETEINFO DelInfo;
\r
4047 if(((Cur == WIN_LOCAL) && (MirDownDelNotify == NO)) ||
\r
4048 ((Cur == WIN_REMOTE) && (MirUpDelNotify == NO)))
\r
4053 if(Notify != YES_ALL)
\r
4055 DelInfo.Cur = Cur;
\r
4056 DelInfo.Pkt = Pkt;
\r
4057 hWnd = Pkt->hWndTrans;
\r
4059 hWnd = GetMainHwnd();
\r
4060 Notify = DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(delete_dlg), hWnd, MirrorDeleteDialogCallBack, (LPARAM)&DelInfo);
\r
4066 /*----- ミラーリングでのファイル削除ダイアログのコールバック ------------------
\r
4069 * HWND hDlg : ウインドウハンドル
\r
4070 * UINT message : メッセージ番号
\r
4071 * WPARAM wParam : メッセージの WPARAM 引数
\r
4072 * LPARAM lParam : メッセージの LPARAM 引数
\r
4076 *----------------------------------------------------------------------------*/
\r
4078 static BOOL CALLBACK MirrorDeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
4080 static MIRRORDELETEINFO *DelInfo;
\r
4083 case WM_INITDIALOG :
\r
4084 DelInfo = (MIRRORDELETEINFO *)lParam;
\r
4086 if(DelInfo->Cur == WIN_LOCAL)
\r
4088 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN124);
\r
4089 SendDlgItemMessage(hDlg, DELETE_TEXT, WM_SETTEXT, 0, (LPARAM)DelInfo->Pkt->LocalFile);
\r
4093 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN125);
\r
4094 SendDlgItemMessage(hDlg, DELETE_TEXT, WM_SETTEXT, 0, (LPARAM)DelInfo->Pkt->RemoteFile);
\r
4099 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
4102 EndDialog(hDlg, YES);
\r
4106 EndDialog(hDlg, NO);
\r
4110 EndDialog(hDlg, YES_ALL);
\r
4115 EndDialog(hDlg, NO_ALL);
\r
4127 static void SetErrorMsg(char *fmt, ...)
\r
4132 // if(strlen(ErrMsg) == 0)
\r
4133 if(strlen(GetErrMsg()) == 0)
\r
4135 va_start(Args, fmt);
\r
4137 // wvsprintf(ErrMsg, fmt, Args);
\r
4138 wvsprintf(GetErrMsg(), fmt, Args);
\r
4149 /*----- ダウンロード時の不正なパスをチェック ----------------------------------
\r
4152 * TRANSPACKET *packet : ダウンロード情報
\r
4155 * int YES=不正なパス/NO=問題ないパス
\r
4156 *----------------------------------------------------------------------------*/
\r
4157 int CheckPathViolation(TRANSPACKET *packet)
\r
4162 if((strncmp(packet->RemoteFile, "..\\", 3) == 0) ||
\r
4163 (strncmp(packet->RemoteFile, "../", 3) == 0) ||
\r
4164 (strstr(packet->RemoteFile, "\\..\\") != NULL) ||
\r
4165 (strstr(packet->RemoteFile, "/../") != NULL))
\r
4167 msg = malloc(strlen(MSGJPN297) + strlen(packet->RemoteFile) + 1);
\r
4170 sprintf(msg, MSGJPN297, packet->RemoteFile);
\r
4171 MessageBox(GetMainHwnd(), msg, MSGJPN086, MB_OK);
\r
4181 static char* GetErrMsg()
\r
4187 WaitForSingleObject(hErrMsgMutex, INFINITE);
\r
4188 ThreadId = GetCurrentThreadId();
\r
4190 while(i < MAX_DATA_CONNECTION + 1)
\r
4192 if(ErrMsgThreadId[i] == ThreadId)
\r
4202 while(i < MAX_DATA_CONNECTION + 1)
\r
4204 if(ErrMsgThreadId[i] == 0)
\r
4206 ErrMsgThreadId[i] = ThreadId;
\r
4213 ReleaseMutex(hErrMsgMutex);
\r