extern int ListHeight;\r
extern char FilterStr[FILTER_EXT_LEN+1];\r
extern HWND hHelpWin;\r
+// 外部アプリケーションへドロップ後にローカル側のファイル一覧に作業フォルダが表示されるバグ対策\r
+extern int SuppressRefresh;\r
\r
/* 設定値 */\r
extern int LocalWidth;\r
static WNDPROC RemoteProcPtr;\r
\r
static HIMAGELIST ListImg = NULL;\r
+// ファイルアイコン表示対応\r
+static HIMAGELIST ListImgFileIcon = NULL;\r
\r
static char FindStr[40+1] = { "*" }; /* 検索文字列 */\r
static int IgnoreNew = NO;\r
LV_COLUMN LvCol;\r
long Tmp;\r
\r
+ // 変数が未初期化のバグ修正\r
+ memset(&LvCol, 0, sizeof(LV_COLUMN));\r
+\r
/*===== ローカル側のリストビュー =====*/\r
\r
hWndListLocal = CreateWindowEx(/*WS_EX_STATICEDGE*/WS_EX_CLIENTEDGE,\r
remove(fn);\r
}\r
\r
+ // 同時接続対応\r
+ DisableUserOpe();\r
+ // 外部アプリケーションへドロップ後にローカル側のファイル一覧に作業フォルダが表示されるバグ対策\r
+ SuppressRefresh = 1;\r
+\r
// ダウンロード先をテンポラリに設定\r
SetLocalDirHist(TmpDir);\r
\r
SetLocalDirHist(LocDir);\r
SetCurrentDirAsDirHist();\r
\r
+ // 外部アプリケーションへドロップ後にローカル側のファイル一覧に作業フォルダが表示されるバグ対策\r
+ SuppressRefresh = 0;\r
+ GetLocalDirForWnd();\r
+ // 同時接続対応\r
+ EnableUserOpe();\r
+\r
remoteFileListBase = FileListBase; // あとでフリーすること\r
remoteFileListBaseNoExpand = FileListBaseNoExpand; // あとでフリーすること\r
strncpy_s(remoteFileDir, sizeof(remoteFileDir), TmpDir, _TRUNCATE);\r
return(CallWindowProc(ProcPtr, hWnd, message, wParam, lParam));\r
\r
case WM_DROPFILES :\r
+ // 同時接続対応\r
+ if(AskUserOpeDisabled() == YES)\r
+ break;\r
// ドラッグ中は処理しない。ドラッグ後にWM_LBUTTONDOWNが飛んでくるため、そこで処理する。\r
if (Dragging == YES) \r
return (FALSE);\r
if(hWnd == hWndListRemote)\r
{\r
if(AskConnecting() == YES)\r
- UpLoadDragProc(wParam);\r
+ UploadDragProc(wParam);\r
}\r
else if(hWnd == hWndListLocal)\r
{\r
hCsrDrg = LoadCursor(NULL, IDC_ARROW);\r
SetCursor(hCsrDrg);\r
\r
+ // 同時接続対応\r
+ if(AskUserOpeDisabled() == YES)\r
+ break;\r
Point.x = (long)(short)LOWORD(lParam);\r
Point.y = (long)(short)HIWORD(lParam);\r
ClientToScreen(hWnd, &Point);\r
LV_COLUMN LvCol;\r
int i;\r
\r
+ // 変数が未初期化のバグ修正\r
+ memset(&LvCol, 0, sizeof(LV_COLUMN));\r
+\r
for(i = 0; i <= 3; i++)\r
{\r
LvCol.mask = LVCF_WIDTH;\r
int i;\r
char Cur[FMAX_PATH+1];\r
SHFILEINFO FileInfo;\r
- SendMessage(hWndListLocal, LVM_SETIMAGELIST, LVSIL_SMALL, (LPARAM)NULL);\r
- ShowWindow(hWndListLocal, SW_SHOW);\r
- SendMessage(hWndListRemote, LVM_SETIMAGELIST, LVSIL_SMALL, (LPARAM)NULL);\r
- ShowWindow(hWndListRemote, SW_SHOW);\r
- ImageList_Destroy(ListImg);\r
- ListImg = ImageList_Create(16, 16, ILC_MASK | ILC_COLOR24, 0, 1);\r
- hBitmap = LoadBitmap(GetFtpInst(), MAKEINTRESOURCE(dirattr_bmp));\r
- ImageList_AddMasked(ListImg, hBitmap, RGB(255,0,0));\r
- DeleteObject(hBitmap);\r
- ImageId = 0;\r
- Pos = Anchor->Top;\r
- for(i = 0; i < Anchor->Files; i++)\r
+ if(AskDispFileIcon() == YES)\r
{\r
- Pos->ImageId = -1;\r
- if(AskDispFileIcon() == YES)\r
+ SendMessage(hWndListLocal, LVM_SETIMAGELIST, LVSIL_SMALL, (LPARAM)NULL);\r
+ ShowWindow(hWndListLocal, SW_SHOW);\r
+ SendMessage(hWndListRemote, LVM_SETIMAGELIST, LVSIL_SMALL, (LPARAM)NULL);\r
+ ShowWindow(hWndListRemote, SW_SHOW);\r
+ ImageList_Destroy(ListImgFileIcon);\r
+ ListImgFileIcon = ImageList_Create(16, 16, ILC_MASK | ILC_COLOR32, 0, 1);\r
+ hBitmap = LoadBitmap(GetFtpInst(), MAKEINTRESOURCE(dirattr16_bmp));\r
+ ImageList_AddMasked(ListImgFileIcon, hBitmap, RGB(255, 0, 0));\r
+ DeleteObject(hBitmap);\r
+ ImageId = 0;\r
+ Pos = Anchor->Top;\r
+ for(i = 0; i < Anchor->Files; i++)\r
{\r
+ Pos->ImageId = -1;\r
if(Pos->Node == NODE_DRIVE)\r
strcpy(Cur, Pos->File);\r
else\r
}\r
if(SHGetFileInfoM(Cur, 0, &FileInfo, sizeof(SHFILEINFO), SHGFI_SMALLICON | SHGFI_ICON) != 0)\r
{\r
- if(ImageList_AddIcon(ListImg, FileInfo.hIcon) >= 0)\r
+ if(ImageList_AddIcon(ListImgFileIcon, FileInfo.hIcon) >= 0)\r
{\r
Pos->ImageId = ImageId;\r
ImageId++;\r
}\r
DestroyIcon(FileInfo.hIcon);\r
}\r
+ Pos = Pos->Next;\r
}\r
- Pos = Pos->Next;\r
+ SendMessage(hWndListLocal, LVM_SETIMAGELIST, LVSIL_SMALL, (LPARAM)ListImgFileIcon);\r
+ ShowWindow(hWndListLocal, SW_SHOW);\r
+ SendMessage(hWndListRemote, LVM_SETIMAGELIST, LVSIL_SMALL, (LPARAM)ListImgFileIcon);\r
+ ShowWindow(hWndListRemote, SW_SHOW);\r
+ }\r
+ else\r
+ {\r
+ SendMessage(hWndListLocal, LVM_SETIMAGELIST, LVSIL_SMALL, (LPARAM)ListImg);\r
+ ShowWindow(hWndListLocal, SW_SHOW);\r
+ SendMessage(hWndListRemote, LVM_SETIMAGELIST, LVSIL_SMALL, (LPARAM)ListImg);\r
+ ShowWindow(hWndListRemote, SW_SHOW);\r
}\r
- SendMessage(hWndListLocal, LVM_SETIMAGELIST, LVSIL_SMALL, (LPARAM)ListImg);\r
- ShowWindow(hWndListLocal, SW_SHOW);\r
- SendMessage(hWndListRemote, LVM_SETIMAGELIST, LVSIL_SMALL, (LPARAM)ListImg);\r
- ShowWindow(hWndListRemote, SW_SHOW);\r
}\r
\r
void GetLocalDirForWnd(void)\r
if(DispDrives)\r
{\r
GetLogicalDriveStrings(FMAX_PATH, Scan);\r
- NoDrives = LoadHideDriveListRegistory();\r
+ NoDrives = LoadHideDriveListRegistry();\r
\r
Pos = Scan;\r
while(*Pos != NUL)\r
\r
if((Sort & SORT_GET_ORD) == SORT_ASCENT)\r
{\r
- if((((Sort & SORT_MASK_ORD) == SORT_EXT) &&\r
- ((Cmp = _mbsicmp(GetFileExt(Name), GetFileExt(Pos->File))) < 0)) ||\r
+ // 読みにくいのでリファクタリング\r
+// if((((Sort & SORT_MASK_ORD) == SORT_EXT) &&\r
+// ((Cmp = _mbsicmp(GetFileExt(Name), GetFileExt(Pos->File))) < 0)) ||\r
+//#if defined(HAVE_TANDEM)\r
+// ((AskHostType() == HTYPE_TANDEM) &&\r
+// ((Sort & SORT_MASK_ORD) == SORT_EXT) &&\r
+// ((Cmp = Attr - Pos->Attr) < 0)) ||\r
+//#endif\r
+// (((Sort & SORT_MASK_ORD) == SORT_SIZE) &&\r
+// ((Cmp = Size - Pos->Size) < 0)) ||\r
+// (((Sort & SORT_MASK_ORD) == SORT_DATE) &&\r
+// ((Cmp = CompareFileTime(Time, &Pos->Time)) < 0)))\r
+// {\r
+// break;\r
+// }\r
+ if(((Sort & SORT_MASK_ORD) == SORT_EXT) &&\r
+ ((Cmp = _mbsicmp(GetFileExt(Name), GetFileExt(Pos->File))) < 0))\r
+ break;\r
#if defined(HAVE_TANDEM)\r
- ((AskHostType() == HTYPE_TANDEM) &&\r
- ((Sort & SORT_MASK_ORD) == SORT_EXT) &&\r
- ((Cmp = Attr - Pos->Attr) < 0)) ||\r
+ if((AskHostType() == HTYPE_TANDEM) &&\r
+ ((Sort & SORT_MASK_ORD) == SORT_EXT) &&\r
+ ((Cmp = Attr - Pos->Attr) < 0))\r
+ break;\r
#endif\r
- (((Sort & SORT_MASK_ORD) == SORT_SIZE) &&\r
- ((Cmp = Size - Pos->Size) < 0)) ||\r
- (((Sort & SORT_MASK_ORD) == SORT_DATE) &&\r
- ((Cmp = CompareFileTime(Time, &Pos->Time)) < 0)))\r
- {\r
+ if(((Sort & SORT_MASK_ORD) == SORT_SIZE) &&\r
+ ((Cmp = Size - Pos->Size) < 0))\r
+ break;\r
+ if(((Sort & SORT_MASK_ORD) == SORT_DATE) &&\r
+ ((Cmp = CompareFileTime(Time, &Pos->Time)) < 0))\r
break;\r
- }\r
\r
if(((Sort & SORT_MASK_ORD) == SORT_NAME) || (Cmp == 0))\r
{\r
if(Pos == -1)\r
Pos = SendMessage(hWnd, LVM_GETITEMCOUNT, 0, 0);\r
\r
+ // 変数が未初期化のバグ修正\r
+ memset(&LvItem, 0, sizeof(LV_ITEM));\r
/* アイコン/ファイル名 */\r
LvItem.mask = LVIF_TEXT | LVIF_IMAGE;\r
LvItem.iItem = Pos;\r
else\r
LvItem.iImage = 4;\r
// ファイルアイコン表示対応\r
- if(hWnd == GetLocalHwnd() && ImageId >= 0)\r
- LvItem.iImage = 5 + ImageId;\r
+ if(AskDispFileIcon() == YES && hWnd == GetLocalHwnd())\r
+ LvItem.iImage = ImageId + 5;\r
LvItem.iItem = SendMessage(hWnd, LVM_INSERTITEM, 0, (LPARAM)&LvItem);\r
\r
/* 日付/時刻 */\r
FILETIME Time2;\r
int Find;\r
\r
+ // 変数が未初期化のバグ修正\r
+ memset(&LvItem, 0, sizeof(LV_ITEM));\r
Win = WIN_LOCAL;\r
WinDst = WIN_REMOTE;\r
if(hWnd == GetRemoteHwnd())\r
LV_ITEM LvItem;\r
char *Title;\r
\r
+ // 変数が未初期化のバグ修正\r
+ memset(&LvItem, 0, sizeof(LV_ITEM));\r
Win = WIN_LOCAL;\r
Title = MSGJPN050;\r
if(hWnd == GetRemoteHwnd())\r
if(Win == WIN_REMOTE)\r
hWnd = GetRemoteHwnd();\r
\r
+ // 変数が未初期化のバグ修正\r
+ memset(&FindInfo, 0, sizeof(LV_FINDINFO));\r
FindInfo.flags = LVFI_STRING;\r
FindInfo.psz = Name;\r
return(SendMessage(hWnd, LVM_FINDITEM, -1, (LPARAM)&FindInfo));\r
if(Win == WIN_REMOTE)\r
hWnd = GetRemoteHwnd();\r
\r
+ // 変数が未初期化のバグ修正\r
+ memset(&LvItem, 0, sizeof(LV_ITEM));\r
LvItem.mask = LVIF_TEXT;\r
LvItem.iItem = Pos;\r
LvItem.iSubItem = 0;\r
if(Win == WIN_REMOTE)\r
hWnd = GetRemoteHwnd();\r
\r
+ // 変数が未初期化のバグ修正\r
+ memset(&LvItem, 0, sizeof(LV_ITEM));\r
LvItem.mask = LVIF_TEXT;\r
LvItem.iItem = Pos;\r
LvItem.iSubItem = 1;\r
if(Win == WIN_REMOTE)\r
hWnd = GetRemoteHwnd();\r
\r
+ // 変数が未初期化のバグ修正\r
+ memset(&LvItem, 0, sizeof(LV_ITEM));\r
LvItem.mask = LVIF_TEXT;\r
LvItem.iItem = Pos;\r
LvItem.iSubItem = 2;\r
Ret = NO;\r
if(Win == WIN_REMOTE)\r
{\r
+ // 変数が未初期化のバグ修正\r
+ memset(&LvItem, 0, sizeof(LV_ITEM));\r
LvItem.mask = LVIF_TEXT;\r
LvItem.iItem = Pos;\r
#if defined(HAVE_TANDEM)\r
if(Win == WIN_REMOTE)\r
hWnd = GetRemoteHwnd();\r
\r
+ // 変数が未初期化のバグ修正\r
+ memset(&LvItem, 0, sizeof(LV_ITEM));\r
LvItem.mask = LVIF_TEXT;\r
LvItem.iItem = Pos;\r
LvItem.iSubItem = 2;\r
strcpy(Buf, "");\r
if(Win == WIN_REMOTE)\r
{\r
+ // 変数が未初期化のバグ修正\r
+ memset(&LvItem, 0, sizeof(LV_ITEM));\r
LvItem.mask = LVIF_TEXT;\r
LvItem.iItem = Pos;\r
LvItem.iSubItem = 5;\r
if((Node == NODE_FILE) ||\r
((Expand == NO) && (Node == NODE_DIR)))\r
{\r
+ // 変数が未初期化のバグ修正\r
+ memset(&Pkt, 0, sizeof(FILELIST));\r
+\r
Pkt.InfoExist = 0;\r
GetNodeName(Win, Pos, Pkt.File, FMAX_PATH);\r
if(GetNodeSize(Win, Pos, &Pkt.Size) == YES)\r
{\r
if(GetNodeType(Win, Pos) == NODE_DIR)\r
{\r
+ // 変数が未初期化のバグ修正\r
+ memset(&Pkt, 0, sizeof(FILELIST));\r
+\r
GetNodeName(Win, Pos, Name, FMAX_PATH);\r
strcpy(Pkt.File, Name);\r
ReplaceAll(Pkt.File, '\\', '/');\r
\r
if((GetFileAttributes(Name) & FILE_ATTRIBUTE_DIRECTORY) == 0)\r
{\r
+ // 変数が未初期化のバグ修正\r
+ memset(&Pkt, 0, sizeof(FILELIST));\r
+\r
Pkt.Node = NODE_FILE;\r
strcpy(Pkt.File, GetFileName(Name));\r
\r
\r
if(GetFileAttributes(Name) & FILE_ATTRIBUTE_DIRECTORY)\r
{\r
+ // 変数が未初期化のバグ修正\r
+ memset(&Pkt, 0, sizeof(FILELIST));\r
+\r
Pkt.Node = NODE_DIR;\r
strcpy(Pkt.File, GetFileName(Name));\r
AddFileList(&Pkt, Base);\r
{\r
if(Pos->Node == NODE_DIR)\r
{\r
+ // 変数が未初期化のバグ修正\r
+ memset(&Pkt, 0, sizeof(FILELIST));\r
+\r
/* まずディレクトリ名をセット */\r
strcpy(Pkt.File, Pos->File);\r
Pkt.Node = NODE_DIR;\r
{\r
if(IncDir == RDIR_NLST)\r
{\r
+ // 変数が未初期化のバグ修正\r
+ memset(&Pkt, 0, sizeof(FILELIST));\r
+\r
strcpy(Pkt.File, Dir);\r
Pkt.Node = NODE_DIR;\r
Pkt.Size = 0;\r
if((Node == NODE_FILE) ||\r
((IncDir == RDIR_CWD) && (Node == NODE_DIR)))\r
{\r
+ // 変数が未初期化のバグ修正\r
+ memset(&Pkt, 0, sizeof(FILELIST));\r
+\r
strcpy(Pkt.File, Dir);\r
if(strlen(Pkt.File) > 0)\r
SetSlashTail(Pkt.File);\r
{\r
if(AskFilterStr(FindBuf.cFileName, NODE_FILE) == YES)\r
{\r
+ // 変数が未初期化のバグ修正\r
+ memset(&Pkt, 0, sizeof(FILELIST));\r
+\r
strcpy(Pkt.File, Path);\r
SetSlashTail(Pkt.File);\r
strcat(Pkt.File, FindBuf.cFileName);\r
(strcmp(FindBuf.cFileName, ".") != 0) &&\r
(strcmp(FindBuf.cFileName, "..") != 0))\r
{\r
+ // 変数が未初期化のバグ修正\r
+ memset(&Pkt, 0, sizeof(FILELIST));\r
+\r
strcpy(Src, Path);\r
SetYenTail(Src);\r
strcat(Src, FindBuf.cFileName);\r
\r
/* まずクリアしておく */\r
Ret = NODE_NONE;\r
+ // バグ対策\r
+ memset(Fname, NUL, FMAX_PATH+1);\r
*Size = -1;\r
*Attr = 0;\r
*Link = NO;\r
break;\r
#endif\r
\r
+ // MLSD対応\r
+ // 以下の形式に対応\r
+ // fact1=value1;fact2=value2;fact3=value3; filename\r\n\r
+ // 不完全な実装のホストが存在するため以下の形式も許容\r
+ // fact1=value1;fact2=value2;fact3=value3 filename\r\n\r
+ // fact1=value1;fact2=value2;fact3=value3;filename\r\n\r
+ case LIST_MLSD:\r
+ {\r
+ int i = 0;\r
+ char StrBuf[(FMAX_PATH * 2) + 1];\r
+ char Fact[FMAX_PATH + 1];\r
+ char Name[FMAX_PATH + 1];\r
+ char Value[FMAX_PATH + 1];\r
+ char* pFileName;\r
+ strncpy(StrBuf, Str, FMAX_PATH * 2);\r
+ StrBuf[FMAX_PATH * 2] = '\0';\r
+ if((pFileName = strstr(StrBuf, "; ")) != NULL)\r
+ {\r
+ *pFileName = '\0';\r
+ pFileName += 2;\r
+ }\r
+ else if((pFileName = strchr(StrBuf, ' ')) != NULL)\r
+ {\r
+ *pFileName = '\0';\r
+ pFileName++;\r
+ }\r
+ else if((pFileName = strrchr(StrBuf, ';')) != NULL)\r
+ {\r
+ *pFileName = '\0';\r
+ pFileName++;\r
+ }\r
+ if(pFileName != NULL)\r
+ strcpy(Fname, pFileName);\r
+ while(FindField2(StrBuf, Fact, ';', i, NO) == FFFTP_SUCCESS)\r
+ {\r
+ if(FindField2(Fact, Name, '=', 0, NO) == FFFTP_SUCCESS && FindField2(Fact, Value, '=', 1, NO) == FFFTP_SUCCESS)\r
+ {\r
+ if(_stricmp(Name, "type") == 0)\r
+ {\r
+ if(_stricmp(Value, "dir") == 0)\r
+ Ret = NODE_DIR;\r
+ else if(_stricmp(Value, "file") == 0)\r
+ Ret = NODE_FILE;\r
+ }\r
+ else if(_stricmp(Name, "size") == 0)\r
+ {\r
+ *Size = _atoi64(Value);\r
+ *InfoExist |= FINFO_SIZE;\r
+ }\r
+ else if(_stricmp(Name, "modify") == 0)\r
+ {\r
+ sTime.wYear = atoi_n(Value, 4);\r
+ sTime.wMonth = atoi_n(Value + 4, 2);\r
+ sTime.wDay = atoi_n(Value + 6, 2);\r
+ sTime.wHour = atoi_n(Value + 8, 2);\r
+ sTime.wMinute = atoi_n(Value + 10, 2);\r
+ sTime.wSecond = atoi_n(Value + 12, 2);\r
+ sTime.wMilliseconds = 0;\r
+ SystemTimeToFileTime(&sTime, Time);\r
+ // 時刻はGMT\r
+// SpecificLocalFileTime2FileTime(Time, AskHostTimeZone());\r
+ *InfoExist |= FINFO_DATE | FINFO_TIME;\r
+ }\r
+ else if(_stricmp(Name, "UNIX.mode") == 0)\r
+ {\r
+ *Attr = strtol(Value, NULL, 16);\r
+ *InfoExist |= FINFO_ATTR;\r
+ }\r
+ else if(_stricmp(Name, "UNIX.owner") == 0)\r
+ strcpy(Owner, Value);\r
+ }\r
+ i++;\r
+ }\r
+ }\r
+ break;\r
+\r
case LIST_UNIX_10 :\r
case LIST_UNIX_11 :\r
case LIST_UNIX_12 :\r
Ret = NODE_NONE;\r
}\r
break;\r
-\r
- // MLSD対応\r
- case LIST_MLSD:\r
- {\r
- int i = 0;\r
- char Tmp[FMAX_PATH + 1];\r
- char Name[FMAX_PATH + 1];\r
- char Value[FMAX_PATH + 1];\r
- while(FindField2(Str, Tmp, ';', i, NO) == FFFTP_SUCCESS)\r
- {\r
- if(i >= 1 && strncmp(Tmp, " ", 1) == 0)\r
- strcpy(Fname, strstr(Str, "; ") + 2);\r
- else if(FindField2(Tmp, Name, '=', 0, NO) == FFFTP_SUCCESS && FindField2(Tmp, Value, '=', 1, NO) == FFFTP_SUCCESS)\r
- {\r
- if(_stricmp(Name, "type") == 0)\r
- {\r
- if(_stricmp(Value, "dir") == 0)\r
- Ret = NODE_DIR;\r
- else if(_stricmp(Value, "file") == 0)\r
- Ret = NODE_FILE;\r
- }\r
- else if(_stricmp(Name, "size") == 0)\r
- {\r
- *Size = _atoi64(Value);\r
- *InfoExist |= FINFO_SIZE;\r
- }\r
- else if(_stricmp(Name, "modify") == 0)\r
- {\r
- sTime.wYear = atoi_n(Value, 4);\r
- sTime.wMonth = atoi_n(Value + 4, 2);\r
- sTime.wDay = atoi_n(Value + 6, 2);\r
- sTime.wHour = atoi_n(Value + 8, 2);\r
- sTime.wMinute = atoi_n(Value + 10, 2);\r
- sTime.wSecond = atoi_n(Value + 12, 2);\r
- sTime.wMilliseconds = 0;\r
- SystemTimeToFileTime(&sTime, Time);\r
-// SpecificLocalFileTime2FileTime(Time, AskHostTimeZone());\r
- *InfoExist |= FINFO_DATE | FINFO_TIME;\r
- }\r
- else if(_stricmp(Name, "UNIX.mode") == 0)\r
- {\r
- *Attr = strtol(Value, NULL, 16);\r
- *InfoExist |= FINFO_ATTR;\r
- }\r
- else if(_stricmp(Name, "UNIX.owner") == 0)\r
- strcpy(Owner, Value);\r
- }\r
- i++;\r
- }\r
- }\r
- break;\r
}\r
\r
// UTF-8対応\r