diff options
| -rw-r--r-- | plugins/AuthState/src/main.cpp | 120 | ||||
| -rw-r--r-- | plugins/AuthState/src/options.cpp | 22 | ||||
| -rw-r--r-- | plugins/AuthState/src/stdafx.h | 28 | 
3 files changed, 85 insertions, 85 deletions
| diff --git a/plugins/AuthState/src/main.cpp b/plugins/AuthState/src/main.cpp index 230edfd5c6..253463fa31 100644 --- a/plugins/AuthState/src/main.cpp +++ b/plugins/AuthState/src/main.cpp @@ -20,20 +20,25 @@  #include "stdafx.h"
  HINSTANCE g_hInst;
 -static HANDLE hOptInitialise;
 -static HANDLE hHookExtraIconsRebuild, hHookExtraIconsApply;
 -static HANDLE hAuthMenuSelected;
  static HGENMENU hUserMenu;
  HANDLE hExtraIcon;
  int hLangpack;
 -BYTE bUseAuthIcon = 0, bUseGrantIcon = 0, bContactMenuItem = 0, bIconsForRecentContacts = 0, bUseAuthGroup = 0;
 +Opts Options;
 -enum {
 -	icon_none,
 -	icon_auth,
 -	icon_grant,
 -	icon_both
 +static IconItem iconList[] =
 +{
 +	{ LPGEN("Request"), "auth_icon", IDI_AUTH },
 +	{ LPGEN("Grant"), "grant_icon", IDI_GRANT },
 +	{ LPGEN("Request & Grant"), "authgrant_icon", IDI_AUTHGRANT }
 +};
 +
 +enum
 +{
 +	ICON_NONE = -1,
 +	ICON_AUTH,
 +	ICON_GRANT,
 +	ICON_BOTH
  };
  PLUGININFOEX pluginInfo = {
 @@ -63,54 +68,45 @@ extern "C" __declspec(dllexport) PLUGININFOEX* MirandaPluginInfoEx(DWORD)  INT_PTR getIconToUse(MCONTACT hContact, LPARAM)
  {
 -	char *proto = GetContactProto(hContact);
 +	const char *proto = GetContactProto(hContact);
  	//	if (lParam == 1) return icon_none;
 -	if (!db_get_b(hContact, "AuthState", "ShowIcons", !bIconsForRecentContacts)) return icon_none;
 +	if (!db_get_b(hContact, "AuthState", "ShowIcons", !Options.bIconsForRecentContacts)) return ICON_NONE;
  	if (db_get_b(0, "ICQ", "UseServerCList", 0))
  		if (db_get_dw(hContact, proto, "ServerId", 1) == 0)
 -			return icon_both;
 +			return ICON_BOTH;
  	// Facebook contact type
  	int type = db_get_b(hContact, proto, "ContactType", 0);
 -	if (bUseAuthIcon & bUseGrantIcon)
 +	if (Options.bUseAuthIcon & Options.bUseGrantIcon)
  		if ((db_get_b(hContact, proto, "Auth", 0) && db_get_b(hContact, proto, "Grant", 0)) || type == 2)
 -			return icon_both;
 +			return ICON_BOTH;
 -	if (bUseAuthIcon)
 +	if (Options.bUseAuthIcon)
  		if (db_get_b(hContact, proto, "Auth", 0) || type == 3)
 -			return icon_auth;
 +			return ICON_AUTH;
 -	if (bUseGrantIcon)
 +	if (Options.bUseGrantIcon)
  		if (db_get_b(hContact, proto, "Grant", 0) || type == 4)
 -			return icon_grant;
 +			return ICON_GRANT;
 -	return icon_none;
 +	return ICON_NONE;
  }
  int onExtraImageApplying(WPARAM hContact, LPARAM lParam)
  {
  	if (hContact == NULL)
  		return 0;
 -
 -	int usedIcon = getIconToUse((MCONTACT)hContact, lParam);
 -
 -	const char *icon;
 -	switch (usedIcon) {
 -	case icon_both:   icon = "authgrant_icon";  break;
 -	case icon_grant:  icon = "grant_icon";  break;
 -	case icon_auth:   icon = "auth_icon";  break;
 -	default:          icon = NULL;  break;
 -	}
 -	ExtraIcon_SetIconByName(hExtraIcon, (MCONTACT)hContact, icon);
 +	int iIcon = getIconToUse((MCONTACT)hContact, lParam);
 +	ExtraIcon_SetIcon(hExtraIcon, (MCONTACT)hContact, iIcon == -1 ? NULL : iconList[iIcon].hIcolib);
  	return 0;
  }
  int onContactSettingChanged(WPARAM hContact, LPARAM lParam)
  {
  	DBCONTACTWRITESETTING *cws = (DBCONTACTWRITESETTING*)lParam;
 -	char *proto = GetContactProto((MCONTACT)hContact);
 +	const char *proto = GetContactProto((MCONTACT)hContact);
  	if (!proto) return 0;
  	if (!strcmp(cws->szModule, proto))
 @@ -122,24 +118,26 @@ int onContactSettingChanged(WPARAM hContact, LPARAM lParam)  int onDBContactAdded(WPARAM hContact, LPARAM)
  {
 -	// A new contact added, mark it as recent
  	db_set_b((MCONTACT)hContact, MODULENAME, "ShowIcons", 1);
  	onExtraImageApplying(hContact, 0);
 -
  	return 0;
  }
  INT_PTR onAuthMenuSelected(WPARAM hContact, LPARAM)
  {
 -	byte enabled = db_get_b((MCONTACT)hContact, "AuthState", "ShowIcons", 1);
 -	db_set_b((MCONTACT)hContact, MODULENAME, "ShowIcons", !enabled);
 -
 +	db_set_b((MCONTACT)hContact, MODULENAME, "ShowIcons", 1 - db_get_b((MCONTACT)hContact, "AuthState", "ShowIcons", 1));
  	onExtraImageApplying(hContact, 0);
  	return 0;
  }
  int onPrebuildContactMenu(WPARAM hContact, LPARAM)
  {
 +	if (!Options.bContactMenuItem)
 +	{
 +		Menu_ShowItem(hUserMenu, false);
 +		return 0;
 +	}
 +
  	char *proto = GetContactProto((MCONTACT)hContact);
  	if (!proto)
  		return 0;
 @@ -153,65 +151,45 @@ int onPrebuildContactMenu(WPARAM hContact, LPARAM)  	return 0;
  }
 -static IconItem iconList[] =
 -{
 -	{ LPGEN("Request"), "auth_icon", IDI_AUTH },
 -	{ LPGEN("Grant"), "grant_icon", IDI_GRANT },
 -	{ LPGEN("Request & Grant"), "authgrant_icon", IDI_AUTHGRANT }
 -};
  int onModulesLoaded(WPARAM, LPARAM)
  {
 +	// extra icons
 +	hExtraIcon = ExtraIcon_RegisterIcolib("authstate", LPGEN("Auth state"), iconList[ICON_BOTH].szName);
 +
  	// Set initial value for all contacts
  	for (MCONTACT hContact = db_find_first(); hContact; hContact = db_find_next(hContact))
  		onExtraImageApplying((WPARAM)hContact, 1);
 -	hOptInitialise = HookEvent(ME_OPT_INITIALISE, onOptInitialise);
 -	if (bContactMenuItem)
 -		HookEvent(ME_CLIST_PREBUILDCONTACTMENU, onPrebuildContactMenu);
 +	HookEvent(ME_OPT_INITIALISE, onOptInitialise);
 +	HookEvent(ME_CLIST_PREBUILDCONTACTMENU, onPrebuildContactMenu);
  	return 0;
  }
 -static int onShutdown(WPARAM, LPARAM)
 -{
 -	DestroyServiceFunction(hAuthMenuSelected);
 -	return 0;
 -}
 -
  extern "C" int __declspec(dllexport) Load(void)
  {
  	mir_getLP(&pluginInfo);
  	HookEvent(ME_SYSTEM_MODULESLOADED, onModulesLoaded);
 -	HookEvent(ME_SYSTEM_PRESHUTDOWN, onShutdown);
  	HookEvent(ME_DB_CONTACT_SETTINGCHANGED, onContactSettingChanged);
 -
 -	bUseAuthIcon = db_get_b(NULL, MODULENAME, "EnableAuthIcon", 1);
 -	bUseGrantIcon = db_get_b(NULL, MODULENAME, "EnableGrantIcon", 1);
 -	bContactMenuItem = db_get_b(NULL, MODULENAME, "MenuItem", 0);
 -	bIconsForRecentContacts = db_get_b(NULL, MODULENAME, "EnableOnlyForRecent", 0);
 -
 +	HookEvent(ME_CLIST_EXTRA_IMAGE_APPLY, onExtraImageApplying);
  	HookEvent(ME_DB_CONTACT_ADDED, onDBContactAdded);
 +	CreateServiceFunction("AuthState/MenuItem", onAuthMenuSelected);
 -	if (bContactMenuItem) {
 -		hAuthMenuSelected = CreateServiceFunction("AuthState/MenuItem", onAuthMenuSelected);
 +	Options.Load();
 -		CMenuItem mi;
 -		SET_UID(mi, 0xc5a784ea, 0x8b07, 0x4b95, 0xa2, 0xb2, 0x84, 0x9d, 0x87, 0x43, 0x7e, 0xda);
 -		mi.position = -1999901005;
 -		mi.flags = CMIF_TCHAR;
 -		mi.name.t = LPGENT("Enable AuthState icons");
 -		mi.pszService = "AuthState/MenuItem";
 -		hUserMenu = Menu_AddContactMenuItem(&mi);
 -	}
 +	CMenuItem mi;
 +	SET_UID(mi, 0xc5a784ea, 0x8b07, 0x4b95, 0xa2, 0xb2, 0x84, 0x9d, 0x87, 0x43, 0x7e, 0xda);
 +	mi.position = -1999901005;
 +	mi.flags = CMIF_TCHAR;
 +	mi.name.t = LPGENT("Enable AuthState icons");
 +	mi.pszService = "AuthState/MenuItem";
 +	hUserMenu = Menu_AddContactMenuItem(&mi);
  	// IcoLib support
  	Icon_Register(g_hInst, LPGEN("Auth state"), iconList, _countof(iconList));
 -	// extra icons
 -	hExtraIcon = ExtraIcon_RegisterIcolib("authstate", LPGEN("Auth state"), "authgrant_icon");
 -
  	return 0;
  }
 diff --git a/plugins/AuthState/src/options.cpp b/plugins/AuthState/src/options.cpp index 2374c8592e..de4b90fedc 100644 --- a/plugins/AuthState/src/options.cpp +++ b/plugins/AuthState/src/options.cpp @@ -27,10 +27,10 @@ INT_PTR CALLBACK DlgProcOptions(HWND hwndDlg, UINT msg, WPARAM wParam, LPARAM lP  		TranslateDialogDefault(hwndDlg);
  		bInitializing = 1;
 -		CheckDlgButton(hwndDlg, IDC_AUTHICON, bUseAuthIcon ? BST_CHECKED : BST_UNCHECKED);
 -		CheckDlgButton(hwndDlg, IDC_GRANTICON, bUseGrantIcon ? BST_CHECKED : BST_UNCHECKED);
 -		CheckDlgButton(hwndDlg, IDC_ENABLEMENUITEM, bContactMenuItem ? BST_CHECKED : BST_UNCHECKED);
 -		CheckDlgButton(hwndDlg, IDC_ICONSFORRECENT, bIconsForRecentContacts ? BST_CHECKED : BST_UNCHECKED);
 +		CheckDlgButton(hwndDlg, IDC_AUTHICON, Options.bUseAuthIcon ? BST_CHECKED : BST_UNCHECKED);
 +		CheckDlgButton(hwndDlg, IDC_GRANTICON, Options.bUseGrantIcon ? BST_CHECKED : BST_UNCHECKED);
 +		CheckDlgButton(hwndDlg, IDC_ENABLEMENUITEM, Options.bContactMenuItem ? BST_CHECKED : BST_UNCHECKED);
 +		CheckDlgButton(hwndDlg, IDC_ICONSFORRECENT, Options.bIconsForRecentContacts ? BST_CHECKED : BST_UNCHECKED);
  		bInitializing = 0;
  		return TRUE;
 @@ -50,19 +50,15 @@ INT_PTR CALLBACK DlgProcOptions(HWND hwndDlg, UINT msg, WPARAM wParam, LPARAM lP  		if (((LPNMHDR)lParam)->idFrom == 0)
  			switch (((LPNMHDR)lParam)->code) {
  			case PSN_APPLY:
 -				bUseAuthIcon = IsDlgButtonChecked(hwndDlg, IDC_AUTHICON);
 -				bUseGrantIcon = IsDlgButtonChecked(hwndDlg, IDC_GRANTICON);
 -				bContactMenuItem = IsDlgButtonChecked(hwndDlg, IDC_ENABLEMENUITEM);
 -				bIconsForRecentContacts = IsDlgButtonChecked(hwndDlg, IDC_ICONSFORRECENT);
 +				Options.bUseAuthIcon = IsDlgButtonChecked(hwndDlg, IDC_AUTHICON);
 +				Options.bUseGrantIcon = IsDlgButtonChecked(hwndDlg, IDC_GRANTICON);
 +				Options.bContactMenuItem = IsDlgButtonChecked(hwndDlg, IDC_ENABLEMENUITEM);
 +				Options.bIconsForRecentContacts = IsDlgButtonChecked(hwndDlg, IDC_ICONSFORRECENT);
  				for (MCONTACT hContact = db_find_first(); hContact; hContact = db_find_next(hContact))
  					onExtraImageApplying((WPARAM)hContact, 0);
 -				//Store options values to DB
 -				db_set_b(NULL, MODULENAME, "EnableAuthIcon", bUseAuthIcon);
 -				db_set_b(NULL, MODULENAME, "EnableGrantIcon", bUseGrantIcon);
 -				db_set_b(NULL, MODULENAME, "MenuItem", bContactMenuItem);
 -				db_set_b(NULL, MODULENAME, "EnableOnlyForRecent", bIconsForRecentContacts);
 +				Options.Save();
  				return TRUE;
  		}
  	}
 diff --git a/plugins/AuthState/src/stdafx.h b/plugins/AuthState/src/stdafx.h index dc1fceea6d..b3fc4a0e4c 100644 --- a/plugins/AuthState/src/stdafx.h +++ b/plugins/AuthState/src/stdafx.h @@ -39,11 +39,37 @@  #define MODULENAME "AuthState"
 +struct Opts
 +{
 +	BYTE bUseAuthIcon;
 +	BYTE bUseGrantIcon;
 +	BYTE bContactMenuItem;
 +	BYTE bIconsForRecentContacts;
 +
 +	void Load()
 +	{
 +		bUseAuthIcon = db_get_b(NULL, MODULENAME, "EnableAuthIcon", 1);
 +		bUseGrantIcon = db_get_b(NULL, MODULENAME, "EnableGrantIcon", 1);
 +		bContactMenuItem = db_get_b(NULL, MODULENAME, "MenuItem", 0);
 +		bIconsForRecentContacts = db_get_b(NULL, MODULENAME, "EnableOnlyForRecent", 0);
 +	}
 +
 +	void Save()
 +	{
 +		db_set_b(NULL, MODULENAME, "EnableAuthIcon", bUseAuthIcon);
 +		db_set_b(NULL, MODULENAME, "EnableGrantIcon", bUseGrantIcon);
 +		db_set_b(NULL, MODULENAME, "MenuItem", bContactMenuItem);
 +		db_set_b(NULL, MODULENAME, "EnableOnlyForRecent", bIconsForRecentContacts);
 +	}
 +
 +};
 +
 +extern Opts Options;
 +
  int onOptInitialise(WPARAM wParam, LPARAM lParam);
  int onExtraImageApplying(WPARAM wParam, LPARAM lParam);
  extern HINSTANCE g_hInst;
 -extern byte bUseAuthIcon, bUseGrantIcon, bContactMenuItem, bIconsForRecentContacts;
  extern HANDLE hExtraIcon;
  #endif //COMMHEADERS_H
 | 
