diff options
| -rw-r--r-- | plugins/Clist_modern/src/hdr/modern_commonheaders.h | 2 | ||||
| -rw-r--r-- | plugins/Clist_modern/src/modern_clistsettings.cpp | 191 | ||||
| -rw-r--r-- | plugins/Clist_modern/src/modern_viewmodebar.cpp | 10 | ||||
| -rw-r--r-- | src/modules/clist/clistmod.cpp | 2 | ||||
| -rw-r--r-- | src/modules/clist/clistsettings.cpp | 44 | 
5 files changed, 98 insertions, 151 deletions
| diff --git a/plugins/Clist_modern/src/hdr/modern_commonheaders.h b/plugins/Clist_modern/src/hdr/modern_commonheaders.h index 41d53055f2..75386a571d 100644 --- a/plugins/Clist_modern/src/hdr/modern_commonheaders.h +++ b/plugins/Clist_modern/src/hdr/modern_commonheaders.h @@ -195,7 +195,7 @@ extern void TRACE_ERROR();  extern BOOL DebugDeleteObject(HGDIOBJ a);
  extern void IvalidateDisplayNameCache(DWORD mode);
 -extern SortedList *clistCache;
 +extern LIST<ClcCacheEntry> clistCache;
  HICON LoadSmallIcon(HINSTANCE hInstance, int idx);
  BOOL DestroyIcon_protect(HICON icon);
 diff --git a/plugins/Clist_modern/src/modern_clistsettings.cpp b/plugins/Clist_modern/src/modern_clistsettings.cpp index 010b3d5d5a..5960f1c12e 100644 --- a/plugins/Clist_modern/src/modern_clistsettings.cpp +++ b/plugins/Clist_modern/src/modern_clistsettings.cpp @@ -28,98 +28,74 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.  #include "hdr/modern_awaymsg.h"
  void InsertContactIntoTree(MCONTACT hContact,int status);
 -static ClcCacheEntry *displayNameCache;
  void CListSettings_FreeCacheItemDataOption( ClcCacheEntry *pDst, DWORD flag );
  int PostAutoRebuidMessage(HWND hwnd);
  static int displayNameCacheSize;
 +LIST<ClcCacheEntry> clistCache(50, NumericKeySortT);
 +
  BOOL CLM_AUTOREBUILD_WAS_POSTED = FALSE;
 -SortedList *clistCache = NULL;
  char *GetProtoForContact(MCONTACT hContact);
  int GetStatusForContact(MCONTACT hContact,char *szProto);
  TCHAR *UnknownConctactTranslatedName = NULL;
  void InvalidateDNCEbyPointer(MCONTACT hContact,ClcCacheEntry *pdnce,int SettingType);
 -static int handleCompare( void* c1, void* c2 )
 -{
 -	INT_PTR p1, p2;
 -
 -	ClcCacheEntry *dnce1 = (ClcCacheEntry *)c1;
 -	ClcCacheEntry *dnce2 = (ClcCacheEntry *)c2;
 -
 -	p1 = (INT_PTR)dnce1->hContact;
 -	p2 = (INT_PTR)dnce2->hContact;
 -
 -	if ( p1 == p2 )
 -		return 0;
 -
 -	return (int)(p1 - p2);
 -}
 -
  void InitCacheAsync();
  void UninitCacheAsync();
  void InitDisplayNameCache(void)
  {
 -	int i=0;
 +	int i = 0;
  	InitCacheAsync();
  	InitAwayMsgModule();
 -	clistCache = List_Create( 0, 50 );
 -	clistCache->sortFunc = handleCompare;
  }
  void FreeDisplayNameCache()
  {
  	UninitCacheAsync();
  	UninitAwayMsgModule();
 -	if ( clistCache != NULL ) {
 -		for (int i=0; i < clistCache->realCount; i++) {
 -			pcli->pfnFreeCacheItem(( ClcCacheEntry* )clistCache->items[i] );
 -			mir_free_and_nil( clistCache->items[i] );
 -		}
 -		List_Destroy( clistCache );
 -		mir_free(clistCache);
 -		clistCache = NULL;
 +	for (int i = 0; i < clistCache.getCount(); i++) {
 +		pcli->pfnFreeCacheItem(clistCache[i]);
 +		mir_free(clistCache[i]);
  	}
 +	clistCache.destroy();
  }
  ClcCacheEntry* cliGetCacheEntry(MCONTACT hContact)
  {
 -	if (!clistCache) return NULL;
 -
 -	int idx;
  	ClcCacheEntry *p;
 -	if (!List_GetIndex( clistCache, &hContact, &idx )) {
 -		if (( p = pcli->pfnCreateCacheItem( hContact )) != NULL ) {
 -			List_Insert( clistCache, p, idx );
 -			pcli->pfnInvalidateDisplayNameCacheEntry( hContact );
 +	int idx = clistCache.getIndex((ClcCacheEntry*)&hContact);
 +	if (idx == -1) {
 +		if ((p = pcli->pfnCreateCacheItem(hContact)) != NULL) {
 +			clistCache.insert(p);
 +			pcli->pfnInvalidateDisplayNameCacheEntry(hContact);
  		}
  	}
 -	else p = (ClcCacheEntry*)clistCache->items[idx];
 -	pcli->pfnCheckCacheItem( p );
 +	else p = clistCache[idx];
 +	pcli->pfnCheckCacheItem(p);
  	return p;
  }
  void CListSettings_FreeCacheItemData(ClcCacheEntry *pDst)
  {
 -	CListSettings_FreeCacheItemDataOption( pDst, CCI_ALL);
 +	CListSettings_FreeCacheItemDataOption(pDst, CCI_ALL);
  }
 -void CListSettings_FreeCacheItemDataOption( ClcCacheEntry *pDst, DWORD flag )
 +void CListSettings_FreeCacheItemDataOption(ClcCacheEntry *pDst, DWORD flag)
  {
  	if (!pDst)
  		return;
 -	if ( flag & CCI_NAME)
 +	if (flag & CCI_NAME)
  		pDst->freeName();
 -	if ( flag & CCI_GROUP )
 +	if (flag & CCI_GROUP)
  		mir_free_and_nil(pDst->tszGroup);
 -	if ( flag & CCI_LINES ) {
 +	if (flag & CCI_LINES) {
  		mir_free_and_nil(pDst->szSecondLineText);
  		mir_free_and_nil(pDst->szThirdLineText);
  		pDst->ssSecondLine.DestroySmileyList();
 @@ -130,13 +106,12 @@ void CListSettings_FreeCacheItemDataOption( ClcCacheEntry *pDst, DWORD flag )  int CListSettings_GetCopyFromCache(ClcCacheEntry *pDest, DWORD flag);
  int CListSettings_SetToCache(ClcCacheEntry *pSrc, DWORD flag);
 -
  void CListSettings_CopyCacheItems(ClcCacheEntry *pDst, ClcCacheEntry *pSrc, DWORD flag)
  {
  	if (!pDst || !pSrc) return;
  	CListSettings_FreeCacheItemDataOption(pDst, flag);
 -	if ( flag & CCI_NAME ) {
 +	if (flag & CCI_NAME) {
  		pDst->isUnknown = pSrc->isUnknown;
  		if (pSrc->isUnknown)
  			pDst->tszName = pSrc->tszName;
 @@ -144,25 +119,25 @@ void CListSettings_CopyCacheItems(ClcCacheEntry *pDst, ClcCacheEntry *pSrc, DWOR  			pDst->tszName = mir_tstrdup(pSrc->tszName);
  	}
 -	if ( flag & CCI_GROUP )  pDst->tszGroup = mir_tstrdup(pSrc->tszGroup);
 -	if ( flag & CCI_PROTO )  pDst->m_cache_cszProto = pSrc->m_cache_cszProto;
 -	if ( flag & CCI_STATUS ) pDst->m_cache_nStatus = pSrc->m_cache_nStatus;
 +	if (flag & CCI_GROUP)  pDst->tszGroup = mir_tstrdup(pSrc->tszGroup);
 +	if (flag & CCI_PROTO)  pDst->m_cache_cszProto = pSrc->m_cache_cszProto;
 +	if (flag & CCI_STATUS) pDst->m_cache_nStatus = pSrc->m_cache_nStatus;
 -	if ( flag & CCI_LINES ) {
 -		mir_free( pDst->szThirdLineText );
 -		pDst->szThirdLineText = mir_tstrdup( pSrc->szThirdLineText );
 +	if (flag & CCI_LINES) {
 +		mir_free(pDst->szThirdLineText);
 +		pDst->szThirdLineText = mir_tstrdup(pSrc->szThirdLineText);
 -		mir_free( pDst->szSecondLineText );
 -		pDst->szSecondLineText = mir_tstrdup( pSrc->szSecondLineText );
 +		mir_free(pDst->szSecondLineText);
 +		pDst->szSecondLineText = mir_tstrdup(pSrc->szSecondLineText);
 -		pDst->ssThirdLine  = pSrc->ssThirdLine;
 +		pDst->ssThirdLine = pSrc->ssThirdLine;
  		pDst->ssSecondLine = pSrc->ssSecondLine;
  	}
 -	if ( flag & CCI_TIME)
 +	if (flag & CCI_TIME)
  		pDst->hTimeZone = pSrc->hTimeZone;
 -	if ( flag & CCI_OTHER) {
 +	if (flag & CCI_OTHER) {
  		pDst->bIsHidden = pSrc->bIsHidden;
  		pDst->m_cache_nNoHiddenOffline = pSrc->m_cache_nNoHiddenOffline;
  		pDst->m_cache_bProtoNotExists = pSrc->m_cache_bProtoNotExists;
 @@ -203,10 +178,10 @@ int CListSettings_SetToCache(ClcCacheEntry *pSrc, DWORD flag)  	return 0;
  }
 -void cliFreeCacheItem( ClcCacheEntry *p )
 +void cliFreeCacheItem(ClcCacheEntry *p)
  {
  	MCONTACT hContact = p->hContact;
 -	TRACEVAR("cliFreeCacheItem hContact = %d",hContact);
 +	TRACEVAR("cliFreeCacheItem hContact = %d", hContact);
  	p->freeName();
  	mir_free_and_nil(p->tszGroup);
  	mir_free_and_nil(p->szSecondLineText);
 @@ -244,12 +219,12 @@ void cliCheckCacheItem(ClcCacheEntry *pdnce)  		}
  	}
 -	if (pdnce___GetStatus( pdnce ) == 0) //very strange look status sort is broken let always reread status
 -		pdnce___SetStatus( pdnce , GetStatusForContact(pdnce->hContact,pdnce->m_cache_cszProto));
 +	if (pdnce___GetStatus(pdnce) == 0) //very strange look status sort is broken let always reread status
 +		pdnce___SetStatus(pdnce, GetStatusForContact(pdnce->hContact, pdnce->m_cache_cszProto));
  	if (pdnce->tszGroup == NULL) {
 -		DBVARIANT dbv = {0};
 -		if (!db_get_ts(pdnce->hContact,"CList","Group",&dbv)) {
 +		DBVARIANT dbv = { 0 };
 +		if (!db_get_ts(pdnce->hContact, "CList", "Group", &dbv)) {
  			pdnce->tszGroup = mir_tstrdup(dbv.ptszVal);
  			db_free(&dbv);
  		}
 @@ -257,24 +232,24 @@ void cliCheckCacheItem(ClcCacheEntry *pdnce)  	}
  	if (pdnce->bIsHidden == -1)
 -		pdnce->bIsHidden = db_get_b(pdnce->hContact,"CList","Hidden",0);
 +		pdnce->bIsHidden = db_get_b(pdnce->hContact, "CList", "Hidden", 0);
  	pdnce->m_cache_nHiddenSubcontact = db_mc_isSub(pdnce->hContact);
  	if (pdnce->m_cache_nNoHiddenOffline == -1)
 -		pdnce->m_cache_nNoHiddenOffline = db_get_b(pdnce->hContact,"CList","noOffline",0);
 +		pdnce->m_cache_nNoHiddenOffline = db_get_b(pdnce->hContact, "CList", "noOffline", 0);
  	if (pdnce->IdleTS == -1)
 -		pdnce->IdleTS = db_get_dw(pdnce->hContact,pdnce->m_cache_cszProto,"IdleTS",0);
 +		pdnce->IdleTS = db_get_dw(pdnce->hContact, pdnce->m_cache_cszProto, "IdleTS", 0);
  	if (pdnce->ApparentMode == -1)
 -		pdnce->ApparentMode = db_get_w(pdnce->hContact,pdnce->m_cache_cszProto,"ApparentMode",0);
 +		pdnce->ApparentMode = db_get_w(pdnce->hContact, pdnce->m_cache_cszProto, "ApparentMode", 0);
  	if (pdnce->NotOnList == -1)
 -		pdnce->NotOnList = db_get_b(pdnce->hContact,"CList","NotOnList",0);
 +		pdnce->NotOnList = db_get_b(pdnce->hContact, "CList", "NotOnList", 0);
  	if (pdnce->IsExpanded == -1)
 -		pdnce->IsExpanded = db_get_b(pdnce->hContact,"CList","Expanded",0);
 +		pdnce->IsExpanded = db_get_b(pdnce->hContact, "CList", "Expanded", 0);
  	if (pdnce->dwLastMsgTime == 0) {
  		pdnce->dwLastMsgTime = db_get_dw(pdnce->hContact, "CList", "mf_lastmsg", 0);
 @@ -285,17 +260,10 @@ void cliCheckCacheItem(ClcCacheEntry *pdnce)  void IvalidateDisplayNameCache(DWORD mode)
  {
 -	if ( clistCache != NULL )
 -	{
 -		int i;
 -		for ( i=0; i < clistCache->realCount; i++)
 -		{
 -			ClcCacheEntry *pdnce = (ClcCacheEntry *)clistCache->items[i];
 -			if (mode&16)
 -			{
 -				InvalidateDNCEbyPointer(pdnce->hContact,pdnce,16);
 -			}
 -		}
 +	for (int i = 0; i < clistCache.getCount(); i++) {
 +		ClcCacheEntry *pdnce = (ClcCacheEntry *)clistCache[i];
 +		if (mode & 16)
 +			InvalidateDNCEbyPointer(pdnce->hContact, pdnce, 16);
  	}
  }
 @@ -313,7 +281,7 @@ void InvalidateDNCEbyPointer(MCONTACT hContact, ClcCacheEntry *pdnce, int Settin  		pdnce->ssThirdLine.iMaxSmileyHeight = 0;
  		pdnce->hTimeZone = NULL;
  		pdnce->dwLastMsgTime = 0;
 -		Cache_GetTimezone(NULL,pdnce->hContact);
 +		Cache_GetTimezone(NULL, pdnce->hContact);
  		SettingType &= ~16;
  	}
 @@ -356,10 +324,10 @@ char *GetContactCachedProtocol(MCONTACT hContact)  char* GetProtoForContact(MCONTACT hContact)
  {
 -	return (char*)CallService(MS_PROTO_GETCONTACTBASEACCOUNT,hContact,0);
 +	return (char*)CallService(MS_PROTO_GETCONTACTBASEACCOUNT, hContact, 0);
  }
 -int GetStatusForContact(MCONTACT hContact,char *szProto)
 +int GetStatusForContact(MCONTACT hContact, char *szProto)
  {
  	return (szProto) ? (int)(db_get_w(hContact, szProto, "Status", ID_STATUS_OFFLINE)) : ID_STATUS_OFFLINE;
  }
 @@ -393,15 +361,14 @@ LBL_Unknown:  	isUnknown = false;
  }
 -int GetContactInfosForSort(MCONTACT hContact,char **Proto,TCHAR **Name,int *Status)
 +int GetContactInfosForSort(MCONTACT hContact, char **Proto, TCHAR **Name, int *Status)
  {
  	ClcCacheEntry *cacheEntry = NULL;
  	cacheEntry = pcli->pfnGetCacheEntry(hContact);
 -	if (cacheEntry != NULL)
 -	{
 +	if (cacheEntry != NULL) {
  		if (Proto != NULL)  *Proto = cacheEntry->m_cache_cszProto;
  		if (Name != NULL)   *Name = cacheEntry->tszName;
 -		if (Status != NULL) *Status = pdnce___GetStatus( cacheEntry );
 +		if (Status != NULL) *Status = pdnce___GetStatus(cacheEntry);
  	}
  	return (0);
  };
 @@ -411,13 +378,13 @@ int GetContactCachedStatus(MCONTACT hContact)  {
  	ClcCacheEntry *cacheEntry = NULL;
  	cacheEntry = pcli->pfnGetCacheEntry(hContact);
 -	return pdnce___GetStatus( cacheEntry );
 +	return pdnce___GetStatus(cacheEntry);
  }
  int ContactAdded(WPARAM hContact, LPARAM lParam)
  {
  	if (!MirandaExiting()) {
 -		cli_ChangeContactIcon(hContact,pcli->pfnIconFromStatusMode((char*)GetContactCachedProtocol(hContact),ID_STATUS_OFFLINE,hContact),1); ///by FYR
 +		cli_ChangeContactIcon(hContact, pcli->pfnIconFromStatusMode((char*)GetContactCachedProtocol(hContact), ID_STATUS_OFFLINE, hContact), 1); ///by FYR
  		pcli->pfnSortContacts();
  	}
  	return 0;
 @@ -425,7 +392,7 @@ int ContactAdded(WPARAM hContact, LPARAM lParam)  int ContactSettingChanged(WPARAM hContact, LPARAM lParam)
  {
 -	if (MirandaExiting() || !pcli || !clistCache || hContact == NULL)
 +	if (MirandaExiting() || !pcli || hContact == NULL)
  		return 0;
  	ClcCacheEntry *pdnce = pcli->pfnGetCacheEntry(hContact);
 @@ -442,7 +409,7 @@ int ContactSettingChanged(WPARAM hContact, LPARAM lParam)  		InvalidateDNCEbyPointer(hContact, pdnce, cws->value.type);
  		if (!strcmp(cws->szSetting, "IsSubcontact"))
 -		 	PostMessage(pcli->hwndContactTree, CLM_AUTOREBUILD, 0, 0);
 +			PostMessage(pcli->hwndContactTree, CLM_AUTOREBUILD, 0, 0);
  		if (!mir_strcmp(cws->szSetting, "Status") || wildcmp(cws->szSetting, "Status?")) {
  			if (!mir_strcmp(cws->szModule, META_PROTO) && mir_strcmp(cws->szSetting, "Status")) {
 @@ -450,19 +417,19 @@ int ContactSettingChanged(WPARAM hContact, LPARAM lParam)  				if (pcli->hwndContactTree && g_flag_bOnModulesLoadedCalled)
  					res = PostAutoRebuidMessage(pcli->hwndContactTree);
 -				if ((db_get_w(NULL,"CList","SecondLineType",SETTING_SECONDLINE_TYPE_DEFAULT) == TEXT_STATUS_MESSAGE || db_get_w(NULL,"CList","ThirdLineType",SETTING_THIRDLINE_TYPE_DEFAULT) == TEXT_STATUS_MESSAGE)  && pdnce->hContact && pdnce->m_cache_cszProto)
 +				if ((db_get_w(NULL, "CList", "SecondLineType", SETTING_SECONDLINE_TYPE_DEFAULT) == TEXT_STATUS_MESSAGE || db_get_w(NULL, "CList", "ThirdLineType", SETTING_THIRDLINE_TYPE_DEFAULT) == TEXT_STATUS_MESSAGE) && pdnce->hContact && pdnce->m_cache_cszProto)
  					amRequestAwayMsg(hContact);
  				return 0;
  			}
  			if (pdnce->bIsHidden != 1) {
 -				pdnce___SetStatus( pdnce , cws->value.wVal ); //dont use direct set
 +				pdnce___SetStatus(pdnce, cws->value.wVal); //dont use direct set
  				if (cws->value.wVal == ID_STATUS_OFFLINE)
  					if (g_CluiData.bRemoveAwayMessageForOffline)
 -						db_set_s(hContact,"CList","StatusMsg","");
 +						db_set_s(hContact, "CList", "StatusMsg", "");
 -				if ((db_get_w(NULL,"CList","SecondLineType",0) == TEXT_STATUS_MESSAGE || db_get_w(NULL,"CList","ThirdLineType",0) == TEXT_STATUS_MESSAGE)  && pdnce->hContact && pdnce->m_cache_cszProto)
 +				if ((db_get_w(NULL, "CList", "SecondLineType", 0) == TEXT_STATUS_MESSAGE || db_get_w(NULL, "CList", "ThirdLineType", 0) == TEXT_STATUS_MESSAGE) && pdnce->hContact && pdnce->m_cache_cszProto)
  					amRequestAwayMsg(hContact);
  				pcli->pfnClcBroadcast(INTM_STATUSCHANGED, hContact, 0);
 @@ -478,37 +445,37 @@ int ContactSettingChanged(WPARAM hContact, LPARAM lParam)  		}
  	}
 -	if (!strcmp(cws->szModule,"CList")) {
 +	if (!strcmp(cws->szModule, "CList")) {
  		//name is null or (setting is myhandle)
 -		if (!strcmp(cws->szSetting,"Rate"))
 +		if (!strcmp(cws->szSetting, "Rate"))
  			pcli->pfnClcBroadcast(CLM_AUTOREBUILD, 0, 0);
 -		else if (pdnce->tszName == NULL || !strcmp(cws->szSetting,"MyHandle"))
 -			InvalidateDNCEbyPointer(hContact,pdnce,cws->value.type);
 +		else if (pdnce->tszName == NULL || !strcmp(cws->szSetting, "MyHandle"))
 +			InvalidateDNCEbyPointer(hContact, pdnce, cws->value.type);
 -		else if (!strcmp(cws->szSetting,"Group"))
 -			InvalidateDNCEbyPointer(hContact,pdnce,cws->value.type);
 +		else if (!strcmp(cws->szSetting, "Group"))
 +			InvalidateDNCEbyPointer(hContact, pdnce, cws->value.type);
 -		else if (!strcmp(cws->szSetting,"Hidden")) {
 -			InvalidateDNCEbyPointer(hContact,pdnce,cws->value.type);
 +		else if (!strcmp(cws->szSetting, "Hidden")) {
 +			InvalidateDNCEbyPointer(hContact, pdnce, cws->value.type);
  			if (cws->value.type == DBVT_DELETED || cws->value.bVal == 0) {
  				char *szProto = GetContactProto(hContact);
 -				cli_ChangeContactIcon(hContact,pcli->pfnIconFromStatusMode(szProto,
 -					szProto == NULL ? ID_STATUS_OFFLINE : db_get_w(hContact,szProto,"Status",ID_STATUS_OFFLINE), hContact),1);  //by FYR
 +				cli_ChangeContactIcon(hContact, pcli->pfnIconFromStatusMode(szProto,
 +					szProto == NULL ? ID_STATUS_OFFLINE : db_get_w(hContact, szProto, "Status", ID_STATUS_OFFLINE), hContact), 1);  //by FYR
  			}
  			pcli->pfnClcBroadcast(CLM_AUTOREBUILD, 0, 0);
  		}
 -		else if (!strcmp(cws->szSetting,"noOffline")) {
 -			InvalidateDNCEbyPointer(hContact,pdnce,cws->value.type);
 +		else if (!strcmp(cws->szSetting, "noOffline")) {
 +			InvalidateDNCEbyPointer(hContact, pdnce, cws->value.type);
  			pcli->pfnClcBroadcast(CLM_AUTOREBUILD, 0, 0);
  		}
  	}
 -	else if (!strcmp(cws->szModule,"Protocol")) {
 -		if (!strcmp(cws->szSetting,"p")) {
 -			InvalidateDNCEbyPointer(hContact,pdnce,cws->value.type);
 +	else if (!strcmp(cws->szModule, "Protocol")) {
 +		if (!strcmp(cws->szSetting, "p")) {
 +			InvalidateDNCEbyPointer(hContact, pdnce, cws->value.type);
  			char *szProto = (cws->value.type == DBVT_DELETED) ? NULL : cws->value.pszVal;
 -			cli_ChangeContactIcon(hContact,pcli->pfnIconFromStatusMode(szProto,
 -				szProto == NULL ? ID_STATUS_OFFLINE : db_get_w(hContact,szProto,"Status",ID_STATUS_OFFLINE), hContact), 0);
 +			cli_ChangeContactIcon(hContact, pcli->pfnIconFromStatusMode(szProto,
 +				szProto == NULL ? ID_STATUS_OFFLINE : db_get_w(hContact, szProto, "Status", ID_STATUS_OFFLINE), hContact), 0);
  		}
  	}
 @@ -518,7 +485,7 @@ int ContactSettingChanged(WPARAM hContact, LPARAM lParam)  int PostAutoRebuidMessage(HWND hwnd)
  {
  	if (!CLM_AUTOREBUILD_WAS_POSTED)
 -		CLM_AUTOREBUILD_WAS_POSTED = PostMessage(hwnd,CLM_AUTOREBUILD, 0, 0);
 +		CLM_AUTOREBUILD_WAS_POSTED = PostMessage(hwnd, CLM_AUTOREBUILD, 0, 0);
  	return CLM_AUTOREBUILD_WAS_POSTED;
  }
 diff --git a/plugins/Clist_modern/src/modern_viewmodebar.cpp b/plugins/Clist_modern/src/modern_viewmodebar.cpp index 4ed058faf3..014d00b4ed 100644 --- a/plugins/Clist_modern/src/modern_viewmodebar.cpp +++ b/plugins/Clist_modern/src/modern_viewmodebar.cpp @@ -1394,14 +1394,11 @@ void ApplyViewMode(const char *Name, bool onlySelector )  		if (g_CluiData.filterFlags & CLVM_USELASTMSG)
  		{
 -			DWORD unit;
 -			int i;
  			BYTE bSaved = g_CluiData.bSortByOrder[0];
  			g_CluiData.bSortByOrder[0] = SORTBY_LASTMSG;
 -			for (i=0; i < clistCache->realCount; i++)
 -			{
 -				ClcCacheEntry *pdnce = (ClcCacheEntry *)clistCache->items[i];
 +			for (int i=0; i < clistCache.getCount(); i++) {
 +				ClcCacheEntry *pdnce = clistCache[i];
  				pdnce->dwLastMsgTime = CompareContacts2_getLMTime(pdnce->hContact);
  			}
  			g_CluiData.bSortByOrder[0] = bSaved;
 @@ -1413,7 +1410,8 @@ void ApplyViewMode(const char *Name, bool onlySelector )  				g_CluiData.bFilterEffective |= CLVM_FILTER_LASTMSG_NEWERTHAN;
  			else
  				g_CluiData.bFilterEffective |= CLVM_FILTER_LASTMSG_OLDERTHAN;
 -			unit = LOWORD(g_CluiData.lastMsgFilter);
 +			
 +			DWORD unit = LOWORD(g_CluiData.lastMsgFilter);
  			switch(HIBYTE(HIWORD(g_CluiData.lastMsgFilter))) {
  			case 0:
  				unit  *= 60;
 diff --git a/src/modules/clist/clistmod.cpp b/src/modules/clist/clistmod.cpp index 72a9c21847..fc6c717519 100644 --- a/src/modules/clist/clistmod.cpp +++ b/src/modules/clist/clistmod.cpp @@ -38,7 +38,6 @@ INT_PTR InvalidateDisplayName(WPARAM wParam, LPARAM lParam);  int InitGroupServices(void);
  void LoadCluiServices();
  INT_PTR Docking_IsDocked(WPARAM wParam, LPARAM lParam);
 -void InitDisplayNameCache(void);
  void FreeDisplayNameCache(void);
  int LoadCLUIModule(void);
  int InitClistHotKeys(void);
 @@ -506,7 +505,6 @@ int LoadContactListModule2(void)  	CreateServiceFunction(MS_CLIST_HOTKEYSPROCESSMESSAGE, HotkeysProcessMessageStub);
  	CreateServiceFunction(MS_CLIST_GETCONTACTICON, GetContactIcon);
 -	InitDisplayNameCache();
  	InitCListEvents();
  	InitGroupServices();
  	cli.pfnInitTray();
 diff --git a/src/modules/clist/clistsettings.cpp b/src/modules/clist/clistsettings.cpp index 196daf1b51..c17e6e0d24 100644 --- a/src/modules/clist/clistsettings.cpp +++ b/src/modules/clist/clistsettings.cpp @@ -25,31 +25,16 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.  #include "..\..\core\commonheaders.h"
  #include "clc.h"
 -SortedList* clistCache = NULL;
 -
 -static int compareContacts(ClcCacheEntry *p1, ClcCacheEntry *p2)
 -{
 -	return (char*)p1->hContact - (char*)p2->hContact;
 -}
 -
 -void InitDisplayNameCache(void)
 -{
 -	clistCache = List_Create(0, 50);
 -	clistCache->sortFunc = (FSortFunc)compareContacts;
 -}
 +static LIST<ClcCacheEntry> clistCache(50, NumericKeySortT);
  void FreeDisplayNameCache(void)
  {
 -	if (clistCache != NULL) {
 -		for (int i=0; i < clistCache->realCount; i++) {
 -			cli.pfnFreeCacheItem((ClcCacheEntry*)clistCache->items[i]);
 -			mir_free(clistCache->items[i]);
 -		}
 -
 -		List_Destroy(clistCache);
 -		mir_free(clistCache);
 -		clistCache = NULL;
 +	for (int i=0; i < clistCache.getCount(); i++) {
 +		cli.pfnFreeCacheItem(clistCache[i]);
 +		mir_free(clistCache[i]);
  	}
 +
 +	clistCache.destroy();
  }
  // default handlers for the cache item creation and destruction
 @@ -89,14 +74,14 @@ void fnFreeCacheItem(ClcCacheEntry *p)  ClcCacheEntry* fnGetCacheEntry(MCONTACT hContact)
  {
  	ClcCacheEntry *p;
 -	int idx;
 -	if (!List_GetIndex(clistCache, &hContact, &idx)) {
 +	int idx = clistCache.getIndex((ClcCacheEntry*)&hContact);
 +	if (idx == -1) {
  		if ((p = cli.pfnCreateCacheItem(hContact)) != NULL) {
 -			List_Insert(clistCache, p, idx);
 -			cli.pfnInvalidateDisplayNameCacheEntry((MCONTACT)p);
 +			clistCache.insert(p);
 +			cli.pfnInvalidateDisplayNameCacheEntry(hContact);
  		}
  	}
 -	else p = (ClcCacheEntry*)clistCache->items[idx];
 +	else p = clistCache[idx];
  	cli.pfnCheckCacheItem(p);
  	return p;
 @@ -106,13 +91,12 @@ void fnInvalidateDisplayNameCacheEntry(MCONTACT hContact)  {
  	if (hContact == INVALID_CONTACT_ID) {
  		FreeDisplayNameCache();
 -		InitDisplayNameCache();
  		SendMessage(cli.hwndContactTree, CLM_AUTOREBUILD, 0, 0);
  	}
  	else {
 -		int idx;
 -		if (List_GetIndex(clistCache, &hContact, &idx))
 -			cli.pfnFreeCacheItem((ClcCacheEntry*)clistCache->items[idx]);
 +		int idx = clistCache.getIndex((ClcCacheEntry*)&hContact);
 +		if (idx != -1)
 +			cli.pfnFreeCacheItem(clistCache[idx]);
  	}
  }
 | 
