1 /*=============================================================================
\r
5 ===============================================================================
\r
6 / Copyright (C) 1997-2007 Sota. All rights reserved.
\r
8 / Redistribution and use in source and binary forms, with or without
\r
9 / modification, are permitted provided that the following conditions
\r
12 / 1. Redistributions of source code must retain the above copyright
\r
13 / notice, this list of conditions and the following disclaimer.
\r
14 / 2. Redistributions in binary form must reproduce the above copyright
\r
15 / notice, this list of conditions and the following disclaimer in the
\r
16 / documentation and/or other materials provided with the distribution.
\r
18 / THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
\r
19 / IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
\r
20 / OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
\r
21 / IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
\r
22 / INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
\r
23 / BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
\r
24 / USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
\r
25 / ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
\r
26 / (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
\r
27 / THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
\r
28 /============================================================================*/
\r
30 /* このソースは一部、WS_FTP Version 93.12.05 のソースを参考にしました。 */
\r
31 /* スレッドの作成/終了に関して、樋口殿作成のパッチを組み込みました。 */
\r
34 一部、高速化のためのコード追加 by H.Shirouzu at 2002/10/02
\r
42 #include <mbstring.h>
\r
45 //#include <winsock.h>
\r
46 #include <winsock2.h>
\r
47 #include <windowsx.h>
\r
48 #include <commctrl.h>
\r
49 #include <process.h>
\r
52 #include "resource.h"
\r
54 #define SET_BUFFER_SIZE
\r
56 /* Add by H.Shirouzu at 2002/10/02 */
\r
58 #define BUFSIZE (32 * 1024)
\r
59 #define SOCKBUF_SIZE (256 * 1024)
\r
62 #ifdef DISABLE_TRANSFER_NETWORK_BUFFERS
\r
64 #define BUFSIZE (64 * 1024) // RWIN値以下で充分な大きさが望ましいと思われる。
\r
65 #undef SET_BUFFER_SIZE
\r
68 #define TIMER_DISPLAY 1 /* 表示更新用タイマのID */
\r
69 #define DISPLAY_TIMING 500 /* 表示更新時間 0.5秒 */
\r
71 #define ERR_MSG_LEN 1024
\r
81 /*===== プロトタイプ =====*/
\r
83 static void DispTransPacket(TRANSPACKET *Pkt);
\r
84 static void EraseTransFileList(void);
\r
85 static ULONG WINAPI TransferThread(void *Dummy);
\r
86 static int MakeNonFullPath(TRANSPACKET *Pkt, char *CurDir, char *Tmp);
\r
87 static int DownloadNonPassive(TRANSPACKET *Pkt, int *CancelCheckWork);
\r
88 static int DownloadPassive(TRANSPACKET *Pkt, int *CancelCheckWork);
\r
89 static int DownloadFile(TRANSPACKET *Pkt, SOCKET dSkt, int CreateMode, int *CancelCheckWork);
\r
90 static void DispDownloadFinishMsg(TRANSPACKET *Pkt, int iRetCode);
\r
92 //static int DispUpDownErrDialog(int ResID, HWND hWnd, char *Fname);
\r
93 static int DispUpDownErrDialog(int ResID, HWND hWnd, TRANSPACKET *Pkt);
\r
95 //static BOOL CALLBACK UpDownErrorDialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam);
\r
96 static INT_PTR CALLBACK UpDownErrorDialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam);
\r
97 static int SetDownloadResume(TRANSPACKET *Pkt, int ProcMode, LONGLONG Size, int *Mode, int *CancelCheckWork);
\r
99 //static BOOL CALLBACK NoResumeWndProc(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
100 static INT_PTR CALLBACK NoResumeWndProc(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
101 static int DoUpload(SOCKET cSkt, TRANSPACKET *Pkt);
\r
102 static int UploadNonPassive(TRANSPACKET *Pkt);
\r
103 static int UploadPassive(TRANSPACKET *Pkt);
\r
104 static int UploadFile(TRANSPACKET *Pkt, SOCKET dSkt);
\r
106 //static int TermCodeConvAndSend(TERMCODECONVINFO *tInfo, SOCKET Skt, char *Data, int Size, int Ascii);
\r
107 static int TermCodeConvAndSend(TERMCODECONVINFO *tInfo, SOCKET Skt, char *Data, int Size, int Ascii, int *CancelCheckWork);
\r
108 static void DispUploadFinishMsg(TRANSPACKET *Pkt, int iRetCode);
\r
109 static int SetUploadResume(TRANSPACKET *Pkt, int ProcMode, LONGLONG Size, int *Mode);
\r
110 static LRESULT CALLBACK TransDlgProc(HWND hDlg, UINT Msg, WPARAM wParam, LPARAM lParam);
\r
111 static void DispTransferStatus(HWND hWnd, int End, TRANSPACKET *Pkt);
\r
112 static void DispTransFileInfo(TRANSPACKET *Pkt, char *Title, int SkipButton, int Info);
\r
114 //static int GetAdrsAndPort(char *Str, char *Adrs, int *Port, int Max);
\r
115 static int GetAdrsAndPort(SOCKET Skt, char *Str, char *Adrs, int *Port, int Max);
\r
116 static int GetAdrsAndPortIPv4(SOCKET Skt, char *Str, char *Adrs, int *Port, int Max);
\r
117 static int GetAdrsAndPortIPv6(SOCKET Skt, char *Str, char *Adrs, int *Port, int Max);
\r
118 static int IsSpecialDevice(char *Fname);
\r
119 static int MirrorDelNotify(int Cur, int Notify, TRANSPACKET *Pkt);
\r
121 //static BOOL CALLBACK MirrorDeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
122 static INT_PTR CALLBACK MirrorDeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam);
\r
123 static void SetErrorMsg(char *fmt, ...);
\r
125 static char* GetErrMsg();
\r
127 /*===== ローカルなワーク =====*/
\r
130 //static HANDLE hTransferThread;
\r
131 static HANDLE hTransferThread[MAX_DATA_CONNECTION];
\r
132 static int fTransferThreadExit = FALSE;
\r
134 static HANDLE hRunMutex; /* 転送スレッド実行ミューテックス */
\r
135 static HANDLE hListAccMutex; /* 転送ファイルアクセス用ミューテックス */
\r
137 static int TransFiles = 0; /* 転送待ちファイル数 */
\r
138 static TRANSPACKET *TransPacketBase = NULL; /* 転送ファイルリスト */
\r
140 static TRANSPACKET *NextTransPacketBase = NULL;
\r
143 //static int Canceled; /* 中止フラグ YES/NO */
\r
144 static int Canceled[MAX_DATA_CONNECTION]; /* 中止フラグ YES/NO */
\r
145 static int ClearAll; /* 全て中止フラグ YES/NO */
\r
147 static int ForceAbort; /* 転送中止フラグ */
\r
148 /* このフラグはスレッドを終了させるときに使う */
\r
151 //static LONGLONG AllTransSizeNow; /* 今回の転送で転送したサイズ */
\r
152 //static time_t TimeStart; /* 転送開始時間 */
\r
153 static LONGLONG AllTransSizeNow[MAX_DATA_CONNECTION]; /* 今回の転送で転送したサイズ */
\r
154 static time_t TimeStart[MAX_DATA_CONNECTION]; /* 転送開始時間 */
\r
156 static int KeepDlg = NO; /* 転送中ダイアログを消さないかどうか (YES/NO) */
\r
157 static int MoveToForeground = NO; /* ウインドウを前面に移動するかどうか (YES/NO) */
\r
160 //static char CurDir[FMAX_PATH+1] = { "" };
\r
161 static char CurDir[MAX_DATA_CONNECTION][FMAX_PATH+1];
\r
163 //static char ErrMsg[ERR_MSG_LEN+7];
\r
164 static char ErrMsg[MAX_DATA_CONNECTION+1][ERR_MSG_LEN+7];
\r
165 static DWORD ErrMsgThreadId[MAX_DATA_CONNECTION+1];
\r
166 static HANDLE hErrMsgMutex;
\r
169 static int WaitForMainThread = NO;
\r
171 static int TransferErrorMode = EXIST_OVW;
\r
172 static int TransferErrorNotify = NO;
\r
174 /*===== 外部参照 =====*/
\r
177 extern int SaveTimeStamp;
\r
179 // extern int TimeOut;
\r
180 extern int FwallType;
\r
181 extern int MirUpDelNotify;
\r
182 extern int MirDownDelNotify;
\r
183 extern int FolderAttr;
\r
184 extern int FolderAttrNum;
\r
186 extern int SendQuit;
\r
189 /*----- ファイル転送スレッドを起動する ----------------------------------------
\r
196 *----------------------------------------------------------------------------*/
\r
198 int MakeTransferThread(void)
\r
203 hListAccMutex = CreateMutex( NULL, FALSE, NULL );
\r
204 hRunMutex = CreateMutex( NULL, TRUE, NULL );
\r
206 hErrMsgMutex = CreateMutex( NULL, FALSE, NULL );
\r
211 fTransferThreadExit = FALSE;
\r
213 // hTransferThread = (HANDLE)_beginthreadex(NULL, 0, TransferThread, 0, 0, &dwID);
\r
214 // if (hTransferThread == NULL)
\r
215 // return(FFFTP_FAIL); /* XXX */
\r
216 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
218 hTransferThread[i] = (HANDLE)_beginthreadex(NULL, 0, TransferThread, (void*)i, 0, &dwID);
\r
219 if(hTransferThread[i] == NULL)
\r
223 return(FFFTP_SUCCESS);
\r
227 /*----- ファイル転送スレッドを終了する ----------------------------------------
\r
234 *----------------------------------------------------------------------------*/
\r
236 void CloseTransferThread(void)
\r
241 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
246 fTransferThreadExit = TRUE;
\r
248 // while(WaitForSingleObject(hTransferThread, 10) == WAIT_TIMEOUT)
\r
250 // BackgrndMessageProc();
\r
253 // CloseHandle(hTransferThread);
\r
254 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
256 while(WaitForSingleObject(hTransferThread[i], 10) == WAIT_TIMEOUT)
\r
258 BackgrndMessageProc();
\r
261 CloseHandle(hTransferThread[i]);
\r
264 ReleaseMutex( hRunMutex );
\r
266 CloseHandle( hListAccMutex );
\r
267 CloseHandle( hRunMutex );
\r
269 CloseHandle( hErrMsgMutex );
\r
274 /*----- 転送するファイル情報をリストに追加する --------------------------------
\r
277 * TRANSPACKET *Pkt : 転送ファイル情報
\r
278 * TRANSPACKET **Base : リストの先頭
\r
282 * FFFTP_SUCCESS/FFFTP_FAIL
\r
283 *----------------------------------------------------------------------------*/
\r
285 int AddTmpTransFileList(TRANSPACKET *Pkt, TRANSPACKET **Base)
\r
292 if((Pos = malloc(sizeof(TRANSPACKET))) != NULL)
\r
294 memcpy(Pos, Pkt, sizeof(TRANSPACKET));
\r
302 while(Prev->Next != NULL)
\r
306 Sts = FFFTP_SUCCESS;
\r
312 /*----- 転送するファイル情報リストをクリアする --------------------------------
\r
315 * TRANSPACKET **Base : リストの先頭
\r
319 *----------------------------------------------------------------------------*/
\r
321 void EraseTmpTransFileList(TRANSPACKET **Base)
\r
338 /*----- 転送するファイル情報リストから1つの情報を取り除く --------------------
\r
341 * TRANSPACKET *Pkt : 転送ファイル情報
\r
342 * TRANSPACKET **Base : リストの先頭
\r
346 * FFFTP_SUCCESS/FFFTP_FAIL
\r
347 *----------------------------------------------------------------------------*/
\r
349 int RemoveTmpTransFileListItem(TRANSPACKET **Base, int Num)
\r
361 Sts = FFFTP_SUCCESS;
\r
371 Prev->Next = Pos->Next;
\r
373 Sts = FFFTP_SUCCESS;
\r
382 /*----- 転送するファイル情報を転送ファイルリストに登録する --------------------
\r
385 * TRANSPACKET *Pkt : 転送ファイル情報
\r
389 *----------------------------------------------------------------------------*/
\r
391 void AddTransFileList(TRANSPACKET *Pkt)
\r
396 DispTransPacket(Pkt);
\r
399 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
400 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
402 WaitForMainThread = YES;
\r
403 BackgrndMessageProc();
\r
408 Pos = TransPacketBase;
\r
411 while(Pos->Next != NULL)
\r
414 if(AddTmpTransFileList(Pkt, &TransPacketBase) == FFFTP_SUCCESS)
\r
416 if((strncmp(Pkt->Cmd, "RETR", 4) == 0) ||
\r
417 (strncmp(Pkt->Cmd, "STOR", 4) == 0))
\r
420 PostMessage(GetMainHwnd(), WM_CHANGE_COND, 0, 0);
\r
424 if(NextTransPacketBase == NULL)
\r
427 NextTransPacketBase = Pos->Next;
\r
429 NextTransPacketBase = TransPacketBase;
\r
431 ReleaseMutex(hListAccMutex);
\r
433 WaitForMainThread = NO;
\r
440 void AddNullTransFileList()
\r
443 memset(&Pkt, 0, sizeof(TRANSPACKET));
\r
444 strcpy(Pkt.Cmd, "NULL");
\r
445 AddTransFileList(&Pkt);
\r
448 /*----- 転送ファイル情報を転送ファイルリストに追加する ------------------------
\r
451 * TRANSPACKET *Pkt : 転送ファイル情報
\r
452 * TRANSPACKET **Base : リストの先頭
\r
459 *----------------------------------------------------------------------------*/
\r
461 void AppendTransFileList(TRANSPACKET *Pkt)
\r
466 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
467 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
469 WaitForMainThread = YES;
\r
470 BackgrndMessageProc();
\r
474 if(TransPacketBase == NULL)
\r
475 TransPacketBase = Pkt;
\r
478 Pos = TransPacketBase;
\r
479 while(Pos->Next != NULL)
\r
484 if(NextTransPacketBase == NULL)
\r
485 NextTransPacketBase = Pkt;
\r
489 DispTransPacket(Pkt);
\r
491 if((strncmp(Pkt->Cmd, "RETR", 4) == 0) ||
\r
492 (strncmp(Pkt->Cmd, "STOR", 4) == 0))
\r
495 PostMessage(GetMainHwnd(), WM_CHANGE_COND, 0, 0);
\r
500 ReleaseMutex(hListAccMutex);
\r
502 WaitForMainThread = NO;
\r
507 /*----- 転送ファイル情報を表示する --------------------------------------------
\r
510 * TRANSPACKET *Pkt : 転送ファイル情報
\r
514 *----------------------------------------------------------------------------*/
\r
516 static void DispTransPacket(TRANSPACKET *Pkt)
\r
518 if((strncmp(Pkt->Cmd, "RETR", 4) == 0) || (strncmp(Pkt->Cmd, "STOR", 4) == 0))
\r
519 DoPrintf("TransList Cmd=%s : %s : %s", Pkt->Cmd, Pkt->RemoteFile, Pkt->LocalFile);
\r
520 else if(strncmp(Pkt->Cmd, "R-", 2) == 0)
\r
521 DoPrintf("TransList Cmd=%s : %s", Pkt->Cmd, Pkt->RemoteFile);
\r
522 else if(strncmp(Pkt->Cmd, "L-", 2) == 0)
\r
523 DoPrintf("TransList Cmd=%s : %s", Pkt->Cmd, Pkt->LocalFile);
\r
524 else if(strncmp(Pkt->Cmd, "MKD", 3) == 0)
\r
526 if(strlen(Pkt->LocalFile) > 0)
\r
527 DoPrintf("TransList Cmd=%s : %s", Pkt->Cmd, Pkt->LocalFile);
\r
529 DoPrintf("TransList Cmd=%s : %s", Pkt->Cmd, Pkt->RemoteFile);
\r
532 DoPrintf("TransList Cmd=%s", Pkt->Cmd);
\r
537 /*----- 転送ファイルリストをクリアする ----------------------------------------
\r
544 *----------------------------------------------------------------------------*/
\r
546 static void EraseTransFileList(void)
\r
550 TRANSPACKET *NotDel;
\r
551 // TRANSPACKET Pkt;
\r
556 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
557 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
559 WaitForMainThread = YES;
\r
560 BackgrndMessageProc();
\r
563 New = TransPacketBase;
\r
566 /* 最後の"BACKCUR"は必要なので消さない */
\r
567 if(strcmp(New->Cmd, "BACKCUR") == 0)
\r
572 strcpy(NotDel->Cmd, "");
\r
576 // NotDel->Next = NULL;
\r
583 strcpy(New->Cmd, "");
\r
587 TransPacketBase = NotDel;
\r
589 NextTransPacketBase = NotDel;
\r
591 PostMessage(GetMainHwnd(), WM_CHANGE_COND, 0, 0);
\r
592 ReleaseMutex(hListAccMutex);
\r
594 WaitForMainThread = NO;
\r
597 // strcpy(Pkt.Cmd, "GOQUIT");
\r
598 // AddTransFileList(&Pkt);
\r
603 /*----- 転送中ダイアログを消さないようにするかどうかを設定 --------------------
\r
606 * int Sw : 転送中ダイアログを消さないかどうか (YES/NO)
\r
610 *----------------------------------------------------------------------------*/
\r
612 void KeepTransferDialog(int Sw)
\r
619 /*----- 現在転送中かどうかを返す ----------------------------------------------
\r
625 * int ステータス (YES/NO=転送中ではない)
\r
626 *----------------------------------------------------------------------------*/
\r
628 int AskTransferNow(void)
\r
630 return(TransPacketBase != NULL ? YES : NO);
\r
634 /*----- 転送するファイルの数を返す --------------------------------------------
\r
641 *----------------------------------------------------------------------------*/
\r
643 int AskTransferFileNum(void)
\r
645 return(TransFiles);
\r
649 /*----- 転送中ウインドウを前面に出す ------------------------------------------
\r
656 *----------------------------------------------------------------------------*/
\r
658 void GoForwardTransWindow(void)
\r
660 MoveToForeground = YES;
\r
665 /*----- 転送ソケットのカレントディレクトリ情報を初期化 ------------------------
\r
672 *----------------------------------------------------------------------------*/
\r
674 void InitTransCurDir(void)
\r
677 // strcpy(CurDir, "");
\r
679 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
680 strcpy(CurDir[i], "");
\r
685 /*----- ファイル転送スレッドのメインループ ------------------------------------
\r
688 * void *Dummy : 使わない
\r
692 *----------------------------------------------------------------------------*/
\r
694 static ULONG WINAPI TransferThread(void *Dummy)
\r
698 char Tmp[FMAX_PATH+1];
\r
721 ThreadCount = (int)Dummy;
\r
722 CmdSkt = INVALID_SOCKET;
\r
723 NewCmdSkt = INVALID_SOCKET;
\r
724 TrnSkt = INVALID_SOCKET;
\r
725 SetThreadPriority(GetCurrentThread(), THREAD_PRIORITY_LOWEST);
\r
727 while((TransPacketBase != NULL) ||
\r
728 (WaitForSingleObject(hRunMutex, 200) == WAIT_TIMEOUT))
\r
730 if(fTransferThreadExit == TRUE)
\r
733 if(WaitForMainThread == YES)
\r
735 BackgrndMessageProc();
\r
740 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
741 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
743 BackgrndMessageProc();
\r
746 // memset(ErrMsg, NUL, ERR_MSG_LEN+7);
\r
747 memset(GetErrMsg(), NUL, ERR_MSG_LEN+7);
\r
750 Canceled[ThreadCount] = NO;
\r
752 while(TransPacketBase != NULL && strcmp(TransPacketBase->Cmd, "") == 0)
\r
754 Pos = TransPacketBase;
\r
755 TransPacketBase = TransPacketBase->Next;
\r
757 if(TransPacketBase == NULL)
\r
760 NewCmdSkt = AskCmdCtrlSkt();
\r
761 if(AskReuseCmdSkt() == YES && ThreadCount == 0)
\r
763 if(TransPacketBase && ThreadCount < AskMaxThreadCount())
\r
764 TrnSkt = AskTrnCtrlSkt();
\r
768 if(TransPacketBase && NewCmdSkt != INVALID_SOCKET && ThreadCount < AskMaxThreadCount())
\r
770 ReleaseMutex(hListAccMutex);
\r
771 if(TrnSkt == INVALID_SOCKET || NewCmdSkt != CmdSkt)
\r
772 ReConnectTrnSkt(&TrnSkt, &Canceled[ThreadCount]);
\r
774 CheckClosedAndReconnectTrnSkt(&TrnSkt, &Canceled[ThreadCount]);
\r
776 if(TrnSkt == INVALID_SOCKET)
\r
778 // 同時ログイン数制限に引っかかった可能性あり
\r
779 // 負荷を下げるために約10秒間待機
\r
781 while(NewCmdSkt != CmdSkt && i > 0)
\r
783 BackgrndMessageProc();
\r
788 LastUsed = timeGetTime();
\r
789 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
790 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
792 BackgrndMessageProc();
\r
798 if(TrnSkt != INVALID_SOCKET)
\r
801 // 60秒間使用されなければログアウト
\r
802 if(timeGetTime() - LastUsed > 60000 || NewCmdSkt == INVALID_SOCKET)
\r
804 ReleaseMutex(hListAccMutex);
\r
805 DoQUIT(TrnSkt, &Canceled[ThreadCount]);
\r
807 TrnSkt = INVALID_SOCKET;
\r
808 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
809 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
811 BackgrndMessageProc();
\r
818 CmdSkt = NewCmdSkt;
\r
819 // if(TransPacketBase != NULL)
\r
820 if(TrnSkt != INVALID_SOCKET && NextTransPacketBase != NULL)
\r
822 Pos = NextTransPacketBase;
\r
823 NextTransPacketBase = NextTransPacketBase->Next;
\r
824 // ディレクトリ操作は非同期で行わない
\r
825 // ReleaseMutex(hListAccMutex);
\r
826 if(hWndTrans == NULL)
\r
828 // if((strncmp(TransPacketBase->Cmd, "RETR", 4) == 0) ||
\r
829 // (strncmp(TransPacketBase->Cmd, "STOR", 4) == 0) ||
\r
830 // (strncmp(TransPacketBase->Cmd, "MKD", 3) == 0) ||
\r
831 // (strncmp(TransPacketBase->Cmd, "L-", 2) == 0) ||
\r
832 // (strncmp(TransPacketBase->Cmd, "R-", 2) == 0))
\r
833 if((strncmp(Pos->Cmd, "RETR", 4) == 0) ||
\r
834 (strncmp(Pos->Cmd, "STOR", 4) == 0) ||
\r
835 (strncmp(Pos->Cmd, "MKD", 3) == 0) ||
\r
836 (strncmp(Pos->Cmd, "L-", 2) == 0) ||
\r
837 (strncmp(Pos->Cmd, "R-", 2) == 0))
\r
839 hWndTrans = CreateDialog(GetFtpInst(), MAKEINTRESOURCE(transfer_dlg), HWND_DESKTOP, (DLGPROC)TransDlgProc);
\r
840 if(MoveToForeground == YES)
\r
841 SetForegroundWindow(hWndTrans);
\r
842 ShowWindow(hWndTrans, SW_SHOWNOACTIVATE);
\r
843 GetWindowRect(hWndTrans, &WndRect);
\r
844 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
847 // TransPacketBase->hWndTrans = hWndTrans;
\r
848 Pos->hWndTrans = hWndTrans;
\r
849 Pos->ctrl_skt = TrnSkt;
\r
850 Pos->Abort = ABORT_NONE;
\r
851 Pos->ThreadCount = ThreadCount;
\r
853 if(hWndTrans != NULL)
\r
855 if(MoveToForeground == YES)
\r
857 SetForegroundWindow(hWndTrans);
\r
858 MoveToForeground = NO;
\r
862 if(hWndTrans != NULL)
\r
863 // SendMessage(hWndTrans, WM_SET_PACKET, 0, (LPARAM)TransPacketBase);
\r
864 SendMessage(hWndTrans, WM_SET_PACKET, 0, (LPARAM)Pos);
\r
866 // 中断後に受信バッファに応答が残っていると次のコマンドの応答が正しく処理できない
\r
867 RemoveReceivedData(TrnSkt);
\r
870 // if(strncmp(TransPacketBase->Cmd, "RETR", 4) == 0)
\r
871 if(strncmp(Pos->Cmd, "RETR", 4) == 0)
\r
873 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
874 // ReleaseMutex(hListAccMutex);
\r
876 // if(CheckPathViolation(TransPacketBase) == NO)
\r
877 if(CheckPathViolation(Pos) == NO)
\r
879 /* フルパスを使わないための処理 */
\r
880 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
881 if(MakeNonFullPath(Pos, CurDir[Pos->ThreadCount], Tmp) == FFFTP_SUCCESS)
\r
883 // if(strncmp(TransPacketBase->Cmd, "RETR-S", 6) == 0)
\r
884 if(strncmp(Pos->Cmd, "RETR-S", 6) == 0)
\r
887 // DoSIZE(TransPacketBase->RemoteFile, &TransPacketBase->Size);
\r
888 // DoMDTM(TransPacketBase->RemoteFile, &TransPacketBase->Time);
\r
889 // strcpy(TransPacketBase->Cmd, "RETR ");
\r
890 DoSIZE(TrnSkt, Pos->RemoteFile, &Pos->Size, &Canceled[Pos->ThreadCount]);
\r
891 DoMDTM(TrnSkt, Pos->RemoteFile, &Pos->Time, &Canceled[Pos->ThreadCount]);
\r
892 strcpy(Pos->Cmd, "RETR ");
\r
896 // if(DoDownload(AskTrnCtrlSkt(), TransPacketBase, NO) == 429)
\r
898 // if(ReConnectTrnSkt() == FFFTP_SUCCESS)
\r
899 // DoDownload(AskTrnCtrlSkt(), TransPacketBase, NO, &Canceled);
\r
900 DoDownload(TrnSkt, Pos, NO, &Canceled[Pos->ThreadCount]);
\r
904 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
905 ReleaseMutex(hListAccMutex);
\r
908 // else if(strncmp(TransPacketBase->Cmd, "STOR", 4) == 0)
\r
909 else if(strncmp(Pos->Cmd, "STOR", 4) == 0)
\r
911 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
912 // ReleaseMutex(hListAccMutex);
\r
913 /* フルパスを使わないための処理 */
\r
914 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
915 if(MakeNonFullPath(Pos, CurDir[Pos->ThreadCount], Tmp) == FFFTP_SUCCESS)
\r
918 // if(DoUpload(AskTrnCtrlSkt(), TransPacketBase) == 429)
\r
920 // if(ReConnectTrnSkt() == FFFTP_SUCCESS)
\r
921 // DoUpload(AskTrnCtrlSkt(), TransPacketBase);
\r
922 DoUpload(TrnSkt, Pos);
\r
926 /* ファイルのタイムスタンプを合わせる */
\r
927 if((SaveTimeStamp == YES) &&
\r
928 ((Pos->Time.dwLowDateTime != 0) || (Pos->Time.dwHighDateTime != 0)))
\r
930 DoMFMT(TrnSkt, Pos->RemoteFile, &Pos->Time, &Canceled[Pos->ThreadCount]);
\r
933 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
934 ReleaseMutex(hListAccMutex);
\r
936 /* フォルダ作成(ローカルまたはホスト) */
\r
937 // else if(strncmp(TransPacketBase->Cmd, "MKD", 3) == 0)
\r
938 else if(strncmp(Pos->Cmd, "MKD", 3) == 0)
\r
940 // DispTransFileInfo(TransPacketBase, MSGJPN078, FALSE, YES);
\r
941 DispTransFileInfo(Pos, MSGJPN078, FALSE, YES);
\r
943 // if(strlen(TransPacketBase->RemoteFile) > 0)
\r
944 if(strlen(Pos->RemoteFile) > 0)
\r
946 /* フルパスを使わないための処理 */
\r
947 CwdSts = FTP_COMPLETE;
\r
949 // strcpy(Tmp, TransPacketBase->RemoteFile);
\r
950 strcpy(Tmp, Pos->RemoteFile);
\r
951 // if(ProcForNonFullpath(Tmp, CurDir, hWndTrans, 1) == FFFTP_FAIL)
\r
952 if(ProcForNonFullpath(TrnSkt, Tmp, CurDir[Pos->ThreadCount], hWndTrans, &Canceled[Pos->ThreadCount]) == FFFTP_FAIL)
\r
955 CwdSts = FTP_ERROR;
\r
958 if(CwdSts == FTP_COMPLETE)
\r
961 // CommandProcTrn(NULL, "MKD %s", Tmp);
\r
962 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "MKD %s", Tmp);
\r
963 /* すでにフォルダがある場合もあるので、 */
\r
964 /* ここではエラーチェックはしない */
\r
967 // CommandProcTrn(NULL, "%s %03d %s", AskHostChmodCmd(), FolderAttrNum, Tmp);
\r
968 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "%s %03d %s", AskHostChmodCmd(), FolderAttrNum, Tmp);
\r
971 // else if(strlen(TransPacketBase->LocalFile) > 0)
\r
972 else if(strlen(Pos->LocalFile) > 0)
\r
975 // DoLocalMKD(TransPacketBase->LocalFile);
\r
976 DoLocalMKD(Pos->LocalFile);
\r
978 ReleaseMutex(hListAccMutex);
\r
980 /* ディレクトリ作成(常にホスト側) */
\r
981 // else if(strncmp(TransPacketBase->Cmd, "R-MKD", 5) == 0)
\r
982 else if(strncmp(Pos->Cmd, "R-MKD", 5) == 0)
\r
984 // DispTransFileInfo(TransPacketBase, MSGJPN079, FALSE, YES);
\r
985 DispTransFileInfo(Pos, MSGJPN079, FALSE, YES);
\r
987 /* フルパスを使わないための処理 */
\r
988 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
989 if(MakeNonFullPath(Pos, CurDir[Pos->ThreadCount], Tmp) == FFFTP_SUCCESS)
\r
992 // CommandProcTrn(NULL, "%s%s", TransPacketBase->Cmd+2, TransPacketBase->RemoteFile);
\r
993 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "%s%s", Pos->Cmd+2, Pos->RemoteFile);
\r
996 // CommandProcTrn(NULL, "%s %03d %s", AskHostChmodCmd(), FolderAttrNum, TransPacketBase->RemoteFile);
\r
997 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "%s %03d %s", AskHostChmodCmd(), FolderAttrNum, Pos->RemoteFile);
\r
999 ReleaseMutex(hListAccMutex);
\r
1001 /* ディレクトリ削除(常にホスト側) */
\r
1002 // else if(strncmp(TransPacketBase->Cmd, "R-RMD", 5) == 0)
\r
1003 else if(strncmp(Pos->Cmd, "R-RMD", 5) == 0)
\r
1005 // DispTransFileInfo(TransPacketBase, MSGJPN080, FALSE, YES);
\r
1006 DispTransFileInfo(Pos, MSGJPN080, FALSE, YES);
\r
1008 // DelNotify = MirrorDelNotify(WIN_REMOTE, DelNotify, TransPacketBase);
\r
1009 DelNotify = MirrorDelNotify(WIN_REMOTE, DelNotify, Pos);
\r
1010 if((DelNotify == YES) || (DelNotify == YES_ALL))
\r
1012 /* フルパスを使わないための処理 */
\r
1013 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
1014 if(MakeNonFullPath(Pos, CurDir[Pos->ThreadCount], Tmp) == FFFTP_SUCCESS)
\r
1017 // CommandProcTrn(NULL, "%s%s", TransPacketBase->Cmd+2, TransPacketBase->RemoteFile);
\r
1018 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "%s%s", Pos->Cmd+2, Pos->RemoteFile);
\r
1021 ReleaseMutex(hListAccMutex);
\r
1023 /* ファイル削除(常にホスト側) */
\r
1024 // else if(strncmp(TransPacketBase->Cmd, "R-DELE", 6) == 0)
\r
1025 else if(strncmp(Pos->Cmd, "R-DELE", 6) == 0)
\r
1027 // DispTransFileInfo(TransPacketBase, MSGJPN081, FALSE, YES);
\r
1028 DispTransFileInfo(Pos, MSGJPN081, FALSE, YES);
\r
1030 // DelNotify = MirrorDelNotify(WIN_REMOTE, DelNotify, TransPacketBase);
\r
1031 DelNotify = MirrorDelNotify(WIN_REMOTE, DelNotify, Pos);
\r
1032 if((DelNotify == YES) || (DelNotify == YES_ALL))
\r
1034 /* フルパスを使わないための処理 */
\r
1035 // if(MakeNonFullPath(TransPacketBase, CurDir, Tmp) == FFFTP_SUCCESS)
\r
1036 if(MakeNonFullPath(Pos, CurDir[Pos->ThreadCount], Tmp) == FFFTP_SUCCESS)
\r
1039 // CommandProcTrn(NULL, "%s%s", TransPacketBase->Cmd+2, TransPacketBase->RemoteFile);
\r
1040 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "%s%s", Pos->Cmd+2, Pos->RemoteFile);
\r
1043 ReleaseMutex(hListAccMutex);
\r
1045 /* ディレクトリ作成(常にローカル側) */
\r
1046 // else if(strncmp(TransPacketBase->Cmd, "L-MKD", 5) == 0)
\r
1047 else if(strncmp(Pos->Cmd, "L-MKD", 5) == 0)
\r
1049 // DispTransFileInfo(TransPacketBase, MSGJPN082, FALSE, YES);
\r
1050 DispTransFileInfo(Pos, MSGJPN082, FALSE, YES);
\r
1053 // DoLocalMKD(TransPacketBase->LocalFile);
\r
1054 DoLocalMKD(Pos->LocalFile);
\r
1055 ReleaseMutex(hListAccMutex);
\r
1057 /* ディレクトリ削除(常にローカル側) */
\r
1058 // else if(strncmp(TransPacketBase->Cmd, "L-RMD", 5) == 0)
\r
1059 else if(strncmp(Pos->Cmd, "L-RMD", 5) == 0)
\r
1061 // DispTransFileInfo(TransPacketBase, MSGJPN083, FALSE, YES);
\r
1062 DispTransFileInfo(Pos, MSGJPN083, FALSE, YES);
\r
1064 // DelNotify = MirrorDelNotify(WIN_LOCAL, DelNotify, TransPacketBase);
\r
1065 DelNotify = MirrorDelNotify(WIN_LOCAL, DelNotify, Pos);
\r
1066 if((DelNotify == YES) || (DelNotify == YES_ALL))
\r
1069 // DoLocalRMD(TransPacketBase->LocalFile);
\r
1070 DoLocalRMD(Pos->LocalFile);
\r
1072 ReleaseMutex(hListAccMutex);
\r
1074 /* ファイル削除(常にローカル側) */
\r
1075 // else if(strncmp(TransPacketBase->Cmd, "L-DELE", 6) == 0)
\r
1076 else if(strncmp(Pos->Cmd, "L-DELE", 6) == 0)
\r
1078 // DispTransFileInfo(TransPacketBase, MSGJPN084, FALSE, YES);
\r
1079 DispTransFileInfo(Pos, MSGJPN084, FALSE, YES);
\r
1081 // DelNotify = MirrorDelNotify(WIN_LOCAL, DelNotify, TransPacketBase);
\r
1082 DelNotify = MirrorDelNotify(WIN_LOCAL, DelNotify, Pos);
\r
1083 if((DelNotify == YES) || (DelNotify == YES_ALL))
\r
1086 // DoLocalDELE(TransPacketBase->LocalFile);
\r
1087 DoLocalDELE(Pos->LocalFile);
\r
1089 ReleaseMutex(hListAccMutex);
\r
1091 /* カレントディレクトリを設定 */
\r
1092 // else if(strcmp(TransPacketBase->Cmd, "SETCUR") == 0)
\r
1093 else if(strcmp(Pos->Cmd, "SETCUR") == 0)
\r
1095 // if(AskShareProh() == YES)
\r
1096 if(AskReuseCmdSkt() == NO || AskShareProh() == YES)
\r
1098 // if(strcmp(CurDir, TransPacketBase->RemoteFile) != 0)
\r
1099 if(strcmp(CurDir[Pos->ThreadCount], Pos->RemoteFile) != 0)
\r
1101 // if(CommandProcTrn(NULL, "CWD %s", TransPacketBase->RemoteFile)/100 != FTP_COMPLETE)
\r
1102 if(CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "CWD %s", Pos->RemoteFile)/100 != FTP_COMPLETE)
\r
1104 DispCWDerror(hWndTrans);
\r
1109 // strcpy(CurDir, TransPacketBase->RemoteFile);
\r
1110 strcpy(CurDir[Pos->ThreadCount], Pos->RemoteFile);
\r
1111 ReleaseMutex(hListAccMutex);
\r
1113 /* カレントディレクトリを戻す */
\r
1114 // else if(strcmp(TransPacketBase->Cmd, "BACKCUR") == 0)
\r
1115 else if(strcmp(Pos->Cmd, "BACKCUR") == 0)
\r
1117 // if(AskShareProh() == NO)
\r
1118 if(AskReuseCmdSkt() == YES && AskShareProh() == NO)
\r
1120 // if(strcmp(CurDir, TransPacketBase->RemoteFile) != 0)
\r
1121 // CommandProcTrn(NULL, "CWD %s", TransPacketBase->RemoteFile);
\r
1122 // strcpy(CurDir, TransPacketBase->RemoteFile);
\r
1123 if(strcmp(CurDir[Pos->ThreadCount], Pos->RemoteFile) != 0)
\r
1124 CommandProcTrn(TrnSkt, NULL, &Canceled[Pos->ThreadCount], "CWD %s", Pos->RemoteFile);
\r
1125 strcpy(CurDir[Pos->ThreadCount], Pos->RemoteFile);
\r
1127 ReleaseMutex(hListAccMutex);
\r
1130 // else if(strcmp(TransPacketBase->Cmd, "GOQUIT") == 0)
\r
1131 // else if(strcmp(Pos->Cmd, "GOQUIT") == 0)
\r
1133 // ReleaseMutex(hListAccMutex);
\r
1137 ReleaseMutex(hListAccMutex);
\r
1139 /*===== 1つの処理終わり =====*/
\r
1141 if(ForceAbort == NO)
\r
1143 // WaitForSingleObject(hListAccMutex, INFINITE);
\r
1144 while(WaitForSingleObject(hListAccMutex, 0) == WAIT_TIMEOUT)
\r
1146 BackgrndMessageProc();
\r
1149 if(ClearAll == YES)
\r
1150 // EraseTransFileList();
\r
1152 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
1153 Canceled[i] = YES;
\r
1155 strcpy(Pos->Cmd, "");
\r
1157 EraseTransFileList();
\r
1162 // if((strncmp(TransPacketBase->Cmd, "RETR", 4) == 0) ||
\r
1163 // (strncmp(TransPacketBase->Cmd, "STOR", 4) == 0))
\r
1164 if((strncmp(Pos->Cmd, "RETR", 4) == 0) ||
\r
1165 (strncmp(Pos->Cmd, "STOR", 4) == 0) ||
\r
1166 (strncmp(Pos->Cmd, "STOU", 4) == 0))
\r
1169 if(TransFiles > 0)
\r
1171 PostMessage(GetMainHwnd(), WM_CHANGE_COND, 0, 0);
\r
1173 // Pos = TransPacketBase;
\r
1174 // TransPacketBase = TransPacketBase->Next;
\r
1178 ReleaseMutex(hListAccMutex);
\r
1180 if(BackgrndMessageProc() == YES)
\r
1182 WaitForSingleObject(hListAccMutex, INFINITE);
\r
1183 EraseTransFileList();
\r
1184 ReleaseMutex(hListAccMutex);
\r
1187 if(hWndTrans != NULL)
\r
1188 SendMessage(hWndTrans, WM_SET_PACKET, 0, 0);
\r
1190 strcpy(Pos->Cmd, "");
\r
1191 LastUsed = timeGetTime();
\r
1194 else if(TransPacketBase == NULL)
\r
1201 SoundPlay(SND_TRANS);
\r
1202 if(AskAutoExit() == NO)
\r
1205 PostMessage(GetMainHwnd(), WM_REFRESH_LOCAL_FLG, 0, 0);
\r
1207 PostMessage(GetMainHwnd(), WM_REFRESH_REMOTE_FLG, 0, 0);
\r
1211 PostMessage(GetMainHwnd(), WM_COMMAND, MAKEWPARAM(MENU_AUTO_EXIT, 0), 0);
\r
1215 ReleaseMutex(hListAccMutex);
\r
1218 if(hWndTrans != NULL)
\r
1220 DestroyWindow(hWndTrans);
\r
1223 // if(GoExit == YES)
\r
1225 // SoundPlay(SND_TRANS);
\r
1227 // if(AskAutoExit() == NO)
\r
1229 // if(Down == YES)
\r
1230 // PostMessage(GetMainHwnd(), WM_REFRESH_LOCAL_FLG, 0, 0);
\r
1232 // PostMessage(GetMainHwnd(), WM_REFRESH_REMOTE_FLG, 0, 0);
\r
1239 BackgrndMessageProc();
\r
1244 TransferErrorMode = AskTransferErrorMode();
\r
1245 TransferErrorNotify = AskTransferErrorNotify();
\r
1249 ReleaseMutex(hListAccMutex);
\r
1250 if(hWndTrans != NULL)
\r
1252 DestroyWindow(hWndTrans);
\r
1255 BackgrndMessageProc();
\r
1256 if(ThreadCount < AskMaxThreadCount())
\r
1262 if(AskReuseCmdSkt() == NO || ThreadCount > 0)
\r
1264 if(TrnSkt != INVALID_SOCKET)
\r
1266 SendData(TrnSkt, "QUIT\r\n", 6, 0, &Canceled[ThreadCount]);
\r
1274 /*----- フルパスを使わないファイルアクセスの準備 ------------------------------
\r
1277 * TRANSPACKET *Pkt : 転送パケット
\r
1278 * char *Cur : カレントディレクトリ
\r
1279 * char *Tmp : 作業用エリア
\r
1282 * int ステータス(FFFTP_SUCCESS/FFFTP_FAIL)
\r
1286 * このモジュール内で CWD を行ない、
\r
1287 * Pkt->RemoteFile にファイル名のみ残す。(パス名は消す)
\r
1288 *----------------------------------------------------------------------------*/
\r
1291 static int MakeNonFullPath(TRANSPACKET *Pkt, char *Cur, char *Tmp)
\r
1295 // Sts = ProcForNonFullpath(Pkt->RemoteFile, Cur, Pkt->hWndTrans, 1);
\r
1296 Sts = ProcForNonFullpath(Pkt->ctrl_skt, Pkt->RemoteFile, Cur, Pkt->hWndTrans, &Canceled[Pkt->ThreadCount]);
\r
1297 if(Sts == FFFTP_FAIL)
\r
1306 /*----- ダウンロードを行なう --------------------------------------------------
\r
1309 * SOCKET cSkt : コントロールソケット
\r
1310 * TRANSPACKET *Pkt : 転送ファイル情報
\r
1311 * int DirList : ディレクトリリストのダウンロード(YES/NO)
\r
1317 * このモジュールは、ファイル一覧の取得などを行なう際にメインのスレッド
\r
1318 * からも呼ばれる。メインのスレッドから呼ばれる時は Pkt->hWndTrans == NULL。
\r
1319 *----------------------------------------------------------------------------*/
\r
1321 int DoDownload(SOCKET cSkt, TRANSPACKET *Pkt, int DirList, int *CancelCheckWork)
\r
1324 char Reply[ERR_MSG_LEN+7];
\r
1326 Pkt->ctrl_skt = cSkt;
\r
1327 if(IsSpecialDevice(GetFileName(Pkt->LocalFile)) == YES)
\r
1330 SetTaskMsg(MSGJPN085, GetFileName(Pkt->LocalFile));
\r
1331 // エラーによってはダイアログが表示されない場合があるバグ対策
\r
1332 // DispDownloadFinishMsg(Pkt, iRetCode);
\r
1334 else if(Pkt->Mode != EXIST_IGNORE)
\r
1336 if(Pkt->Type == TYPE_I)
\r
1337 Pkt->KanjiCode = KANJI_NOCNV;
\r
1339 iRetCode = command(Pkt->ctrl_skt, Reply, CancelCheckWork, "TYPE %c", Pkt->Type);
\r
1340 if(iRetCode/100 < FTP_RETRY)
\r
1342 if(Pkt->hWndTrans != NULL)
\r
1345 // AllTransSizeNow = 0;
\r
1346 AllTransSizeNow[Pkt->ThreadCount] = 0;
\r
1349 DispTransFileInfo(Pkt, MSGJPN086, TRUE, YES);
\r
1351 DispTransFileInfo(Pkt, MSGJPN087, FALSE, NO);
\r
1355 // if(BackgrndMessageProc() == NO)
\r
1356 if(IsSFTPAttached(Pkt->ctrl_skt))
\r
1360 else if(BackgrndMessageProc() == NO)
\r
1362 if(AskPasvMode() != YES)
\r
1363 iRetCode = DownloadNonPassive(Pkt, CancelCheckWork);
\r
1365 iRetCode = DownloadPassive(Pkt, CancelCheckWork);
\r
1371 SetErrorMsg(Reply);
\r
1372 // エラーによってはダイアログが表示されない場合があるバグ対策
\r
1373 DispDownloadFinishMsg(Pkt, iRetCode);
\r
1377 DispTransFileInfo(Pkt, MSGJPN088, TRUE, YES);
\r
1378 SetTaskMsg(MSGJPN089, Pkt->RemoteFile);
\r
1385 /*----- 通常モードでファイルをダウンロード ------------------------------------
\r
1388 * TRANSPACKET *Pkt : 転送ファイル情報
\r
1392 *----------------------------------------------------------------------------*/
\r
1394 static int DownloadNonPassive(TRANSPACKET *Pkt, int *CancelCheckWork)
\r
1398 SOCKET data_socket = INVALID_SOCKET; // data channel socket
\r
1399 SOCKET listen_socket = INVALID_SOCKET; // data listen socket
\r
1401 // char Buf[1024];
\r
1402 char Buf[FMAX_PATH+1024];
\r
1405 // struct sockaddr_in saSockAddr1;
\r
1406 struct sockaddr_in saSockAddrIPv4;
\r
1407 struct sockaddr_in6 saSockAddrIPv6;
\r
1408 char Reply[ERR_MSG_LEN+7];
\r
1410 if((listen_socket = GetFTPListenSocket(Pkt->ctrl_skt, CancelCheckWork)) != INVALID_SOCKET)
\r
1412 if(SetDownloadResume(Pkt, Pkt->Mode, Pkt->ExistSize, &CreateMode, CancelCheckWork) == YES)
\r
1414 sprintf(Buf, "%s%s", Pkt->Cmd, Pkt->RemoteFile);
\r
1415 iRetCode = command(Pkt->ctrl_skt, Reply, CancelCheckWork, "%s", Buf);
\r
1416 if(iRetCode/100 == FTP_PRELIM)
\r
1419 // if(SocksGet2ndBindReply(listen_socket, &data_socket) == FFFTP_FAIL)
\r
1420 if(SocksGet2ndBindReply(listen_socket, &data_socket, CancelCheckWork) == FFFTP_FAIL)
\r
1423 // iLength = sizeof(saSockAddr1);
\r
1424 // data_socket = do_accept(listen_socket, (struct sockaddr *)&saSockAddr1, (int *)&iLength);
\r
1425 switch(AskCurNetType())
\r
1428 iLength=sizeof(saSockAddrIPv4);
\r
1429 data_socket = do_accept(listen_socket,(struct sockaddr *)&saSockAddrIPv4, (int *)&iLength);
\r
1432 iLength=sizeof(saSockAddrIPv6);
\r
1433 data_socket = do_accept(listen_socket,(struct sockaddr *)&saSockAddrIPv6, (int *)&iLength);
\r
1437 if(shutdown(listen_socket, 1) != 0)
\r
1438 ReportWSError("shutdown listen", WSAGetLastError());
\r
1439 listen_socket = DoClose(listen_socket);
\r
1441 if(data_socket == INVALID_SOCKET)
\r
1443 SetErrorMsg(MSGJPN280);
\r
1444 ReportWSError("accept", WSAGetLastError());
\r
1449 // DoPrintf("Skt=%u : accept from %s port %u", data_socket, inet_ntoa(saSockAddr1.sin_addr), ntohs(saSockAddr1.sin_port));
\r
1451 switch(AskCurNetType())
\r
1454 DoPrintf("Skt=%u : accept from %s port %u", data_socket, inet_ntoa(saSockAddrIPv4.sin_addr), ntohs(saSockAddrIPv4.sin_port));
\r
1457 DoPrintf("Skt=%u : accept from %s port %u", data_socket, inet6_ntoa(saSockAddrIPv6.sin6_addr), ntohs(saSockAddrIPv6.sin6_port));
\r
1463 if(data_socket != INVALID_SOCKET)
\r
1465 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
1466 ReleaseMutex(hListAccMutex);
\r
1468 // iRetCode = DownloadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1469 if(IsSSLAttached(Pkt->ctrl_skt))
\r
1471 if(AttachSSL(data_socket, Pkt->ctrl_skt, CancelCheckWork))
\r
1472 iRetCode = DownloadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1477 iRetCode = DownloadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1478 // data_socket = DoClose(data_socket);
\r
1483 SetErrorMsg(Reply);
\r
1484 SetTaskMsg(MSGJPN090);
\r
1485 listen_socket = DoClose(listen_socket);
\r
1495 SetErrorMsg(MSGJPN279);
\r
1497 // エラーによってはダイアログが表示されない場合があるバグ対策
\r
1498 // DispDownloadFinishMsg(Pkt, iRetCode);
\r
1504 /*----- Passiveモードでファイルをダウンロード ---------------------------------
\r
1507 * TRANSPACKET *Pkt : 転送ファイル情報
\r
1511 *----------------------------------------------------------------------------*/
\r
1513 static int DownloadPassive(TRANSPACKET *Pkt, int *CancelCheckWork)
\r
1516 SOCKET data_socket = INVALID_SOCKET; // data channel socket
\r
1518 // char Buf[1024];
\r
1519 char Buf[FMAX_PATH+1024];
\r
1526 char Reply[ERR_MSG_LEN+7];
\r
1529 // iRetCode = command(Pkt->ctrl_skt, Buf, CancelCheckWork, "PASV");
\r
1530 switch(AskCurNetType())
\r
1533 iRetCode = command(Pkt->ctrl_skt, Buf, CancelCheckWork, "PASV");
\r
1536 iRetCode = command(Pkt->ctrl_skt, Buf, CancelCheckWork, "EPSV");
\r
1539 if(iRetCode/100 == FTP_COMPLETE)
\r
1542 // if(GetAdrsAndPort(Buf, Adrs, &Port, 19) == FFFTP_SUCCESS)
\r
1543 if(GetAdrsAndPort(Pkt->ctrl_skt, Buf, Adrs, &Port, 39) == FFFTP_SUCCESS)
\r
1545 if((data_socket = connectsock(Adrs, Port, MSGJPN091, CancelCheckWork)) != INVALID_SOCKET)
\r
1549 if(setsockopt(data_socket, IPPROTO_TCP, TCP_NODELAY, (LPSTR)&Flg, sizeof(Flg)) == SOCKET_ERROR)
\r
1550 ReportWSError("setsockopt", WSAGetLastError());
\r
1552 if(SetDownloadResume(Pkt, Pkt->Mode, Pkt->ExistSize, &CreateMode, CancelCheckWork) == YES)
\r
1554 sprintf(Buf, "%s%s", Pkt->Cmd, Pkt->RemoteFile);
\r
1555 iRetCode = command(Pkt->ctrl_skt, Reply, CancelCheckWork, "%s", Buf);
\r
1556 if(iRetCode/100 == FTP_PRELIM)
\r
1558 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
1559 ReleaseMutex(hListAccMutex);
\r
1561 // iRetCode = DownloadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1562 if(IsSSLAttached(Pkt->ctrl_skt))
\r
1564 if(AttachSSL(data_socket, Pkt->ctrl_skt, CancelCheckWork))
\r
1565 iRetCode = DownloadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1570 iRetCode = DownloadFile(Pkt, data_socket, CreateMode, CancelCheckWork);
\r
1571 // data_socket = DoClose(data_socket);
\r
1575 SetErrorMsg(Reply);
\r
1576 SetTaskMsg(MSGJPN092);
\r
1577 data_socket = DoClose(data_socket);
\r
1589 SetErrorMsg(MSGJPN093);
\r
1590 SetTaskMsg(MSGJPN093);
\r
1597 // エラーによってはダイアログが表示されない場合があるバグ対策
\r
1598 // DispDownloadFinishMsg(Pkt, iRetCode);
\r
1604 /*----- ダウンロードの実行 ----------------------------------------------------
\r
1607 * TRANSPACKET *Pkt : 転送ファイル情報
\r
1608 * SOCKET dSkt : データソケット
\r
1609 * int CreateMode : ファイル作成モード (CREATE_ALWAYS/OPEN_ALWAYS)
\r
1616 * ダイアログを出す(Pkt->hWndTrans!=NULL)場合、インターバルタイマで経過を表示する
\r
1617 * ダイアログを出さない場合、このルーチンからDispDownloadSize()を呼ぶ
\r
1618 *----------------------------------------------------------------------------*/
\r
1620 static int DownloadFile(TRANSPACKET *Pkt, SOCKET dSkt, int CreateMode, int *CancelCheckWork)
\r
1623 char Buf[BUFSIZE];
\r
1624 char Buf2[BUFSIZE+3];
\r
1625 HANDLE iFileHandle;
\r
1626 SECURITY_ATTRIBUTES Sec;
\r
1628 CODECONVINFO cInfo;
\r
1630 // fd_set ReadFds;
\r
1631 // struct timeval Tout;
\r
1632 // struct timeval *ToutPtr;
\r
1635 char TmpBuf[ONELINE_BUF_SIZE];
\r
1636 DWORD dwFileAttributes;
\r
1638 #ifdef SET_BUFFER_SIZE
\r
1639 /* Add by H.Shirouzu at 2002/10/02 */
\r
1640 int buf_size = SOCKBUF_SIZE;
\r
1641 for ( ; buf_size > 0; buf_size /= 2)
\r
1642 if (setsockopt(dSkt, SOL_SOCKET, SO_RCVBUF, (char *)&buf_size, sizeof(buf_size)) == 0)
\r
1647 // 念のため受信バッファを無効にする
\r
1648 #ifdef DISABLE_TRANSFER_NETWORK_BUFFERS
\r
1650 setsockopt(dSkt, SOL_SOCKET, SO_RCVBUF, (char *)&buf_size, sizeof(buf_size));
\r
1653 Pkt->Abort = ABORT_NONE;
\r
1655 Sec.nLength = sizeof(SECURITY_ATTRIBUTES);
\r
1656 Sec.lpSecurityDescriptor = NULL;
\r
1657 Sec.bInheritHandle = FALSE;
\r
1659 dwFileAttributes = GetFileAttributes(Pkt->LocalFile);
\r
1660 if (dwFileAttributes != INVALID_FILE_ATTRIBUTES && (dwFileAttributes & FILE_ATTRIBUTE_READONLY)) {
\r
1662 if (MessageBox(GetMainHwnd(), MSGJPN296, MSGJPN086, MB_YESNO) == IDYES) {
\r
1664 SetFileAttributes(Pkt->LocalFile, dwFileAttributes ^ FILE_ATTRIBUTE_READONLY);
\r
1668 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
1671 char Buf3[(BUFSIZE + 3) * 4];
\r
1672 CODECONVINFO cInfo2;
\r
1673 int ProcessedBOM = NO;
\r
1674 // 4GB超対応(kaokunさん提供)
\r
1676 if(CreateMode == OPEN_ALWAYS)
\r
1677 // 4GB超対応(kaokunさん提供)
\r
1678 // SetFilePointer(iFileHandle, 0, 0, FILE_END);
\r
1679 SetFilePointer(iFileHandle, 0, &High, FILE_END);
\r
1681 if(Pkt->hWndTrans != NULL)
\r
1684 // TimeStart = time(NULL);
\r
1685 TimeStart[Pkt->ThreadCount] = time(NULL);
\r
1686 SetTimer(Pkt->hWndTrans, TIMER_DISPLAY, DISPLAY_TIMING, NULL);
\r
1689 InitCodeConvInfo(&cInfo);
\r
1690 cInfo.KanaCnv = Pkt->KanaCnv;
\r
1692 InitCodeConvInfo(&cInfo2);
\r
1693 cInfo2.KanaCnv = Pkt->KanaCnv;
\r
1695 /*===== ファイルを受信するループ =====*/
\r
1696 while((Pkt->Abort == ABORT_NONE) && (ForceAbort == NO))
\r
1698 // FD_ZERO(&ReadFds);
\r
1699 // FD_SET(dSkt, &ReadFds);
\r
1700 // ToutPtr = NULL;
\r
1701 // if(TimeOut != 0)
\r
1703 // Tout.tv_sec = TimeOut;
\r
1704 // Tout.tv_usec = 0;
\r
1705 // ToutPtr = &Tout;
\r
1707 // iNumBytes = select(0, &ReadFds, NULL, NULL, ToutPtr);
\r
1708 // if(iNumBytes == SOCKET_ERROR)
\r
1710 // ReportWSError("select", WSAGetLastError());
\r
1711 // if(Pkt->Abort == ABORT_NONE)
\r
1712 // Pkt->Abort = ABORT_ERROR;
\r
1715 // else if(iNumBytes == 0)
\r
1717 // SetErrorMsg(MSGJPN094);
\r
1718 // SetTaskMsg(MSGJPN094);
\r
1719 // Pkt->Abort = ABORT_ERROR;
\r
1723 if((iNumBytes = do_recv(dSkt, Buf, BUFSIZE, 0, &TimeOutErr, CancelCheckWork)) <= 0)
\r
1725 if(TimeOutErr == YES)
\r
1727 SetErrorMsg(MSGJPN094);
\r
1728 SetTaskMsg(MSGJPN094);
\r
1729 if(Pkt->hWndTrans != NULL)
\r
1731 if(Pkt->Abort == ABORT_NONE)
\r
1732 Pkt->Abort = ABORT_ERROR;
\r
1734 else if(iNumBytes == SOCKET_ERROR)
\r
1736 if(Pkt->Abort == ABORT_NONE)
\r
1737 Pkt->Abort = ABORT_ERROR;
\r
1743 if(Pkt->KanjiCode != KANJI_NOCNV)
\r
1746 cInfo.StrLen = iNumBytes;
\r
1748 cInfo.BufSize = BUFSIZE+3;
\r
1751 // ここで全てUTF-8へ変換する
\r
1752 // TODO: SJIS以外も直接UTF-8へ変換
\r
1753 // if(Pkt->KanjiCode == KANJI_JIS)
\r
1754 // Continue = ConvJIStoSJIS(&cInfo);
\r
1756 // Continue = ConvEUCtoSJIS(&cInfo);
\r
1757 switch(Pkt->KanjiCode)
\r
1760 switch(Pkt->KanjiCodeDesired)
\r
1763 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1764 // cInfo2.OutLen = cInfo.StrLen;
\r
1767 Continue = ConvSJIStoJIS(&cInfo);
\r
1768 cInfo2.Str = cInfo.Buf;
\r
1769 cInfo2.StrLen = cInfo.OutLen;
\r
1770 cInfo2.Buf = Buf3;
\r
1771 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1772 ConvJIStoSJIS(&cInfo2);
\r
1775 Continue = ConvSJIStoJIS(&cInfo);
\r
1776 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1777 cInfo2.OutLen = cInfo.OutLen;
\r
1780 Continue = ConvSJIStoEUC(&cInfo);
\r
1781 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1782 cInfo2.OutLen = cInfo.OutLen;
\r
1785 Continue = ConvSJIStoUTF8N(&cInfo);
\r
1786 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1787 cInfo2.OutLen = cInfo.OutLen;
\r
1789 case KANJI_UTF8BOM:
\r
1790 if(ProcessedBOM == NO)
\r
1792 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
1793 cInfo2.OutLen = 3;
\r
1795 ProcessedBOM = YES;
\r
1798 Continue = ConvSJIStoUTF8N(&cInfo);
\r
1799 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1800 cInfo2.OutLen = cInfo.OutLen;
\r
1805 switch(Pkt->KanjiCodeDesired)
\r
1808 Continue = ConvJIStoSJIS(&cInfo);
\r
1809 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1810 cInfo2.OutLen = cInfo.OutLen;
\r
1813 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1814 // cInfo2.OutLen = cInfo.StrLen;
\r
1817 Continue = ConvJIStoSJIS(&cInfo);
\r
1818 cInfo2.Str = cInfo.Buf;
\r
1819 cInfo2.StrLen = cInfo.OutLen;
\r
1820 cInfo2.Buf = Buf3;
\r
1821 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1822 ConvSJIStoJIS(&cInfo2);
\r
1825 Continue = ConvJIStoSJIS(&cInfo);
\r
1826 cInfo2.Str = cInfo.Buf;
\r
1827 cInfo2.StrLen = cInfo.OutLen;
\r
1828 cInfo2.Buf = Buf3;
\r
1829 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1830 ConvSJIStoEUC(&cInfo2);
\r
1833 Continue = ConvJIStoSJIS(&cInfo);
\r
1834 cInfo2.Str = cInfo.Buf;
\r
1835 cInfo2.StrLen = cInfo.OutLen;
\r
1836 cInfo2.Buf = Buf3;
\r
1837 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1838 ConvSJIStoUTF8N(&cInfo2);
\r
1840 case KANJI_UTF8BOM:
\r
1841 if(ProcessedBOM == NO)
\r
1843 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
1844 cInfo2.OutLen = 3;
\r
1846 ProcessedBOM = YES;
\r
1849 Continue = ConvJIStoSJIS(&cInfo);
\r
1850 cInfo2.Str = cInfo.Buf;
\r
1851 cInfo2.StrLen = cInfo.OutLen;
\r
1852 cInfo2.Buf = Buf3;
\r
1853 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1854 ConvSJIStoUTF8N(&cInfo2);
\r
1859 switch(Pkt->KanjiCodeDesired)
\r
1862 Continue = ConvEUCtoSJIS(&cInfo);
\r
1863 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1864 cInfo2.OutLen = cInfo.OutLen;
\r
1867 Continue = ConvEUCtoSJIS(&cInfo);
\r
1868 cInfo2.Str = cInfo.Buf;
\r
1869 cInfo2.StrLen = cInfo.OutLen;
\r
1870 cInfo2.Buf = Buf3;
\r
1871 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1872 ConvSJIStoJIS(&cInfo2);
\r
1875 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1876 // cInfo2.OutLen = cInfo.StrLen;
\r
1879 Continue = ConvEUCtoSJIS(&cInfo);
\r
1880 cInfo2.Str = cInfo.Buf;
\r
1881 cInfo2.StrLen = cInfo.OutLen;
\r
1882 cInfo2.Buf = Buf3;
\r
1883 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1884 ConvSJIStoEUC(&cInfo2);
\r
1887 Continue = ConvEUCtoSJIS(&cInfo);
\r
1888 cInfo2.Str = cInfo.Buf;
\r
1889 cInfo2.StrLen = cInfo.OutLen;
\r
1890 cInfo2.Buf = Buf3;
\r
1891 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1892 ConvSJIStoUTF8N(&cInfo2);
\r
1894 case KANJI_UTF8BOM:
\r
1895 if(ProcessedBOM == NO)
\r
1897 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
1898 cInfo2.OutLen = 3;
\r
1900 ProcessedBOM = YES;
\r
1903 Continue = ConvEUCtoSJIS(&cInfo);
\r
1904 cInfo2.Str = cInfo.Buf;
\r
1905 cInfo2.StrLen = cInfo.OutLen;
\r
1906 cInfo2.Buf = Buf3;
\r
1907 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1908 ConvSJIStoUTF8N(&cInfo2);
\r
1913 switch(Pkt->KanjiCodeDesired)
\r
1916 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1917 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1918 cInfo2.OutLen = cInfo.OutLen;
\r
1921 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1922 cInfo2.Str = cInfo.Buf;
\r
1923 cInfo2.StrLen = cInfo.OutLen;
\r
1924 cInfo2.Buf = Buf3;
\r
1925 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1926 ConvSJIStoJIS(&cInfo2);
\r
1929 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1930 cInfo2.Str = cInfo.Buf;
\r
1931 cInfo2.StrLen = cInfo.OutLen;
\r
1932 cInfo2.Buf = Buf3;
\r
1933 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1934 ConvSJIStoEUC(&cInfo2);
\r
1937 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1938 cInfo2.OutLen = cInfo.StrLen;
\r
1941 case KANJI_UTF8BOM:
\r
1942 if(ProcessedBOM == NO)
\r
1944 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
1945 cInfo2.OutLen = 3;
\r
1947 ProcessedBOM = YES;
\r
1950 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
1951 cInfo2.OutLen = cInfo.StrLen;
\r
1956 case KANJI_UTF8BOM:
\r
1957 if(ProcessedBOM == NO)
\r
1959 if(memcmp(Buf, "\xEF\xBB\xBF", 3) == 0)
\r
1962 cInfo.StrLen -= 3;
\r
1964 cInfo2.OutLen = 0;
\r
1965 switch(Pkt->KanjiCodeDesired)
\r
1967 case KANJI_UTF8BOM:
\r
1968 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
1969 cInfo2.OutLen = 3;
\r
1973 ProcessedBOM = YES;
\r
1976 switch(Pkt->KanjiCodeDesired)
\r
1979 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1980 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
1981 cInfo2.OutLen = cInfo.OutLen;
\r
1984 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1985 cInfo2.Str = cInfo.Buf;
\r
1986 cInfo2.StrLen = cInfo.OutLen;
\r
1987 cInfo2.Buf = Buf3;
\r
1988 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1989 ConvSJIStoJIS(&cInfo2);
\r
1992 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
1993 cInfo2.Str = cInfo.Buf;
\r
1994 cInfo2.StrLen = cInfo.OutLen;
\r
1995 cInfo2.Buf = Buf3;
\r
1996 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
1997 ConvSJIStoEUC(&cInfo2);
\r
2000 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
2001 cInfo2.OutLen = cInfo.StrLen;
\r
2004 case KANJI_UTF8BOM:
\r
2005 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
2006 cInfo2.OutLen = cInfo.StrLen;
\r
2012 // if(WriteFile(iFileHandle, Buf2, cInfo.OutLen, &Writed, NULL) == FALSE)
\r
2013 if(WriteFile(iFileHandle, Buf3, cInfo2.OutLen, &Writed, NULL) == FALSE)
\r
2014 Pkt->Abort = ABORT_DISKFULL;
\r
2016 while((Continue == YES) && (Pkt->Abort == ABORT_NONE));
\r
2020 if(WriteFile(iFileHandle, Buf, iNumBytes, &Writed, NULL) == FALSE)
\r
2021 Pkt->Abort = ABORT_DISKFULL;
\r
2024 Pkt->ExistSize += iNumBytes;
\r
2025 if(Pkt->hWndTrans != NULL)
\r
2027 // AllTransSizeNow += iNumBytes;
\r
2028 AllTransSizeNow[Pkt->ThreadCount] += iNumBytes;
\r
2031 /* 転送ダイアログを出さない時の経過表示 */
\r
2032 DispDownloadSize(Pkt->ExistSize);
\r
2035 if(BackgrndMessageProc() == YES)
\r
2039 /* 書き残したデータを書き込む */
\r
2040 if(Pkt->KanjiCode != KANJI_NOCNV)
\r
2043 cInfo.BufSize = BUFSIZE+3;
\r
2044 FlushRestData(&cInfo);
\r
2045 switch(Pkt->KanjiCode)
\r
2048 switch(Pkt->KanjiCodeDesired)
\r
2052 cInfo2.Str = cInfo.Buf;
\r
2053 cInfo2.StrLen = cInfo.OutLen;
\r
2054 cInfo2.Buf = Buf3;
\r
2055 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2056 ConvJIStoSJIS(&cInfo2);
\r
2059 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2060 cInfo2.OutLen = cInfo.OutLen;
\r
2063 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2064 cInfo2.OutLen = cInfo.OutLen;
\r
2067 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2068 cInfo2.OutLen = cInfo.OutLen;
\r
2070 case KANJI_UTF8BOM:
\r
2071 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2072 cInfo2.OutLen = cInfo.OutLen;
\r
2077 switch(Pkt->KanjiCodeDesired)
\r
2080 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2081 cInfo2.OutLen = cInfo.OutLen;
\r
2085 cInfo2.Str = cInfo.Buf;
\r
2086 cInfo2.StrLen = cInfo.OutLen;
\r
2087 cInfo2.Buf = Buf3;
\r
2088 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2089 ConvSJIStoJIS(&cInfo2);
\r
2092 cInfo2.Str = cInfo.Buf;
\r
2093 cInfo2.StrLen = cInfo.OutLen;
\r
2094 cInfo2.Buf = Buf3;
\r
2095 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2096 ConvSJIStoEUC(&cInfo2);
\r
2099 cInfo2.Str = cInfo.Buf;
\r
2100 cInfo2.StrLen = cInfo.OutLen;
\r
2101 cInfo2.Buf = Buf3;
\r
2102 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2103 ConvSJIStoUTF8N(&cInfo2);
\r
2105 case KANJI_UTF8BOM:
\r
2106 cInfo2.Str = cInfo.Buf;
\r
2107 cInfo2.StrLen = cInfo.OutLen;
\r
2108 cInfo2.Buf = Buf3;
\r
2109 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2110 ConvSJIStoUTF8N(&cInfo2);
\r
2115 switch(Pkt->KanjiCodeDesired)
\r
2118 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2119 cInfo2.OutLen = cInfo.OutLen;
\r
2122 cInfo2.Str = cInfo.Buf;
\r
2123 cInfo2.StrLen = cInfo.OutLen;
\r
2124 cInfo2.Buf = Buf3;
\r
2125 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2126 ConvSJIStoJIS(&cInfo2);
\r
2130 cInfo2.Str = cInfo.Buf;
\r
2131 cInfo2.StrLen = cInfo.OutLen;
\r
2132 cInfo2.Buf = Buf3;
\r
2133 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2134 ConvSJIStoEUC(&cInfo2);
\r
2137 cInfo2.Str = cInfo.Buf;
\r
2138 cInfo2.StrLen = cInfo.OutLen;
\r
2139 cInfo2.Buf = Buf3;
\r
2140 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2141 ConvSJIStoUTF8N(&cInfo2);
\r
2143 case KANJI_UTF8BOM:
\r
2144 cInfo2.Str = cInfo.Buf;
\r
2145 cInfo2.StrLen = cInfo.OutLen;
\r
2146 cInfo2.Buf = Buf3;
\r
2147 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2148 ConvSJIStoUTF8N(&cInfo2);
\r
2153 switch(Pkt->KanjiCodeDesired)
\r
2156 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2157 cInfo2.OutLen = cInfo.OutLen;
\r
2160 cInfo2.Str = cInfo.Buf;
\r
2161 cInfo2.StrLen = cInfo.OutLen;
\r
2162 cInfo2.Buf = Buf3;
\r
2163 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2164 ConvSJIStoJIS(&cInfo2);
\r
2167 cInfo2.Str = cInfo.Buf;
\r
2168 cInfo2.StrLen = cInfo.OutLen;
\r
2169 cInfo2.Buf = Buf3;
\r
2170 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2171 ConvSJIStoEUC(&cInfo2);
\r
2174 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2175 cInfo2.OutLen = cInfo.OutLen;
\r
2177 case KANJI_UTF8BOM:
\r
2178 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2179 cInfo2.OutLen = cInfo.OutLen;
\r
2183 case KANJI_UTF8BOM:
\r
2184 switch(Pkt->KanjiCodeDesired)
\r
2187 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2188 cInfo2.OutLen = cInfo.OutLen;
\r
2191 cInfo2.Str = cInfo.Buf;
\r
2192 cInfo2.StrLen = cInfo.OutLen;
\r
2193 cInfo2.Buf = Buf3;
\r
2194 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2195 ConvSJIStoJIS(&cInfo2);
\r
2198 cInfo2.Str = cInfo.Buf;
\r
2199 cInfo2.StrLen = cInfo.OutLen;
\r
2200 cInfo2.Buf = Buf3;
\r
2201 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2202 ConvSJIStoEUC(&cInfo2);
\r
2205 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2206 cInfo2.OutLen = cInfo.OutLen;
\r
2208 case KANJI_UTF8BOM:
\r
2209 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
2210 cInfo2.OutLen = cInfo.OutLen;
\r
2215 // if(WriteFile(iFileHandle, Buf2, cInfo.OutLen, &Writed, NULL) == FALSE)
\r
2216 if(WriteFile(iFileHandle, Buf3, cInfo2.OutLen, &Writed, NULL) == FALSE)
\r
2217 Pkt->Abort = ABORT_DISKFULL;
\r
2218 cInfo2.Buf = Buf3;
\r
2219 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
2220 FlushRestData(&cInfo2);
\r
2221 if(WriteFile(iFileHandle, Buf3, cInfo2.OutLen, &Writed, NULL) == FALSE)
\r
2222 Pkt->Abort = ABORT_DISKFULL;
\r
2226 if(Pkt->hWndTrans != NULL)
\r
2228 KillTimer(Pkt->hWndTrans, TIMER_DISPLAY);
\r
2229 DispTransferStatus(Pkt->hWndTrans, YES, Pkt);
\r
2231 // TimeStart = time(NULL) - TimeStart + 1;
\r
2232 TimeStart[Pkt->ThreadCount] = time(NULL) - TimeStart[Pkt->ThreadCount] + 1;
\r
2236 /* 転送ダイアログを出さない時の経過表示を消す */
\r
2237 DispDownloadSize(-1);
\r
2240 /* ファイルのタイムスタンプを合わせる */
\r
2241 if((SaveTimeStamp == YES) &&
\r
2242 ((Pkt->Time.dwLowDateTime != 0) || (Pkt->Time.dwHighDateTime != 0)))
\r
2244 SetFileTime(iFileHandle, &Pkt->Time, &Pkt->Time, &Pkt->Time);
\r
2247 CloseHandle(iFileHandle);
\r
2249 if(iNumBytes == SOCKET_ERROR)
\r
2250 ReportWSError("recv",WSAGetLastError());
\r
2254 SetErrorMsg(MSGJPN095, Pkt->LocalFile);
\r
2255 SetTaskMsg(MSGJPN095, Pkt->LocalFile);
\r
2256 Pkt->Abort = ABORT_ERROR;
\r
2260 if(shutdown(dSkt, 1) != 0)
\r
2261 ReportWSError("shutdown", WSAGetLastError());
\r
2265 if(ForceAbort == NO)
\r
2267 /* Abortをホストに伝える */
\r
2268 if(Pkt->Abort != ABORT_NONE && iFileHandle != INVALID_HANDLE_VALUE)
\r
2270 SendData(Pkt->ctrl_skt, "\xFF\xF4\xFF", 3, MSG_OOB, CancelCheckWork); /* MSG_OOBに注意 */
\r
2271 SendData(Pkt->ctrl_skt, "\xF2", 1, 0, CancelCheckWork);
\r
2272 command(Pkt->ctrl_skt, NULL, CancelCheckWork, "ABOR");
\r
2276 iRetCode = ReadReplyMessage(Pkt->ctrl_skt, Buf, 1024, CancelCheckWork, TmpBuf);
\r
2279 //DoPrintf("##DOWN REPLY : %s", Buf);
\r
2281 if(Pkt->Abort == ABORT_DISKFULL)
\r
2283 SetErrorMsg(MSGJPN096);
\r
2284 SetTaskMsg(MSGJPN096);
\r
2287 // if(iRetCode >= FTP_RETRY)
\r
2288 if((iRetCode/100) >= FTP_RETRY)
\r
2290 if(Pkt->Abort != ABORT_NONE)
\r
2297 /*----- ダウンロード終了/中止時のメッセージを表示 ----------------------------
\r
2300 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2301 * int iRetCode : 応答コード
\r
2305 *----------------------------------------------------------------------------*/
\r
2307 static void DispDownloadFinishMsg(TRANSPACKET *Pkt, int iRetCode)
\r
2309 char Fname[FMAX_PATH+1];
\r
2312 ReleaseMutex(hListAccMutex);
\r
2313 if(ForceAbort == NO)
\r
2315 if((iRetCode/100) >= FTP_CONTINUE)
\r
2317 strcpy(Fname, Pkt->RemoteFile);
\r
2319 #if defined(HAVE_OPENVMS)
\r
2320 /* OpenVMSの場合、空ディレクトリへ移動すると550 File not foundになって
\r
2321 * エラーダイアログやエラーメッセージが出るので何もしない */
\r
2322 if (AskHostType() == HTYPE_VMS)
\r
2325 #if defined(HAVE_TANDEM)
\r
2326 /* HP Nonstop Server の場合、ファイルのない subvol へ移動すると550 File not found
\r
2327 * になるが問題ないのでエラーダイアログやエラーメッセージを出さないため */
\r
2328 if (AskHostType() == HTYPE_TANDEM)
\r
2333 // if((strncmp(Pkt->Cmd, "NLST", 4) == 0) || (strncmp(Pkt->Cmd, "LIST", 4) == 0))
\r
2334 if((strncmp(Pkt->Cmd, "NLST", 4) == 0) || (strncmp(Pkt->Cmd, "LIST", 4) == 0) || (strncmp(Pkt->Cmd, "MLSD", 4) == 0))
\r
2336 SetTaskMsg(MSGJPN097);
\r
2337 strcpy(Fname, MSGJPN098);
\r
2340 // else if((Pkt->hWndTrans != NULL) && (TimeStart != 0))
\r
2341 // SetTaskMsg(MSGJPN099, TimeStart, Pkt->ExistSize/TimeStart);
\r
2342 else if((Pkt->hWndTrans != NULL) && (TimeStart[Pkt->ThreadCount] != 0))
\r
2343 SetTaskMsg(MSGJPN099, TimeStart[Pkt->ThreadCount], Pkt->ExistSize/TimeStart[Pkt->ThreadCount]);
\r
2345 SetTaskMsg(MSGJPN100);
\r
2347 if(Pkt->Abort != ABORT_USER)
\r
2349 // 全て中止を選択後にダイアログが表示されるバグ対策
\r
2350 // if(DispUpDownErrDialog(downerr_dlg, Pkt->hWndTrans, Fname) == NO)
\r
2352 // if(Canceled[Pkt->ThreadCount] == NO && ClearAll == NO && DispUpDownErrDialog(downerr_dlg, Pkt->hWndTrans, Fname) == NO)
\r
2353 // ClearAll = YES;
\r
2354 if(Canceled[Pkt->ThreadCount] == NO && ClearAll == NO)
\r
2356 if(strncmp(Pkt->Cmd, "RETR", 4) == 0 || strncmp(Pkt->Cmd, "STOR", 4) == 0)
\r
2358 if(TransferErrorNotify == YES && DispUpDownErrDialog(downerr_dlg, Pkt->hWndTrans, Pkt) == NO)
\r
2362 Pkt->Mode = TransferErrorMode;
\r
2363 AddTransFileList(Pkt);
\r
2372 // if((strncmp(Pkt->Cmd, "NLST", 4) == 0) || (strncmp(Pkt->Cmd, "LIST", 4) == 0))
\r
2373 if((strncmp(Pkt->Cmd, "NLST", 4) == 0) || (strncmp(Pkt->Cmd, "LIST", 4) == 0) || (strncmp(Pkt->Cmd, "MLSD", 4) == 0))
\r
2374 SetTaskMsg(MSGJPN101, Pkt->ExistSize);
\r
2376 // else if((Pkt->hWndTrans != NULL) && (TimeStart != 0))
\r
2377 // SetTaskMsg(MSGJPN102, TimeStart, Pkt->ExistSize/TimeStart);
\r
2378 else if((Pkt->hWndTrans != NULL) && (TimeStart[Pkt->ThreadCount] != 0))
\r
2379 // "0 B/S"と表示されるバグを修正
\r
2380 // 原因は%dにあたる部分に64ビット値が渡されているため
\r
2381 // SetTaskMsg(MSGJPN102, TimeStart[Pkt->ThreadCount], Pkt->ExistSize/TimeStart[Pkt->ThreadCount]);
\r
2382 SetTaskMsg(MSGJPN102, (LONG)TimeStart[Pkt->ThreadCount], (LONG)(Pkt->ExistSize/TimeStart[Pkt->ThreadCount]));
\r
2384 SetTaskMsg(MSGJPN103, Pkt->ExistSize);
\r
2391 /*----- ダウンロード/アップロードエラーのダイアログを表示 --------------------
\r
2394 * int RedID : ダイアログボックスのリソースID
\r
2395 * HWND hWnd : 書き込み中ダイアログのウインドウ
\r
2396 * char *Fname : ファイル名
\r
2399 * int ステータス (YES=中止/NO=全て中止)
\r
2400 *----------------------------------------------------------------------------*/
\r
2403 //static int DispUpDownErrDialog(int ResID, HWND hWnd, char *Fname)
\r
2404 static int DispUpDownErrDialog(int ResID, HWND hWnd, TRANSPACKET *Pkt)
\r
2407 hWnd = GetMainHwnd();
\r
2409 SoundPlay(SND_ERROR);
\r
2411 // return(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(ResID), hWnd, UpDownErrorDialogProc, (LPARAM)Fname));
\r
2412 return(DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(ResID), hWnd, UpDownErrorDialogProc, (LPARAM)Pkt));
\r
2416 /*----- ダウンロードエラー/アップロードエラーダイアログのコールバック --------
\r
2419 * HWND hDlg : ウインドウハンドル
\r
2420 * UINT message : メッセージ番号
\r
2421 * WPARAM wParam : メッセージの WPARAM 引数
\r
2422 * LPARAM lParam : メッセージの LPARAM 引数
\r
2426 *----------------------------------------------------------------------------*/
\r
2429 //static BOOL CALLBACK UpDownErrorDialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
\r
2430 static INT_PTR CALLBACK UpDownErrorDialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
\r
2432 static TRANSPACKET *Pkt;
\r
2433 static const RADIOBUTTON DownExistButton[] = {
\r
2434 { DOWN_EXIST_OVW, EXIST_OVW },
\r
2435 { DOWN_EXIST_RESUME, EXIST_RESUME },
\r
2436 { DOWN_EXIST_IGNORE, EXIST_IGNORE }
\r
2438 #define DOWNEXISTBUTTONS (sizeof(DownExistButton)/sizeof(RADIOBUTTON))
\r
2442 case WM_INITDIALOG :
\r
2443 Pkt = (TRANSPACKET *)lParam;
\r
2444 // SendDlgItemMessage(hDlg, UPDOWN_ERR_FNAME, WM_SETTEXT, 0, (LPARAM)lParam);
\r
2445 SendDlgItemMessage(hDlg, UPDOWN_ERR_FNAME, WM_SETTEXT, 0, (LPARAM)Pkt->RemoteFile);
\r
2447 // SendDlgItemMessage(hDlg, UPDOWN_ERR_MSG, WM_SETTEXT, 0, (LPARAM)ErrMsg);
\r
2448 SendDlgItemMessage(hDlg, UPDOWN_ERR_MSG, WM_SETTEXT, 0, (LPARAM)GetErrMsg());
\r
2450 if((Pkt->Type == TYPE_A) || (Pkt->ExistSize <= 0))
\r
2451 EnableWindow(GetDlgItem(hDlg, DOWN_EXIST_RESUME), FALSE);
\r
2453 SetRadioButtonByValue(hDlg, TransferErrorMode, DownExistButton, DOWNEXISTBUTTONS);
\r
2457 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2460 TransferErrorNotify = NO;
\r
2461 /* ここに break はない */
\r
2464 TransferErrorMode = AskRadioButtonValue(hDlg, DownExistButton, DOWNEXISTBUTTONS);
\r
2465 EndDialog(hDlg, YES);
\r
2469 EndDialog(hDlg, NO);
\r
2473 // hHelpWin = HtmlHelp(NULL, AskHelpFilePath(), HH_HELP_CONTEXT, IDH_HELP_TOPIC_0000009);
\r
2482 /*----- ダウンロードのリジュームの準備を行う ----------------------------------
\r
2485 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2486 * iont ProcMode : 処理モード(EXIST_xxx)
\r
2487 * LONGLONG Size : ロード済みのファイルのサイズ
\r
2488 * int *Mode : ファイル作成モード (CREATE_xxxx)
\r
2491 * int 転送を行うかどうか(YES/NO=このファイルを中止/NO_ALL=全て中止)
\r
2494 * Pkt->ExistSizeのセットを行なう
\r
2495 *----------------------------------------------------------------------------*/
\r
2497 static int SetDownloadResume(TRANSPACKET *Pkt, int ProcMode, LONGLONG Size, int *Mode, int *CancelCheckWork)
\r
2501 char Reply[ERR_MSG_LEN+7];
\r
2506 Pkt->ExistSize = 0;
\r
2507 *Mode = CREATE_ALWAYS;
\r
2509 if(ProcMode == EXIST_RESUME)
\r
2511 iRetCode = command(Pkt->ctrl_skt, Reply, CancelCheckWork, "REST %s", MakeNumString(Size, Tmp, FALSE));
\r
2512 if(iRetCode/100 < FTP_RETRY)
\r
2515 if(Pkt->hWndTrans != NULL)
\r
2516 Pkt->ExistSize = Size;
\r
2517 *Mode = OPEN_ALWAYS;
\r
2521 Com = DialogBox(GetFtpInst(), MAKEINTRESOURCE(noresume_dlg), Pkt->hWndTrans, NoResumeWndProc);
\r
2524 if(Com == NO_ALL) /* 全て中止 */
\r
2526 Pkt->Abort = ABORT_USER;
\r
2534 /*----- resumeエラーダイアログのコールバック ----------------------------------
\r
2537 * HWND hDlg : ウインドウハンドル
\r
2538 * UINT message : メッセージ番号
\r
2539 * WPARAM wParam : メッセージの WPARAM 引数
\r
2540 * LPARAM lParam : メッセージの LPARAM 引数
\r
2544 *----------------------------------------------------------------------------*/
\r
2547 //static BOOL CALLBACK NoResumeWndProc(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2548 static INT_PTR CALLBACK NoResumeWndProc(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
2552 case WM_INITDIALOG :
\r
2556 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
2559 EndDialog(hDlg, YES);
\r
2563 EndDialog(hDlg, NO);
\r
2566 case RESUME_CANCEL_ALL :
\r
2567 EndDialog(hDlg, NO_ALL);
\r
2577 /*----- アップロードを行なう --------------------------------------------------
\r
2580 * SOCKET cSkt : コントロールソケット
\r
2581 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2585 *----------------------------------------------------------------------------*/
\r
2587 static int DoUpload(SOCKET cSkt, TRANSPACKET *Pkt)
\r
2590 char Reply[ERR_MSG_LEN+7];
\r
2592 Pkt->ctrl_skt = cSkt;
\r
2594 if(Pkt->Mode != EXIST_IGNORE)
\r
2596 if(CheckFileReadable(Pkt->LocalFile) == FFFTP_SUCCESS)
\r
2598 if(Pkt->Type == TYPE_I)
\r
2599 Pkt->KanjiCode = KANJI_NOCNV;
\r
2602 // iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled, "TYPE %c", Pkt->Type);
\r
2603 iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled[Pkt->ThreadCount], "TYPE %c", Pkt->Type);
\r
2604 if(iRetCode/100 < FTP_RETRY)
\r
2606 if(Pkt->Mode == EXIST_UNIQUE)
\r
2607 strcpy(Pkt->Cmd, "STOU ");
\r
2609 if(Pkt->hWndTrans != NULL)
\r
2610 DispTransFileInfo(Pkt, MSGJPN104, TRUE, YES);
\r
2613 // if(BackgrndMessageProc() == NO)
\r
2614 if(IsSFTPAttached(Pkt->ctrl_skt))
\r
2618 else if(BackgrndMessageProc() == NO)
\r
2620 if(AskPasvMode() != YES)
\r
2621 iRetCode = UploadNonPassive(Pkt);
\r
2623 iRetCode = UploadPassive(Pkt);
\r
2629 SetErrorMsg(Reply);
\r
2632 if((Pkt->Attr != -1) && ((iRetCode/100) == FTP_COMPLETE))
\r
2634 // command(Pkt->ctrl_skt, Reply, &Canceled, "%s %03X %s", AskHostChmodCmd(), Pkt->Attr, Pkt->RemoteFile);
\r
2635 command(Pkt->ctrl_skt, Reply, &Canceled[Pkt->ThreadCount], "%s %03X %s", AskHostChmodCmd(), Pkt->Attr, Pkt->RemoteFile);
\r
2639 SetErrorMsg(MSGJPN105, Pkt->LocalFile);
\r
2640 SetTaskMsg(MSGJPN105, Pkt->LocalFile);
\r
2642 Pkt->Abort = ABORT_ERROR;
\r
2643 // エラーによってはダイアログが表示されない場合があるバグ対策
\r
2644 // DispUploadFinishMsg(Pkt, iRetCode);
\r
2646 // エラーによってはダイアログが表示されない場合があるバグ対策
\r
2647 DispUploadFinishMsg(Pkt, iRetCode);
\r
2651 DispTransFileInfo(Pkt, MSGJPN106, TRUE, YES);
\r
2652 SetTaskMsg(MSGJPN107, Pkt->LocalFile);
\r
2659 /*----- 通常モードでファイルをアップロード ------------------------------------
\r
2662 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2666 *----------------------------------------------------------------------------*/
\r
2668 static int UploadNonPassive(TRANSPACKET *Pkt)
\r
2672 SOCKET data_socket = INVALID_SOCKET; // data channel socket
\r
2673 SOCKET listen_socket = INVALID_SOCKET; // data listen socket
\r
2675 // char Buf[1024];
\r
2676 char Buf[FMAX_PATH+1024];
\r
2678 // struct sockaddr_in saSockAddr1;
\r
2679 struct sockaddr_in saSockAddrIPv4;
\r
2680 struct sockaddr_in6 saSockAddrIPv6;
\r
2682 char Reply[ERR_MSG_LEN+7];
\r
2685 // if((listen_socket = GetFTPListenSocket(Pkt->ctrl_skt, &Canceled)) != INVALID_SOCKET)
\r
2686 if((listen_socket = GetFTPListenSocket(Pkt->ctrl_skt, &Canceled[Pkt->ThreadCount])) != INVALID_SOCKET)
\r
2688 SetUploadResume(Pkt, Pkt->Mode, Pkt->ExistSize, &Resume);
\r
2690 #if defined(HAVE_TANDEM)
\r
2691 if(AskHostType() == HTYPE_TANDEM && AskOSS() == NO && Pkt->Type != TYPE_A) {
\r
2692 if( Pkt->PriExt == DEF_PRIEXT && Pkt->SecExt == DEF_SECEXT && Pkt->MaxExt == DEF_MAXEXT) {
\r
2693 // EXTENTがデフォルトのときはコードのみ
\r
2694 sprintf(Buf, "%s%s,%d", Pkt->Cmd, Pkt->RemoteFile, Pkt->FileCode);
\r
2696 sprintf(Buf, "%s%s,%d,%d,%d,%d", Pkt->Cmd, Pkt->RemoteFile, Pkt->FileCode, Pkt->PriExt, Pkt->SecExt, Pkt->MaxExt);
\r
2700 sprintf(Buf, "%s%s", Pkt->Cmd, Pkt->RemoteFile);
\r
2702 sprintf(Buf, "%s%s", "APPE ", Pkt->RemoteFile);
\r
2705 // iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled, "%s", Buf);
\r
2706 iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled[Pkt->ThreadCount], "%s", Buf);
\r
2707 if((iRetCode/100) == FTP_PRELIM)
\r
2710 // 応答の形式に規格が無くファイル名を取得できないため属性変更を無効化
\r
2711 if(Pkt->Mode == EXIST_UNIQUE)
\r
2714 // if(SocksGet2ndBindReply(listen_socket, &data_socket) == FFFTP_FAIL)
\r
2715 if(SocksGet2ndBindReply(listen_socket, &data_socket, &Canceled[Pkt->ThreadCount]) == FFFTP_FAIL)
\r
2718 // iLength=sizeof(saSockAddr1);
\r
2719 // data_socket = do_accept(listen_socket,(struct sockaddr *)&saSockAddr1, (int *)&iLength);
\r
2720 switch(AskCurNetType())
\r
2723 iLength=sizeof(saSockAddrIPv4);
\r
2724 data_socket = do_accept(listen_socket,(struct sockaddr *)&saSockAddrIPv4, (int *)&iLength);
\r
2727 iLength=sizeof(saSockAddrIPv6);
\r
2728 data_socket = do_accept(listen_socket,(struct sockaddr *)&saSockAddrIPv6, (int *)&iLength);
\r
2732 if(shutdown(listen_socket, 1) != 0)
\r
2733 ReportWSError("shutdown listen", WSAGetLastError());
\r
2734 listen_socket = DoClose(listen_socket);
\r
2736 if(data_socket == INVALID_SOCKET)
\r
2738 SetErrorMsg(MSGJPN280);
\r
2739 ReportWSError("accept", WSAGetLastError());
\r
2744 // DoPrintf("Skt=%u : accept from %s port %u", data_socket, inet_ntoa(saSockAddr1.sin_addr), ntohs(saSockAddr1.sin_port));
\r
2746 switch(AskCurNetType())
\r
2749 DoPrintf("Skt=%u : accept from %s port %u", data_socket, inet_ntoa(saSockAddrIPv4.sin_addr), ntohs(saSockAddrIPv4.sin_port));
\r
2752 DoPrintf("Skt=%u : accept from %s port %u", data_socket, inet6_ntoa(saSockAddrIPv6.sin6_addr), ntohs(saSockAddrIPv6.sin6_port));
\r
2758 if(data_socket != INVALID_SOCKET)
\r
2760 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
2761 ReleaseMutex(hListAccMutex);
\r
2763 // iRetCode = UploadFile(Pkt, data_socket);
\r
2764 if(IsSSLAttached(Pkt->ctrl_skt))
\r
2766 if(AttachSSL(data_socket, Pkt->ctrl_skt, &Canceled[Pkt->ThreadCount]))
\r
2767 iRetCode = UploadFile(Pkt, data_socket);
\r
2772 iRetCode = UploadFile(Pkt, data_socket);
\r
2773 data_socket = DoClose(data_socket);
\r
2778 SetErrorMsg(Reply);
\r
2779 SetTaskMsg(MSGJPN108);
\r
2780 listen_socket = DoClose(listen_socket);
\r
2786 SetErrorMsg(MSGJPN279);
\r
2789 // エラーによってはダイアログが表示されない場合があるバグ対策
\r
2790 // DispUploadFinishMsg(Pkt, iRetCode);
\r
2796 /*----- Passiveモードでファイルをアップロード ---------------------------------
\r
2799 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2803 *----------------------------------------------------------------------------*/
\r
2805 static int UploadPassive(TRANSPACKET *Pkt)
\r
2808 SOCKET data_socket = INVALID_SOCKET; // data channel socket
\r
2810 // char Buf[1024];
\r
2811 char Buf[FMAX_PATH+1024];
\r
2818 char Reply[ERR_MSG_LEN+7];
\r
2821 // iRetCode = command(Pkt->ctrl_skt, Buf, &Canceled, "PASV");
\r
2823 // iRetCode = command(Pkt->ctrl_skt, Buf, &Canceled[Pkt->ThreadCount], "PASV");
\r
2824 switch(AskCurNetType())
\r
2827 iRetCode = command(Pkt->ctrl_skt, Buf, &Canceled[Pkt->ThreadCount], "PASV");
\r
2830 iRetCode = command(Pkt->ctrl_skt, Buf, &Canceled[Pkt->ThreadCount], "EPSV");
\r
2833 if(iRetCode/100 == FTP_COMPLETE)
\r
2836 // if(GetAdrsAndPort(Buf, Adrs, &Port, 19) == FFFTP_SUCCESS)
\r
2837 if(GetAdrsAndPort(Pkt->ctrl_skt, Buf, Adrs, &Port, 39) == FFFTP_SUCCESS)
\r
2840 // if((data_socket = connectsock(Adrs, Port, MSGJPN109, &Canceled)) != INVALID_SOCKET)
\r
2841 if((data_socket = connectsock(Adrs, Port, MSGJPN109, &Canceled[Pkt->ThreadCount])) != INVALID_SOCKET)
\r
2845 if(setsockopt(data_socket, IPPROTO_TCP, TCP_NODELAY, (LPSTR)&Flg, sizeof(Flg)) == SOCKET_ERROR)
\r
2846 ReportWSError("setsockopt", WSAGetLastError());
\r
2848 SetUploadResume(Pkt, Pkt->Mode, Pkt->ExistSize, &Resume);
\r
2850 #if defined(HAVE_TANDEM)
\r
2851 if(AskHostType() == HTYPE_TANDEM && AskOSS() == NO && Pkt->Type != TYPE_A) {
\r
2852 if( Pkt->PriExt == DEF_PRIEXT && Pkt->SecExt == DEF_SECEXT && Pkt->MaxExt == DEF_MAXEXT) {
\r
2853 // EXTENTがデフォルトのときはコードのみ
\r
2854 sprintf(Buf, "%s%s,%d", Pkt->Cmd, Pkt->RemoteFile, Pkt->FileCode);
\r
2856 sprintf(Buf, "%s%s,%d,%d,%d,%d", Pkt->Cmd, Pkt->RemoteFile, Pkt->FileCode, Pkt->PriExt, Pkt->SecExt, Pkt->MaxExt);
\r
2860 sprintf(Buf, "%s%s", Pkt->Cmd, Pkt->RemoteFile);
\r
2862 sprintf(Buf, "%s%s", "APPE ", Pkt->RemoteFile);
\r
2865 // iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled, "%s", Buf);
\r
2866 iRetCode = command(Pkt->ctrl_skt, Reply, &Canceled[Pkt->ThreadCount], "%s", Buf);
\r
2867 if(iRetCode/100 == FTP_PRELIM)
\r
2870 // 応答の形式に規格が無くファイル名を取得できないため属性変更を無効化
\r
2871 if(Pkt->Mode == EXIST_UNIQUE)
\r
2873 // 一部TYPE、STOR(RETR)、PORT(PASV)を並列に処理できないホストがあるため
\r
2874 ReleaseMutex(hListAccMutex);
\r
2876 // iRetCode = UploadFile(Pkt, data_socket);
\r
2877 if(IsSSLAttached(Pkt->ctrl_skt))
\r
2879 if(AttachSSL(data_socket, Pkt->ctrl_skt, &Canceled[Pkt->ThreadCount]))
\r
2880 iRetCode = UploadFile(Pkt, data_socket);
\r
2885 iRetCode = UploadFile(Pkt, data_socket);
\r
2887 data_socket = DoClose(data_socket);
\r
2891 SetErrorMsg(Reply);
\r
2892 SetTaskMsg(MSGJPN110);
\r
2893 data_socket = DoClose(data_socket);
\r
2899 SetErrorMsg(MSGJPN281);
\r
2906 SetTaskMsg(MSGJPN111);
\r
2913 // エラーによってはダイアログが表示されない場合があるバグ対策
\r
2914 // DispUploadFinishMsg(Pkt, iRetCode);
\r
2920 /*----- アップロードの実行 ----------------------------------------------------
\r
2923 * TRANSPACKET *Pkt : 転送ファイル情報
\r
2924 * SOCKET dSkt : データソケット
\r
2930 * 転送の経過表示は、インターバルタイマで経過を表示する
\r
2931 * 転送ダイアログを出さないでアップロードすることはない
\r
2932 *----------------------------------------------------------------------------*/
\r
2934 static int UploadFile(TRANSPACKET *Pkt, SOCKET dSkt)
\r
2937 HANDLE iFileHandle;
\r
2938 SECURITY_ATTRIBUTES Sec;
\r
2939 char Buf[BUFSIZE];
\r
2940 char Buf2[BUFSIZE+3];
\r
2941 CODECONVINFO cInfo;
\r
2942 TERMCODECONVINFO tInfo;
\r
2949 char TmpBuf[ONELINE_BUF_SIZE];
\r
2953 #ifdef SET_BUFFER_SIZE
\r
2954 /* Add by H.Shirouzu at 2002/10/02 */
\r
2955 int buf_size = SOCKBUF_SIZE;
\r
2956 for ( ; buf_size > 0; buf_size /= 2)
\r
2957 if (setsockopt(dSkt, SOL_SOCKET, SO_SNDBUF, (char *)&buf_size, sizeof(buf_size)) == 0)
\r
2962 // 念のため送信バッファを無効にする
\r
2963 #ifdef DISABLE_TRANSFER_NETWORK_BUFFERS
\r
2965 setsockopt(dSkt, SOL_SOCKET, SO_SNDBUF, (char *)&buf_size, sizeof(buf_size));
\r
2968 Pkt->Abort = ABORT_NONE;
\r
2970 Sec.nLength = sizeof(SECURITY_ATTRIBUTES);
\r
2971 Sec.lpSecurityDescriptor = NULL;
\r
2972 Sec.bInheritHandle = FALSE;
\r
2974 if((iFileHandle = CreateFile(Pkt->LocalFile, GENERIC_READ,
\r
2975 FILE_SHARE_READ|FILE_SHARE_WRITE, &Sec, OPEN_EXISTING, 0, NULL)) != INVALID_HANDLE_VALUE)
\r
2978 char Buf3[(BUFSIZE + 3) * 4];
\r
2979 CODECONVINFO cInfo2;
\r
2980 int ProcessedBOM = NO;
\r
2981 if(Pkt->hWndTrans != NULL)
\r
2983 Low = GetFileSize(iFileHandle, &High);
\r
2984 Pkt->Size = MakeLongLong(High, Low);
\r
2986 High = (DWORD)HIGH32(Pkt->ExistSize);
\r
2987 Low = (DWORD)LOW32(Pkt->ExistSize);
\r
2988 SetFilePointer(iFileHandle, Low, &High, FILE_BEGIN);
\r
2991 // AllTransSizeNow = 0;
\r
2992 // TimeStart = time(NULL);
\r
2993 AllTransSizeNow[Pkt->ThreadCount] = 0;
\r
2994 TimeStart[Pkt->ThreadCount] = time(NULL);
\r
2995 SetTimer(Pkt->hWndTrans, TIMER_DISPLAY, DISPLAY_TIMING, NULL);
\r
2998 InitCodeConvInfo(&cInfo);
\r
2999 cInfo.KanaCnv = Pkt->KanaCnv;
\r
3000 InitTermCodeConvInfo(&tInfo);
\r
3002 InitCodeConvInfo(&cInfo2);
\r
3003 cInfo2.KanaCnv = Pkt->KanaCnv;
\r
3005 /*===== ファイルを送信するループ =====*/
\r
3006 while((Pkt->Abort == ABORT_NONE) &&
\r
3007 (ForceAbort == NO) &&
\r
3008 (ReadFile(iFileHandle, Buf, BUFSIZE, &iNumBytes, NULL) == TRUE))
\r
3010 if(iNumBytes == 0)
\r
3015 if((RmEOF == YES) && (Pkt->Type == TYPE_A))
\r
3017 if((EofPos = memchr(Buf, 0x1A, iNumBytes)) != NULL)
\r
3018 iNumBytes = EofPos - Buf;
\r
3022 if(Pkt->KanjiCode != KANJI_NOCNV)
\r
3025 cInfo.StrLen = iNumBytes;
\r
3027 cInfo.BufSize = BUFSIZE+3;
\r
3030 // ここで全てUTF-8へ変換する
\r
3031 // TODO: SJIS以外も直接UTF-8へ変換
\r
3032 // if(Pkt->KanjiCode == KANJI_JIS)
\r
3033 // Continue = ConvSJIStoJIS(&cInfo);
\r
3035 // Continue = ConvSJIStoEUC(&cInfo);
\r
3036 switch(Pkt->KanjiCodeDesired)
\r
3039 switch(Pkt->KanjiCode)
\r
3042 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
3043 // cInfo2.OutLen = cInfo.StrLen;
\r
3046 Continue = ConvSJIStoJIS(&cInfo);
\r
3047 cInfo2.Str = cInfo.Buf;
\r
3048 cInfo2.StrLen = cInfo.OutLen;
\r
3049 cInfo2.Buf = Buf3;
\r
3050 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3051 ConvJIStoSJIS(&cInfo2);
\r
3054 Continue = ConvSJIStoJIS(&cInfo);
\r
3055 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3056 cInfo2.OutLen = cInfo.OutLen;
\r
3059 Continue = ConvSJIStoEUC(&cInfo);
\r
3060 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3061 cInfo2.OutLen = cInfo.OutLen;
\r
3064 Continue = ConvSJIStoUTF8N(&cInfo);
\r
3065 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3066 cInfo2.OutLen = cInfo.OutLen;
\r
3068 case KANJI_UTF8BOM:
\r
3069 if(ProcessedBOM == NO)
\r
3071 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
3072 cInfo2.OutLen = 3;
\r
3074 ProcessedBOM = YES;
\r
3077 Continue = ConvSJIStoUTF8N(&cInfo);
\r
3078 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3079 cInfo2.OutLen = cInfo.OutLen;
\r
3084 switch(Pkt->KanjiCode)
\r
3087 Continue = ConvJIStoSJIS(&cInfo);
\r
3088 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3089 cInfo2.OutLen = cInfo.OutLen;
\r
3092 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
3093 // cInfo2.OutLen = cInfo.StrLen;
\r
3096 Continue = ConvJIStoSJIS(&cInfo);
\r
3097 cInfo2.Str = cInfo.Buf;
\r
3098 cInfo2.StrLen = cInfo.OutLen;
\r
3099 cInfo2.Buf = Buf3;
\r
3100 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3101 ConvSJIStoJIS(&cInfo2);
\r
3104 Continue = ConvJIStoSJIS(&cInfo);
\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 Continue = ConvJIStoSJIS(&cInfo);
\r
3113 cInfo2.Str = cInfo.Buf;
\r
3114 cInfo2.StrLen = cInfo.OutLen;
\r
3115 cInfo2.Buf = Buf3;
\r
3116 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3117 ConvSJIStoUTF8N(&cInfo2);
\r
3119 case KANJI_UTF8BOM:
\r
3120 if(ProcessedBOM == NO)
\r
3122 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
3123 cInfo2.OutLen = 3;
\r
3125 ProcessedBOM = YES;
\r
3128 Continue = ConvJIStoSJIS(&cInfo);
\r
3129 cInfo2.Str = cInfo.Buf;
\r
3130 cInfo2.StrLen = cInfo.OutLen;
\r
3131 cInfo2.Buf = Buf3;
\r
3132 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3133 ConvSJIStoUTF8N(&cInfo2);
\r
3138 switch(Pkt->KanjiCode)
\r
3141 Continue = ConvEUCtoSJIS(&cInfo);
\r
3142 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3143 cInfo2.OutLen = cInfo.OutLen;
\r
3146 Continue = ConvEUCtoSJIS(&cInfo);
\r
3147 cInfo2.Str = cInfo.Buf;
\r
3148 cInfo2.StrLen = cInfo.OutLen;
\r
3149 cInfo2.Buf = Buf3;
\r
3150 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3151 ConvSJIStoJIS(&cInfo2);
\r
3154 // memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
3155 // cInfo2.OutLen = cInfo.StrLen;
\r
3158 Continue = ConvEUCtoSJIS(&cInfo);
\r
3159 cInfo2.Str = cInfo.Buf;
\r
3160 cInfo2.StrLen = cInfo.OutLen;
\r
3161 cInfo2.Buf = Buf3;
\r
3162 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3163 ConvSJIStoEUC(&cInfo2);
\r
3166 Continue = ConvEUCtoSJIS(&cInfo);
\r
3167 cInfo2.Str = cInfo.Buf;
\r
3168 cInfo2.StrLen = cInfo.OutLen;
\r
3169 cInfo2.Buf = Buf3;
\r
3170 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3171 ConvSJIStoUTF8N(&cInfo2);
\r
3173 case KANJI_UTF8BOM:
\r
3174 if(ProcessedBOM == NO)
\r
3176 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
3177 cInfo2.OutLen = 3;
\r
3179 ProcessedBOM = YES;
\r
3182 Continue = ConvEUCtoSJIS(&cInfo);
\r
3183 cInfo2.Str = cInfo.Buf;
\r
3184 cInfo2.StrLen = cInfo.OutLen;
\r
3185 cInfo2.Buf = Buf3;
\r
3186 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3187 ConvSJIStoUTF8N(&cInfo2);
\r
3192 switch(Pkt->KanjiCode)
\r
3195 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
3196 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3197 cInfo2.OutLen = cInfo.OutLen;
\r
3200 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
3201 cInfo2.Str = cInfo.Buf;
\r
3202 cInfo2.StrLen = cInfo.OutLen;
\r
3203 cInfo2.Buf = Buf3;
\r
3204 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3205 ConvSJIStoJIS(&cInfo2);
\r
3208 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
3209 cInfo2.Str = cInfo.Buf;
\r
3210 cInfo2.StrLen = cInfo.OutLen;
\r
3211 cInfo2.Buf = Buf3;
\r
3212 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3213 ConvSJIStoEUC(&cInfo2);
\r
3216 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
3217 cInfo2.OutLen = cInfo.StrLen;
\r
3220 case KANJI_UTF8BOM:
\r
3221 if(ProcessedBOM == NO)
\r
3223 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
3224 cInfo2.OutLen = 3;
\r
3226 ProcessedBOM = YES;
\r
3229 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
3230 cInfo2.OutLen = cInfo.StrLen;
\r
3235 case KANJI_UTF8BOM:
\r
3236 if(ProcessedBOM == NO)
\r
3238 if(memcmp(Buf, "\xEF\xBB\xBF", 3) == 0)
\r
3241 cInfo.StrLen -= 3;
\r
3243 cInfo2.OutLen = 0;
\r
3244 switch(Pkt->KanjiCode)
\r
3246 case KANJI_UTF8BOM:
\r
3247 memcpy(Buf3, "\xEF\xBB\xBF", 3);
\r
3248 cInfo2.OutLen = 3;
\r
3252 ProcessedBOM = YES;
\r
3255 switch(Pkt->KanjiCode)
\r
3258 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
3259 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3260 cInfo2.OutLen = cInfo.OutLen;
\r
3263 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
3264 cInfo2.Str = cInfo.Buf;
\r
3265 cInfo2.StrLen = cInfo.OutLen;
\r
3266 cInfo2.Buf = Buf3;
\r
3267 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3268 ConvSJIStoJIS(&cInfo2);
\r
3271 Continue = ConvUTF8NtoSJIS(&cInfo);
\r
3272 cInfo2.Str = cInfo.Buf;
\r
3273 cInfo2.StrLen = cInfo.OutLen;
\r
3274 cInfo2.Buf = Buf3;
\r
3275 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3276 ConvSJIStoEUC(&cInfo2);
\r
3279 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
3280 cInfo2.OutLen = cInfo.StrLen;
\r
3283 case KANJI_UTF8BOM:
\r
3284 memcpy(Buf3, cInfo.Str, cInfo.StrLen);
\r
3285 cInfo2.OutLen = cInfo.StrLen;
\r
3292 // if(TermCodeConvAndSend(&tInfo, dSkt, Buf2, cInfo.OutLen, Pkt->Type) == FFFTP_FAIL)
\r
3293 if(TermCodeConvAndSend(&tInfo, dSkt, Buf3, cInfo2.OutLen, Pkt->Type, &Canceled[Pkt->ThreadCount]) == FFFTP_FAIL)
\r
3295 Pkt->Abort = ABORT_ERROR;
\r
3299 while(Continue == YES);
\r
3304 // if(TermCodeConvAndSend(&tInfo, dSkt, Buf, iNumBytes, Pkt->Type) == FFFTP_FAIL)
\r
3305 if(TermCodeConvAndSend(&tInfo, dSkt, Buf, iNumBytes, Pkt->Type, &Canceled[Pkt->ThreadCount]) == FFFTP_FAIL)
\r
3306 Pkt->Abort = ABORT_ERROR;
\r
3309 Pkt->ExistSize += iNumBytes;
\r
3310 if(Pkt->hWndTrans != NULL)
\r
3312 // AllTransSizeNow += iNumBytes;
\r
3313 AllTransSizeNow[Pkt->ThreadCount] += iNumBytes;
\r
3315 if(BackgrndMessageProc() == YES)
\r
3318 if(EofPos != NULL)
\r
3322 if((ForceAbort == NO) && (Pkt->Abort == ABORT_NONE))
\r
3325 if(Pkt->KanjiCode != KANJI_NOCNV)
\r
3328 cInfo.BufSize = BUFSIZE+3;
\r
3329 FlushRestData(&cInfo);
\r
3330 switch(Pkt->KanjiCodeDesired)
\r
3333 switch(Pkt->KanjiCode)
\r
3337 cInfo2.Str = cInfo.Buf;
\r
3338 cInfo2.StrLen = cInfo.OutLen;
\r
3339 cInfo2.Buf = Buf3;
\r
3340 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3341 ConvJIStoSJIS(&cInfo2);
\r
3344 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3345 cInfo2.OutLen = cInfo.OutLen;
\r
3348 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3349 cInfo2.OutLen = cInfo.OutLen;
\r
3352 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3353 cInfo2.OutLen = cInfo.OutLen;
\r
3355 case KANJI_UTF8BOM:
\r
3356 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3357 cInfo2.OutLen = cInfo.OutLen;
\r
3362 switch(Pkt->KanjiCode)
\r
3365 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3366 cInfo2.OutLen = cInfo.OutLen;
\r
3370 cInfo2.Str = cInfo.Buf;
\r
3371 cInfo2.StrLen = cInfo.OutLen;
\r
3372 cInfo2.Buf = Buf3;
\r
3373 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3374 ConvSJIStoJIS(&cInfo2);
\r
3377 cInfo2.Str = cInfo.Buf;
\r
3378 cInfo2.StrLen = cInfo.OutLen;
\r
3379 cInfo2.Buf = Buf3;
\r
3380 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3381 ConvSJIStoEUC(&cInfo2);
\r
3384 cInfo2.Str = cInfo.Buf;
\r
3385 cInfo2.StrLen = cInfo.OutLen;
\r
3386 cInfo2.Buf = Buf3;
\r
3387 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3388 ConvSJIStoUTF8N(&cInfo2);
\r
3390 case KANJI_UTF8BOM:
\r
3391 cInfo2.Str = cInfo.Buf;
\r
3392 cInfo2.StrLen = cInfo.OutLen;
\r
3393 cInfo2.Buf = Buf3;
\r
3394 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3395 ConvSJIStoUTF8N(&cInfo2);
\r
3400 switch(Pkt->KanjiCode)
\r
3403 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3404 cInfo2.OutLen = cInfo.OutLen;
\r
3407 cInfo2.Str = cInfo.Buf;
\r
3408 cInfo2.StrLen = cInfo.OutLen;
\r
3409 cInfo2.Buf = Buf3;
\r
3410 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3411 ConvSJIStoJIS(&cInfo2);
\r
3415 cInfo2.Str = cInfo.Buf;
\r
3416 cInfo2.StrLen = cInfo.OutLen;
\r
3417 cInfo2.Buf = Buf3;
\r
3418 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3419 ConvSJIStoEUC(&cInfo2);
\r
3422 cInfo2.Str = cInfo.Buf;
\r
3423 cInfo2.StrLen = cInfo.OutLen;
\r
3424 cInfo2.Buf = Buf3;
\r
3425 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3426 ConvSJIStoUTF8N(&cInfo2);
\r
3428 case KANJI_UTF8BOM:
\r
3429 cInfo2.Str = cInfo.Buf;
\r
3430 cInfo2.StrLen = cInfo.OutLen;
\r
3431 cInfo2.Buf = Buf3;
\r
3432 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3433 ConvSJIStoUTF8N(&cInfo2);
\r
3438 switch(Pkt->KanjiCode)
\r
3441 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3442 cInfo2.OutLen = cInfo.OutLen;
\r
3445 cInfo2.Str = cInfo.Buf;
\r
3446 cInfo2.StrLen = cInfo.OutLen;
\r
3447 cInfo2.Buf = Buf3;
\r
3448 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3449 ConvSJIStoJIS(&cInfo2);
\r
3452 cInfo2.Str = cInfo.Buf;
\r
3453 cInfo2.StrLen = cInfo.OutLen;
\r
3454 cInfo2.Buf = Buf3;
\r
3455 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3456 ConvSJIStoEUC(&cInfo2);
\r
3459 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3460 cInfo2.OutLen = cInfo.OutLen;
\r
3462 case KANJI_UTF8BOM:
\r
3463 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3464 cInfo2.OutLen = cInfo.OutLen;
\r
3468 case KANJI_UTF8BOM:
\r
3469 switch(Pkt->KanjiCode)
\r
3472 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3473 cInfo2.OutLen = cInfo.OutLen;
\r
3476 cInfo2.Str = cInfo.Buf;
\r
3477 cInfo2.StrLen = cInfo.OutLen;
\r
3478 cInfo2.Buf = Buf3;
\r
3479 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3480 ConvSJIStoJIS(&cInfo2);
\r
3483 cInfo2.Str = cInfo.Buf;
\r
3484 cInfo2.StrLen = cInfo.OutLen;
\r
3485 cInfo2.Buf = Buf3;
\r
3486 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3487 ConvSJIStoEUC(&cInfo2);
\r
3490 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3491 cInfo2.OutLen = cInfo.OutLen;
\r
3493 case KANJI_UTF8BOM:
\r
3494 memcpy(Buf3, cInfo.Buf, cInfo.OutLen);
\r
3495 cInfo2.OutLen = cInfo.OutLen;
\r
3501 // if(TermCodeConvAndSend(&tInfo, dSkt, Buf2, cInfo.OutLen, Pkt->Type) == FFFTP_FAIL)
\r
3502 if(TermCodeConvAndSend(&tInfo, dSkt, Buf3, cInfo2.OutLen, Pkt->Type, &Canceled[Pkt->ThreadCount]) == FFFTP_FAIL)
\r
3503 Pkt->Abort = ABORT_ERROR;
\r
3504 cInfo2.Buf = Buf3;
\r
3505 cInfo2.BufSize = (BUFSIZE + 3) * 4;
\r
3506 FlushRestData(&cInfo2);
\r
3507 if(TermCodeConvAndSend(&tInfo, dSkt, Buf3, cInfo2.OutLen, Pkt->Type, &Canceled[Pkt->ThreadCount]) == FFFTP_FAIL)
\r
3508 Pkt->Abort = ABORT_ERROR;
\r
3512 tInfo.BufSize = BUFSIZE+3;
\r
3513 FlushRestTermCodeConvData(&tInfo);
\r
3515 // if(SendData(dSkt, Buf2, tInfo.OutLen, 0, &Canceled) == FFFTP_FAIL)
\r
3516 if(SendData(dSkt, Buf2, tInfo.OutLen, 0, &Canceled[Pkt->ThreadCount]) == FFFTP_FAIL)
\r
3517 Pkt->Abort = ABORT_ERROR;
\r
3521 if(Pkt->hWndTrans != NULL)
\r
3523 KillTimer(Pkt->hWndTrans, TIMER_DISPLAY);
\r
3524 DispTransferStatus(Pkt->hWndTrans, YES, Pkt);
\r
3526 // TimeStart = time(NULL) - TimeStart + 1;
\r
3527 TimeStart[Pkt->ThreadCount] = time(NULL) - TimeStart[Pkt->ThreadCount] + 1;
\r
3529 CloseHandle(iFileHandle);
\r
3533 SetErrorMsg(MSGJPN112, Pkt->LocalFile);
\r
3534 SetTaskMsg(MSGJPN112, Pkt->LocalFile);
\r
3535 Pkt->Abort = ABORT_ERROR;
\r
3538 if(shutdown(dSkt, 1) != 0)
\r
3539 ReportWSError("shutdown", WSAGetLastError());
\r
3543 while(do_recv(dSkt, Buf, BUFSIZE, 0, &TimeOutErr, &Canceled) > 0)
\r
3548 // iRetCode = ReadReplyMessage(Pkt->ctrl_skt, Buf, 1024, &Canceled, TmpBuf);
\r
3549 iRetCode = ReadReplyMessage(Pkt->ctrl_skt, Buf, 1024, &Canceled[Pkt->ThreadCount], TmpBuf);
\r
3552 //DoPrintf("##UP REPLY : %s", Buf);
\r
3555 // if(iRetCode >= FTP_RETRY)
\r
3556 if((iRetCode/100) >= FTP_RETRY)
\r
3559 if(Pkt->Abort != ABORT_NONE)
\r
3566 /*----- バッファの内容を改行コード変換して送信 --------------------------------
\r
3569 * TERMCODECONVINFO *tInfo : 改行コード変換パケット
\r
3570 * SOCKET Skt : ソケット
\r
3571 * char *Data : データ
\r
3572 * int Size : データのサイズ
\r
3573 * int Ascii : モード (TYPE_xx)
\r
3577 *----------------------------------------------------------------------------*/
\r
3580 //static int TermCodeConvAndSend(TERMCODECONVINFO *tInfo, SOCKET Skt, char *Data, int Size, int Ascii)
\r
3581 static int TermCodeConvAndSend(TERMCODECONVINFO *tInfo, SOCKET Skt, char *Data, int Size, int Ascii, int *CancelCheckWork)
\r
3583 char Buf3[BUFSIZE*2];
\r
3587 Ret = FFFTP_SUCCESS;
\r
3589 // CR-LF以外の改行コードを変換しないモードはここへ追加
\r
3590 if(Ascii == TYPE_A)
\r
3592 tInfo->Str = Data;
\r
3593 tInfo->StrLen = Size;
\r
3594 tInfo->Buf = Buf3;
\r
3595 tInfo->BufSize = BUFSIZE*2;
\r
3598 Continue = ConvTermCodeToCRLF(tInfo);
\r
3600 // if((Ret = SendData(Skt, Buf3, tInfo->OutLen, 0, &Canceled)) == FFFTP_FAIL)
\r
3601 if((Ret = SendData(Skt, Buf3, tInfo->OutLen, 0, CancelCheckWork)) == FFFTP_FAIL)
\r
3604 while(Continue == YES);
\r
3608 // Ret = SendData(Skt, Data, Size, 0, &Canceled);
\r
3609 Ret = SendData(Skt, Data, Size, 0, CancelCheckWork);
\r
3615 /*----- アップロード終了/中止時のメッセージを表示 ----------------------------
\r
3618 * TRANSPACKET *Pkt : 転送ファイル情報
\r
3619 * int iRetCode : 応答コード
\r
3623 *----------------------------------------------------------------------------*/
\r
3625 static void DispUploadFinishMsg(TRANSPACKET *Pkt, int iRetCode)
\r
3628 ReleaseMutex(hListAccMutex);
\r
3629 if(ForceAbort == NO)
\r
3631 if((iRetCode/100) >= FTP_CONTINUE)
\r
3634 // if((Pkt->hWndTrans != NULL) && (TimeStart != 0))
\r
3635 // SetTaskMsg(MSGJPN113, TimeStart, Pkt->ExistSize/TimeStart);
\r
3636 if((Pkt->hWndTrans != NULL) && (TimeStart[Pkt->ThreadCount] != 0))
\r
3637 SetTaskMsg(MSGJPN113, TimeStart[Pkt->ThreadCount], Pkt->ExistSize/TimeStart[Pkt->ThreadCount]);
\r
3639 SetTaskMsg(MSGJPN114);
\r
3641 if(Pkt->Abort != ABORT_USER)
\r
3643 // 全て中止を選択後にダイアログが表示されるバグ対策
\r
3644 // if(DispUpDownErrDialog(uperr_dlg, Pkt->hWndTrans, Pkt->LocalFile) == NO)
\r
3646 // if(Canceled[Pkt->ThreadCount] == NO && ClearAll == NO && DispUpDownErrDialog(uperr_dlg, Pkt->hWndTrans, Pkt->LocalFile) == NO)
\r
3647 // ClearAll = YES;
\r
3648 if(Canceled[Pkt->ThreadCount] == NO && ClearAll == NO)
\r
3650 if(strncmp(Pkt->Cmd, "RETR", 4) == 0 || strncmp(Pkt->Cmd, "STOR", 4) == 0)
\r
3652 if(TransferErrorNotify == YES && DispUpDownErrDialog(uperr_dlg, Pkt->hWndTrans, Pkt) == NO)
\r
3656 Pkt->Mode = TransferErrorMode;
\r
3657 AddTransFileList(Pkt);
\r
3666 // if((Pkt->hWndTrans != NULL) && (TimeStart != 0))
\r
3667 // SetTaskMsg(MSGJPN115, TimeStart, Pkt->ExistSize/TimeStart);
\r
3668 if((Pkt->hWndTrans != NULL) && (TimeStart[Pkt->ThreadCount] != 0))
\r
3669 // "0 B/S"と表示されるバグを修正
\r
3670 // 原因は%dにあたる部分に64ビット値が渡されているため
\r
3671 // SetTaskMsg(MSGJPN115, TimeStart[Pkt->ThreadCount], Pkt->ExistSize/TimeStart[Pkt->ThreadCount]);
\r
3672 SetTaskMsg(MSGJPN115, (LONG)TimeStart[Pkt->ThreadCount], (LONG)(Pkt->ExistSize/TimeStart[Pkt->ThreadCount]));
\r
3674 SetTaskMsg(MSGJPN116);
\r
3681 /*----- アップロードのリジュームの準備を行う ----------------------------------
\r
3684 * TRANSPACKET *Pkt : 転送ファイル情報
\r
3685 * iont ProcMode : 処理モード(EXIST_xxx)
\r
3686 * LONGLONG Size : ホストにあるファイルのサイズ
\r
3687 * int *Mode : リジュームを行うかどうか (YES/NO)
\r
3693 * Pkt->ExistSizeのセットを行なう
\r
3694 *----------------------------------------------------------------------------*/
\r
3696 static int SetUploadResume(TRANSPACKET *Pkt, int ProcMode, LONGLONG Size, int *Mode)
\r
3698 Pkt->ExistSize = 0;
\r
3700 if(ProcMode == EXIST_RESUME)
\r
3702 if(Pkt->hWndTrans != NULL)
\r
3704 Pkt->ExistSize = Size;
\r
3712 /*----- 転送中ダイアログボックスのコールバック --------------------------------
\r
3715 * HWND hDlg : ウインドウハンドル
\r
3716 * UINT message : メッセージ番号
\r
3717 * WPARAM wParam : メッセージの WPARAM 引数
\r
3718 * LPARAM lParam : メッセージの LPARAM 引数
\r
3722 *----------------------------------------------------------------------------*/
\r
3724 static LRESULT CALLBACK TransDlgProc(HWND hDlg, UINT Msg, WPARAM wParam, LPARAM lParam)
\r
3730 // static TRANSPACKET *Pkt;
\r
3736 case WM_INITDIALOG :
\r
3737 GetWindowRect(hDlg, &RectDlg);
\r
3738 RectDlg.right -= RectDlg.left;
\r
3739 RectDlg.bottom -= RectDlg.top;
\r
3740 GetWindowRect(GetMainHwnd(), &RectPar);
\r
3742 ((RectPar.right + RectPar.left) / 2) - (RectDlg.right / 2),
\r
3743 ((RectPar.bottom + RectPar.top) / 2) - (RectDlg.bottom / 2),
\r
3748 hMenu = GetSystemMenu(hDlg, FALSE);
\r
3749 EnableMenuItem(hMenu, SC_CLOSE, MF_GRAYED);
\r
3753 switch(LOWORD(wParam))
\r
3755 case TRANS_STOP_NEXT :
\r
3759 case TRANS_STOP_ALL :
\r
3761 for(i = 0; i < MAX_DATA_CONNECTION; i++)
\r
3762 Canceled[i] = YES;
\r
3763 /* ここに break はない */
\r
3767 // if(!(Pkt = (TRANSPACKET*)GetWindowLong(hDlg, GWL_USERDATA)))
\r
3768 if(!(Pkt = (TRANSPACKET*)GetWindowLongPtr(hDlg, GWLP_USERDATA)))
\r
3770 Pkt->Abort = ABORT_USER;
\r
3771 // Canceled = YES;
\r
3772 Canceled[Pkt->ThreadCount] = YES;
\r
3778 if(wParam == TIMER_DISPLAY)
\r
3780 if(MoveToForeground == YES)
\r
3781 SetForegroundWindow(hDlg);
\r
3782 MoveToForeground = NO;
\r
3783 KillTimer(hDlg, TIMER_DISPLAY);
\r
3785 // if(!(Pkt = (TRANSPACKET*)GetWindowLong(hDlg, GWL_USERDATA)))
\r
3786 if(!(Pkt = (TRANSPACKET*)GetWindowLongPtr(hDlg, GWLP_USERDATA)))
\r
3788 DispTransferStatus(hDlg, NO, Pkt);
\r
3789 SetTimer(hDlg, TIMER_DISPLAY, DISPLAY_TIMING, NULL);
\r
3793 case WM_SET_PACKET :
\r
3794 // Pkt = (TRANSPACKET *)lParam;
\r
3796 // SetWindowLong(hDlg, GWL_USERDATA, (LONG)lParam);
\r
3797 SetWindowLongPtr(hDlg, GWLP_USERDATA, (LONG_PTR)lParam);
\r
3804 /*----- 転送ステータスを表示 --------------------------------------------------
\r
3807 * HWND hWnd : ウインドウハンドル
\r
3808 * int End : 転送が完了したかどうか (YES/NO)
\r
3812 *----------------------------------------------------------------------------*/
\r
3814 static void DispTransferStatus(HWND hWnd, int End, TRANSPACKET *Pkt)
\r
3828 SendMessage(hWnd, WM_GETTEXT, 79, (LPARAM)Str);
\r
3829 if((Pos = strchr(Str, ')')) != NULL)
\r
3833 sprintf(Tmp, "(%d)%s", AskTransferFileNum(), Pos);
\r
3834 SendMessage(hWnd, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
3836 if(Pkt->Abort == ABORT_NONE)
\r
3841 // TotalLap = time(NULL) - TimeStart + 1;
\r
3842 TotalLap = time(NULL) - TimeStart[Pkt->ThreadCount] + 1;
\r
3847 // Bps = AllTransSizeNow / TotalLap;
\r
3848 Bps = AllTransSizeNow[Pkt->ThreadCount] / TotalLap;
\r
3849 Transed = Pkt->Size - Pkt->ExistSize;
\r
3851 if(Pkt->Size <= 0)
\r
3852 sprintf(Tmp, "%d ", Pkt->ExistSize);
\r
3853 else if(Pkt->Size < 1024)
\r
3854 sprintf(Tmp, "%s / %s ", MakeNumString(Pkt->ExistSize, Num1, TRUE), MakeNumString(Pkt->Size, Num2, TRUE));
\r
3856 sprintf(Tmp, "%sk / %sk ", MakeNumString(Pkt->ExistSize/1024, Num1, TRUE), MakeNumString(Pkt->Size/1024, Num2, TRUE));
\r
3860 sprintf(Tmp, "( 0 B/S )");
\r
3861 else if(Bps < 1000)
\r
3862 sprintf(Tmp, "( %s B/S )", MakeNumString(Bps, Num1, TRUE));
\r
3864 sprintf(Tmp, "( %s.%02d KB/S )", MakeNumString(Bps/1000, Num1, TRUE), (int)((Bps%1000)/10));
\r
3867 if((Bps > 0) && (Pkt->Size > 0) && (Transed >= 0))
\r
3869 sprintf(Tmp, " %d:%02d", (int)((Transed/Bps)/60), (int)((Transed/Bps)%60));
\r
3873 strcat(Str, " ??:??");
\r
3876 strcpy(Str, MSGJPN117);
\r
3879 strcpy(Str, MSGJPN118);
\r
3881 SendDlgItemMessage(hWnd, TRANS_STATUS, WM_SETTEXT, 0, (LPARAM)Str);
\r
3883 if(Pkt->Size <= 0)
\r
3885 else if(Pkt->Size < 1024*1024)
\r
3886 Per = (int)(Pkt->ExistSize * 100 / Pkt->Size);
\r
3888 Per = (int)((Pkt->ExistSize/1024) * 100 / (Pkt->Size/1024));
\r
3889 SendDlgItemMessage(hWnd, TRANS_TIME_BAR, PBM_SETPOS, Per, 0);
\r
3895 /*----- 転送するファイルの情報を表示 ------------------------------------------
\r
3898 * TRANSPACKET *Pkt : 転送ファイル情報
\r
3899 * char *Title : ウインドウのタイトル
\r
3900 * int SkipButton : 「このファイルを中止」ボタンの有無 (TRUE/FALSE)
\r
3901 * int Info : ファイル情報を表示するかどうか (YES/NO)
\r
3905 *----------------------------------------------------------------------------*/
\r
3907 static void DispTransFileInfo(TRANSPACKET *Pkt, char *Title, int SkipButton, int Info)
\r
3911 if(Pkt->hWndTrans != NULL)
\r
3913 EnableWindow(GetDlgItem(Pkt->hWndTrans, IDCANCEL), SkipButton);
\r
3915 sprintf(Tmp, "(%d)%s", AskTransferFileNum(), Title);
\r
3916 SendMessage(Pkt->hWndTrans, WM_SETTEXT, 0, (LPARAM)Tmp);
\r
3917 SendDlgItemMessage(Pkt->hWndTrans, TRANS_STATUS, WM_SETTEXT, 0, (LPARAM)"");
\r
3919 SendDlgItemMessage(Pkt->hWndTrans, TRANS_TIME_BAR, PBM_SETRANGE, 0, MAKELPARAM(0, 100));
\r
3920 SendDlgItemMessage(Pkt->hWndTrans, TRANS_TIME_BAR, PBM_SETSTEP, 1, 0);
\r
3921 SendDlgItemMessage(Pkt->hWndTrans, TRANS_TIME_BAR, PBM_SETPOS, 0, 0);
\r
3925 DispStaticText(GetDlgItem(Pkt->hWndTrans, TRANS_REMOTE), Pkt->RemoteFile);
\r
3926 DispStaticText(GetDlgItem(Pkt->hWndTrans, TRANS_LOCAL), Pkt->LocalFile);
\r
3928 if(Pkt->Type == TYPE_I)
\r
3929 SendDlgItemMessage(Pkt->hWndTrans, TRANS_MODE, WM_SETTEXT, 0, (LPARAM)MSGJPN119);
\r
3930 else if(Pkt->Type == TYPE_A)
\r
3931 SendDlgItemMessage(Pkt->hWndTrans, TRANS_MODE, WM_SETTEXT, 0, (LPARAM)MSGJPN120);
\r
3934 if(Pkt->KanjiCode == KANJI_NOCNV)
\r
3935 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN121);
\r
3936 else if(Pkt->KanjiCode == KANJI_SJIS)
\r
3937 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN305);
\r
3938 else if(Pkt->KanjiCode == KANJI_JIS)
\r
3939 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN122);
\r
3940 else if(Pkt->KanjiCode == KANJI_EUC)
\r
3941 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN123);
\r
3942 else if(Pkt->KanjiCode == KANJI_UTF8N)
\r
3943 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN306);
\r
3944 else if(Pkt->KanjiCode == KANJI_UTF8BOM)
\r
3945 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)MSGJPN329);
\r
3949 SendDlgItemMessage(Pkt->hWndTrans, TRANS_REMOTE, WM_SETTEXT, 0, (LPARAM)"");
\r
3950 SendDlgItemMessage(Pkt->hWndTrans, TRANS_LOCAL, WM_SETTEXT, 0, (LPARAM)"");
\r
3951 SendDlgItemMessage(Pkt->hWndTrans, TRANS_MODE, WM_SETTEXT, 0, (LPARAM)"");
\r
3952 SendDlgItemMessage(Pkt->hWndTrans, TRANS_KANJI, WM_SETTEXT, 0, (LPARAM)"");
\r
3959 /*----- PASVコマンドの戻り値からアドレスとポート番号を抽出 --------------------
\r
3962 * char *Str : PASVコマンドのリプライ
\r
3963 * char *Adrs : アドレスのコピー先 ("www.xxx.yyy.zzz")
\r
3964 * int *Port : ポート番号をセットするワーク
\r
3965 * int Max : アドレス文字列の最大長
\r
3969 * FFFTP_SUCCESS/FFFTP_FAIL
\r
3970 *----------------------------------------------------------------------------*/
\r
3972 static int GetAdrsAndPort(SOCKET Skt, char *Str, char *Adrs, int *Port, int Max)
\r
3975 Result = FFFTP_FAIL;
\r
3976 switch(AskCurNetType())
\r
3979 Result = GetAdrsAndPortIPv4(Skt, Str, Adrs, Port, Max);
\r
3982 Result = GetAdrsAndPortIPv6(Skt, Str, Adrs, Port, Max);
\r
3990 //static int GetAdrsAndPort(char *Str, char *Adrs, int *Port, int Max)
\r
3991 static int GetAdrsAndPortIPv4(SOCKET Skt, char *Str, char *Adrs, int *Port, int Max)
\r
3995 // コンマではなくドットを返すホストがあるため
\r
4001 Pos = strchr(Str, '(');
\r
4005 Btm = strchr(Pos, ',');
\r
4006 // コンマではなくドットを返すホストがあるため
\r
4008 Btm = strchr(Pos, '.');
\r
4012 // コンマではなくドットを返すホストがあるため
\r
4013 // Btm = strchr(Btm, ',');
\r
4015 Btm = strchr(OldBtm, ',');
\r
4017 Btm = strchr(OldBtm, '.');
\r
4021 // コンマではなくドットを返すホストがあるため
\r
4022 // Btm = strchr(Btm, ',');
\r
4024 Btm = strchr(OldBtm, ',');
\r
4026 Btm = strchr(OldBtm, '.');
\r
4030 // コンマではなくドットを返すホストがあるため
\r
4031 // Btm = strchr(Btm, ',');
\r
4033 Btm = strchr(OldBtm, ',');
\r
4035 Btm = strchr(OldBtm, '.');
\r
4038 if((Btm - Pos) <= Max)
\r
4040 strncpy(Adrs, Pos, Btm - Pos);
\r
4041 *(Adrs + (Btm - Pos)) = NUL;
\r
4042 ReplaceAll(Adrs, ',', '.');
\r
4045 Btm = strchr(Pos, ',');
\r
4046 // コンマではなくドットを返すホストがあるため
\r
4048 Btm = strchr(Pos, '.');
\r
4052 *Port = (atoi(Pos) * 0x100) + atoi(Btm);
\r
4053 Sts = FFFTP_SUCCESS;
\r
4066 static int GetAdrsAndPortIPv6(SOCKET Skt, char *Str, char *Adrs, int *Port, int Max)
\r
4072 struct sockaddr_in6 SockAddr;
\r
4076 Btm = strchr(Str, '(');
\r
4080 Btm = strchr(Btm, '|');
\r
4084 Btm = strchr(Pos, '|');
\r
4088 Btm = strchr(Pos, '|');
\r
4091 if((Btm - Pos) <= Max)
\r
4093 if((Btm - Pos) > 0)
\r
4095 strncpy(Adrs, Pos, Btm - Pos);
\r
4096 *(Adrs + (Btm - Pos)) = NUL;
\r
4100 // i = sizeof(SockAddr);
\r
4101 // if(getpeername(Skt, (struct sockaddr*)&SockAddr, &i) != SOCKET_ERROR)
\r
4102 if(GetAsyncTableDataIPv6(Skt, &SockAddr, NULL) == YES)
\r
4103 AddressToStringIPv6(Adrs, &SockAddr.sin6_addr);
\r
4107 Btm = strchr(Pos, '|');
\r
4111 *Port = atoi(Pos);
\r
4112 Btm = strchr(Btm, ')');
\r
4114 Sts = FFFTP_SUCCESS;
\r
4125 /*----- Windowsのスペシャルデバイスかどうかを返す -----------------------------
\r
4128 * char *Fname : ファイル名
\r
4131 * int ステータス (YES/NO)
\r
4132 *----------------------------------------------------------------------------*/
\r
4134 static int IsSpecialDevice(char *Fname)
\r
4140 // if((_stricmp(Fname, "CON") == 0) ||
\r
4141 // (_stricmp(Fname, "PRN") == 0) ||
\r
4142 // (_stricmp(Fname, "AUX") == 0) ||
\r
4143 // (_strnicmp(Fname, "CON.", 4) == 0) ||
\r
4144 // (_strnicmp(Fname, "PRN.", 4) == 0) ||
\r
4145 // (_strnicmp(Fname, "AUX.", 4) == 0))
\r
4149 if(_strnicmp(Fname, "AUX", 3) == 0|| _strnicmp(Fname, "CON", 3) == 0 || _strnicmp(Fname, "NUL", 3) == 0 || _strnicmp(Fname, "PRN", 3) == 0)
\r
4151 if(*(Fname + 3) == '\0' || *(Fname + 3) == '.')
\r
4154 else if(_strnicmp(Fname, "COM", 3) == 0 || _strnicmp(Fname, "LPT", 3) == 0)
\r
4156 if(isdigit(*(Fname + 3)) != 0)
\r
4158 if(*(Fname + 4) == '\0' || *(Fname + 4) == '.')
\r
4166 /*----- ミラーリングでのファイル削除確認 --------------------------------------
\r
4171 * TRANSPACKET *Pkt
\r
4175 *----------------------------------------------------------------------------*/
\r
4177 static int MirrorDelNotify(int Cur, int Notify, TRANSPACKET *Pkt)
\r
4179 MIRRORDELETEINFO DelInfo;
\r
4182 if(((Cur == WIN_LOCAL) && (MirDownDelNotify == NO)) ||
\r
4183 ((Cur == WIN_REMOTE) && (MirUpDelNotify == NO)))
\r
4188 if(Notify != YES_ALL)
\r
4190 DelInfo.Cur = Cur;
\r
4191 DelInfo.Pkt = Pkt;
\r
4192 hWnd = Pkt->hWndTrans;
\r
4194 hWnd = GetMainHwnd();
\r
4195 Notify = DialogBoxParam(GetFtpInst(), MAKEINTRESOURCE(delete_dlg), hWnd, MirrorDeleteDialogCallBack, (LPARAM)&DelInfo);
\r
4201 /*----- ミラーリングでのファイル削除ダイアログのコールバック ------------------
\r
4204 * HWND hDlg : ウインドウハンドル
\r
4205 * UINT message : メッセージ番号
\r
4206 * WPARAM wParam : メッセージの WPARAM 引数
\r
4207 * LPARAM lParam : メッセージの LPARAM 引数
\r
4211 *----------------------------------------------------------------------------*/
\r
4214 //static BOOL CALLBACK MirrorDeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
4215 static INT_PTR CALLBACK MirrorDeleteDialogCallBack(HWND hDlg, UINT iMessage, WPARAM wParam, LPARAM lParam)
\r
4217 static MIRRORDELETEINFO *DelInfo;
\r
4220 case WM_INITDIALOG :
\r
4221 DelInfo = (MIRRORDELETEINFO *)lParam;
\r
4223 if(DelInfo->Cur == WIN_LOCAL)
\r
4225 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN124);
\r
4226 SendDlgItemMessage(hDlg, DELETE_TEXT, WM_SETTEXT, 0, (LPARAM)DelInfo->Pkt->LocalFile);
\r
4230 SendMessage(hDlg, WM_SETTEXT, 0, (LPARAM)MSGJPN125);
\r
4231 SendDlgItemMessage(hDlg, DELETE_TEXT, WM_SETTEXT, 0, (LPARAM)DelInfo->Pkt->RemoteFile);
\r
4236 switch(GET_WM_COMMAND_ID(wParam, lParam))
\r
4239 EndDialog(hDlg, YES);
\r
4243 EndDialog(hDlg, NO);
\r
4247 EndDialog(hDlg, YES_ALL);
\r
4252 EndDialog(hDlg, NO_ALL);
\r
4264 static void SetErrorMsg(char *fmt, ...)
\r
4269 // if(strlen(ErrMsg) == 0)
\r
4270 if(strlen(GetErrMsg()) == 0)
\r
4272 va_start(Args, fmt);
\r
4274 // wvsprintf(ErrMsg, fmt, Args);
\r
4275 wvsprintf(GetErrMsg(), fmt, Args);
\r
4286 /*----- ダウンロード時の不正なパスをチェック ----------------------------------
\r
4289 * TRANSPACKET *packet : ダウンロード情報
\r
4292 * int YES=不正なパス/NO=問題ないパス
\r
4293 *----------------------------------------------------------------------------*/
\r
4294 int CheckPathViolation(TRANSPACKET *packet)
\r
4299 if((strncmp(packet->RemoteFile, "..\\", 3) == 0) ||
\r
4300 (strncmp(packet->RemoteFile, "../", 3) == 0) ||
\r
4301 (strstr(packet->RemoteFile, "\\..\\") != NULL) ||
\r
4302 (strstr(packet->RemoteFile, "/../") != NULL))
\r
4304 msg = malloc(strlen(MSGJPN297) + strlen(packet->RemoteFile) + 1);
\r
4307 sprintf(msg, MSGJPN297, packet->RemoteFile);
\r
4308 MessageBox(GetMainHwnd(), msg, MSGJPN086, MB_OK);
\r
4318 static char* GetErrMsg()
\r
4324 WaitForSingleObject(hErrMsgMutex, INFINITE);
\r
4325 ThreadId = GetCurrentThreadId();
\r
4327 while(i < MAX_DATA_CONNECTION + 1)
\r
4329 if(ErrMsgThreadId[i] == ThreadId)
\r
4339 while(i < MAX_DATA_CONNECTION + 1)
\r
4341 if(ErrMsgThreadId[i] == 0)
\r
4343 ErrMsgThreadId[i] = ThreadId;
\r
4350 ReleaseMutex(hErrMsgMutex);
\r