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
91 static int DispUpDownErrDialog(int ResID, HWND hWnd, char *Fname);
\r
92 static BOOL CALLBACK UpDownErrorDialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam);
\r
93 static int SetDownloadResume(TRANSPACKET *Pkt, int ProcMode, LONGLONG Size, int *Mode, int *CancelCheckWork);
\r
94 static BOOL CALLBACK NoResumeWndProc(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
95 static int DoUpLoad(SOCKET cSkt, TRANSPACKET *Pkt);
\r
96 static int UpLoadNonPassive(TRANSPACKET *Pkt);
\r
97 static int UpLoadPassive(TRANSPACKET *Pkt);
\r
98 static int UpLoadFile(TRANSPACKET *Pkt, SOCKET dSkt);
\r
100 //static int TermCodeConvAndSend(TERMCODECONVINFO *tInfo, SOCKET Skt, char *Data, int Size, int Ascii);
\r
101 static int TermCodeConvAndSend(TERMCODECONVINFO *tInfo, SOCKET Skt, char *Data, int Size, int Ascii, int *CancelCheckWork);
\r
102 static void DispUploadFinishMsg(TRANSPACKET *Pkt, int iRetCode);
\r
103 static int SetUploadResume(TRANSPACKET *Pkt, int ProcMode, LONGLONG Size, int *Mode);
\r
104 static LRESULT CALLBACK TransDlgProc(HWND hDlg, UINT Msg, WPARAM wParam, LPARAM lParam);
\r
105 static void DispTransferStatus(HWND hWnd, int End, TRANSPACKET *Pkt);
\r
106 static void DispTransFileInfo(TRANSPACKET *Pkt, char *Title, int SkipButton, int Info);
\r
107 static int GetAdrsAndPort(char *Str, char *Adrs, int *Port, int Max);
\r
108 static int IsSpecialDevice(char *Fname);
\r
109 static int MirrorDelNotify(int Cur, int Notify, TRANSPACKET *Pkt);
\r
110 static BOOL CALLBACK MirrorDeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
111 static void SetErrorMsg(char *fmt, ...);
\r
113 static char* GetErrMsg();
\r
115 /*===== ローカルなワーク =====*/
\r
118 //static HANDLE hTransferThread;
\r
119 static HANDLE hTransferThread[MAX_DATA_CONNECTION];
\r
120 static int fTransferThreadExit = FALSE;
\r
122 static HANDLE hRunMutex; /* 転送スレッド実行ミューテックス */
\r
123 static HANDLE hListAccMutex; /* 転送ファイルアクセス用ミューテックス */
\r
125 static int TransFiles = 0; /* 転送待ちファイル数 */
\r
126 static TRANSPACKET *TransPacketBase = NULL; /* 転送ファイルリスト */
\r
128 static TRANSPACKET *NextTransPacketBase = NULL;
\r
131 //static int Canceled; /* 中止フラグ YES/NO */
\r
132 static int Canceled[MAX_DATA_CONNECTION]; /* 中止フラグ YES/NO */
\r
133 static int ClearAll; /* 全て中止フラグ YES/NO */
\r
135 static int ForceAbort; /* 転送中止フラグ */
\r
136 /* このフラグはスレッドを終了させるときに使う */
\r
139 //static LONGLONG AllTransSizeNow; /* 今回の転送で転送したサイズ */
\r
140 //static time_t TimeStart; /* 転送開始時間 */
\r
141 static LONGLONG AllTransSizeNow[MAX_DATA_CONNECTION]; /* 今回の転送で転送したサイズ */
\r
142 static time_t TimeStart[MAX_DATA_CONNECTION]; /* 転送開始時間 */
\r
144 static int KeepDlg = NO; /* 転送中ダイアログを消さないかどうか (YES/NO) */
\r
145 static int MoveToForeground = NO; /* ウインドウを前面に移動するかどうか (YES/NO) */
\r
148 //static char CurDir[FMAX_PATH+1] = { "" };
\r
149 static char CurDir[MAX_DATA_CONNECTION][FMAX_PATH+1];
\r
151 //static char ErrMsg[ERR_MSG_LEN+7];
\r
152 static char ErrMsg[MAX_DATA_CONNECTION+1][ERR_MSG_LEN+7];
\r
153 static DWORD ErrMsgThreadId[MAX_DATA_CONNECTION+1];
\r
154 static HANDLE hErrMsgMutex;
\r
157 static int WaitForMainThread = NO;
\r
159 /*===== 外部参照 =====*/
\r
162 extern int SaveTimeStamp;
\r
164 // extern int TimeOut;
\r
165 extern int FwallType;
\r
166 extern int MirUpDelNotify;
\r
167 extern int MirDownDelNotify;
\r
168 extern int FolderAttr;
\r
169 extern int FolderAttrNum;
\r
172 /*----- ファイル転送スレッドを起動する ----------------------------------------
\r
179 *----------------------------------------------------------------------------*/
\r
181 int MakeTransferThread(void)
\r
186 hListAccMutex = CreateMutex( NULL, FALSE, NULL );
\r
187 hRunMutex = CreateMutex( NULL, TRUE, NULL );
\r
189 hErrMsgMutex = CreateMutex( NULL, FALSE, NULL );
\r
194 fTransferThreadExit = FALSE;
\r
196 // hTransferThread = (HANDLE)_beginthreadex(NULL, 0, TransferThread, 0, 0, &dwID);
\r
197 // if (hTransferThread == NULL)
\r
198 // return(FFFTP_FAIL); /* XXX */
\r
199 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
201 hTransferThread[i] = (HANDLE)_beginthreadex(NULL, 0, TransferThread, (void*)i, 0, &dwID);
\r
202 if(hTransferThread[i] == NULL)
\r
206 return(FFFTP_SUCCESS);
\r
210 /*----- ファイル転送スレッドを終了する ----------------------------------------
\r
217 *----------------------------------------------------------------------------*/
\r
219 void CloseTransferThread(void)
\r
224 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
229 fTransferThreadExit = TRUE;
\r
231 // while(WaitForSingleObject(hTransferThread, 10) == WAIT_TIMEOUT)
\r
233 // BackgrndMessageProc();
\r
236 // CloseHandle(hTransferThread);
\r
237 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
239 while(WaitForSingleObject(hTransferThread[i], 10) == WAIT_TIMEOUT)
\r
241 BackgrndMessageProc();
\r
244 CloseHandle(hTransferThread[i]);
\r
247 ReleaseMutex( hRunMutex );
\r
249 CloseHandle( hListAccMutex );
\r
250 CloseHandle( hRunMutex );
\r
252 CloseHandle( hErrMsgMutex );
\r
257 /*----- 転送するファイル情報をリストに追加する --------------------------------
\r
260 * TRANSPACKET *Pkt : 転送ファイル情報
\r
261 * TRANSPACKET **Base : リストの先頭
\r
265 * FFFTP_SUCCESS/FFFTP_FAIL
\r
266 *----------------------------------------------------------------------------*/
\r
268 int AddTmpTransFileList(TRANSPACKET *Pkt, TRANSPACKET **Base)
\r
275 if((Pos = malloc(sizeof(TRANSPACKET))) != NULL)
\r
277 memcpy(Pos, Pkt, sizeof(TRANSPACKET));
\r
285 while(Prev->Next != NULL)
\r
289 Sts = FFFTP_SUCCESS;
\r
295 /*----- 転送するファイル情報リストをクリアする --------------------------------
\r
298 * TRANSPACKET **Base : リストの先頭
\r
302 *----------------------------------------------------------------------------*/
\r
304 void EraseTmpTransFileList(TRANSPACKET **Base)
\r
321 /*----- 転送するファイル情報リストから1つの情報を取り除く --------------------
\r
324 * TRANSPACKET *Pkt : 転送ファイル情報
\r
325 * TRANSPACKET **Base : リストの先頭
\r
329 * FFFTP_SUCCESS/FFFTP_FAIL
\r
330 *----------------------------------------------------------------------------*/
\r
332 int RemoveTmpTransFileListItem(TRANSPACKET **Base, int Num)
\r
344 Sts = FFFTP_SUCCESS;
\r
354 Prev->Next = Pos->Next;
\r
356 Sts = FFFTP_SUCCESS;
\r
365 /*----- 転送するファイル情報を転送ファイルリストに登録する --------------------
\r
368 * TRANSPACKET *Pkt : 転送ファイル情報
\r
372 *----------------------------------------------------------------------------*/
\r
374 void AddTransFileList(TRANSPACKET *Pkt)
\r
376 DispTransPacket(Pkt);
\r
379 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
380 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
382 WaitForMainThread = YES;
\r
383 BackgrndMessageProc();
\r
387 if(AddTmpTransFileList(Pkt, &TransPacketBase) == FFFTP_SUCCESS)
\r
389 if((strncmp(Pkt->Cmd, "RETR", 4) == 0) ||
\r
390 (strncmp(Pkt->Cmd, "STOR", 4) == 0))
\r
393 PostMessage(GetMainHwnd(), WM_CHANGE_COND, 0, 0);
\r
397 if(NextTransPacketBase == NULL)
\r
398 NextTransPacketBase = TransPacketBase;
\r
399 ReleaseMutex(hListAccMutex);
\r
401 WaitForMainThread = NO;
\r
407 /*----- 転送ファイル情報を転送ファイルリストに追加する ------------------------
\r
410 * TRANSPACKET *Pkt : 転送ファイル情報
\r
411 * TRANSPACKET **Base : リストの先頭
\r
418 *----------------------------------------------------------------------------*/
\r
420 void AppendTransFileList(TRANSPACKET *Pkt)
\r
425 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
426 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
428 WaitForMainThread = YES;
\r
429 BackgrndMessageProc();
\r
433 if(TransPacketBase == NULL)
\r
434 TransPacketBase = Pkt;
\r
437 Pos = TransPacketBase;
\r
438 while(Pos->Next != NULL)
\r
443 if(NextTransPacketBase == NULL)
\r
444 NextTransPacketBase = TransPacketBase;
\r
448 DispTransPacket(Pkt);
\r
450 if((strncmp(Pkt->Cmd, "RETR", 4) == 0) ||
\r
451 (strncmp(Pkt->Cmd, "STOR", 4) == 0))
\r
454 PostMessage(GetMainHwnd(), WM_CHANGE_COND, 0, 0);
\r
459 ReleaseMutex(hListAccMutex);
\r
461 WaitForMainThread = NO;
\r
466 /*----- 転送ファイル情報を表示する --------------------------------------------
\r
469 * TRANSPACKET *Pkt : 転送ファイル情報
\r
473 *----------------------------------------------------------------------------*/
\r
475 static void DispTransPacket(TRANSPACKET *Pkt)
\r
477 if((strncmp(Pkt->Cmd, "RETR", 4) == 0) || (strncmp(Pkt->Cmd, "STOR", 4) == 0))
\r
478 DoPrintf("TransList Cmd=%s : %s : %s", Pkt->Cmd, Pkt->RemoteFile, Pkt->LocalFile);
\r
479 else if(strncmp(Pkt->Cmd, "R-", 2) == 0)
\r
480 DoPrintf("TransList Cmd=%s : %s", Pkt->Cmd, Pkt->RemoteFile);
\r
481 else if(strncmp(Pkt->Cmd, "L-", 2) == 0)
\r
482 DoPrintf("TransList Cmd=%s : %s", Pkt->Cmd, Pkt->LocalFile);
\r
483 else if(strncmp(Pkt->Cmd, "MKD", 3) == 0)
\r
485 if(strlen(Pkt->LocalFile) > 0)
\r
486 DoPrintf("TransList Cmd=%s : %s", Pkt->Cmd, Pkt->LocalFile);
\r
488 DoPrintf("TransList Cmd=%s : %s", Pkt->Cmd, Pkt->RemoteFile);
\r
491 DoPrintf("TransList Cmd=%s", Pkt->Cmd);
\r
496 /*----- 転送ファイルリストをクリアする ----------------------------------------
\r
503 *----------------------------------------------------------------------------*/
\r
505 static void EraseTransFileList(void)
\r
509 TRANSPACKET *NotDel;
\r
515 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
516 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
518 WaitForMainThread = YES;
\r
519 BackgrndMessageProc();
\r
522 New = TransPacketBase;
\r
525 /* 最後の"BACKCUR"は必要なので消さない */
\r
526 if(strcmp(New->Cmd, "BACKCUR") == 0)
\r
531 strcpy(NotDel->Cmd, "");
\r
535 // NotDel->Next = NULL;
\r
542 strcpy(New->Cmd, "");
\r
546 TransPacketBase = NotDel;
\r
548 NextTransPacketBase = TransPacketBase;
\r
550 PostMessage(GetMainHwnd(), WM_CHANGE_COND, 0, 0);
\r
551 ReleaseMutex(hListAccMutex);
\r
553 WaitForMainThread = NO;
\r
555 strcpy(Pkt.Cmd, "GOQUIT");
\r
556 AddTransFileList(&Pkt);
\r
561 /*----- 転送中ダイアログを消さないようにするかどうかを設定 --------------------
\r
564 * int Sw : 転送中ダイアログを消さないかどうか (YES/NO)
\r
568 *----------------------------------------------------------------------------*/
\r
570 void KeepTransferDialog(int Sw)
\r
577 /*----- 現在転送中かどうかを返す ----------------------------------------------
\r
583 * int ステータス (YES/NO=転送中ではない)
\r
584 *----------------------------------------------------------------------------*/
\r
586 int AskTransferNow(void)
\r
588 return(TransPacketBase != NULL ? YES : NO);
\r
592 /*----- 転送するファイルの数を返す --------------------------------------------
\r
599 *----------------------------------------------------------------------------*/
\r
601 int AskTransferFileNum(void)
\r
603 return(TransFiles);
\r
607 /*----- 転送中ウインドウを前面に出す ------------------------------------------
\r
614 *----------------------------------------------------------------------------*/
\r
616 void GoForwardTransWindow(void)
\r
618 MoveToForeground = YES;
\r
623 /*----- 転送ソケットのカレントディレクトリ情報を初期化 ------------------------
\r
630 *----------------------------------------------------------------------------*/
\r
632 void InitTransCurDir(void)
\r
635 // strcpy(CurDir, "");
\r
637 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
638 strcpy(CurDir[i], "");
\r
643 /*----- ファイル転送スレッドのメインループ ------------------------------------
\r
646 * void *Dummy : 使わない
\r
650 *----------------------------------------------------------------------------*/
\r
652 static ULONG WINAPI TransferThread(void *Dummy)
\r
656 char Tmp[FMAX_PATH+1];
\r
678 ThreadCount = (int)Dummy;
\r
679 CmdSkt = INVALID_SOCKET;
\r
680 NewCmdSkt = INVALID_SOCKET;
\r
681 TrnSkt = INVALID_SOCKET;
\r
682 SetThreadPriority(GetCurrentThread(), THREAD_PRIORITY_LOWEST);
\r
684 while((TransPacketBase != NULL) ||
\r
685 (WaitForSingleObject(hRunMutex, 200) == WAIT_TIMEOUT))
\r
687 if(fTransferThreadExit == TRUE)
\r
690 if(WaitForMainThread == YES)
\r
692 BackgrndMessageProc();
\r
697 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
698 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
700 BackgrndMessageProc();
\r
703 // memset(ErrMsg, NUL, ERR_MSG_LEN+7);
\r
704 memset(GetErrMsg(), NUL, ERR_MSG_LEN+7);
\r
707 Canceled[ThreadCount] = NO;
\r
709 while(TransPacketBase != NULL && strcmp(TransPacketBase->Cmd, "") == 0)
\r
711 Pos = TransPacketBase;
\r
712 TransPacketBase = TransPacketBase->Next;
\r
715 NewCmdSkt = AskCmdCtrlSkt();
\r
716 if(AskReuseCmdSkt() == YES && ThreadCount == 0)
\r
718 if(TransPacketBase && ThreadCount < AskMaxThreadCount())
\r
719 TrnSkt = AskTrnCtrlSkt();
\r
723 if(TransPacketBase && NewCmdSkt != INVALID_SOCKET && ThreadCount < AskMaxThreadCount())
\r
725 if(TrnSkt == INVALID_SOCKET || NewCmdSkt != CmdSkt)
\r
727 ReleaseMutex(hListAccMutex);
\r
728 ReConnectTrnSkt(&TrnSkt, &Canceled[ThreadCount]);
\r
729 // 同時ログイン数制限に引っかかった可能性あり
\r
731 if(TrnSkt == INVALID_SOCKET)
\r
734 while(NewCmdSkt != CmdSkt && i > 0)
\r
736 BackgrndMessageProc();
\r
741 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
742 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
744 BackgrndMessageProc();
\r
751 if(TrnSkt != INVALID_SOCKET)
\r
753 ReleaseMutex(hListAccMutex);
\r
754 SendData(TrnSkt, "QUIT\r\n", 6, 0, &Canceled[ThreadCount]);
\r
756 TrnSkt = INVALID_SOCKET;
\r
757 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
758 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
760 BackgrndMessageProc();
\r
766 CmdSkt = NewCmdSkt;
\r
767 // if(TransPacketBase != NULL)
\r
768 if(TrnSkt != INVALID_SOCKET && NextTransPacketBase != NULL)
\r
770 Pos = NextTransPacketBase;
\r
771 NextTransPacketBase = NextTransPacketBase->Next;
\r
772 // ディレクトリ操作は非同期で行わない
\r
773 // ReleaseMutex(hListAccMutex);
\r
774 if(hWndTrans == NULL)
\r
776 // if((strncmp(TransPacketBase->Cmd, "RETR", 4) == 0) ||
\r
777 // (strncmp(TransPacketBase->Cmd, "STOR", 4) == 0) ||
\r
778 // (strncmp(TransPacketBase->Cmd, "MKD", 3) == 0) ||
\r
779 // (strncmp(TransPacketBase->Cmd, "L-", 2) == 0) ||
\r
780 // (strncmp(TransPacketBase->Cmd, "R-", 2) == 0))
\r
781 if((strncmp(Pos->Cmd, "RETR", 4) == 0) ||
\r
782 (strncmp(Pos->Cmd, "STOR", 4) == 0) ||
\r
783 (strncmp(Pos->Cmd, "MKD", 3) == 0) ||
\r
784 (strncmp(Pos->Cmd, "L-", 2) == 0) ||
\r
785 (strncmp(Pos->Cmd, "R-", 2) == 0))
\r
787 hWndTrans = CreateDialog(GetFtpInst(), MAKEINTRESOURCE(transfer_dlg), HWND_DESKTOP, (DLGPROC)TransDlgProc);
\r
788 if(MoveToForeground == YES)
\r
789 SetForegroundWindow(hWndTrans);
\r
790 ShowWindow(hWndTrans, SW_SHOWNOACTIVATE);
\r
791 GetWindowRect(hWndTrans, &WndRect);
\r
792 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
795 // TransPacketBase->hWndTrans = hWndTrans;
\r
796 Pos->hWndTrans = hWndTrans;
\r
797 Pos->ctrl_skt = TrnSkt;
\r
798 Pos->ThreadCount = ThreadCount;
\r
800 if(hWndTrans != NULL)
\r
802 if(MoveToForeground == YES)
\r
804 SetForegroundWindow(hWndTrans);
\r
805 MoveToForeground = NO;
\r
809 if(hWndTrans != NULL)
\r
810 // SendMessage(hWndTrans, WM_SET_PACKET, 0, (LPARAM)TransPacketBase);
\r
811 SendMessage(hWndTrans, WM_SET_PACKET, 0, (LPARAM)Pos);
\r
814 // if(strncmp(TransPacketBase->Cmd, "RETR", 4) == 0)
\r
815 if(strncmp(Pos->Cmd, "RETR", 4) == 0)
\r
817 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
818 // ReleaseMutex(hListAccMutex);
\r
820 // if(CheckPathViolation(TransPacketBase) == NO)
\r
821 if(CheckPathViolation(Pos) == NO)
\r
823 /* フルパスを使わないための処理 */
\r
824 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
825 if(MakeNonFullPath(Pos, CurDir[Pos->ThreadCount], Tmp) == FFFTP_SUCCESS)
\r
827 // if(strncmp(TransPacketBase->Cmd, "RETR-S", 6) == 0)
\r
828 if(strncmp(Pos->Cmd, "RETR-S", 6) == 0)
\r
831 // DoSIZE(TransPacketBase->RemoteFile, &TransPacketBase->Size);
\r
832 // DoMDTM(TransPacketBase->RemoteFile, &TransPacketBase->Time);
\r
833 // strcpy(TransPacketBase->Cmd, "RETR ");
\r
834 DoSIZE(TrnSkt, Pos->RemoteFile, &Pos->Size, &Canceled[Pos->ThreadCount]);
\r
835 DoMDTM(TrnSkt, Pos->RemoteFile, &Pos->Time, &Canceled[Pos->ThreadCount]);
\r
836 strcpy(Pos->Cmd, "RETR ");
\r
840 // if(DoDownLoad(AskTrnCtrlSkt(), TransPacketBase, NO) == 429)
\r
842 // if(ReConnectTrnSkt() == FFFTP_SUCCESS)
\r
843 // DoDownLoad(AskTrnCtrlSkt(), TransPacketBase, NO, &Canceled);
\r
844 DoDownLoad(TrnSkt, Pos, NO, &Canceled[Pos->ThreadCount]);
\r
848 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
849 ReleaseMutex(hListAccMutex);
\r
852 // else if(strncmp(TransPacketBase->Cmd, "STOR", 4) == 0)
\r
853 else if(strncmp(Pos->Cmd, "STOR", 4) == 0)
\r
855 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
856 // ReleaseMutex(hListAccMutex);
\r
857 /* フルパスを使わないための処理 */
\r
858 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
859 if(MakeNonFullPath(Pos, CurDir[Pos->ThreadCount], Tmp) == FFFTP_SUCCESS)
\r
862 // if(DoUpLoad(AskTrnCtrlSkt(), TransPacketBase) == 429)
\r
864 // if(ReConnectTrnSkt() == FFFTP_SUCCESS)
\r
865 // DoUpLoad(AskTrnCtrlSkt(), TransPacketBase);
\r
866 DoUpLoad(TrnSkt, Pos);
\r
869 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
870 ReleaseMutex(hListAccMutex);
\r
872 /* フォルダ作成(ローカルまたはホスト) */
\r
873 // else if(strncmp(TransPacketBase->Cmd, "MKD", 3) == 0)
\r
874 else if(strncmp(Pos->Cmd, "MKD", 3) == 0)
\r
876 // DispTransFileInfo(TransPacketBase, MSGJPN078, FALSE, YES);
\r
877 DispTransFileInfo(Pos, MSGJPN078, FALSE, YES);
\r
879 // if(strlen(TransPacketBase->RemoteFile) > 0)
\r
880 if(strlen(Pos->RemoteFile) > 0)
\r
882 /* フルパスを使わないための処理 */
\r
883 CwdSts = FTP_COMPLETE;
\r
885 // strcpy(Tmp, TransPacketBase->RemoteFile);
\r
886 strcpy(Tmp, Pos->RemoteFile);
\r
887 // if(ProcForNonFullpath(Tmp, CurDir, hWndTrans, 1) == FFFTP_FAIL)
\r
888 if(ProcForNonFullpath(TrnSkt, Tmp, CurDir[Pos->ThreadCount], hWndTrans, &Canceled[Pos->ThreadCount]) == FFFTP_FAIL)
\r
891 CwdSts = FTP_ERROR;
\r
894 if(CwdSts == FTP_COMPLETE)
\r
897 // CommandProcTrn(NULL, "MKD %s", Tmp);
\r
898 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "MKD %s", Tmp);
\r
899 /* すでにフォルダがある場合もあるので、 */
\r
900 /* ここではエラーチェックはしない */
\r
903 // CommandProcTrn(NULL, "%s %03d %s", AskHostChmodCmd(), FolderAttrNum, Tmp);
\r
904 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "%s %03d %s", AskHostChmodCmd(), FolderAttrNum, Tmp);
\r
907 // else if(strlen(TransPacketBase->LocalFile) > 0)
\r
908 else if(strlen(Pos->LocalFile) > 0)
\r
911 // DoLocalMKD(TransPacketBase->LocalFile);
\r
912 DoLocalMKD(Pos->LocalFile);
\r
914 ReleaseMutex(hListAccMutex);
\r
916 /* ディレクトリ作成(常にホスト側) */
\r
917 // else if(strncmp(TransPacketBase->Cmd, "R-MKD", 5) == 0)
\r
918 else if(strncmp(Pos->Cmd, "R-MKD", 5) == 0)
\r
920 // DispTransFileInfo(TransPacketBase, MSGJPN079, FALSE, YES);
\r
921 DispTransFileInfo(Pos, MSGJPN079, FALSE, YES);
\r
923 /* フルパスを使わないための処理 */
\r
924 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
925 if(MakeNonFullPath(Pos, CurDir[Pos->ThreadCount], Tmp) == FFFTP_SUCCESS)
\r
928 // CommandProcTrn(NULL, "%s%s", TransPacketBase->Cmd+2, TransPacketBase->RemoteFile);
\r
929 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "%s%s", Pos->Cmd+2, Pos->RemoteFile);
\r
932 // CommandProcTrn(NULL, "%s %03d %s", AskHostChmodCmd(), FolderAttrNum, TransPacketBase->RemoteFile);
\r
933 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "%s %03d %s", AskHostChmodCmd(), FolderAttrNum, Pos->RemoteFile);
\r
935 ReleaseMutex(hListAccMutex);
\r
937 /* ディレクトリ削除(常にホスト側) */
\r
938 // else if(strncmp(TransPacketBase->Cmd, "R-RMD", 5) == 0)
\r
939 else if(strncmp(Pos->Cmd, "R-RMD", 5) == 0)
\r
941 // DispTransFileInfo(TransPacketBase, MSGJPN080, FALSE, YES);
\r
942 DispTransFileInfo(Pos, MSGJPN080, FALSE, YES);
\r
944 // DelNotify = MirrorDelNotify(WIN_REMOTE, DelNotify, TransPacketBase);
\r
945 DelNotify = MirrorDelNotify(WIN_REMOTE, DelNotify, Pos);
\r
946 if((DelNotify == YES) || (DelNotify == YES_ALL))
\r
948 /* フルパスを使わないための処理 */
\r
949 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
950 if(MakeNonFullPath(Pos, CurDir[Pos->ThreadCount], Tmp) == FFFTP_SUCCESS)
\r
953 // CommandProcTrn(NULL, "%s%s", TransPacketBase->Cmd+2, TransPacketBase->RemoteFile);
\r
954 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "%s%s", Pos->Cmd+2, Pos->RemoteFile);
\r
957 ReleaseMutex(hListAccMutex);
\r
959 /* ファイル削除(常にホスト側) */
\r
960 // else if(strncmp(TransPacketBase->Cmd, "R-DELE", 6) == 0)
\r
961 else if(strncmp(Pos->Cmd, "R-DELE", 6) == 0)
\r
963 // DispTransFileInfo(TransPacketBase, MSGJPN081, FALSE, YES);
\r
964 DispTransFileInfo(Pos, MSGJPN081, FALSE, YES);
\r
966 // DelNotify = MirrorDelNotify(WIN_REMOTE, DelNotify, TransPacketBase);
\r
967 DelNotify = MirrorDelNotify(WIN_REMOTE, DelNotify, Pos);
\r
968 if((DelNotify == YES) || (DelNotify == YES_ALL))
\r
970 /* フルパスを使わないための処理 */
\r
971 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
972 if(MakeNonFullPath(Pos, CurDir[Pos->ThreadCount], Tmp) == FFFTP_SUCCESS)
\r
975 // CommandProcTrn(NULL, "%s%s", TransPacketBase->Cmd+2, TransPacketBase->RemoteFile);
\r
976 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "%s%s", Pos->Cmd+2, Pos->RemoteFile);
\r
979 ReleaseMutex(hListAccMutex);
\r
981 /* ディレクトリ作成(常にローカル側) */
\r
982 // else if(strncmp(TransPacketBase->Cmd, "L-MKD", 5) == 0)
\r
983 else if(strncmp(Pos->Cmd, "L-MKD", 5) == 0)
\r
985 // DispTransFileInfo(TransPacketBase, MSGJPN082, FALSE, YES);
\r
986 DispTransFileInfo(Pos, MSGJPN082, FALSE, YES);
\r
989 // DoLocalMKD(TransPacketBase->LocalFile);
\r
990 DoLocalMKD(Pos->LocalFile);
\r
991 ReleaseMutex(hListAccMutex);
\r
993 /* ディレクトリ削除(常にローカル側) */
\r
994 // else if(strncmp(TransPacketBase->Cmd, "L-RMD", 5) == 0)
\r
995 else if(strncmp(Pos->Cmd, "L-RMD", 5) == 0)
\r
997 // DispTransFileInfo(TransPacketBase, MSGJPN083, FALSE, YES);
\r
998 DispTransFileInfo(Pos, MSGJPN083, FALSE, YES);
\r
1000 // DelNotify = MirrorDelNotify(WIN_LOCAL, DelNotify, TransPacketBase);
\r
1001 DelNotify = MirrorDelNotify(WIN_LOCAL, DelNotify, Pos);
\r
1002 if((DelNotify == YES) || (DelNotify == YES_ALL))
\r
1005 // DoLocalRMD(TransPacketBase->LocalFile);
\r
1006 DoLocalRMD(Pos->LocalFile);
\r
1008 ReleaseMutex(hListAccMutex);
\r
1010 /* ファイル削除(常にローカル側) */
\r
1011 // else if(strncmp(TransPacketBase->Cmd, "L-DELE", 6) == 0)
\r
1012 else if(strncmp(Pos->Cmd, "L-DELE", 6) == 0)
\r
1014 // DispTransFileInfo(TransPacketBase, MSGJPN084, FALSE, YES);
\r
1015 DispTransFileInfo(Pos, MSGJPN084, FALSE, YES);
\r
1017 // DelNotify = MirrorDelNotify(WIN_LOCAL, DelNotify, TransPacketBase);
\r
1018 DelNotify = MirrorDelNotify(WIN_LOCAL, DelNotify, Pos);
\r
1019 if((DelNotify == YES) || (DelNotify == YES_ALL))
\r
1022 // DoLocalDELE(TransPacketBase->LocalFile);
\r
1023 DoLocalDELE(Pos->LocalFile);
\r
1025 ReleaseMutex(hListAccMutex);
\r
1027 /* カレントディレクトリを設定 */
\r
1028 // else if(strcmp(TransPacketBase->Cmd, "SETCUR") == 0)
\r
1029 else if(strcmp(Pos->Cmd, "SETCUR") == 0)
\r
1031 // if(AskShareProh() == YES)
\r
1032 if(AskReuseCmdSkt() == NO || AskShareProh() == YES)
\r
1034 // if(strcmp(CurDir, TransPacketBase->RemoteFile) != 0)
\r
1035 if(strcmp(CurDir[Pos->ThreadCount], Pos->RemoteFile) != 0)
\r
1037 // if(CommandProcTrn(NULL, "CWD %s", TransPacketBase->RemoteFile)/100 != FTP_COMPLETE)
\r
1038 if(CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "CWD %s", Pos->RemoteFile)/100 != FTP_COMPLETE)
\r
1040 DispCWDerror(hWndTrans);
\r
1045 // strcpy(CurDir, TransPacketBase->RemoteFile);
\r
1046 strcpy(CurDir[Pos->ThreadCount], Pos->RemoteFile);
\r
1047 ReleaseMutex(hListAccMutex);
\r
1049 /* カレントディレクトリを戻す */
\r
1050 // else if(strcmp(TransPacketBase->Cmd, "BACKCUR") == 0)
\r
1051 else if(strcmp(Pos->Cmd, "BACKCUR") == 0)
\r
1053 // if(AskShareProh() == NO)
\r
1054 if(AskReuseCmdSkt() == YES && AskShareProh() == NO)
\r
1056 // if(strcmp(CurDir, TransPacketBase->RemoteFile) != 0)
\r
1057 // CommandProcTrn(NULL, "CWD %s", TransPacketBase->RemoteFile);
\r
1058 // strcpy(CurDir, TransPacketBase->RemoteFile);
\r
1059 if(strcmp(CurDir[Pos->ThreadCount], Pos->RemoteFile) != 0)
\r
1060 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "CWD %s", Pos->RemoteFile);
\r
1061 strcpy(CurDir[Pos->ThreadCount], Pos->RemoteFile);
\r
1063 ReleaseMutex(hListAccMutex);
\r
1066 // else if(strcmp(TransPacketBase->Cmd, "GOQUIT") == 0)
\r
1067 else if(strcmp(Pos->Cmd, "GOQUIT") == 0)
\r
1069 ReleaseMutex(hListAccMutex);
\r
1073 ReleaseMutex(hListAccMutex);
\r
1075 /*===== 1つの処理終わり =====*/
\r
1077 if(ForceAbort == NO)
\r
1079 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
1080 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
1082 BackgrndMessageProc();
\r
1085 if(ClearAll == YES)
\r
1086 // EraseTransFileList();
\r
1088 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
1089 Canceled[i] = YES;
\r
1090 EraseTransFileList();
\r
1095 // if((strncmp(TransPacketBase->Cmd, "RETR", 4) == 0) ||
\r
1096 // (strncmp(TransPacketBase->Cmd, "STOR", 4) == 0))
\r
1097 if((strncmp(Pos->Cmd, "RETR", 4) == 0) ||
\r
1098 (strncmp(Pos->Cmd, "STOR", 4) == 0))
\r
1101 if(TransFiles > 0)
\r
1103 PostMessage(GetMainHwnd(), WM_CHANGE_COND, 0, 0);
\r
1105 // Pos = TransPacketBase;
\r
1106 // TransPacketBase = TransPacketBase->Next;
\r
1110 ReleaseMutex(hListAccMutex);
\r
1112 if(BackgrndMessageProc() == YES)
\r
1114 WaitForSingleObject(hListAccMutex, INFINITE);
\r
1115 EraseTransFileList();
\r
1116 ReleaseMutex(hListAccMutex);
\r
1119 if(hWndTrans != NULL)
\r
1120 SendMessage(hWndTrans, WM_SET_PACKET, 0, 0);
\r
1122 strcpy(Pos->Cmd, "");
\r
1125 else if(TransPacketBase == NULL)
\r
1129 ReleaseMutex(hListAccMutex);
\r
1132 if(hWndTrans != NULL)
\r
1134 DestroyWindow(hWndTrans);
\r
1137 // if(GoExit == YES)
\r
1139 // SoundPlay(SND_TRANS);
\r
1141 // if(AskAutoExit() == NO)
\r
1143 // if(Down == YES)
\r
1144 // PostMessage(GetMainHwnd(), WM_REFRESH_LOCAL_FLG, 0, 0);
\r
1146 // PostMessage(GetMainHwnd(), WM_REFRESH_REMOTE_FLG, 0, 0);
\r
1153 BackgrndMessageProc();
\r
1159 SoundPlay(SND_TRANS);
\r
1160 if(AskAutoExit() == NO)
\r
1163 PostMessage(GetMainHwnd(), WM_REFRESH_LOCAL_FLG, 0, 0);
\r
1165 PostMessage(GetMainHwnd(), WM_REFRESH_REMOTE_FLG, 0, 0);
\r
1169 PostMessage(GetMainHwnd(), WM_COMMAND, MAKEWPARAM(MENU_AUTO_EXIT, 0), 0);
\r
1175 ReleaseMutex(hListAccMutex);
\r
1176 if(hWndTrans != NULL)
\r
1178 DestroyWindow(hWndTrans);
\r
1181 BackgrndMessageProc();
\r
1182 if(ThreadCount < AskMaxThreadCount())
\r
1188 if(AskReuseCmdSkt() == NO || ThreadCount > 0)
\r
1190 if(TrnSkt != INVALID_SOCKET)
\r
1192 SendData(TrnSkt, "QUIT\r\n", 6, 0, &Canceled[ThreadCount]);
\r
1200 /*----- フルパスを使わないファイルアクセスの準備 ------------------------------
\r
1203 * TRANSPACKET *Pkt : 転送パケット
\r
1204 * char *Cur : カレントディレクトリ
\r
1205 * char *Tmp : 作業用エリア
\r
1208 * int ステータス(FFFTP_SUCCESS/FFFTP_FAIL)
\r
1212 * このモジュール内で CWD を行ない、
\r
1213 * Pkt->RemoteFile にファイル名のみ残す。(パス名は消す)
\r
1214 *----------------------------------------------------------------------------*/
\r
1217 static int MakeNonFullPath(TRANSPACKET *Pkt, char *Cur, char *Tmp)
\r
1221 // Sts = ProcForNonFullpath(Pkt->RemoteFile, Cur, Pkt->hWndTrans, 1);
\r
1222 Sts = ProcForNonFullpath(Pkt->ctrl_skt, Pkt->RemoteFile, Cur, Pkt->hWndTrans, &Canceled[Pkt->ThreadCount]);
\r
1223 if(Sts == FFFTP_FAIL)
\r
1232 /*----- ダウンロードを行なう --------------------------------------------------
\r
1235 * SOCKET cSkt : コントロールソケット
\r
1236 * TRANSPACKET *Pkt : 転送ファイル情報
\r
1237 * int DirList : ディレクトリリストのダウンロード(YES/NO)
\r
1243 * このモジュールは、ファイル一覧の取得などを行なう際にメインのスレッド
\r
1244 * からも呼ばれる。メインのスレッドから呼ばれる時は Pkt->hWndTrans == NULL。
\r
1245 *----------------------------------------------------------------------------*/
\r
1247 int DoDownLoad(SOCKET cSkt, TRANSPACKET *Pkt, int DirList, int *CancelCheckWork)
\r
1250 char Reply[ERR_MSG_LEN+7];
\r
1252 Pkt->ctrl_skt = cSkt;
\r
1253 if(IsSpecialDevice(GetFileName(Pkt->LocalFile)) == YES)
\r
1256 SetTaskMsg(MSGJPN085, GetFileName(Pkt->LocalFile));
\r
1257 DispDownloadFinishMsg(Pkt, iRetCode);
\r
1259 else if(Pkt->Mode != EXIST_IGNORE)
\r
1261 if(Pkt->Type == TYPE_I)
\r
1262 Pkt->KanjiCode = KANJI_NOCNV;
\r
1264 iRetCode = command(Pkt->ctrl_skt, Reply, CancelCheckWork, "TYPE %c", Pkt->Type);
\r
1265 if(iRetCode/100 < FTP_RETRY)
\r
1267 if(Pkt->hWndTrans != NULL)
\r
1270 // AllTransSizeNow = 0;
\r
1271 AllTransSizeNow[Pkt->ThreadCount] = 0;
\r
1274 DispTransFileInfo(Pkt, MSGJPN086, TRUE, YES);
\r
1276 DispTransFileInfo(Pkt, MSGJPN087, FALSE, NO);
\r
1279 if(BackgrndMessageProc() == NO)
\r
1281 if(AskPasvMode() != YES)
\r
1282 iRetCode = DownLoadNonPassive(Pkt, CancelCheckWork);
\r
1284 iRetCode = DownLoadPassive(Pkt, CancelCheckWork);
\r
1290 SetErrorMsg(Reply);
\r
1294 DispTransFileInfo(Pkt, MSGJPN088, TRUE, YES);
\r
1295 SetTaskMsg(MSGJPN089, Pkt->RemoteFile);
\r
1302 /*----- 通常モードでファイルをダウンロード ------------------------------------
\r
1305 * TRANSPACKET *Pkt : 転送ファイル情報
\r
1309 *----------------------------------------------------------------------------*/
\r
1311 static int DownLoadNonPassive(TRANSPACKET *Pkt, int *CancelCheckWork)
\r
1315 SOCKET data_socket = INVALID_SOCKET; // data channel socket
\r
1316 SOCKET listen_socket = INVALID_SOCKET; // data listen socket
\r
1319 struct sockaddr_in saSockAddr1;
\r
1320 char Reply[ERR_MSG_LEN+7];
\r
1322 if((listen_socket = GetFTPListenSocket(Pkt->ctrl_skt, CancelCheckWork)) != INVALID_SOCKET)
\r
1324 if(SetDownloadResume(Pkt, Pkt->Mode, Pkt->ExistSize, &CreateMode, CancelCheckWork) == YES)
\r
1326 sprintf(Buf, "%s%s", Pkt->Cmd, Pkt->RemoteFile);
\r
1327 iRetCode = command(Pkt->ctrl_skt, Reply, CancelCheckWork, "%s", Buf);
\r
1328 if(iRetCode/100 == FTP_PRELIM)
\r
1331 // if(SocksGet2ndBindReply(listen_socket, &data_socket) == FFFTP_FAIL)
\r
1332 if(SocksGet2ndBindReply(listen_socket, &data_socket, CancelCheckWork) == FFFTP_FAIL)
\r
1334 iLength = sizeof(saSockAddr1);
\r
1335 data_socket = do_accept(listen_socket, (struct sockaddr *)&saSockAddr1, (int *)&iLength);
\r
1337 if(shutdown(listen_socket, 1) != 0)
\r
1338 ReportWSError("shutdown listen", WSAGetLastError());
\r
1339 listen_socket = DoClose(listen_socket);
\r
1341 if(data_socket == INVALID_SOCKET)
\r
1343 SetErrorMsg(MSGJPN280);
\r
1344 ReportWSError("accept", WSAGetLastError());
\r
1348 DoPrintf("Skt=%u : accept from %s port %u", data_socket, inet_ntoa(saSockAddr1.sin_addr), ntohs(saSockAddr1.sin_port));
\r
1351 if(data_socket != INVALID_SOCKET)
\r
1353 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
1354 ReleaseMutex(hListAccMutex);
\r
1356 // iRetCode = DownLoadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1357 if(IsSSLAttached(Pkt->ctrl_skt))
\r
1359 if(AttachSSL(data_socket, Pkt->ctrl_skt, CancelCheckWork))
\r
1360 iRetCode = DownLoadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1365 iRetCode = DownLoadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1366 // data_socket = DoClose(data_socket);
\r
1371 SetErrorMsg(Reply);
\r
1372 SetTaskMsg(MSGJPN090);
\r
1373 listen_socket = DoClose(listen_socket);
\r
1383 SetErrorMsg(MSGJPN279);
\r
1385 DispDownloadFinishMsg(Pkt, iRetCode);
\r
1391 /*----- Passiveモードでファイルをダウンロード ---------------------------------
\r
1394 * TRANSPACKET *Pkt : 転送ファイル情報
\r
1398 *----------------------------------------------------------------------------*/
\r
1400 static int DownLoadPassive(TRANSPACKET *Pkt, int *CancelCheckWork)
\r
1403 SOCKET data_socket = INVALID_SOCKET; // data channel socket
\r
1409 char Reply[ERR_MSG_LEN+7];
\r
1411 iRetCode = command(Pkt->ctrl_skt, Buf, CancelCheckWork, "PASV");
\r
1412 if(iRetCode/100 == FTP_COMPLETE)
\r
1414 if(GetAdrsAndPort(Buf, Adrs, &Port, 19) == FFFTP_SUCCESS)
\r
1416 if((data_socket = connectsock(Adrs, Port, MSGJPN091, CancelCheckWork)) != INVALID_SOCKET)
\r
1420 if(setsockopt(data_socket, IPPROTO_TCP, TCP_NODELAY, (LPSTR)&Flg, sizeof(Flg)) == SOCKET_ERROR)
\r
1421 ReportWSError("setsockopt", WSAGetLastError());
\r
1423 if(SetDownloadResume(Pkt, Pkt->Mode, Pkt->ExistSize, &CreateMode, CancelCheckWork) == YES)
\r
1425 sprintf(Buf, "%s%s", Pkt->Cmd, Pkt->RemoteFile);
\r
1426 iRetCode = command(Pkt->ctrl_skt, Reply, CancelCheckWork, "%s", Buf);
\r
1427 if(iRetCode/100 == FTP_PRELIM)
\r
1429 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
1430 ReleaseMutex(hListAccMutex);
\r
1432 // iRetCode = DownLoadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1433 if(IsSSLAttached(Pkt->ctrl_skt))
\r
1435 if(AttachSSL(data_socket, Pkt->ctrl_skt, CancelCheckWork))
\r
1436 iRetCode = DownLoadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1441 iRetCode = DownLoadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1442 // data_socket = DoClose(data_socket);
\r
1446 SetErrorMsg(Reply);
\r
1447 SetTaskMsg(MSGJPN092);
\r
1448 data_socket = DoClose(data_socket);
\r
1460 SetErrorMsg(MSGJPN093);
\r
1461 SetTaskMsg(MSGJPN093);
\r
1468 DispDownloadFinishMsg(Pkt, iRetCode);
\r
1474 /*----- ダウンロードの実行 ----------------------------------------------------
\r
1477 * TRANSPACKET *Pkt : 転送ファイル情報
\r
1478 * SOCKET dSkt : データソケット
\r
1479 * int CreateMode : ファイル作成モード (CREATE_ALWAYS/OPEN_ALWAYS)
\r
1486 * ダイアログを出す(Pkt->hWndTrans!=NULL)場合、インターバルタイマで経過を表示する
\r
1487 * ダイアログを出さない場合、このルーチンからDispDownloadSize()を呼ぶ
\r
1488 *----------------------------------------------------------------------------*/
\r
1490 static int DownLoadFile(TRANSPACKET *Pkt, SOCKET dSkt, int CreateMode, int *CancelCheckWork)
\r
1493 char Buf[BUFSIZE];
\r
1494 char Buf2[BUFSIZE+3];
\r
1495 HANDLE iFileHandle;
\r
1496 SECURITY_ATTRIBUTES Sec;
\r
1498 CODECONVINFO cInfo;
\r
1500 // fd_set ReadFds;
\r
1501 // struct timeval Tout;
\r
1502 // struct timeval *ToutPtr;
\r
1505 char TmpBuf[ONELINE_BUF_SIZE];
\r
1506 DWORD dwFileAttributes;
\r
1508 #ifdef SET_BUFFER_SIZE
\r
1509 /* Add by H.Shirouzu at 2002/10/02 */
\r
1510 int buf_size = SOCKBUF_SIZE;
\r
1511 for ( ; buf_size > 0; buf_size /= 2)
\r
1512 if (setsockopt(dSkt, SOL_SOCKET, SO_RCVBUF, (char *)&buf_size, sizeof(buf_size)) == 0)
\r
1517 // 念のため受信バッファを無効にする
\r
1518 #ifdef DISABLE_TRANSFER_NETWORK_BUFFERS
\r
1520 setsockopt(dSkt, SOL_SOCKET, SO_RCVBUF, (char *)&buf_size, sizeof(buf_size));
\r
1523 Pkt->Abort = ABORT_NONE;
\r
1525 Sec.nLength = sizeof(SECURITY_ATTRIBUTES);
\r
1526 Sec.lpSecurityDescriptor = NULL;
\r
1527 Sec.bInheritHandle = FALSE;
\r
1529 dwFileAttributes = GetFileAttributes(Pkt->LocalFile);
\r
1530 if (dwFileAttributes != INVALID_FILE_ATTRIBUTES && (dwFileAttributes & FILE_ATTRIBUTE_READONLY)) {
\r
1532 if (MessageBox(GetMainHwnd(), MSGJPN296, MSGJPN086, MB_YESNO) == IDYES) {
\r
1534 SetFileAttributes(Pkt->LocalFile, dwFileAttributes ^ FILE_ATTRIBUTE_READONLY);
\r
1538 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
1541 char Buf3[(BUFSIZE + 3) * 4];
\r
1542 CODECONVINFO cInfo2;
\r
1543 int ProcessedBOM = NO;
\r
1544 // 4GB超対応(kaokunさん提供)
\r
1546 if(CreateMode == OPEN_ALWAYS)
\r
1547 // 4GB超対応(kaokunさん提供)
\r
1548 // SetFilePointer(iFileHandle, 0, 0, FILE_END);
\r
1549 SetFilePointer(iFileHandle, 0, &High, FILE_END);
\r
1551 if(Pkt->hWndTrans != NULL)
\r
1554 // TimeStart = time(NULL);
\r
1555 TimeStart[Pkt->ThreadCount] = time(NULL);
\r
1556 SetTimer(Pkt->hWndTrans, TIMER_DISPLAY, DISPLAY_TIMING, NULL);
\r
1559 InitCodeConvInfo(&cInfo);
\r
1560 cInfo.KanaCnv = Pkt->KanaCnv;
\r
1562 InitCodeConvInfo(&cInfo2);
\r
1563 cInfo2.KanaCnv = Pkt->KanaCnv;
\r
1565 /*===== ファイルを受信するループ =====*/
\r
1566 while((Pkt->Abort == ABORT_NONE) && (ForceAbort == NO))
\r
1568 // FD_ZERO(&ReadFds);
\r
1569 // FD_SET(dSkt, &ReadFds);
\r
1570 // ToutPtr = NULL;
\r
1571 // if(TimeOut != 0)
\r
1573 // Tout.tv_sec = TimeOut;
\r
1574 // Tout.tv_usec = 0;
\r
1575 // ToutPtr = &Tout;
\r
1577 // iNumBytes = select(0, &ReadFds, NULL, NULL, ToutPtr);
\r
1578 // if(iNumBytes == SOCKET_ERROR)
\r
1580 // ReportWSError("select", WSAGetLastError());
\r
1581 // if(Pkt->Abort == ABORT_NONE)
\r
1582 // Pkt->Abort = ABORT_ERROR;
\r
1585 // else if(iNumBytes == 0)
\r
1587 // SetErrorMsg(MSGJPN094);
\r
1588 // SetTaskMsg(MSGJPN094);
\r
1589 // Pkt->Abort = ABORT_ERROR;
\r
1593 if((iNumBytes = do_recv(dSkt, Buf, BUFSIZE, 0, &TimeOutErr, CancelCheckWork)) <= 0)
\r
1595 if(TimeOutErr == YES)
\r
1597 SetErrorMsg(MSGJPN094);
\r
1598 SetTaskMsg(MSGJPN094);
\r
1599 if(Pkt->hWndTrans != NULL)
\r
1601 if(Pkt->Abort == ABORT_NONE)
\r
1602 Pkt->Abort = ABORT_ERROR;
\r
1604 else if(iNumBytes == SOCKET_ERROR)
\r
1606 if(Pkt->Abort == ABORT_NONE)
\r
1607 Pkt->Abort = ABORT_ERROR;
\r
1613 if(Pkt->KanjiCode != KANJI_NOCNV)
\r
1616 cInfo.StrLen = iNumBytes;
\r
1618 cInfo.BufSize = BUFSIZE+3;
\r
1621 // ここで全てUTF-8へ変換する
\r
1622 // TODO: SJIS以外も直接UTF-8へ変換
\r
1623 // if(Pkt->KanjiCode == KANJI_JIS)
\r
1624 // Continue = ConvJIStoSJIS(&cInfo);
\r
1626 // Continue = ConvEUCtoSJIS(&cInfo);
\r
1627 char Buf3[(BUFSIZE + 3) * 4];
\r
1628 CODECONVINFO cInfo2;
\r
1629 switch(Pkt->KanjiCode)
\r
1632 switch(Pkt->KanjiCodeDesired)
\r
1635 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1636 // cInfo2.OutLen = cInfo.StrLen;
\r
1639 Continue = ConvSJIStoJIS(&cInfo);
\r
1640 cInfo2.Str = cInfo.Buf;
\r
1641 cInfo2.StrLen = cInfo.OutLen;
\r
1642 cInfo2.Buf = Buf3;
\r
1643 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1644 ConvJIStoSJIS(&cInfo2);
\r
1647 Continue = ConvSJIStoJIS(&cInfo);
\r
1648 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1649 cInfo2.OutLen = cInfo.OutLen;
\r
1652 Continue = ConvSJIStoEUC(&cInfo);
\r
1653 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1654 cInfo2.OutLen = cInfo.OutLen;
\r
1657 Continue = ConvSJIStoUTF8N(&cInfo);
\r
1658 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1659 cInfo2.OutLen = cInfo.OutLen;
\r
1661 case KANJI_UTF8BOM:
\r
1662 if(ProcessedBOM == NO)
\r
1664 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
1665 cInfo2.OutLen = 3;
\r
1667 ProcessedBOM = YES;
\r
1670 Continue = ConvSJIStoUTF8N(&cInfo);
\r
1671 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1672 cInfo2.OutLen = cInfo.OutLen;
\r
1677 switch(Pkt->KanjiCodeDesired)
\r
1680 Continue = ConvJIStoSJIS(&cInfo);
\r
1681 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1682 cInfo2.OutLen = cInfo.OutLen;
\r
1685 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1686 // cInfo2.OutLen = cInfo.StrLen;
\r
1689 Continue = ConvJIStoSJIS(&cInfo);
\r
1690 cInfo2.Str = cInfo.Buf;
\r
1691 cInfo2.StrLen = cInfo.OutLen;
\r
1692 cInfo2.Buf = Buf3;
\r
1693 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1694 ConvSJIStoJIS(&cInfo2);
\r
1697 Continue = ConvJIStoSJIS(&cInfo);
\r
1698 cInfo2.Str = cInfo.Buf;
\r
1699 cInfo2.StrLen = cInfo.OutLen;
\r
1700 cInfo2.Buf = Buf3;
\r
1701 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1702 ConvSJIStoEUC(&cInfo2);
\r
1705 Continue = ConvJIStoSJIS(&cInfo);
\r
1706 cInfo2.Str = cInfo.Buf;
\r
1707 cInfo2.StrLen = cInfo.OutLen;
\r
1708 cInfo2.Buf = Buf3;
\r
1709 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1710 ConvSJIStoUTF8N(&cInfo2);
\r
1712 case KANJI_UTF8BOM:
\r
1713 if(ProcessedBOM == NO)
\r
1715 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
1716 cInfo2.OutLen = 3;
\r
1718 ProcessedBOM = YES;
\r
1721 Continue = ConvJIStoSJIS(&cInfo);
\r
1722 cInfo2.Str = cInfo.Buf;
\r
1723 cInfo2.StrLen = cInfo.OutLen;
\r
1724 cInfo2.Buf = Buf3;
\r
1725 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1726 ConvSJIStoUTF8N(&cInfo2);
\r
1731 switch(Pkt->KanjiCodeDesired)
\r
1734 Continue = ConvEUCtoSJIS(&cInfo);
\r
1735 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1736 cInfo2.OutLen = cInfo.OutLen;
\r
1739 Continue = ConvEUCtoSJIS(&cInfo);
\r
1740 cInfo2.Str = cInfo.Buf;
\r
1741 cInfo2.StrLen = cInfo.OutLen;
\r
1742 cInfo2.Buf = Buf3;
\r
1743 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1744 ConvSJIStoJIS(&cInfo2);
\r
1747 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1748 // cInfo2.OutLen = cInfo.StrLen;
\r
1751 Continue = ConvEUCtoSJIS(&cInfo);
\r
1752 cInfo2.Str = cInfo.Buf;
\r
1753 cInfo2.StrLen = cInfo.OutLen;
\r
1754 cInfo2.Buf = Buf3;
\r
1755 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1756 ConvSJIStoEUC(&cInfo2);
\r
1759 Continue = ConvEUCtoSJIS(&cInfo);
\r
1760 cInfo2.Str = cInfo.Buf;
\r
1761 cInfo2.StrLen = cInfo.OutLen;
\r
1762 cInfo2.Buf = Buf3;
\r
1763 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1764 ConvSJIStoUTF8N(&cInfo2);
\r
1766 case KANJI_UTF8BOM:
\r
1767 if(ProcessedBOM == NO)
\r
1769 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
1770 cInfo2.OutLen = 3;
\r
1772 ProcessedBOM = YES;
\r
1775 Continue = ConvEUCtoSJIS(&cInfo);
\r
1776 cInfo2.Str = cInfo.Buf;
\r
1777 cInfo2.StrLen = cInfo.OutLen;
\r
1778 cInfo2.Buf = Buf3;
\r
1779 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1780 ConvSJIStoUTF8N(&cInfo2);
\r
1785 switch(Pkt->KanjiCodeDesired)
\r
1788 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1789 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1790 cInfo2.OutLen = cInfo.OutLen;
\r
1793 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1794 cInfo2.Str = cInfo.Buf;
\r
1795 cInfo2.StrLen = cInfo.OutLen;
\r
1796 cInfo2.Buf = Buf3;
\r
1797 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1798 ConvSJIStoJIS(&cInfo2);
\r
1801 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1802 cInfo2.Str = cInfo.Buf;
\r
1803 cInfo2.StrLen = cInfo.OutLen;
\r
1804 cInfo2.Buf = Buf3;
\r
1805 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1806 ConvSJIStoEUC(&cInfo2);
\r
1809 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1810 cInfo2.OutLen = cInfo.StrLen;
\r
1813 case KANJI_UTF8BOM:
\r
1814 if(ProcessedBOM == NO)
\r
1816 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
1817 cInfo2.OutLen = 3;
\r
1819 ProcessedBOM = YES;
\r
1822 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1823 cInfo2.OutLen = cInfo.StrLen;
\r
1828 case KANJI_UTF8BOM:
\r
1829 if(ProcessedBOM == NO)
\r
1831 if(memcmp(Buf, "\xEF\xBB\xBF", 3) == 0)
\r
1834 cInfo.StrLen -= 3;
\r
1836 cInfo2.OutLen = 0;
\r
1837 switch(Pkt->KanjiCodeDesired)
\r
1839 case KANJI_UTF8BOM:
\r
1840 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
1841 cInfo2.OutLen = 3;
\r
1845 ProcessedBOM = YES;
\r
1848 switch(Pkt->KanjiCodeDesired)
\r
1851 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1852 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1853 cInfo2.OutLen = cInfo.OutLen;
\r
1856 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1857 cInfo2.Str = cInfo.Buf;
\r
1858 cInfo2.StrLen = cInfo.OutLen;
\r
1859 cInfo2.Buf = Buf3;
\r
1860 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1861 ConvSJIStoJIS(&cInfo2);
\r
1864 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1865 cInfo2.Str = cInfo.Buf;
\r
1866 cInfo2.StrLen = cInfo.OutLen;
\r
1867 cInfo2.Buf = Buf3;
\r
1868 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1869 ConvSJIStoEUC(&cInfo2);
\r
1872 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1873 cInfo2.OutLen = cInfo.StrLen;
\r
1876 case KANJI_UTF8BOM:
\r
1877 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1878 cInfo2.OutLen = cInfo.StrLen;
\r
1884 // if(WriteFile(iFileHandle, Buf2, cInfo.OutLen, &Writed, NULL) == FALSE)
\r
1885 if(WriteFile(iFileHandle, Buf3, cInfo2.OutLen, &Writed, NULL) == FALSE)
\r
1886 Pkt->Abort = ABORT_DISKFULL;
\r
1888 while((Continue == YES) && (Pkt->Abort == ABORT_NONE));
\r
1892 if(WriteFile(iFileHandle, Buf, iNumBytes, &Writed, NULL) == FALSE)
\r
1893 Pkt->Abort = ABORT_DISKFULL;
\r
1896 Pkt->ExistSize += iNumBytes;
\r
1897 if(Pkt->hWndTrans != NULL)
\r
1899 // AllTransSizeNow += iNumBytes;
\r
1900 AllTransSizeNow[Pkt->ThreadCount] += iNumBytes;
\r
1903 /* 転送ダイアログを出さない時の経過表示 */
\r
1904 DispDownloadSize(Pkt->ExistSize);
\r
1907 if(BackgrndMessageProc() == YES)
\r
1911 /* 書き残したデータを書き込む */
\r
1912 if(Pkt->KanjiCode != KANJI_NOCNV)
\r
1915 cInfo.BufSize = BUFSIZE+3;
\r
1916 FlushRestData(&cInfo);
\r
1917 switch(Pkt->KanjiCode)
\r
1920 switch(Pkt->KanjiCodeDesired)
\r
1924 cInfo2.Str = cInfo.Buf;
\r
1925 cInfo2.StrLen = cInfo.OutLen;
\r
1926 cInfo2.Buf = Buf3;
\r
1927 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1928 ConvJIStoSJIS(&cInfo2);
\r
1931 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1932 cInfo2.OutLen = cInfo.OutLen;
\r
1935 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1936 cInfo2.OutLen = cInfo.OutLen;
\r
1939 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1940 cInfo2.OutLen = cInfo.OutLen;
\r
1942 case KANJI_UTF8BOM:
\r
1943 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1944 cInfo2.OutLen = cInfo.OutLen;
\r
1949 switch(Pkt->KanjiCodeDesired)
\r
1952 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1953 cInfo2.OutLen = cInfo.OutLen;
\r
1957 cInfo2.Str = cInfo.Buf;
\r
1958 cInfo2.StrLen = cInfo.OutLen;
\r
1959 cInfo2.Buf = Buf3;
\r
1960 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1961 ConvSJIStoJIS(&cInfo2);
\r
1964 cInfo2.Str = cInfo.Buf;
\r
1965 cInfo2.StrLen = cInfo.OutLen;
\r
1966 cInfo2.Buf = Buf3;
\r
1967 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1968 ConvSJIStoEUC(&cInfo2);
\r
1971 cInfo2.Str = cInfo.Buf;
\r
1972 cInfo2.StrLen = cInfo.OutLen;
\r
1973 cInfo2.Buf = Buf3;
\r
1974 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1975 ConvSJIStoUTF8N(&cInfo2);
\r
1977 case KANJI_UTF8BOM:
\r
1978 cInfo2.Str = cInfo.Buf;
\r
1979 cInfo2.StrLen = cInfo.OutLen;
\r
1980 cInfo2.Buf = Buf3;
\r
1981 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1982 ConvSJIStoUTF8N(&cInfo2);
\r
1987 switch(Pkt->KanjiCodeDesired)
\r
1990 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1991 cInfo2.OutLen = cInfo.OutLen;
\r
1994 cInfo2.Str = cInfo.Buf;
\r
1995 cInfo2.StrLen = cInfo.OutLen;
\r
1996 cInfo2.Buf = Buf3;
\r
1997 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1998 ConvSJIStoJIS(&cInfo2);
\r
2002 cInfo2.Str = cInfo.Buf;
\r
2003 cInfo2.StrLen = cInfo.OutLen;
\r
2004 cInfo2.Buf = Buf3;
\r
2005 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2006 ConvSJIStoEUC(&cInfo2);
\r
2009 cInfo2.Str = cInfo.Buf;
\r
2010 cInfo2.StrLen = cInfo.OutLen;
\r
2011 cInfo2.Buf = Buf3;
\r
2012 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2013 ConvSJIStoUTF8N(&cInfo2);
\r
2015 case KANJI_UTF8BOM:
\r
2016 cInfo2.Str = cInfo.Buf;
\r
2017 cInfo2.StrLen = cInfo.OutLen;
\r
2018 cInfo2.Buf = Buf3;
\r
2019 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2020 ConvSJIStoUTF8N(&cInfo2);
\r
2025 switch(Pkt->KanjiCodeDesired)
\r
2028 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2029 cInfo2.OutLen = cInfo.OutLen;
\r
2032 cInfo2.Str = cInfo.Buf;
\r
2033 cInfo2.StrLen = cInfo.OutLen;
\r
2034 cInfo2.Buf = Buf3;
\r
2035 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2036 ConvSJIStoJIS(&cInfo2);
\r
2039 cInfo2.Str = cInfo.Buf;
\r
2040 cInfo2.StrLen = cInfo.OutLen;
\r
2041 cInfo2.Buf = Buf3;
\r
2042 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2043 ConvSJIStoEUC(&cInfo2);
\r
2046 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2047 cInfo2.OutLen = cInfo.OutLen;
\r
2049 case KANJI_UTF8BOM:
\r
2050 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2051 cInfo2.OutLen = cInfo.OutLen;
\r
2055 case KANJI_UTF8BOM:
\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
2070 cInfo2.Str = cInfo.Buf;
\r
2071 cInfo2.StrLen = cInfo.OutLen;
\r
2072 cInfo2.Buf = Buf3;
\r
2073 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2074 ConvSJIStoEUC(&cInfo2);
\r
2077 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2078 cInfo2.OutLen = cInfo.OutLen;
\r
2080 case KANJI_UTF8BOM:
\r
2081 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2082 cInfo2.OutLen = cInfo.OutLen;
\r
2087 // if(WriteFile(iFileHandle, Buf2, cInfo.OutLen, &Writed, NULL) == FALSE)
\r
2088 if(WriteFile(iFileHandle, Buf3, cInfo2.OutLen, &Writed, NULL) == FALSE)
\r
2089 Pkt->Abort = ABORT_DISKFULL;
\r
2090 cInfo2.Buf = Buf3;
\r
2091 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2092 FlushRestData(&cInfo2);
\r
2093 if(WriteFile(iFileHandle, Buf3, cInfo2.OutLen, &Writed, NULL) == FALSE)
\r
2094 Pkt->Abort = ABORT_DISKFULL;
\r
2098 if(Pkt->hWndTrans != NULL)
\r
2100 KillTimer(Pkt->hWndTrans, TIMER_DISPLAY);
\r
2101 DispTransferStatus(Pkt->hWndTrans, YES, Pkt);
\r
2103 // TimeStart = time(NULL) - TimeStart + 1;
\r
2104 TimeStart[Pkt->ThreadCount] = time(NULL) - TimeStart[Pkt->ThreadCount] + 1;
\r
2108 /* 転送ダイアログを出さない時の経過表示を消す */
\r
2109 DispDownloadSize(-1);
\r
2112 /* ファイルのタイムスタンプを合わせる */
\r
2113 if((SaveTimeStamp == YES) &&
\r
2114 ((Pkt->Time.dwLowDateTime != 0) || (Pkt->Time.dwHighDateTime != 0)))
\r
2116 SetFileTime(iFileHandle, &Pkt->Time, &Pkt->Time, &Pkt->Time);
\r
2119 CloseHandle(iFileHandle);
\r
2121 if(iNumBytes == SOCKET_ERROR)
\r
2122 ReportWSError("recv",WSAGetLastError());
\r
2126 SetErrorMsg(MSGJPN095, Pkt->LocalFile);
\r
2127 SetTaskMsg(MSGJPN095, Pkt->LocalFile);
\r
2128 Pkt->Abort = ABORT_ERROR;
\r
2132 if(shutdown(dSkt, 1) != 0)
\r
2133 ReportWSError("shutdown", WSAGetLastError());
\r
2137 if(ForceAbort == NO)
\r
2139 /* Abortをホストに伝える */
\r
2140 if(Pkt->Abort != ABORT_NONE && iFileHandle != INVALID_HANDLE_VALUE)
\r
2142 SendData(Pkt->ctrl_skt, "\xFF\xF4\xFF", 3, MSG_OOB, CancelCheckWork); /* MSG_OOBに注意 */
\r
2143 SendData(Pkt->ctrl_skt, "\xF2", 1, 0, CancelCheckWork);
\r
2144 command(Pkt->ctrl_skt, NULL, CancelCheckWork, "ABOR");
\r
2148 iRetCode = ReadReplyMessage(Pkt->ctrl_skt, Buf, 1024, CancelCheckWork, TmpBuf);
\r
2151 //DoPrintf("##DOWN REPLY : %s", Buf);
\r
2153 if(Pkt->Abort == ABORT_DISKFULL)
\r
2155 SetErrorMsg(MSGJPN096);
\r
2156 SetTaskMsg(MSGJPN096);
\r
2158 if(iRetCode >= FTP_RETRY)
\r
2160 if(Pkt->Abort != ABORT_NONE)
\r
2167 /*----- ダウンロード終了/中止時のメッセージを表示 ----------------------------
\r
2170 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2171 * int iRetCode : 応答コード
\r
2175 *----------------------------------------------------------------------------*/
\r
2177 static void DispDownloadFinishMsg(TRANSPACKET *Pkt, int iRetCode)
\r
2179 char Fname[FMAX_PATH+1];
\r
2181 if(ForceAbort == NO)
\r
2183 if((iRetCode/100) >= FTP_CONTINUE)
\r
2185 strcpy(Fname, Pkt->RemoteFile);
\r
2187 #if defined(HAVE_OPENVMS)
\r
2188 /* OpenVMSの場合、空ディレクトリへ移動すると550 File not foundになって
\r
2189 * エラーダイアログやエラーメッセージが出るので何もしない */
\r
2190 if (AskHostType() == HTYPE_VMS)
\r
2194 if((strncmp(Pkt->Cmd, "NLST", 4) == 0) || (strncmp(Pkt->Cmd, "LIST", 4) == 0))
\r
2196 SetTaskMsg(MSGJPN097);
\r
2197 strcpy(Fname, MSGJPN098);
\r
2200 // else if((Pkt->hWndTrans != NULL) && (TimeStart != 0))
\r
2201 // SetTaskMsg(MSGJPN099, TimeStart, Pkt->ExistSize/TimeStart);
\r
2202 else if((Pkt->hWndTrans != NULL) && (TimeStart[Pkt->ThreadCount] != 0))
\r
2203 SetTaskMsg(MSGJPN099, TimeStart[Pkt->ThreadCount], Pkt->ExistSize/TimeStart[Pkt->ThreadCount]);
\r
2205 SetTaskMsg(MSGJPN100);
\r
2207 if(Pkt->Abort != ABORT_USER)
\r
2209 // 全て中止を選択後にダイアログが表示されるバグ対策
\r
2210 // if(DispUpDownErrDialog(downerr_dlg, Pkt->hWndTrans, Fname) == NO)
\r
2211 if(Canceled[Pkt->ThreadCount] == NO && ClearAll == NO && DispUpDownErrDialog(downerr_dlg, Pkt->hWndTrans, Fname) == NO)
\r
2217 if((strncmp(Pkt->Cmd, "NLST", 4) == 0) || (strncmp(Pkt->Cmd, "LIST", 4) == 0))
\r
2218 SetTaskMsg(MSGJPN101, Pkt->ExistSize);
\r
2220 // else if((Pkt->hWndTrans != NULL) && (TimeStart != 0))
\r
2221 // SetTaskMsg(MSGJPN102, TimeStart, Pkt->ExistSize/TimeStart);
\r
2222 else if((Pkt->hWndTrans != NULL) && (TimeStart[Pkt->ThreadCount] != 0))
\r
2223 // "0 B/S"と表示されるバグを修正
\r
2224 // 原因は%dにあたる部分に64ビット値が渡されているため
\r
2225 // SetTaskMsg(MSGJPN102, TimeStart[Pkt->ThreadCount], Pkt->ExistSize/TimeStart[Pkt->ThreadCount]);
\r
2226 SetTaskMsg(MSGJPN102, (LONG)TimeStart[Pkt->ThreadCount], (LONG)(Pkt->ExistSize/TimeStart[Pkt->ThreadCount]));
\r
2228 SetTaskMsg(MSGJPN103, Pkt->ExistSize);
\r
2235 /*----- ダウンロード/アップロードエラーのダイアログを表示 --------------------
\r
2238 * int RedID : ダイアログボックスのリソースID
\r
2239 * HWND hWnd : 書き込み中ダイアログのウインドウ
\r
2240 * char *Fname : ファイル名
\r
2243 * int ステータス (YES=中止/NO=全て中止)
\r
2244 *----------------------------------------------------------------------------*/
\r
2246 static int DispUpDownErrDialog(int ResID, HWND hWnd, char *Fname)
\r
2249 hWnd = GetMainHwnd();
\r
2251 SoundPlay(SND_ERROR);
\r
2252 return(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(ResID), hWnd, UpDownErrorDialogProc, (LPARAM)Fname));
\r
2256 /*----- ダウンロードエラー/アップロードエラーダイアログのコールバック --------
\r
2259 * HWND hDlg : ウインドウハンドル
\r
2260 * UINT message : メッセージ番号
\r
2261 * WPARAM wParam : メッセージの WPARAM 引数
\r
2262 * LPARAM lParam : メッセージの LPARAM 引数
\r
2266 *----------------------------------------------------------------------------*/
\r
2268 static BOOL CALLBACK UpDownErrorDialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
\r
2272 case WM_INITDIALOG :
\r
2273 SendDlgItemMessage(hDlg, UPDOWN_ERR_FNAME, WM_SETTEXT, 0, (LPARAM)lParam);
\r
2275 // SendDlgItemMessage(hDlg, UPDOWN_ERR_MSG, WM_SETTEXT, 0, (LPARAM)ErrMsg);
\r
2276 SendDlgItemMessage(hDlg, UPDOWN_ERR_MSG, WM_SETTEXT, 0, (LPARAM)GetErrMsg());
\r
2280 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2283 EndDialog(hDlg, YES);
\r
2287 EndDialog(hDlg, NO);
\r
2296 /*----- ダウンロードのリジュームの準備を行う ----------------------------------
\r
2299 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2300 * iont ProcMode : 処理モード(EXIST_xxx)
\r
2301 * LONGLONG Size : ロード済みのファイルのサイズ
\r
2302 * int *Mode : ファイル作成モード (CREATE_xxxx)
\r
2305 * int 転送を行うかどうか(YES/NO=このファイルを中止/NO_ALL=全て中止)
\r
2308 * Pkt->ExistSizeのセットを行なう
\r
2309 *----------------------------------------------------------------------------*/
\r
2311 static int SetDownloadResume(TRANSPACKET *Pkt, int ProcMode, LONGLONG Size, int *Mode, int *CancelCheckWork)
\r
2315 char Reply[ERR_MSG_LEN+7];
\r
2320 Pkt->ExistSize = 0;
\r
2321 *Mode = CREATE_ALWAYS;
\r
2323 if(ProcMode == EXIST_RESUME)
\r
2325 iRetCode = command(Pkt->ctrl_skt, Reply, CancelCheckWork, "REST %s", MakeNumString(Size, Tmp, FALSE));
\r
2326 if(iRetCode/100 < FTP_RETRY)
\r
2329 if(Pkt->hWndTrans != NULL)
\r
2330 Pkt->ExistSize = Size;
\r
2331 *Mode = OPEN_ALWAYS;
\r
2335 Com = DialogBox(GetFtpInst(), MAKEINTRESOURCE(noresume_dlg), Pkt->hWndTrans, NoResumeWndProc);
\r
2338 if(Com == NO_ALL) /* 全て中止 */
\r
2340 Pkt->Abort = ABORT_USER;
\r
2348 /*----- resumeエラーダイアログのコールバック ----------------------------------
\r
2351 * HWND hDlg : ウインドウハンドル
\r
2352 * UINT message : メッセージ番号
\r
2353 * WPARAM wParam : メッセージの WPARAM 引数
\r
2354 * LPARAM lParam : メッセージの LPARAM 引数
\r
2358 *----------------------------------------------------------------------------*/
\r
2360 static BOOL CALLBACK NoResumeWndProc(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2364 case WM_INITDIALOG :
\r
2368 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2371 EndDialog(hDlg, YES);
\r
2375 EndDialog(hDlg, NO);
\r
2378 case RESUME_CANCEL_ALL :
\r
2379 EndDialog(hDlg, NO_ALL);
\r
2389 /*----- アップロードを行なう --------------------------------------------------
\r
2392 * SOCKET cSkt : コントロールソケット
\r
2393 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2397 *----------------------------------------------------------------------------*/
\r
2399 static int DoUpLoad(SOCKET cSkt, TRANSPACKET *Pkt)
\r
2402 char Reply[ERR_MSG_LEN+7];
\r
2404 Pkt->ctrl_skt = cSkt;
\r
2406 if(Pkt->Mode != EXIST_IGNORE)
\r
2408 if(CheckFileReadable(Pkt->LocalFile) == FFFTP_SUCCESS)
\r
2410 if(Pkt->Type == TYPE_I)
\r
2411 Pkt->KanjiCode = KANJI_NOCNV;
\r
2414 // iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled, "TYPE %c", Pkt->Type);
\r
2415 iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled[Pkt->ThreadCount], "TYPE %c", Pkt->Type);
\r
2416 if(iRetCode/100 < FTP_RETRY)
\r
2418 if(Pkt->Mode == EXIST_UNIQUE)
\r
2419 strcpy(Pkt->Cmd, "STOU ");
\r
2421 if(Pkt->hWndTrans != NULL)
\r
2422 DispTransFileInfo(Pkt, MSGJPN104, TRUE, YES);
\r
2424 if(BackgrndMessageProc() == NO)
\r
2426 if(AskPasvMode() != YES)
\r
2427 iRetCode = UpLoadNonPassive(Pkt);
\r
2429 iRetCode = UpLoadPassive(Pkt);
\r
2435 SetErrorMsg(Reply);
\r
2438 if((Pkt->Attr != -1) && ((iRetCode/100) == FTP_COMPLETE))
\r
2440 // command(Pkt->ctrl_skt, Reply, &Canceled, "%s %03X %s", AskHostChmodCmd(), Pkt->Attr, Pkt->RemoteFile);
\r
2441 command(Pkt->ctrl_skt, Reply, &Canceled[Pkt->ThreadCount], "%s %03X %s", AskHostChmodCmd(), Pkt->Attr, Pkt->RemoteFile);
\r
2445 SetErrorMsg(MSGJPN105, Pkt->LocalFile);
\r
2446 SetTaskMsg(MSGJPN105, Pkt->LocalFile);
\r
2448 Pkt->Abort = ABORT_ERROR;
\r
2449 DispUploadFinishMsg(Pkt, iRetCode);
\r
2454 DispTransFileInfo(Pkt, MSGJPN106, TRUE, YES);
\r
2455 SetTaskMsg(MSGJPN107, Pkt->LocalFile);
\r
2462 /*----- 通常モードでファイルをアップロード ------------------------------------
\r
2465 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2469 *----------------------------------------------------------------------------*/
\r
2471 static int UpLoadNonPassive(TRANSPACKET *Pkt)
\r
2475 SOCKET data_socket = INVALID_SOCKET; // data channel socket
\r
2476 SOCKET listen_socket = INVALID_SOCKET; // data listen socket
\r
2478 struct sockaddr_in saSockAddr1;
\r
2480 char Reply[ERR_MSG_LEN+7];
\r
2483 // if((listen_socket = GetFTPListenSocket(Pkt->ctrl_skt, &Canceled)) != INVALID_SOCKET)
\r
2484 if((listen_socket = GetFTPListenSocket(Pkt->ctrl_skt, &Canceled[Pkt->ThreadCount])) != INVALID_SOCKET)
\r
2486 SetUploadResume(Pkt, Pkt->Mode, Pkt->ExistSize, &Resume);
\r
2488 sprintf(Buf, "%s%s", Pkt->Cmd, Pkt->RemoteFile);
\r
2490 sprintf(Buf, "%s%s", "APPE ", Pkt->RemoteFile);
\r
2493 // iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled, "%s", Buf);
\r
2494 iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled[Pkt->ThreadCount], "%s", Buf);
\r
2495 if((iRetCode/100) == FTP_PRELIM)
\r
2498 // if(SocksGet2ndBindReply(listen_socket, &data_socket) == FFFTP_FAIL)
\r
2499 if(SocksGet2ndBindReply(listen_socket, &data_socket, &Canceled[Pkt->ThreadCount]) == FFFTP_FAIL)
\r
2501 iLength=sizeof(saSockAddr1);
\r
2502 data_socket = do_accept(listen_socket,(struct sockaddr *)&saSockAddr1, (int *)&iLength);
\r
2504 if(shutdown(listen_socket, 1) != 0)
\r
2505 ReportWSError("shutdown listen", WSAGetLastError());
\r
2506 listen_socket = DoClose(listen_socket);
\r
2508 if(data_socket == INVALID_SOCKET)
\r
2510 SetErrorMsg(MSGJPN280);
\r
2511 ReportWSError("accept", WSAGetLastError());
\r
2515 DoPrintf("Skt=%u : accept from %s port %u", data_socket, inet_ntoa(saSockAddr1.sin_addr), ntohs(saSockAddr1.sin_port));
\r
2518 if(data_socket != INVALID_SOCKET)
\r
2520 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
2521 ReleaseMutex(hListAccMutex);
\r
2523 // iRetCode = UpLoadFile(Pkt, data_socket);
\r
2524 if(IsSSLAttached(Pkt->ctrl_skt))
\r
2526 if(AttachSSL(data_socket, Pkt->ctrl_skt, &Canceled[Pkt->ThreadCount]))
\r
2527 iRetCode = UpLoadFile(Pkt, data_socket);
\r
2532 iRetCode = UpLoadFile(Pkt, data_socket);
\r
2533 data_socket = DoClose(data_socket);
\r
2538 SetErrorMsg(Reply);
\r
2539 SetTaskMsg(MSGJPN108);
\r
2540 listen_socket = DoClose(listen_socket);
\r
2546 SetErrorMsg(MSGJPN279);
\r
2549 DispUploadFinishMsg(Pkt, iRetCode);
\r
2555 /*----- Passiveモードでファイルをアップロード ---------------------------------
\r
2558 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2562 *----------------------------------------------------------------------------*/
\r
2564 static int UpLoadPassive(TRANSPACKET *Pkt)
\r
2567 SOCKET data_socket = INVALID_SOCKET; // data channel socket
\r
2573 char Reply[ERR_MSG_LEN+7];
\r
2576 // iRetCode = command(Pkt->ctrl_skt, Buf, &Canceled, "PASV");
\r
2577 iRetCode = command(Pkt->ctrl_skt, Buf, &Canceled[Pkt->ThreadCount], "PASV");
\r
2578 if(iRetCode/100 == FTP_COMPLETE)
\r
2580 if(GetAdrsAndPort(Buf, Adrs, &Port, 19) == FFFTP_SUCCESS)
\r
2583 // if((data_socket = connectsock(Adrs, Port, MSGJPN109, &Canceled)) != INVALID_SOCKET)
\r
2584 if((data_socket = connectsock(Adrs, Port, MSGJPN109, &Canceled[Pkt->ThreadCount])) != INVALID_SOCKET)
\r
2588 if(setsockopt(data_socket, IPPROTO_TCP, TCP_NODELAY, (LPSTR)&Flg, sizeof(Flg)) == SOCKET_ERROR)
\r
2589 ReportWSError("setsockopt", WSAGetLastError());
\r
2591 SetUploadResume(Pkt, Pkt->Mode, Pkt->ExistSize, &Resume);
\r
2593 sprintf(Buf, "%s%s", Pkt->Cmd, Pkt->RemoteFile);
\r
2595 sprintf(Buf, "%s%s", "APPE ", Pkt->RemoteFile);
\r
2598 // iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled, "%s", Buf);
\r
2599 iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled[Pkt->ThreadCount], "%s", Buf);
\r
2600 if(iRetCode/100 == FTP_PRELIM)
\r
2602 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
2603 ReleaseMutex(hListAccMutex);
\r
2605 // iRetCode = UpLoadFile(Pkt, data_socket);
\r
2606 if(IsSSLAttached(Pkt->ctrl_skt))
\r
2608 if(AttachSSL(data_socket, Pkt->ctrl_skt, &Canceled[Pkt->ThreadCount]))
\r
2609 iRetCode = UpLoadFile(Pkt, data_socket);
\r
2614 iRetCode = UpLoadFile(Pkt, data_socket);
\r
2616 data_socket = DoClose(data_socket);
\r
2620 SetErrorMsg(Reply);
\r
2621 SetTaskMsg(MSGJPN110);
\r
2622 data_socket = DoClose(data_socket);
\r
2628 SetErrorMsg(MSGJPN281);
\r
2635 SetTaskMsg(MSGJPN111);
\r
2642 DispUploadFinishMsg(Pkt, iRetCode);
\r
2648 /*----- アップロードの実行 ----------------------------------------------------
\r
2651 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2652 * SOCKET dSkt : データソケット
\r
2658 * 転送の経過表示は、インターバルタイマで経過を表示する
\r
2659 * 転送ダイアログを出さないでアップロードすることはない
\r
2660 *----------------------------------------------------------------------------*/
\r
2662 static int UpLoadFile(TRANSPACKET *Pkt, SOCKET dSkt)
\r
2665 HANDLE iFileHandle;
\r
2666 SECURITY_ATTRIBUTES Sec;
\r
2667 char Buf[BUFSIZE];
\r
2668 char Buf2[BUFSIZE+3];
\r
2669 CODECONVINFO cInfo;
\r
2670 TERMCODECONVINFO tInfo;
\r
2677 char TmpBuf[ONELINE_BUF_SIZE];
\r
2681 #ifdef SET_BUFFER_SIZE
\r
2682 /* Add by H.Shirouzu at 2002/10/02 */
\r
2683 int buf_size = SOCKBUF_SIZE;
\r
2684 for ( ; buf_size > 0; buf_size /= 2)
\r
2685 if (setsockopt(dSkt, SOL_SOCKET, SO_SNDBUF, (char *)&buf_size, sizeof(buf_size)) == 0)
\r
2690 // 念のため送信バッファを無効にする
\r
2691 #ifdef DISABLE_TRANSFER_NETWORK_BUFFERS
\r
2693 setsockopt(dSkt, SOL_SOCKET, SO_SNDBUF, (char *)&buf_size, sizeof(buf_size));
\r
2696 Pkt->Abort = ABORT_NONE;
\r
2698 Sec.nLength = sizeof(SECURITY_ATTRIBUTES);
\r
2699 Sec.lpSecurityDescriptor = NULL;
\r
2700 Sec.bInheritHandle = FALSE;
\r
2702 if((iFileHandle = CreateFile(Pkt->LocalFile, GENERIC_READ,
\r
2703 FILE_SHARE_READ|FILE_SHARE_WRITE, &Sec, OPEN_EXISTING, 0, NULL)) != INVALID_HANDLE_VALUE)
\r
2706 char Buf3[(BUFSIZE + 3) * 4];
\r
2707 CODECONVINFO cInfo2;
\r
2708 int ProcessedBOM = NO;
\r
2709 if(Pkt->hWndTrans != NULL)
\r
2711 Low = GetFileSize(iFileHandle, &High);
\r
2712 Pkt->Size = MakeLongLong(High, Low);
\r
2714 High = (DWORD)HIGH32(Pkt->ExistSize);
\r
2715 Low = (DWORD)LOW32(Pkt->ExistSize);
\r
2716 SetFilePointer(iFileHandle, Low, &High, FILE_BEGIN);
\r
2719 // AllTransSizeNow = 0;
\r
2720 // TimeStart = time(NULL);
\r
2721 AllTransSizeNow[Pkt->ThreadCount] = 0;
\r
2722 TimeStart[Pkt->ThreadCount] = time(NULL);
\r
2723 SetTimer(Pkt->hWndTrans, TIMER_DISPLAY, DISPLAY_TIMING, NULL);
\r
2726 InitCodeConvInfo(&cInfo);
\r
2727 cInfo.KanaCnv = Pkt->KanaCnv;
\r
2728 InitTermCodeConvInfo(&tInfo);
\r
2730 InitCodeConvInfo(&cInfo2);
\r
2731 cInfo2.KanaCnv = Pkt->KanaCnv;
\r
2733 /*===== ファイルを送信するループ =====*/
\r
2734 while((Pkt->Abort == ABORT_NONE) &&
\r
2735 (ForceAbort == NO) &&
\r
2736 (ReadFile(iFileHandle, Buf, BUFSIZE, &iNumBytes, NULL) == TRUE))
\r
2738 if(iNumBytes == 0)
\r
2743 if((RmEOF == YES) && (Pkt->Type == TYPE_A))
\r
2745 if((EofPos = memchr(Buf, 0x1A, iNumBytes)) != NULL)
\r
2746 iNumBytes = EofPos - Buf;
\r
2750 if(Pkt->KanjiCode != KANJI_NOCNV)
\r
2753 cInfo.StrLen = iNumBytes;
\r
2755 cInfo.BufSize = BUFSIZE+3;
\r
2758 // ここで全てUTF-8へ変換する
\r
2759 // TODO: SJIS以外も直接UTF-8へ変換
\r
2760 // if(Pkt->KanjiCode == KANJI_JIS)
\r
2761 // Continue = ConvSJIStoJIS(&cInfo);
\r
2763 // Continue = ConvSJIStoEUC(&cInfo);
\r
2764 switch(Pkt->KanjiCodeDesired)
\r
2767 switch(Pkt->KanjiCode)
\r
2770 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
2771 // cInfo2.OutLen = cInfo.StrLen;
\r
2774 Continue = ConvSJIStoJIS(&cInfo);
\r
2775 cInfo2.Str = cInfo.Buf;
\r
2776 cInfo2.StrLen = cInfo.OutLen;
\r
2777 cInfo2.Buf = Buf3;
\r
2778 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2779 ConvJIStoSJIS(&cInfo2);
\r
2782 Continue = ConvSJIStoJIS(&cInfo);
\r
2783 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2784 cInfo2.OutLen = cInfo.OutLen;
\r
2787 Continue = ConvSJIStoEUC(&cInfo);
\r
2788 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2789 cInfo2.OutLen = cInfo.OutLen;
\r
2792 Continue = ConvSJIStoUTF8N(&cInfo);
\r
2793 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2794 cInfo2.OutLen = cInfo.OutLen;
\r
2796 case KANJI_UTF8BOM:
\r
2797 if(ProcessedBOM == NO)
\r
2799 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
2800 cInfo2.OutLen = 3;
\r
2802 ProcessedBOM = YES;
\r
2805 Continue = ConvSJIStoUTF8N(&cInfo);
\r
2806 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2807 cInfo2.OutLen = cInfo.OutLen;
\r
2812 switch(Pkt->KanjiCode)
\r
2815 Continue = ConvJIStoSJIS(&cInfo);
\r
2816 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2817 cInfo2.OutLen = cInfo.OutLen;
\r
2820 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
2821 // cInfo2.OutLen = cInfo.StrLen;
\r
2824 Continue = ConvJIStoSJIS(&cInfo);
\r
2825 cInfo2.Str = cInfo.Buf;
\r
2826 cInfo2.StrLen = cInfo.OutLen;
\r
2827 cInfo2.Buf = Buf3;
\r
2828 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2829 ConvSJIStoJIS(&cInfo2);
\r
2832 Continue = ConvJIStoSJIS(&cInfo);
\r
2833 cInfo2.Str = cInfo.Buf;
\r
2834 cInfo2.StrLen = cInfo.OutLen;
\r
2835 cInfo2.Buf = Buf3;
\r
2836 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2837 ConvSJIStoEUC(&cInfo2);
\r
2840 Continue = ConvJIStoSJIS(&cInfo);
\r
2841 cInfo2.Str = cInfo.Buf;
\r
2842 cInfo2.StrLen = cInfo.OutLen;
\r
2843 cInfo2.Buf = Buf3;
\r
2844 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2845 ConvSJIStoUTF8N(&cInfo2);
\r
2847 case KANJI_UTF8BOM:
\r
2848 if(ProcessedBOM == NO)
\r
2850 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
2851 cInfo2.OutLen = 3;
\r
2853 ProcessedBOM = YES;
\r
2856 Continue = ConvJIStoSJIS(&cInfo);
\r
2857 cInfo2.Str = cInfo.Buf;
\r
2858 cInfo2.StrLen = cInfo.OutLen;
\r
2859 cInfo2.Buf = Buf3;
\r
2860 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2861 ConvSJIStoUTF8N(&cInfo2);
\r
2866 switch(Pkt->KanjiCode)
\r
2869 Continue = ConvEUCtoSJIS(&cInfo);
\r
2870 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2871 cInfo2.OutLen = cInfo.OutLen;
\r
2874 Continue = ConvEUCtoSJIS(&cInfo);
\r
2875 cInfo2.Str = cInfo.Buf;
\r
2876 cInfo2.StrLen = cInfo.OutLen;
\r
2877 cInfo2.Buf = Buf3;
\r
2878 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2879 ConvSJIStoJIS(&cInfo2);
\r
2882 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
2883 // cInfo2.OutLen = cInfo.StrLen;
\r
2886 Continue = ConvEUCtoSJIS(&cInfo);
\r
2887 cInfo2.Str = cInfo.Buf;
\r
2888 cInfo2.StrLen = cInfo.OutLen;
\r
2889 cInfo2.Buf = Buf3;
\r
2890 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2891 ConvSJIStoEUC(&cInfo2);
\r
2894 Continue = ConvEUCtoSJIS(&cInfo);
\r
2895 cInfo2.Str = cInfo.Buf;
\r
2896 cInfo2.StrLen = cInfo.OutLen;
\r
2897 cInfo2.Buf = Buf3;
\r
2898 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2899 ConvSJIStoUTF8N(&cInfo2);
\r
2901 case KANJI_UTF8BOM:
\r
2902 if(ProcessedBOM == NO)
\r
2904 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
2905 cInfo2.OutLen = 3;
\r
2907 ProcessedBOM = YES;
\r
2910 Continue = ConvEUCtoSJIS(&cInfo);
\r
2911 cInfo2.Str = cInfo.Buf;
\r
2912 cInfo2.StrLen = cInfo.OutLen;
\r
2913 cInfo2.Buf = Buf3;
\r
2914 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2915 ConvSJIStoUTF8N(&cInfo2);
\r
2920 switch(Pkt->KanjiCode)
\r
2923 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
2924 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2925 cInfo2.OutLen = cInfo.OutLen;
\r
2928 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
2929 cInfo2.Str = cInfo.Buf;
\r
2930 cInfo2.StrLen = cInfo.OutLen;
\r
2931 cInfo2.Buf = Buf3;
\r
2932 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2933 ConvSJIStoJIS(&cInfo2);
\r
2936 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
2937 cInfo2.Str = cInfo.Buf;
\r
2938 cInfo2.StrLen = cInfo.OutLen;
\r
2939 cInfo2.Buf = Buf3;
\r
2940 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2941 ConvSJIStoEUC(&cInfo2);
\r
2944 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
2945 cInfo2.OutLen = cInfo.StrLen;
\r
2948 case KANJI_UTF8BOM:
\r
2949 if(ProcessedBOM == NO)
\r
2951 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
2952 cInfo2.OutLen = 3;
\r
2954 ProcessedBOM = YES;
\r
2957 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
2958 cInfo2.OutLen = cInfo.StrLen;
\r
2963 case KANJI_UTF8BOM:
\r
2964 if(ProcessedBOM == NO)
\r
2966 if(memcmp(Buf, "\xEF\xBB\xBF", 3) == 0)
\r
2969 cInfo.StrLen -= 3;
\r
2971 cInfo2.OutLen = 0;
\r
2972 switch(Pkt->KanjiCode)
\r
2974 case KANJI_UTF8BOM:
\r
2975 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
2976 cInfo2.OutLen = 3;
\r
2980 ProcessedBOM = YES;
\r
2983 switch(Pkt->KanjiCode)
\r
2986 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
2987 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2988 cInfo2.OutLen = cInfo.OutLen;
\r
2991 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
2992 cInfo2.Str = cInfo.Buf;
\r
2993 cInfo2.StrLen = cInfo.OutLen;
\r
2994 cInfo2.Buf = Buf3;
\r
2995 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2996 ConvSJIStoJIS(&cInfo2);
\r
2999 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
3000 cInfo2.Str = cInfo.Buf;
\r
3001 cInfo2.StrLen = cInfo.OutLen;
\r
3002 cInfo2.Buf = Buf3;
\r
3003 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3004 ConvSJIStoEUC(&cInfo2);
\r
3007 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
3008 cInfo2.OutLen = cInfo.StrLen;
\r
3011 case KANJI_UTF8BOM:
\r
3012 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
3013 cInfo2.OutLen = cInfo.StrLen;
\r
3020 // if(TermCodeConvAndSend(&tInfo, dSkt, Buf2, cInfo.OutLen, Pkt->Type) == FFFTP_FAIL)
\r
3021 if(TermCodeConvAndSend(&tInfo, dSkt, Buf3, cInfo2.OutLen, Pkt->Type, &Canceled[Pkt->ThreadCount]) == FFFTP_FAIL)
\r
3023 Pkt->Abort = ABORT_ERROR;
\r
3027 while(Continue == YES);
\r
3032 // if(TermCodeConvAndSend(&tInfo, dSkt, Buf, iNumBytes, Pkt->Type) == FFFTP_FAIL)
\r
3033 if(TermCodeConvAndSend(&tInfo, dSkt, Buf, iNumBytes, Pkt->Type, &Canceled[Pkt->ThreadCount]) == FFFTP_FAIL)
\r
3034 Pkt->Abort = ABORT_ERROR;
\r
3037 Pkt->ExistSize += iNumBytes;
\r
3038 if(Pkt->hWndTrans != NULL)
\r
3040 // AllTransSizeNow += iNumBytes;
\r
3041 AllTransSizeNow[Pkt->ThreadCount] += iNumBytes;
\r
3043 if(BackgrndMessageProc() == YES)
\r
3046 if(EofPos != NULL)
\r
3050 if((ForceAbort == NO) && (Pkt->Abort == ABORT_NONE))
\r
3053 if(Pkt->KanjiCode != KANJI_NOCNV)
\r
3056 cInfo.BufSize = BUFSIZE+3;
\r
3057 FlushRestData(&cInfo);
\r
3058 switch(Pkt->KanjiCodeDesired)
\r
3061 switch(Pkt->KanjiCode)
\r
3065 cInfo2.Str = cInfo.Buf;
\r
3066 cInfo2.StrLen = cInfo.OutLen;
\r
3067 cInfo2.Buf = Buf3;
\r
3068 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3069 ConvJIStoSJIS(&cInfo2);
\r
3072 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3073 cInfo2.OutLen = cInfo.OutLen;
\r
3076 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3077 cInfo2.OutLen = cInfo.OutLen;
\r
3080 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3081 cInfo2.OutLen = cInfo.OutLen;
\r
3083 case KANJI_UTF8BOM:
\r
3084 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3085 cInfo2.OutLen = cInfo.OutLen;
\r
3090 switch(Pkt->KanjiCode)
\r
3093 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3094 cInfo2.OutLen = cInfo.OutLen;
\r
3098 cInfo2.Str = cInfo.Buf;
\r
3099 cInfo2.StrLen = cInfo.OutLen;
\r
3100 cInfo2.Buf = Buf3;
\r
3101 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3102 ConvSJIStoJIS(&cInfo2);
\r
3105 cInfo2.Str = cInfo.Buf;
\r
3106 cInfo2.StrLen = cInfo.OutLen;
\r
3107 cInfo2.Buf = Buf3;
\r
3108 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3109 ConvSJIStoEUC(&cInfo2);
\r
3112 cInfo2.Str = cInfo.Buf;
\r
3113 cInfo2.StrLen = cInfo.OutLen;
\r
3114 cInfo2.Buf = Buf3;
\r
3115 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3116 ConvSJIStoUTF8N(&cInfo2);
\r
3118 case KANJI_UTF8BOM:
\r
3119 cInfo2.Str = cInfo.Buf;
\r
3120 cInfo2.StrLen = cInfo.OutLen;
\r
3121 cInfo2.Buf = Buf3;
\r
3122 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3123 ConvSJIStoUTF8N(&cInfo2);
\r
3128 switch(Pkt->KanjiCode)
\r
3131 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3132 cInfo2.OutLen = cInfo.OutLen;
\r
3135 cInfo2.Str = cInfo.Buf;
\r
3136 cInfo2.StrLen = cInfo.OutLen;
\r
3137 cInfo2.Buf = Buf3;
\r
3138 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3139 ConvSJIStoJIS(&cInfo2);
\r
3143 cInfo2.Str = cInfo.Buf;
\r
3144 cInfo2.StrLen = cInfo.OutLen;
\r
3145 cInfo2.Buf = Buf3;
\r
3146 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3147 ConvSJIStoEUC(&cInfo2);
\r
3150 cInfo2.Str = cInfo.Buf;
\r
3151 cInfo2.StrLen = cInfo.OutLen;
\r
3152 cInfo2.Buf = Buf3;
\r
3153 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3154 ConvSJIStoUTF8N(&cInfo2);
\r
3156 case KANJI_UTF8BOM:
\r
3157 cInfo2.Str = cInfo.Buf;
\r
3158 cInfo2.StrLen = cInfo.OutLen;
\r
3159 cInfo2.Buf = Buf3;
\r
3160 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3161 ConvSJIStoUTF8N(&cInfo2);
\r
3166 switch(Pkt->KanjiCode)
\r
3169 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3170 cInfo2.OutLen = cInfo.OutLen;
\r
3173 cInfo2.Str = cInfo.Buf;
\r
3174 cInfo2.StrLen = cInfo.OutLen;
\r
3175 cInfo2.Buf = Buf3;
\r
3176 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3177 ConvSJIStoJIS(&cInfo2);
\r
3180 cInfo2.Str = cInfo.Buf;
\r
3181 cInfo2.StrLen = cInfo.OutLen;
\r
3182 cInfo2.Buf = Buf3;
\r
3183 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3184 ConvSJIStoEUC(&cInfo2);
\r
3187 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3188 cInfo2.OutLen = cInfo.OutLen;
\r
3190 case KANJI_UTF8BOM:
\r
3191 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3192 cInfo2.OutLen = cInfo.OutLen;
\r
3196 case KANJI_UTF8BOM:
\r
3197 switch(Pkt->KanjiCode)
\r
3200 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3201 cInfo2.OutLen = cInfo.OutLen;
\r
3204 cInfo2.Str = cInfo.Buf;
\r
3205 cInfo2.StrLen = cInfo.OutLen;
\r
3206 cInfo2.Buf = Buf3;
\r
3207 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3208 ConvSJIStoJIS(&cInfo2);
\r
3211 cInfo2.Str = cInfo.Buf;
\r
3212 cInfo2.StrLen = cInfo.OutLen;
\r
3213 cInfo2.Buf = Buf3;
\r
3214 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3215 ConvSJIStoEUC(&cInfo2);
\r
3218 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3219 cInfo2.OutLen = cInfo.OutLen;
\r
3221 case KANJI_UTF8BOM:
\r
3222 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3223 cInfo2.OutLen = cInfo.OutLen;
\r
3229 // if(TermCodeConvAndSend(&tInfo, dSkt, Buf2, cInfo.OutLen, Pkt->Type) == FFFTP_FAIL)
\r
3230 if(TermCodeConvAndSend(&tInfo, dSkt, Buf3, cInfo2.OutLen, Pkt->Type, &Canceled[Pkt->ThreadCount]) == FFFTP_FAIL)
\r
3231 Pkt->Abort = ABORT_ERROR;
\r
3232 cInfo2.Buf = Buf3;
\r
3233 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3234 FlushRestData(&cInfo2);
\r
3235 if(TermCodeConvAndSend(&tInfo, dSkt, Buf3, cInfo2.OutLen, Pkt->Type, &Canceled[Pkt->ThreadCount]) == FFFTP_FAIL)
\r
3236 Pkt->Abort = ABORT_ERROR;
\r
3240 tInfo.BufSize = BUFSIZE+3;
\r
3241 FlushRestTermCodeConvData(&tInfo);
\r
3243 // if(SendData(dSkt, Buf2, tInfo.OutLen, 0, &Canceled) == FFFTP_FAIL)
\r
3244 if(SendData(dSkt, Buf2, tInfo.OutLen, 0, &Canceled[Pkt->ThreadCount]) == FFFTP_FAIL)
\r
3245 Pkt->Abort = ABORT_ERROR;
\r
3249 if(Pkt->hWndTrans != NULL)
\r
3251 KillTimer(Pkt->hWndTrans, TIMER_DISPLAY);
\r
3252 DispTransferStatus(Pkt->hWndTrans, YES, Pkt);
\r
3254 // TimeStart = time(NULL) - TimeStart + 1;
\r
3255 TimeStart[Pkt->ThreadCount] = time(NULL) - TimeStart[Pkt->ThreadCount] + 1;
\r
3257 CloseHandle(iFileHandle);
\r
3261 SetErrorMsg(MSGJPN112, Pkt->LocalFile);
\r
3262 SetTaskMsg(MSGJPN112, Pkt->LocalFile);
\r
3263 Pkt->Abort = ABORT_ERROR;
\r
3266 if(shutdown(dSkt, 1) != 0)
\r
3267 ReportWSError("shutdown", WSAGetLastError());
\r
3271 while(do_recv(dSkt, Buf, BUFSIZE, 0, &TimeOutErr, &Canceled) > 0)
\r
3276 // iRetCode = ReadReplyMessage(Pkt->ctrl_skt, Buf, 1024, &Canceled, TmpBuf);
\r
3277 iRetCode = ReadReplyMessage(Pkt->ctrl_skt, Buf, 1024, &Canceled[Pkt->ThreadCount], TmpBuf);
\r
3280 //DoPrintf("##UP REPLY : %s", Buf);
\r
3282 if(iRetCode >= FTP_RETRY)
\r
3285 if(Pkt->Abort != ABORT_NONE)
\r
3292 /*----- バッファの内容を改行コード変換して送信 --------------------------------
\r
3295 * TERMCODECONVINFO *tInfo : 改行コード変換パケット
\r
3296 * SOCKET Skt : ソケット
\r
3297 * char *Data : データ
\r
3298 * int Size : データのサイズ
\r
3299 * int Ascii : モード (TYPE_xx)
\r
3303 *----------------------------------------------------------------------------*/
\r
3306 //static int TermCodeConvAndSend(TERMCODECONVINFO *tInfo, SOCKET Skt, char *Data, int Size, int Ascii)
\r
3307 static int TermCodeConvAndSend(TERMCODECONVINFO *tInfo, SOCKET Skt, char *Data, int Size, int Ascii, int *CancelCheckWork)
\r
3309 char Buf3[BUFSIZE*2];
\r
3313 Ret = FFFTP_SUCCESS;
\r
3315 // CR-LF以外の改行コードを変換しないモードはここへ追加
\r
3316 if(Ascii == TYPE_A)
\r
3318 tInfo->Str = Data;
\r
3319 tInfo->StrLen = Size;
\r
3320 tInfo->Buf = Buf3;
\r
3321 tInfo->BufSize = BUFSIZE*2;
\r
3324 Continue = ConvTermCodeToCRLF(tInfo);
\r
3326 // if((Ret = SendData(Skt, Buf3, tInfo->OutLen, 0, &Canceled)) == FFFTP_FAIL)
\r
3327 if((Ret = SendData(Skt, Buf3, tInfo->OutLen, 0, CancelCheckWork)) == FFFTP_FAIL)
\r
3330 while(Continue == YES);
\r
3334 // Ret = SendData(Skt, Data, Size, 0, &Canceled);
\r
3335 Ret = SendData(Skt, Data, Size, 0, CancelCheckWork);
\r
3341 /*----- アップロード終了/中止時のメッセージを表示 ----------------------------
\r
3344 * TRANSPACKET *Pkt : 転送ファイル情報
\r
3345 * int iRetCode : 応答コード
\r
3349 *----------------------------------------------------------------------------*/
\r
3351 static void DispUploadFinishMsg(TRANSPACKET *Pkt, int iRetCode)
\r
3353 if(ForceAbort == NO)
\r
3355 if((iRetCode/100) >= FTP_CONTINUE)
\r
3358 // if((Pkt->hWndTrans != NULL) && (TimeStart != 0))
\r
3359 // SetTaskMsg(MSGJPN113, TimeStart, Pkt->ExistSize/TimeStart);
\r
3360 if((Pkt->hWndTrans != NULL) && (TimeStart[Pkt->ThreadCount] != 0))
\r
3361 SetTaskMsg(MSGJPN113, TimeStart[Pkt->ThreadCount], Pkt->ExistSize/TimeStart[Pkt->ThreadCount]);
\r
3363 SetTaskMsg(MSGJPN114);
\r
3365 if(Pkt->Abort != ABORT_USER)
\r
3367 // 全て中止を選択後にダイアログが表示されるバグ対策
\r
3368 // if(DispUpDownErrDialog(uperr_dlg, Pkt->hWndTrans, Pkt->LocalFile) == NO)
\r
3369 if(Canceled[Pkt->ThreadCount] == NO && ClearAll == NO && DispUpDownErrDialog(uperr_dlg, Pkt->hWndTrans, Pkt->LocalFile) == NO)
\r
3376 // if((Pkt->hWndTrans != NULL) && (TimeStart != 0))
\r
3377 // SetTaskMsg(MSGJPN115, TimeStart, Pkt->ExistSize/TimeStart);
\r
3378 if((Pkt->hWndTrans != NULL) && (TimeStart[Pkt->ThreadCount] != 0))
\r
3379 // "0 B/S"と表示されるバグを修正
\r
3380 // 原因は%dにあたる部分に64ビット値が渡されているため
\r
3381 // SetTaskMsg(MSGJPN115, TimeStart[Pkt->ThreadCount], Pkt->ExistSize/TimeStart[Pkt->ThreadCount]);
\r
3382 SetTaskMsg(MSGJPN115, (LONG)TimeStart[Pkt->ThreadCount], (LONG)(Pkt->ExistSize/TimeStart[Pkt->ThreadCount]));
\r
3384 SetTaskMsg(MSGJPN116);
\r
3391 /*----- アップロードのリジュームの準備を行う ----------------------------------
\r
3394 * TRANSPACKET *Pkt : 転送ファイル情報
\r
3395 * iont ProcMode : 処理モード(EXIST_xxx)
\r
3396 * LONGLONG Size : ホストにあるファイルのサイズ
\r
3397 * int *Mode : リジュームを行うかどうか (YES/NO)
\r
3403 * Pkt->ExistSizeのセットを行なう
\r
3404 *----------------------------------------------------------------------------*/
\r
3406 static int SetUploadResume(TRANSPACKET *Pkt, int ProcMode, LONGLONG Size, int *Mode)
\r
3408 Pkt->ExistSize = 0;
\r
3410 if(ProcMode == EXIST_RESUME)
\r
3412 if(Pkt->hWndTrans != NULL)
\r
3414 Pkt->ExistSize = Size;
\r
3422 /*----- 転送中ダイアログボックスのコールバック --------------------------------
\r
3425 * HWND hDlg : ウインドウハンドル
\r
3426 * UINT message : メッセージ番号
\r
3427 * WPARAM wParam : メッセージの WPARAM 引数
\r
3428 * LPARAM lParam : メッセージの LPARAM 引数
\r
3432 *----------------------------------------------------------------------------*/
\r
3434 static LRESULT CALLBACK TransDlgProc(HWND hDlg, UINT Msg, WPARAM wParam, LPARAM lParam)
\r
3440 // static TRANSPACKET *Pkt;
\r
3446 case WM_INITDIALOG :
\r
3447 GetWindowRect(hDlg, &RectDlg);
\r
3448 RectDlg.right -= RectDlg.left;
\r
3449 RectDlg.bottom -= RectDlg.top;
\r
3450 GetWindowRect(GetMainHwnd(), &RectPar);
\r
3452 ((RectPar.right + RectPar.left) / 2) - (RectDlg.right / 2),
\r
3453 ((RectPar.bottom + RectPar.top) / 2) - (RectDlg.bottom / 2),
\r
3458 hMenu = GetSystemMenu(hDlg, FALSE);
\r
3459 EnableMenuItem(hMenu, SC_CLOSE, MF_GRAYED);
\r
3463 switch(LOWORD(wParam))
\r
3465 case TRANS_STOP_NEXT :
\r
3469 case TRANS_STOP_ALL :
\r
3471 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
3472 Canceled[i] = YES;
\r
3473 /* ここに break はない */
\r
3476 if(!(Pkt = (TRANSPACKET*)GetWindowLong(hDlg, GWL_USERDATA)))
\r
3478 Pkt->Abort = ABORT_USER;
\r
3479 // Canceled = YES;
\r
3480 Canceled[Pkt->ThreadCount] = YES;
\r
3486 if(wParam == TIMER_DISPLAY)
\r
3488 if(MoveToForeground == YES)
\r
3489 SetForegroundWindow(hDlg);
\r
3490 MoveToForeground = NO;
\r
3491 KillTimer(hDlg, TIMER_DISPLAY);
\r
3492 if(!(Pkt = (TRANSPACKET*)GetWindowLong(hDlg, GWL_USERDATA)))
\r
3494 if(Canceled[Pkt->ThreadCount] == YES)
\r
3495 Pkt->Abort = ABORT_USER;
\r
3496 DispTransferStatus(hDlg, NO, Pkt);
\r
3497 SetTimer(hDlg, TIMER_DISPLAY, DISPLAY_TIMING, NULL);
\r
3501 case WM_SET_PACKET :
\r
3502 // Pkt = (TRANSPACKET *)lParam;
\r
3503 SetWindowLong(hDlg, GWL_USERDATA, (LONG)lParam);
\r
3510 /*----- 転送ステータスを表示 --------------------------------------------------
\r
3513 * HWND hWnd : ウインドウハンドル
\r
3514 * int End : 転送が完了したかどうか (YES/NO)
\r
3518 *----------------------------------------------------------------------------*/
\r
3520 static void DispTransferStatus(HWND hWnd, int End, TRANSPACKET *Pkt)
\r
3534 SendMessage(hWnd, WM_GETTEXT, 79, (LPARAM)Str);
\r
3535 if((Pos = strchr(Str, ')')) != NULL)
\r
3539 sprintf(Tmp, "(%d)%s", AskTransferFileNum(), Pos);
\r
3540 SendMessage(hWnd, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
3542 if(Pkt->Abort == ABORT_NONE)
\r
3547 // TotalLap = time(NULL) - TimeStart + 1;
\r
3548 TotalLap = time(NULL) - TimeStart[Pkt->ThreadCount] + 1;
\r
3553 // Bps = AllTransSizeNow / TotalLap;
\r
3554 Bps = AllTransSizeNow[Pkt->ThreadCount] / TotalLap;
\r
3555 Transed = Pkt->Size - Pkt->ExistSize;
\r
3557 if(Pkt->Size <= 0)
\r
3558 sprintf(Tmp, "%d ", Pkt->ExistSize);
\r
3559 else if(Pkt->Size < 1024)
\r
3560 sprintf(Tmp, "%s / %s ", MakeNumString(Pkt->ExistSize, Num1, TRUE), MakeNumString(Pkt->Size, Num2, TRUE));
\r
3562 sprintf(Tmp, "%sk / %sk ", MakeNumString(Pkt->ExistSize/1024, Num1, TRUE), MakeNumString(Pkt->Size/1024, Num2, TRUE));
\r
3566 sprintf(Tmp, "( 0 B/S )");
\r
3567 else if(Bps < 1000)
\r
3568 sprintf(Tmp, "( %s B/S )", MakeNumString(Bps, Num1, TRUE));
\r
3570 sprintf(Tmp, "( %s.%02d KB/S )", MakeNumString(Bps/1000, Num1, TRUE), (int)((Bps%1000)/10));
\r
3573 if((Bps > 0) && (Pkt->Size > 0) && (Transed >= 0))
\r
3575 sprintf(Tmp, " %d:%02d", (int)((Transed/Bps)/60), (int)((Transed/Bps)%60));
\r
3579 strcat(Str, " ??:??");
\r
3582 strcpy(Str, MSGJPN117);
\r
3585 strcpy(Str, MSGJPN118);
\r
3587 SendDlgItemMessage(hWnd, TRANS_STATUS, WM_SETTEXT, 0, (LPARAM)Str);
\r
3589 if(Pkt->Size <= 0)
\r
3591 else if(Pkt->Size < 1024*1024)
\r
3592 Per = (int)(Pkt->ExistSize * 100 / Pkt->Size);
\r
3594 Per = (int)((Pkt->ExistSize/1024) * 100 / (Pkt->Size/1024));
\r
3595 SendDlgItemMessage(hWnd, TRANS_TIME_BAR, PBM_SETPOS, Per, 0);
\r
3601 /*----- 転送するファイルの情報を表示 ------------------------------------------
\r
3604 * TRANSPACKET *Pkt : 転送ファイル情報
\r
3605 * char *Title : ウインドウのタイトル
\r
3606 * int SkipButton : 「このファイルを中止」ボタンの有無 (TRUE/FALSE)
\r
3607 * int Info : ファイル情報を表示するかどうか (YES/NO)
\r
3611 *----------------------------------------------------------------------------*/
\r
3613 static void DispTransFileInfo(TRANSPACKET *Pkt, char *Title, int SkipButton, int Info)
\r
3617 if(Pkt->hWndTrans != NULL)
\r
3619 EnableWindow(GetDlgItem(Pkt->hWndTrans, IDCANCEL), SkipButton);
\r
3621 sprintf(Tmp, "(%d)%s", AskTransferFileNum(), Title);
\r
3622 SendMessage(Pkt->hWndTrans, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
3623 SendDlgItemMessage(Pkt->hWndTrans, TRANS_STATUS, WM_SETTEXT, 0, (LPARAM)"");
\r
3625 SendDlgItemMessage(Pkt->hWndTrans, TRANS_TIME_BAR, PBM_SETRANGE, 0, MAKELPARAM(0, 100));
\r
3626 SendDlgItemMessage(Pkt->hWndTrans, TRANS_TIME_BAR, PBM_SETSTEP, 1, 0);
\r
3627 SendDlgItemMessage(Pkt->hWndTrans, TRANS_TIME_BAR, PBM_SETPOS, 0, 0);
\r
3631 DispStaticText(GetDlgItem(Pkt->hWndTrans, TRANS_REMOTE), Pkt->RemoteFile);
\r
3632 DispStaticText(GetDlgItem(Pkt->hWndTrans, TRANS_LOCAL), Pkt->LocalFile);
\r
3634 if(Pkt->Type == TYPE_I)
\r
3635 SendDlgItemMessage(Pkt->hWndTrans, TRANS_MODE, WM_SETTEXT, 0, (LPARAM)MSGJPN119);
\r
3636 else if(Pkt->Type == TYPE_A)
\r
3637 SendDlgItemMessage(Pkt->hWndTrans, TRANS_MODE, WM_SETTEXT, 0, (LPARAM)MSGJPN120);
\r
3640 if(Pkt->KanjiCode == KANJI_NOCNV)
\r
3641 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN121);
\r
3642 else if(Pkt->KanjiCode == KANJI_SJIS)
\r
3643 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN305);
\r
3644 else if(Pkt->KanjiCode == KANJI_JIS)
\r
3645 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN122);
\r
3646 else if(Pkt->KanjiCode == KANJI_EUC)
\r
3647 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN123);
\r
3648 else if(Pkt->KanjiCode == KANJI_UTF8N)
\r
3649 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN306);
\r
3650 else if(Pkt->KanjiCode == KANJI_UTF8BOM)
\r
3651 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN329);
\r
3655 SendDlgItemMessage(Pkt->hWndTrans, TRANS_REMOTE, WM_SETTEXT, 0, (LPARAM)"");
\r
3656 SendDlgItemMessage(Pkt->hWndTrans, TRANS_LOCAL, WM_SETTEXT, 0, (LPARAM)"");
\r
3657 SendDlgItemMessage(Pkt->hWndTrans, TRANS_MODE, WM_SETTEXT, 0, (LPARAM)"");
\r
3658 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)"");
\r
3665 /*----- PASVコマンドの戻り値からアドレスとポート番号を抽出 --------------------
\r
3668 * char *Str : PASVコマンドのリプライ
\r
3669 * char *Adrs : アドレスのコピー先 ("www.xxx.yyy.zzz")
\r
3670 * int *Port : ポート番号をセットするワーク
\r
3671 * int Max : アドレス文字列の最大長
\r
3675 * FFFTP_SUCCESS/FFFTP_FAIL
\r
3676 *----------------------------------------------------------------------------*/
\r
3678 static int GetAdrsAndPort(char *Str, char *Adrs, int *Port, int Max)
\r
3686 Pos = strchr(Str, '(');
\r
3690 Btm = strchr(Pos, ',');
\r
3691 // コンマではなくドットを返すホストがあるため
\r
3693 Btm = strchr(Pos, '.');
\r
3697 Btm = strchr(Btm, ',');
\r
3698 // コンマではなくドットを返すホストがあるため
\r
3700 Btm = strchr(Btm, '.');
\r
3704 Btm = strchr(Btm, ',');
\r
3705 // コンマではなくドットを返すホストがあるため
\r
3707 Btm = strchr(Btm, '.');
\r
3711 Btm = strchr(Btm, ',');
\r
3712 // コンマではなくドットを返すホストがあるため
\r
3714 Btm = strchr(Btm, '.');
\r
3717 if((Btm - Pos) <= Max)
\r
3719 strncpy(Adrs, Pos, Btm - Pos);
\r
3720 *(Adrs + (Btm - Pos)) = NUL;
\r
3721 ReplaceAll(Adrs, ',', '.');
\r
3724 Btm = strchr(Pos, ',');
\r
3725 // コンマではなくドットを返すホストがあるため
\r
3727 Btm = strchr(Pos, '.');
\r
3731 *Port = (atoi(Pos) * 0x100) + atoi(Btm);
\r
3732 Sts = FFFTP_SUCCESS;
\r
3745 static int GetAdrsAndPortIPv6(char *Str, char *Adrs, int *Port, int Max, short *Family)
\r
3753 Pos = strchr(Str, '|');
\r
3757 Btm = strchr(Pos, '|');
\r
3763 *Family = AF_INET;
\r
3766 *Family = AF_INET6;
\r
3770 Btm = strchr(Pos, '|');
\r
3773 if((Btm - Pos) <= Max)
\r
3775 if((Btm - Pos) > 0)
\r
3777 strncpy(Adrs, Pos, Btm - Pos);
\r
3778 *(Adrs + (Btm - Pos)) = NUL;
\r
3782 Btm = strchr(Pos, '|');
\r
3786 *Port = atoi(Pos);
\r
3787 Sts = FFFTP_SUCCESS;
\r
3797 /*----- Windowsのスペシャルデバイスかどうかを返す -----------------------------
\r
3800 * char *Fname : ファイル名
\r
3803 * int ステータス (YES/NO)
\r
3804 *----------------------------------------------------------------------------*/
\r
3806 static int IsSpecialDevice(char *Fname)
\r
3812 // if((_stricmp(Fname, "CON") == 0) ||
\r
3813 // (_stricmp(Fname, "PRN") == 0) ||
\r
3814 // (_stricmp(Fname, "AUX") == 0) ||
\r
3815 // (_strnicmp(Fname, "CON.", 4) == 0) ||
\r
3816 // (_strnicmp(Fname, "PRN.", 4) == 0) ||
\r
3817 // (_strnicmp(Fname, "AUX.", 4) == 0))
\r
3821 if(_strnicmp(Fname, "AUX", 3) == 0|| _strnicmp(Fname, "CON", 3) == 0 || _strnicmp(Fname, "NUL", 3) == 0 || _strnicmp(Fname, "PRN", 3) == 0)
\r
3823 if(*(Fname + 3) == '\0' || *(Fname + 3) == '.')
\r
3826 else if(_strnicmp(Fname, "COM", 3) == 0 || _strnicmp(Fname, "LPT", 3) == 0)
\r
3828 if(isdigit(*(Fname + 3)) != 0)
\r
3830 if(*(Fname + 4) == '\0' || *(Fname + 4) == '.')
\r
3838 /*----- ミラーリングでのファイル削除確認 --------------------------------------
\r
3843 * TRANSPACKET *Pkt
\r
3847 *----------------------------------------------------------------------------*/
\r
3849 static int MirrorDelNotify(int Cur, int Notify, TRANSPACKET *Pkt)
\r
3851 MIRRORDELETEINFO DelInfo;
\r
3854 if(((Cur == WIN_LOCAL) && (MirDownDelNotify == NO)) ||
\r
3855 ((Cur == WIN_REMOTE) && (MirUpDelNotify == NO)))
\r
3860 if(Notify != YES_ALL)
\r
3862 DelInfo.Cur = Cur;
\r
3863 DelInfo.Pkt = Pkt;
\r
3864 hWnd = Pkt->hWndTrans;
\r
3866 hWnd = GetMainHwnd();
\r
3867 Notify = DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(delete_dlg), hWnd, MirrorDeleteDialogCallBack, (LPARAM)&DelInfo);
\r
3873 /*----- ミラーリングでのファイル削除ダイアログのコールバック ------------------
\r
3876 * HWND hDlg : ウインドウハンドル
\r
3877 * UINT message : メッセージ番号
\r
3878 * WPARAM wParam : メッセージの WPARAM 引数
\r
3879 * LPARAM lParam : メッセージの LPARAM 引数
\r
3883 *----------------------------------------------------------------------------*/
\r
3885 static BOOL CALLBACK MirrorDeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
3887 static MIRRORDELETEINFO *DelInfo;
\r
3890 case WM_INITDIALOG :
\r
3891 DelInfo = (MIRRORDELETEINFO *)lParam;
\r
3893 if(DelInfo->Cur == WIN_LOCAL)
\r
3895 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN124);
\r
3896 SendDlgItemMessage(hDlg, DELETE_TEXT, WM_SETTEXT, 0, (LPARAM)DelInfo->Pkt->LocalFile);
\r
3900 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN125);
\r
3901 SendDlgItemMessage(hDlg, DELETE_TEXT, WM_SETTEXT, 0, (LPARAM)DelInfo->Pkt->RemoteFile);
\r
3906 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
3909 EndDialog(hDlg, YES);
\r
3913 EndDialog(hDlg, NO);
\r
3917 EndDialog(hDlg, YES_ALL);
\r
3922 EndDialog(hDlg, NO_ALL);
\r
3934 static void SetErrorMsg(char *fmt, ...)
\r
3939 // if(strlen(ErrMsg) == 0)
\r
3940 if(strlen(GetErrMsg()) == 0)
\r
3942 va_start(Args, fmt);
\r
3944 // wvsprintf(ErrMsg, fmt, Args);
\r
3945 wvsprintf(GetErrMsg(), fmt, Args);
\r
3956 /*----- ダウンロード時の不正なパスをチェック ----------------------------------
\r
3959 * TRANSPACKET *packet : ダウンロード情報
\r
3962 * int YES=不正なパス/NO=問題ないパス
\r
3963 *----------------------------------------------------------------------------*/
\r
3964 int CheckPathViolation(TRANSPACKET *packet)
\r
3969 if((strncmp(packet->RemoteFile, "..\\", 3) == 0) ||
\r
3970 (strncmp(packet->RemoteFile, "../", 3) == 0) ||
\r
3971 (strstr(packet->RemoteFile, "\\..\\") != NULL) ||
\r
3972 (strstr(packet->RemoteFile, "/../") != NULL))
\r
3974 msg = malloc(strlen(MSGJPN297) + strlen(packet->RemoteFile) + 1);
\r
3977 sprintf(msg, MSGJPN297, packet->RemoteFile);
\r
3978 MessageBox(GetMainHwnd(), msg, MSGJPN086, MB_OK);
\r
3988 static char* GetErrMsg()
\r
3994 WaitForSingleObject(hErrMsgMutex, INFINITE);
\r
3995 ThreadId = GetCurrentThreadId();
\r
3997 while(i < MAX_DATA_CONNECTION + 1)
\r
3999 if(ErrMsgThreadId[i] == ThreadId)
\r
4009 while(i < MAX_DATA_CONNECTION + 1)
\r
4011 if(ErrMsgThreadId[i] == 0)
\r
4013 ErrMsgThreadId[i] = ThreadId;
\r
4020 ReleaseMutex(hErrMsgMutex);
\r