X-Git-Url: http://git.sourceforge.jp/view?p=ffftp%2Fffftp.git;a=blobdiff_plain;f=toolmenu.c;h=7fcc205b458e04f42c2a86113f217063fea3e197;hp=786a75484f7cd5d4ec239468dbffac2a86d0f8d2;hb=948f80c440c0251ec470882c68da56346d0d89c1;hpb=aa32f5e2158184770bffc7ae4216db128fda1499 diff --git a/toolmenu.c b/toolmenu.c index 786a754..7fcc205 100644 --- a/toolmenu.c +++ b/toolmenu.c @@ -28,6 +28,8 @@ /============================================================================*/ #define STRICT +// IPv6対応 +#include #include #include #include @@ -37,7 +39,8 @@ #include #include #include -#include +// IPv6対応 +//#include #include "common.h" #include "resource.h" @@ -100,7 +103,9 @@ static int TmpRemoteDirSort; static int SyncMove = NO; -static int HideUI = NO; +// デッドロック対策 +//static int HideUI = NO; +static int HideUI = 0; /* 2007/09/21 sunasunamix ここから *********************/ @@ -249,7 +254,9 @@ int MakeToolBarWindow(HWND hWnd, HINSTANCE hInst) if(hWndTbarMain != NULL) { /* 2007/09/21 sunasunamix ここから *********************/ - pOldTbarMainProc = (WNDPROC)SetWindowLong(hWndTbarMain, GWL_WNDPROC, (DWORD)CountermeasureTbarMainProc); + // 64ビット対応 +// pOldTbarMainProc = (WNDPROC)SetWindowLong(hWndTbarMain, GWL_WNDPROC, (DWORD)CountermeasureTbarMainProc); + pOldTbarMainProc = (WNDPROC)SetWindowLongPtr(hWndTbarMain, GWLP_WNDPROC, (LONG_PTR)CountermeasureTbarMainProc); /********************************************* ここまで */ GetClientRect(hWnd, &Rect1); @@ -274,7 +281,9 @@ int MakeToolBarWindow(HWND hWnd, HINSTANCE hInst) if(hWndTbarLocal != NULL) { /* 2007/09/21 sunasunamix ここから *********************/ - pOldTbarLocalProc = (WNDPROC)SetWindowLong(hWndTbarLocal, GWL_WNDPROC, (DWORD)CountermeasureTbarLocalProc); + // 64ビット対応 +// pOldTbarLocalProc = (WNDPROC)SetWindowLong(hWndTbarLocal, GWL_WNDPROC, (DWORD)CountermeasureTbarLocalProc); + pOldTbarLocalProc = (WNDPROC)SetWindowLongPtr(hWndTbarLocal, GWLP_WNDPROC, (LONG_PTR)CountermeasureTbarLocalProc); /********************************************* ここまで */ MoveWindow(hWndTbarLocal, 0, TOOLWIN_HEIGHT, LocalWidth, TOOLWIN_HEIGHT, FALSE); @@ -282,7 +291,7 @@ int MakeToolBarWindow(HWND hWnd, HINSTANCE hInst) /*===== ローカルのディレクトリ名ウインドウ =====*/ SendMessage(hWndTbarLocal, TB_GETITEMRECT, 3, (LPARAM)&Rect1); -#ifndef ENGLISH +#ifndef FFFTP_ENGLISH DlgFont = CreateFont(Rect1.bottom-Rect1.top-8, 0, 0, 0, 0, FALSE,FALSE,FALSE,SHIFTJIS_CHARSET,OUT_DEFAULT_PRECIS,CLIP_DEFAULT_PRECIS,DEFAULT_QUALITY,DEFAULT_PITCH,MSGJPN254); #else DlgFont = CreateFont(Rect1.bottom-Rect1.top-8, 0, 0, 0, 0, FALSE,FALSE,FALSE,ANSI_CHARSET,OUT_DEFAULT_PRECIS,CLIP_DEFAULT_PRECIS,DEFAULT_QUALITY,DEFAULT_PITCH,MSGJPN254); @@ -299,14 +308,16 @@ int MakeToolBarWindow(HWND hWnd, HINSTANCE hInst) /* エディットコントロールを探す */ hWndDirLocalEdit = GetWindow(hWndDirLocal, GW_CHILD); if(hWndDirLocalEdit != NULL) - HistEditBoxProcPtr = (WNDPROC)SetWindowLong(hWndDirLocalEdit, GWL_WNDPROC, (LONG)HistEditBoxWndProc); + // 64ビット対応 +// HistEditBoxProcPtr = (WNDPROC)SetWindowLong(hWndDirLocalEdit, GWL_WNDPROC, (LONG)HistEditBoxWndProc); + HistEditBoxProcPtr = (WNDPROC)SetWindowLongPtr(hWndDirLocalEdit, GWLP_WNDPROC, (LONG_PTR)HistEditBoxWndProc); SendMessage(hWndDirLocal, WM_SETFONT, (WPARAM)DlgFont, MAKELPARAM(TRUE, 0)); SendMessage(hWndDirLocal, CB_LIMITTEXT, FMAX_PATH, 0); /* ドライブ名をセットしておく */ GetLogicalDriveStrings(FMAX_PATH, Tmp); - NoDrives = LoadHideDriveListRegistory(); + NoDrives = LoadHideDriveListRegistry(); Pos = Tmp; while(*Pos != NUL) { @@ -337,7 +348,9 @@ int MakeToolBarWindow(HWND hWnd, HINSTANCE hInst) if(hWndTbarRemote != NULL) { /* 2007/09/21 sunasunamix ここから *********************/ - pOldTbarRemoteProc = (WNDPROC)SetWindowLong(hWndTbarRemote, GWL_WNDPROC, (DWORD)CountermeasureTbarRemoteProc); + // 64ビット対応 +// pOldTbarRemoteProc = (WNDPROC)SetWindowLong(hWndTbarRemote, GWL_WNDPROC, (DWORD)CountermeasureTbarRemoteProc); + pOldTbarRemoteProc = (WNDPROC)SetWindowLongPtr(hWndTbarRemote, GWLP_WNDPROC, (LONG_PTR)CountermeasureTbarRemoteProc); /********************************************* ここまで */ MoveWindow(hWndTbarRemote, LocalWidth + SepaWidth, TOOLWIN_HEIGHT, RemoteWidth, TOOLWIN_HEIGHT, FALSE); @@ -356,7 +369,9 @@ int MakeToolBarWindow(HWND hWnd, HINSTANCE hInst) /* エディットコントロールを探す */ hWndDirRemoteEdit = GetWindow(hWndDirRemote, GW_CHILD); if(hWndDirRemoteEdit != NULL) - HistEditBoxProcPtr = (WNDPROC)SetWindowLong(hWndDirRemoteEdit, GWL_WNDPROC, (LONG)HistEditBoxWndProc); + // 64ビット対応 +// HistEditBoxProcPtr = (WNDPROC)SetWindowLong(hWndDirRemoteEdit, GWL_WNDPROC, (LONG)HistEditBoxWndProc); + HistEditBoxProcPtr = (WNDPROC)SetWindowLongPtr(hWndDirRemoteEdit, GWLP_WNDPROC, (LONG_PTR)HistEditBoxWndProc); SendMessage(hWndDirRemote, WM_SETFONT, (WPARAM)DlgFont, MAKELPARAM(TRUE, 0)); SendMessage(hWndDirRemote, CB_LIMITTEXT, FMAX_PATH, 0); @@ -575,7 +590,9 @@ HWND GetRemoteTbarWnd(void) int GetHideUI(void) { - return(HideUI); + // デッドロック対策 +// return(HideUI); + return (HideUI > 0 ? YES : NO); } @@ -595,7 +612,9 @@ void MakeButtonsFocus(void) int Count; int Win; - if(HideUI == NO) + // デッドロック対策 +// if(HideUI == NO) + if(HideUI == 0) { hWndMain = GetMainHwnd(); hWndFocus = GetFocus(); @@ -753,7 +772,9 @@ void DisableUserOpe(void) { int i; - HideUI = YES; + // デッドロック対策 +// HideUI = YES; + HideUI++; for(i = 0; i < sizeof(HideMenus) / sizeof(int); i++) { @@ -783,7 +804,11 @@ void EnableUserOpe(void) { int i; - if(HideUI == YES) + // デッドロック対策 +// if(HideUI == YES) + if(HideUI > 0) + HideUI--; + if(HideUI == 0) { for(i = 0; i < sizeof(HideMenus) / sizeof(int); i++) { @@ -799,7 +824,8 @@ void EnableUserOpe(void) HideHostKanjiButton(); HideLocalKanjiButton(); - HideUI = NO; + // バグ修正 +// HideUI = NO; MakeButtonsFocus(); } @@ -819,7 +845,9 @@ void EnableUserOpe(void) int AskUserOpeDisabled(void) { - return(HideUI); + // デッドロック対策 +// return(HideUI); + return (HideUI > 0 ? YES : NO); } @@ -1745,7 +1773,9 @@ void LocalRbuttonMenu(int Pos) UINT Flg3; int Count; - if(HideUI == NO) + // デッドロック対策 +// if(HideUI == NO) + if(HideUI == 0) { Flg1 = 0; if(AskConnecting() == NO) @@ -1810,7 +1840,9 @@ void RemoteRbuttonMenu(int Pos) UINT Flg3; int Count; - if(HideUI == NO) + // デッドロック対策 +// if(HideUI == NO) + if(HideUI == 0) { Flg1 = 0; if(AskConnecting() == NO) @@ -1833,9 +1865,18 @@ void RemoteRbuttonMenu(int Pos) AppendMenu(hMenu, MF_STRING | Flg1, MENU_DOWNLOAD_ALL, MSGJPN266); AppendMenu(hMenu, MF_STRING | Flg1 | Flg2, MENU_DELETE, MSGJPN267); AppendMenu(hMenu, MF_STRING | Flg1 | Flg2, MENU_RENAME, MSGJPN268); +#if defined(HAVE_TANDEM) + /* HP NonStop Server では CHMOD の仕様が異なるため使用不可 */ + if (AskRealHostType() != HTYPE_TANDEM) +#endif AppendMenu(hMenu, MF_STRING | Flg1 | Flg2, MENU_CHMOD, MSGJPN269); AppendMenu(hMenu, MF_STRING | Flg1, MENU_MKDIR, MSGJPN270); AppendMenu(hMenu, MF_STRING | Flg1 | Flg2, MENU_URL_COPY, MSGJPN271); +#if defined(HAVE_TANDEM) + /* OSS モードのときに表示されるように AskRealHostType() を使用する */ + if (AskRealHostType() == HTYPE_TANDEM) + AppendMenu(hMenu, MF_STRING | Flg1, MENU_SWITCH_OSS, MSGJPN2001); +#endif AppendMenu(hMenu, MF_SEPARATOR, 0, NULL); AppendMenu(hMenu, MF_STRING | Flg1, MENU_FILESIZE, MSGJPN272); AppendMenu(hMenu, MF_SEPARATOR, 0, NULL); @@ -1874,7 +1915,9 @@ static void AddOpenMenu(HMENU hMenu, UINT Flg) char Tmp[FMAX_PATH+1]; int i; - AppendMenu(hMenu, MF_STRING | Flg, MENU_DCLICK, MSGJPN274); + // ローカルフォルダを開く +// AppendMenu(hMenu, MF_STRING | Flg, MENU_DCLICK, MSGJPN274); + AppendMenu(hMenu, MF_STRING | Flg, MENU_OPEN, MSGJPN274); for(i = 0; i < VIEWERS; i++) { if(strlen(ViewerName[i]) != 0) @@ -1896,7 +1939,9 @@ static LRESULT CALLBACK CountermeasureTbarMainProc(HWND hWnd,UINT uMessage,WPARA { switch (uMessage) { case WM_DESTROY : - SetWindowLong(hWnd,GWL_WNDPROC,(DWORD)pOldTbarMainProc); + // 64ビット対応 +// SetWindowLong(hWnd,GWL_WNDPROC,(DWORD)pOldTbarMainProc); + SetWindowLongPtr(hWnd,GWLP_WNDPROC,(LONG_PTR)pOldTbarMainProc); break; case WM_RBUTTONDBLCLK : case WM_RBUTTONDOWN : @@ -1913,7 +1958,9 @@ static LRESULT CALLBACK CountermeasureTbarLocalProc(HWND hWnd,UINT uMessage,WPAR { switch (uMessage) { case WM_DESTROY : - SetWindowLong(hWnd,GWL_WNDPROC,(DWORD)pOldTbarLocalProc); + // 64ビット対応 +// SetWindowLong(hWnd,GWL_WNDPROC,(DWORD)pOldTbarLocalProc); + SetWindowLongPtr(hWnd,GWLP_WNDPROC,(LONG_PTR)pOldTbarLocalProc); break; case WM_RBUTTONDBLCLK : case WM_RBUTTONDOWN : @@ -1930,7 +1977,9 @@ static LRESULT CALLBACK CountermeasureTbarRemoteProc(HWND hWnd,UINT uMessage,WPA { switch (uMessage) { case WM_DESTROY : - SetWindowLong(hWnd,GWL_WNDPROC,(DWORD)pOldTbarRemoteProc); + // 64ビット対応 +// SetWindowLong(hWnd,GWL_WNDPROC,(DWORD)pOldTbarRemoteProc); + SetWindowLongPtr(hWnd,GWLP_WNDPROC,(LONG_PTR)pOldTbarRemoteProc); break; case WM_RBUTTONDBLCLK : case WM_RBUTTONDOWN :