diff options
| author | George Hazan <ghazan@miranda.im> | 2019-10-28 20:23:26 +0300 | 
|---|---|---|
| committer | George Hazan <ghazan@miranda.im> | 2019-10-28 20:23:26 +0300 | 
| commit | c9ea0a63cc82a0dbe1d2b5a7fcb9a95c8b9f1aae (patch) | |
| tree | 049c90de91937f810a7b2ffd1ab75e98c08c8ec1 | |
| parent | dc470da0b1e99fdc0e32b4fe4db9599696811284 (diff) | |
fixes #2105 for UserInfoEx
| -rw-r--r-- | plugins/UserInfoEx/src/classPsTree.cpp | 315 | ||||
| -rw-r--r-- | plugins/UserInfoEx/src/dlg_propsheet.cpp | 44 | ||||
| -rw-r--r-- | plugins/UserInfoEx/src/dlg_propsheet.h | 73 | 
3 files changed, 211 insertions, 221 deletions
| diff --git a/plugins/UserInfoEx/src/classPsTree.cpp b/plugins/UserInfoEx/src/classPsTree.cpp index c3939a94f9..7e3a9bb73a 100644 --- a/plugins/UserInfoEx/src/classPsTree.cpp +++ b/plugins/UserInfoEx/src/classPsTree.cpp @@ -32,18 +32,14 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.   * param:	none   * return:	none   **/ -CPsTree::CPsTree(LPPS pPs) +CPsTree::CPsTree(LPPS pPs) : +	_pages(1)  { -	_hWndTree = nullptr; -	_hImages = nullptr; - -	_pItems = nullptr; -	_numItems = 0;  	_curItem = -1;  	_dwFlags = 0;  	_hLabelEdit = nullptr;  	_hDragItem = nullptr; -	_isDragging = FALSE; +	_isDragging = false;  	_pPs = pPs;  } @@ -60,20 +56,9 @@ CPsTree::~CPsTree()  		DestroyWindow(_hLabelEdit);  		_hLabelEdit = nullptr;  	} -	if (_pItems)  -	{ -		for (int i = 0; i < _numItems; i++)  -		{ -			if (_pItems[i]) -			{ -				delete _pItems[i]; -				_pItems[i] = nullptr; -			} -		} -		MIR_FREE(_pItems); -		_pItems = nullptr; -		_numItems = NULL; -	} + +	_pages.destroy(); +  	ImageList_Destroy(_hImages);  	_hImages = nullptr;  } @@ -93,10 +78,13 @@ BYTE CPsTree::Create(HWND hWndTree, CPsHdr* pPsh)  	{  		_hWndTree = hWndTree;  		_hImages = pPsh->_hImages; -		_pItems = pPsh->_pPages; -		_numItems = pPsh->_numPages;  		_dwFlags = pPsh->_dwFlags; -		 + +		for (int i = 0; i < pPsh->_numPages; i++) +			_pages.insert(pPsh->_pPages[i]); +		pPsh->_pPages = nullptr; +		pPsh->_numPages = 0; +  		TreeView_SetImageList(_hWndTree, _hImages, TVSIL_NORMAL);  		TreeView_SetItemHeight(_hWndTree, TreeView_GetItemHeight(_hWndTree) + 4);  		SetUserData(_hWndTree, this); @@ -116,30 +104,48 @@ BYTE CPsTree::Create(HWND hWndTree, CPsHdr* pPsh)   * param:	pszGroup	- utf8 encoded string of the item to add   * return:	index of the new item or -1 if failed to add   **/ +  int CPsTree::AddDummyItem(LPCSTR pszGroup)  { -	if (mir_strcmpi(pszGroup, TREE_ROOTITEM))  -	{ -		CPsHdr psh; -		psh._hContact = _pPs->hContact; -		psh._pszProto = _pPs->pszProto; -		psh._hImages	= _hImages; -		psh._pPages	 = _pItems; -		psh._numPages = _numItems; - -		OPTIONSDIALOGPAGE odp = {}; -		odp.flags = ODPF_UNICODE; -		odp.szTitle.w = mir_utf8decodeW(pszGroup); +	if (!mir_strcmpi(pszGroup, TREE_ROOTITEM)) +		return -1; -		int rc = g_plugin.addUserInfo((WPARAM)&psh, &odp); -		mir_free(odp.szTitle.w); -		if (!rc) { -			_pItems = psh._pPages; -			_numItems = psh._numPages; -			return _numItems - 1; +	CPsHdr psh; +	psh._hContact = _pPs->hContact; +	psh._pszProto = _pPs->pszProto; +	psh._hImages = _hImages; + +	OPTIONSDIALOGPAGE odp = {}; +	odp.flags = ODPF_UNICODE; +	odp.szTitle.w = mir_utf8decodeW(pszGroup); + +	auto *p = new CPsTreeItem(); +	p->Create(&psh, &odp); +	_pages.insert(p); +	 +	return _pages.indexOf(&p); +} + +void CPsTree::Remove(HINSTANCE hInst) +{ +	bool bRemoved = false; + +	for (auto &it : _pages.rev_iter()) { +		if (it->Inst() == hInst) { +			if (!bRemoved) { +				TreeView_DeleteAllItems(_hWndTree); +				bRemoved = true; +			} +			_pages.remove(_pages.indexOf(&it));  		}  	} -	return -1; + +	if (bRemoved) { +		for (auto &it : _pages) +			it->Hti(nullptr); + +		InitTreeItems(nullptr); +	}  }  /** @@ -150,58 +156,45 @@ int CPsTree::AddDummyItem(LPCSTR pszGroup)   **/  BYTE CPsTree::InitTreeItems(LPWORD needWidth)  { -	int i; -	DBVARIANT dbv; - -	if (!_hWndTree || !_pItems) -	{ +	if (!_hWndTree || !_pages.getCount())  		return FALSE; -	} -	if (!DB::Setting::GetUString(0, MODULENAME, SET_LASTITEM, &dbv))  -	{ +	DBVARIANT dbv; +	if (!DB::Setting::GetUString(0, MODULENAME, SET_LASTITEM, &dbv)) {  		_curItem = FindItemIndexByName(dbv.pszVal);  		db_free(&dbv);  	}  	// init the groups -	if ((_dwFlags & PSTVF_GROUPS) || (!_pPs->hContact && myGlobals.CanChangeDetails))  -	{ -		LPSTR pszGroup; -		 +	if ((_dwFlags & PSTVF_GROUPS) || (!_pPs->hContact && myGlobals.CanChangeDetails)) {  		// set treeview styles  		TreeView_SetIndent(_hWndTree, 3); -		SetWindowLongPtr(_hWndTree, GWL_STYLE, GetWindowLongPtr(_hWndTree, GWL_STYLE)|TVS_HASBUTTONS); +		SetWindowLongPtr(_hWndTree, GWL_STYLE, GetWindowLongPtr(_hWndTree, GWL_STYLE) | TVS_HASBUTTONS);  		// init the iParent member for all the items -		for (i = 0; i < _numItems; i++)  -		{ -			if (_pItems[i] && (pszGroup = _pItems[i]->ParentItemName()) != nullptr)  -			{ +		for (auto &it : _pages) { +			LPSTR pszGroup = it->ParentItemName(); +			if (pszGroup != nullptr) {  				int iParent = FindItemIndexByName(pszGroup); -				 +  				// need to add an empty parent item -				if (iParent == -1)  +				if (iParent == -1)  					iParent = AddDummyItem(pszGroup); -				_pItems[i]->Parent(iParent); +				it->Parent(iParent);  				mir_free(pszGroup);  			}  		}  	}  	if (needWidth) -	{  		*needWidth = 0; -	} +  	ShowWindow(_hWndTree, SW_HIDE); -	for (i = 0; i < _numItems; i++) -	{ -		if (_pItems[i]->State() != DBTVIS_INVISIBLE) -		{ -			ShowItem(i, needWidth); -		} -	} +	for (auto &it : _pages) +		if (it->State() != DBTVIS_INVISIBLE) +			ShowItem(_pages.indexOf(&it), needWidth); +  	ShowWindow(_hWndTree, SW_SHOW);  	return TRUE;  } @@ -217,16 +210,13 @@ BYTE CPsTree::InitTreeItems(LPWORD needWidth)   * param:	hItem		- handle of the treeview's treeitem   * return:	HTREEITEM if item exists or NULL otherwise   **/ +  int CPsTree::FindItemIndexByHandle(HTREEITEM hItem)  { -	int i; -	for (i = 0; i < _numItems; i++)  -	{ -		if (_pItems[i] && hItem == _pItems[i]->Hti()) -		{ -			return i; -		} -	} +	for (auto &it : _pages) +		if (it && hItem == it->Hti()) +			return _pages.indexOf(&it); +  	return -1;  } @@ -237,16 +227,13 @@ int CPsTree::FindItemIndexByHandle(HTREEITEM hItem)   * param:	hItem		- handle of the treeview's treeitem   * return:	HTREEITEM if item exists or NULL otherwise   **/ +  int CPsTree::FindItemIndexByName(LPCSTR pszName)  { -	int i; -	for (i = 0; i < _numItems; i++)  -	{ -		if (_pItems[i] && _pItems[i]->HasName(pszName)) -		{ -			return i; -		} -	} +	for (auto &it : _pages) +		if (it && it->HasName(pszName)) +			return _pages.indexOf(&it); +  	return -1;  } @@ -257,14 +244,13 @@ int CPsTree::FindItemIndexByName(LPCSTR pszName)   * param:	hItem		- handle of the treeview's treeitem   * return:	HTREEITEM if item exists or NULL otherwise   **/ +  CPsTreeItem* CPsTree::FindItemByHandle(HTREEITEM hItem)  { -	int i; +	int i = FindItemIndexByHandle(hItem); +	if (i > -1) +		return &_pages[i]; -	if ((i = FindItemIndexByHandle(hItem)) > -1) -	{ -		return _pItems[i]; -	}  	return nullptr;  } @@ -277,12 +263,10 @@ CPsTreeItem* CPsTree::FindItemByHandle(HTREEITEM hItem)   **/  CPsTreeItem* CPsTree::FindItemByName(LPCSTR pszName)  { -	int i; -	 -	if ((i = FindItemIndexByName(pszName)) > -1)  -	{ -		return _pItems[i]; -	} +	int i = FindItemIndexByName(pszName); +	if (i > -1)  +		return &_pages[i]; +  	return nullptr;  } @@ -293,16 +277,13 @@ CPsTreeItem* CPsTree::FindItemByName(LPCSTR pszName)   * param:	hItem		- handle of the treeview's treeitem   * return:	HTREEITEM if item exists or NULL otherwise   **/ +  CPsTreeItem* CPsTree::FindItemByResource(HINSTANCE hInst, int idDlg)  { -	int i; -	for (i = 0; i < _numItems; i++)  -	{ -		if (_pItems[i] && _pItems[i]->Inst() == hInst && _pItems[i]->DlgId() == idDlg)  -		{ -			return _pItems[i]; -		} -	} +	for (auto &it : _pages) +		if (it && it->Inst() == hInst && it->DlgId() == idDlg)  +			return it; +  	return nullptr;  } @@ -314,14 +295,13 @@ CPsTreeItem* CPsTree::FindItemByResource(HINSTANCE hInst, int idDlg)   * param:	pszName		- name of the item to search for   * return:	HTREEITEM if item exists or NULL otherwise   **/ +  HTREEITEM CPsTree::FindItemHandleByName(LPCSTR pszName)  { -	int i; +	int i = FindItemIndexByName(pszName); +	if (i > -1) +		return _pages[i].Hti(); -	if ((i = FindItemIndexByName(pszName)) > -1) -	{ -		return _pItems[i]->Hti(); -	}  	return nullptr;  } @@ -337,12 +317,13 @@ HTREEITEM CPsTree::FindItemHandleByName(LPCSTR pszName)   * param:	iPageIndex	- the index of the treeitem in the array.   * return:	nothing   **/ +  void CPsTree::HideItem(const int iPageIndex)  { -	if (IsIndexValid(iPageIndex))  -	{ -		TreeView_DeleteItem(_hWndTree, _pItems[iPageIndex]->Hti()); -		_pItems[iPageIndex]->Hti(nullptr); +	if (IsIndexValid(iPageIndex)) { +		auto &p = _pages[iPageIndex]; +		TreeView_DeleteItem(_hWndTree, p.Hti()); +		p.Hti(nullptr);  		_dwFlags |= PSTVF_STATE_CHANGED;  	}  } @@ -363,7 +344,7 @@ HTREEITEM CPsTree::ShowItem(const int iPageIndex, LPWORD needWidth)  	// check parameters  	if (!_hWndTree ||   		!IsIndexValid(iPageIndex) ||  -		!(pti = _pItems[iPageIndex]) || +		!(pti = &_pages[iPageIndex]) ||  		!pti->Name() ||  		!pti->Label())  	{ @@ -419,7 +400,6 @@ HTREEITEM CPsTree::MoveItem(HTREEITEM hItem, HTREEITEM hInsertAfter, BYTE bAsChi  {  	TVINSERTSTRUCT tvis;  	HTREEITEM hParent, hChild, hNewItem; -	int iItemIndex;  	if (!hItem || !hInsertAfter)  		return nullptr; @@ -440,10 +420,14 @@ HTREEITEM CPsTree::MoveItem(HTREEITEM hItem, HTREEITEM hInsertAfter, BYTE bAsChi  	// do not move a parent next to its own children!  	if (hItem == hParent)  		return hItem; +	  	// get detailed information about the item to move -	if (FAILED(iItemIndex = FindItemIndexByHandle(hItem))) +	int idx = FindItemIndexByHandle(hItem); +	if (idx < 0)  		return hItem; -	 + +	auto &pItem = _pages[idx]; +  	// item should be inserted as the first child of an existing root item  	if (bAsChild) {   		tvis.hParent = hInsertAfter; @@ -456,30 +440,30 @@ HTREEITEM CPsTree::MoveItem(HTREEITEM hItem, HTREEITEM hInsertAfter, BYTE bAsChi  	}  	// don't move subitems of a protocol to root as this would mean them not to be unique anymore -	if (!_pPs->hContact && (_pItems[iItemIndex]->Flags() & PSPF_PROTOPREPENDED) && !tvis.hParent) +	if (!_pPs->hContact && (pItem.Flags() & PSPF_PROTOPREPENDED) && !tvis.hParent)  		return hItem;  	// prepare the insert structure  	tvis.itemex.mask = TVIF_PARAM|TVIF_TEXT;  	tvis.itemex.state = TVIS_EXPANDED;  	tvis.itemex.stateMask = TVIS_EXPANDED; -	tvis.itemex.pszText = _pItems[iItemIndex]->Label(); -	tvis.itemex.lParam = (LPARAM)iItemIndex; -	if ((tvis.itemex.iImage = tvis.itemex.iSelectedImage = _pItems[iItemIndex]->Image()) >= 0) +	tvis.itemex.pszText = pItem.Label(); +	tvis.itemex.lParam = idx; +	if ((tvis.itemex.iImage = tvis.itemex.iSelectedImage = pItem.Image()) >= 0)  		tvis.itemex.mask |= TVIF_IMAGE|TVIF_SELECTEDIMAGE;  	// insert the item  	if (!(hNewItem = TreeView_InsertItem(_hWndTree, &tvis)))  		return hItem;  	// update handle pointer in the page structure -	_pItems[iItemIndex]->Hti(hNewItem); +	pItem.Hti(hNewItem);  	// get the index of the parent -	_pItems[iItemIndex]->Parent(FindItemIndexByHandle(tvis.hParent)); +	pItem.Parent(FindItemIndexByHandle(tvis.hParent));  	// move children  	hInsertAfter = hNewItem; -	while (hChild = TreeView_GetChild(_hWndTree, hItem)) { +	while (hChild = TreeView_GetChild(_hWndTree, hItem))  		MoveItem(hChild, hInsertAfter, 2); -	} +  	// delete old tree  	TreeView_DeleteItem(_hWndTree, hItem);  	_dwFlags |= PSTVF_POS_CHANGED; @@ -498,23 +482,22 @@ HTREEITEM CPsTree::MoveItem(HTREEITEM hItem, HTREEITEM hInsertAfter, BYTE bAsChi   *			iItem			- index of the current item for position saving   * return:	0 on success or 1 otherwise   **/ +  WORD CPsTree::SaveItemsState(LPCSTR pszGroup, HTREEITEM hRootItem, int& iItem)  {  	TVITEMEX tvi; -	WORD numErrors = 0; -  	tvi.mask = TVIF_CHILDREN|TVIF_STATE|TVIF_PARAM;  	tvi.state = 0;  	tvi.stateMask = TVIS_EXPANDED;  	tvi.lParam = (LPARAM)-1;  	// save all visible items -	for (tvi.hItem = TreeView_GetChild(_hWndTree, hRootItem); -			 TreeView_GetItem(_hWndTree, &tvi); -			 tvi.hItem = TreeView_GetNextSibling(_hWndTree, tvi.hItem))  -	{ -		numErrors += _pItems[tvi.lParam]->DBSaveItemState(pszGroup, iItem++, tvi.state, _dwFlags); -		if (tvi.cChildren) numErrors += SaveItemsState(_pItems[tvi.lParam]->Name(), tvi.hItem, iItem); +	WORD numErrors = 0; +	for (tvi.hItem = TreeView_GetChild(_hWndTree, hRootItem); TreeView_GetItem(_hWndTree, &tvi); tvi.hItem = TreeView_GetNextSibling(_hWndTree, tvi.hItem)) { +		auto &it = _pages[tvi.lParam]; +		numErrors += it.DBSaveItemState(pszGroup, iItem++, tvi.state, _dwFlags); +		if (tvi.cChildren) +			numErrors += SaveItemsState(it.Name(), tvi.hItem, iItem);  	}  	return numErrors;  } @@ -526,25 +509,25 @@ WORD CPsTree::SaveItemsState(LPCSTR pszGroup, HTREEITEM hRootItem, int& iItem)   * param:	none   * return:	nothing   **/ +  void CPsTree::SaveState()  {  	CPsTreeItem *pti = CurrentItem();  	if (_hWndTree && (_dwFlags & (PSTVF_LABEL_CHANGED|PSTVF_POS_CHANGED|PSTVF_STATE_CHANGED))) { -		SHORT i;  		int iItem = 0;  		// save all visible items  		WORD numErrors = SaveItemsState(TREE_ROOTITEM, TVGN_ROOT, iItem);  		// save all invisible items of the current subtree -		for (i = 0; i < _numItems; i++) { -			if (!_pItems[i]->Hti()) { +		for (auto &it : _pages) { +			if (!it->Hti()) {  				LPSTR pszGroup; -				if (!IsIndexValid(_pItems[i]->Parent()) || !(pszGroup = _pItems[_pItems[i]->Parent()]->Name())) +				if (!IsIndexValid(it->Parent()) || !(pszGroup = _pages[it->Parent()].Name()))  					pszGroup = TREE_ROOTITEM; -				numErrors += _pItems[i]->DBSaveItemState(pszGroup, iItem++, DBTVIS_INVISIBLE, _dwFlags); +				numErrors += it->DBSaveItemState(pszGroup, iItem++, DBTVIS_INVISIBLE, _dwFlags);  			}  		}  		// remove changed flags @@ -565,6 +548,7 @@ void CPsTree::SaveState()   *			iItem			- index of the current item for position saving   * return: 0 on success or 1 otherwise   **/ +  void CPsTree::DBResetState()  {  	DB::CEnumList	Settings; @@ -622,6 +606,7 @@ static LRESULT CALLBACK TPropsheetTree_LabelEditProc(HWND hwnd, UINT uMsg, WPARA   * param:	hItem		- handle of the treeitm whose label to edit   * return:	0   **/ +  int CPsTree::BeginLabelEdit(HTREEITEM hItem)  {  	CPsTreeItem* pti; @@ -672,6 +657,7 @@ int CPsTree::BeginLabelEdit(HTREEITEM hItem)   *			bSave		- tell whether to save changes or not   * return:	0   **/ +  int CPsTree::EndLabelEdit(const BYTE bSave)  {  	wchar_t szEdit[MAX_TINAME]; @@ -708,7 +694,7 @@ void CPsTree::PopupMenu()  	HMENU hPopup;  	TVHITTESTINFO hti;  	POINT pt; -	int iItem, i; +	int iItem;  	// init popup menu  	if (!(hPopup = CreatePopupMenu())) @@ -747,13 +733,15 @@ void CPsTree::PopupMenu()  		InsertMenuItem(hPopup, 0, FALSE, &mii);  	}  	else { +		int i = 0;  		// add hidden items to menu  		mii.wID = 0; -		for (i = 0; i < _numItems; i++) { -			if (!_pItems[i]->Hti()) { -				mii.dwTypeData = _pItems[i]->Label(); +		for (auto &it : _pages) { +			if (!it->Hti()) { +				mii.dwTypeData = it->Label();  				mii.wID = 100 + i;  				InsertMenuItem(hPopup, 0, FALSE, &mii); +				i++;  			}  		}  		// add headline @@ -805,11 +793,11 @@ void CPsTree::PopupMenu()   * param:	none   * return:	nothing   **/ +  void CPsTree::OnIconsChanged()  { -	for (int i = 0; i < _numItems; i++) { -		_pItems[i]->OnIconsChanged(this); -	} +	for (auto &it : _pages) +		it->OnIconsChanged(this);  }  /** @@ -819,6 +807,7 @@ void CPsTree::OnIconsChanged()   * param:	none   * return:	TRUE if any page holds changed information   **/ +  BYTE CPsTree::OnInfoChanged()  {  	PSHNOTIFY pshn; @@ -826,15 +815,15 @@ BYTE CPsTree::OnInfoChanged()  	pshn.hdr.idFrom = 0;  	pshn.hdr.code = PSN_INFOCHANGED; -	for (int i = 0; i < _numItems; i++) { -		pshn.hdr.hwndFrom = _pItems[i]->Wnd(); +	for (auto &it : _pages) { +		pshn.hdr.hwndFrom = it->Wnd();  		if (pshn.hdr.hwndFrom != nullptr) { -			pshn.lParam = (LPARAM)_pItems[i]->hContact(); +			pshn.lParam = (LPARAM)it->hContact();  			SendMessage(pshn.hdr.hwndFrom, WM_NOTIFY, 0, (LPARAM)&pshn);  			if (PSP_CHANGED == GetWindowLongPtr(pshn.hdr.hwndFrom, DWLP_MSGRESULT))  				bChanged |= 1;  			else -				_pItems[i]->RemoveFlags(PSPF_CHANGED); +				it->RemoveFlags(PSPF_CHANGED);  		}  	}  	return bChanged; @@ -908,10 +897,10 @@ void CPsTree::OnCancel()  	PSHNOTIFY pshn;  	pshn.hdr.idFrom = 0;  	pshn.hdr.code = PSN_RESET; -	for (int i = 0; i < _numItems; i++) { -		pshn.hdr.hwndFrom = _pItems[i]->Wnd(); -		if (pshn.hdr.hwndFrom && (_pItems[i]->Flags() & PSPF_CHANGED)) { -			pshn.lParam = (LPARAM)_pItems[i]->hContact(); +	for (auto &it : _pages) { +		pshn.hdr.hwndFrom = it->Wnd(); +		if (pshn.hdr.hwndFrom && (it->Flags() & PSPF_CHANGED)) { +			pshn.lParam = (LPARAM)it->hContact();  			SendMessage(pshn.hdr.hwndFrom, WM_NOTIFY, 0, (LPARAM)&pshn);  		}  	} @@ -938,18 +927,18 @@ int CPsTree::OnApply()  		return 1;  	// save everything to database  	pshn.hdr.code = PSN_APPLY; -	for (int i = 0; i < _numItems; i++) { -		if (_pItems[i] && _pItems[i]->Wnd() && _pItems[i]->Flags() & PSPF_CHANGED) { -			pshn.lParam = (LPARAM)_pItems[i]->hContact(); -			pshn.hdr.hwndFrom = _pItems[i]->Wnd(); +	for (auto &it : _pages) { +		if (it && it->Wnd() && it->Flags() & PSPF_CHANGED) { +			pshn.lParam = (LPARAM)it->hContact(); +			pshn.hdr.hwndFrom = it->Wnd();  			if (SendMessage(pshn.hdr.hwndFrom, WM_NOTIFY, 0, (LPARAM)&pshn) == PSNRET_INVALID_NOCHANGEPAGE) {  				if (pti = CurrentItem())  					ShowWindow(pti->Wnd(), SW_HIDE); -				_curItem = i; -				ShowWindow(_pItems[i]->Wnd(), SW_SHOW); +				_curItem = _pages.indexOf(&it); +				ShowWindow(it->Wnd(), SW_SHOW);  				return 1;  			} -			_pItems[i]->RemoveFlags(PSPF_CHANGED); +			it->RemoveFlags(PSPF_CHANGED);  		}  	}  	return 0; diff --git a/plugins/UserInfoEx/src/dlg_propsheet.cpp b/plugins/UserInfoEx/src/dlg_propsheet.cpp index 8946945159..d7099f1667 100644 --- a/plugins/UserInfoEx/src/dlg_propsheet.cpp +++ b/plugins/UserInfoEx/src/dlg_propsheet.cpp @@ -36,10 +36,11 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  #define HM_SETTING_CHANGED		(WM_USER + 12)
  #define HM_RELOADICONS			(WM_USER + 13)
  #define HM_SETWINDOWTITLE		(WM_USER + 14)
 +#define HM_UNLOADED           (WM_USER + 15)
 -#define TIMERID_UPDATING		1
 +#define TIMERID_UPDATING      1
  #ifndef TIMERID_RENAME
 -#define TIMERID_RENAME		2
 +#define TIMERID_RENAME        2
  #endif
  // flags for the PS structure
 @@ -61,16 +62,9 @@ static HANDLE g_hDetailsInitEvent = nullptr;  static INT_PTR CALLBACK DlgProc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam);
 -CPsHdr::CPsHdr()
 -	: _ignore(10, wcscmp)
 +CPsHdr::CPsHdr() :
 +	_ignore(10, wcscmp)
  {
 -	_hContact = NULL;
 -	_pszProto = nullptr;
 -	_pszPrefix = nullptr;
 -	_pPages = nullptr;
 -	_numPages = 0;
 -	_dwFlags = 0;
 -	_hImages = nullptr;
  }
  CPsHdr::~CPsHdr()
 @@ -521,9 +515,9 @@ void DlgContactInfoInitTreeIcons()  			psh._hContact = NULL;
  			psh._pszProto = nullptr;
  			NotifyEventHooks(g_hDetailsInitEvent, (WPARAM)&psh, (LPARAM)psh._hContact);
 -			if (psh._pPages) {
 +			if (psh._pPages)
  				psh.Free_pPages();
 -			}
 +
  			bInitIcons |= INIT_ICONS_OWNER;
  		}
  		ImageList_Destroy(psh._hImages);
 @@ -578,6 +572,7 @@ static INT_PTR CALLBACK DlgProc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lPar  			pPs->dwFlags |= PSF_LOCKED;
  			pPs->hContact = pPsh->_hContact;
  			pPs->hProtoAckEvent = HookEventMessage(ME_PROTO_ACK, hDlg, HM_PROTOACK);
 +			pPs->hModuleUnloaded = HookEventMessage(ME_SYSTEM_MODULEUNLOAD, hDlg, HM_UNLOADED);
  			pPs->hSettingChanged = HookEventMessage(ME_DB_CONTACT_SETTINGCHANGED, hDlg, HM_SETTING_CHANGED);
  			pPs->hIconsChanged = HookEventMessage(ME_SKIN_ICONSCHANGED, hDlg, HM_RELOADICONS);
 @@ -619,7 +614,7 @@ static INT_PTR CALLBACK DlgProc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lPar  			// initialize the optionpages and tree control
  			WORD needWidth = 0;
 -			if (!pPs->pTree->InitTreeItems((LPWORD)&needWidth))
 +			if (!pPs->pTree->InitTreeItems(&needWidth))
  				return FALSE;
  			// move and resize dialog and its controls
 @@ -935,17 +930,19 @@ static INT_PTR CALLBACK DlgProc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lPar  		}
  	case M_CHECKONLINE: // determines whether miranda is online or not
 -		{
 -			if (IsProtoOnline(pPs->pszProto)) {
 -				EnableWindow(GetDlgItem(hDlg, BTN_UPDATE), !IsWindowVisible(GetDlgItem(hDlg, TXT_UPDATING)));
 -				return TRUE;
 -			}
 -
 -			EnableWindow(GetDlgItem(hDlg, BTN_UPDATE), FALSE);
 -			EnableWindow(GetDlgItem(hDlg, TXT_UPDATING), FALSE);
 -			break;
 +		if (IsProtoOnline(pPs->pszProto)) {
 +			EnableWindow(GetDlgItem(hDlg, BTN_UPDATE), !IsWindowVisible(GetDlgItem(hDlg, TXT_UPDATING)));
 +			return TRUE;
  		}
 +		EnableWindow(GetDlgItem(hDlg, BTN_UPDATE), FALSE);
 +		EnableWindow(GetDlgItem(hDlg, TXT_UPDATING), FALSE);
 +		break;
 +
 +	case HM_UNLOADED:
 +		pPs->pTree->Remove((HINSTANCE)lParam);
 +		break;
 +
  	case HM_PROTOACK: // handles all acks from the protocol plugin
  		{
  			ACKDATA *ack = (ACKDATA *)lParam;
 @@ -1369,6 +1366,7 @@ static INT_PTR CALLBACK DlgProc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lPar  		UnhookEvent(pPs->hProtoAckEvent);
  		UnhookEvent(pPs->hSettingChanged);
  		UnhookEvent(pPs->hIconsChanged);
 +		UnhookEvent(pPs->hModuleUnloaded);
  		// save my window position
  		Utils_SaveWindowPosition(hDlg, NULL, MODULENAME, "DetailsDlg");
 diff --git a/plugins/UserInfoEx/src/dlg_propsheet.h b/plugins/UserInfoEx/src/dlg_propsheet.h index 6bdd973173..7272ffa403 100644 --- a/plugins/UserInfoEx/src/dlg_propsheet.h +++ b/plugins/UserInfoEx/src/dlg_propsheet.h @@ -134,16 +134,16 @@ public:  class CPsTree
  {
 -	HWND _hWndTree;
 -	HIMAGELIST _hImages;
 -	CPsTreeItem **_pItems;
 -	int _curItem;
 -	int _numItems;
 -	DWORD _dwFlags;
 -	HWND _hLabelEdit;
 -	HTREEITEM _hDragItem;
 -	BYTE _isDragging;
 -	LPPS _pPs;
 +	OBJLIST<CPsTreeItem> _pages;
 +
 +	HWND _hWndTree = nullptr;
 +	HIMAGELIST _hImages = nullptr;
 +	int _curItem = -1;
 +	DWORD _dwFlags = 0;
 +	HWND _hLabelEdit = nullptr;
 +	HTREEITEM _hDragItem = nullptr;
 +	bool _isDragging = false;
 +	LPPS _pPs = nullptr;
  	WORD	SaveItemsState(LPCSTR pszGroup, HTREEITEM hRootItem, int& iItem);
 @@ -151,23 +151,23 @@ public:  	CPsTree(LPPS pPs);
  	~CPsTree();
 -	__inline void BeginDrag(HTREEITEM hDragItem) { _isDragging = TRUE; _hDragItem = hDragItem; };
 -	__inline void EndDrag() { _isDragging = FALSE; _hDragItem = nullptr; };
 -	__inline BYTE IsDragging() const { return _isDragging; };
 -	__inline HTREEITEM DragItem() const { return _hDragItem; };
 -
 -	__inline DWORD Flags() const { return _dwFlags; };
 -	__inline void Flags(DWORD dwFlags) { _dwFlags = dwFlags; };
 -	__inline void AddFlags(DWORD dwFlags) { _dwFlags |= dwFlags; };
 -	__inline void RemoveFlags(DWORD dwFlags) { _dwFlags &= ~dwFlags; };
 -
 -	__inline int NumItems() const { return _numItems; };
 -	__inline HWND Window() const { return _hWndTree; };
 -	__inline HIMAGELIST ImageList() const { return _hImages; };
 -	__inline BYTE IsIndexValid(const int index) const { return (index >= 0 && index < _numItems); };
 +	__inline void BeginDrag(HTREEITEM hDragItem) { _isDragging = true; _hDragItem = hDragItem; }
 +	__inline void EndDrag() { _isDragging = false; _hDragItem = nullptr; }
 +	__inline bool IsDragging() const { return _isDragging; }
 +	__inline HTREEITEM DragItem() const { return _hDragItem; }
 +
 +	__inline DWORD Flags() const { return _dwFlags; }
 +	__inline void Flags(DWORD dwFlags) { _dwFlags = dwFlags; }
 +	__inline void AddFlags(DWORD dwFlags) { _dwFlags |= dwFlags; }
 +	__inline void RemoveFlags(DWORD dwFlags) { _dwFlags &= ~dwFlags; }
 +
 +	__inline int NumItems() const { return _pages.getCount(); }
 +	__inline HWND Window() const { return _hWndTree; }
 +	__inline HIMAGELIST ImageList() const { return _hImages; }
 +	__inline BYTE IsIndexValid(const int index) const { return (index >= 0 && index < _pages.getCount()); }
 -	__inline CPsTreeItem* TreeItem(int index) const { return (IsIndexValid(index) ? _pItems[index] : nullptr); };
 -	__inline HTREEITEM TreeItemHandle(int index) const { return (IsIndexValid(index) ? _pItems[index]->Hti() : nullptr); };
 +	__inline CPsTreeItem* TreeItem(int index) const { return (IsIndexValid(index) ? &_pages[index] : nullptr); };
 +	__inline HTREEITEM TreeItemHandle(int index) const { return (IsIndexValid(index) ? _pages[index].Hti() : nullptr); };
  	__inline int CurrentItemIndex() const { return _curItem; };
  	__inline CPsTreeItem* CurrentItem() const { return TreeItem(CurrentItemIndex()); };
 @@ -175,6 +175,7 @@ public:  	int  AddDummyItem(LPCSTR pszGroup);
  	BYTE Create(HWND hWndTree, CPsHdr *pPsh);
  	BYTE InitTreeItems(LPWORD needWidth);
 +	void Remove(HINSTANCE);
  	void HideItem(const int iPageIndex);
  	HTREEITEM ShowItem(const int iPageIndex, LPWORD needWidth);
 @@ -218,15 +219,15 @@ class CPsUpload;  struct CPsHdr
  {
 -	MCONTACT _hContact;     // handle to the owning contact
 -	LPCSTR   _pszProto;     // owning contact's protocol 
 -	LPCSTR   _pszPrefix;    // name prefix for treeitem settings
 -	CPsTreeItem** _pPages;  // the pages
 -	WORD     _numPages;     // number of pages
 -	DWORD    _dwFlags;      // some option flags
 -	HIMAGELIST _hImages;    // the imagelist with all tree item icons
 -	LIST<wchar_t> _ignore;  // list of skipped items when adding metasubcontacts pages
 -	int      _nSubContact;  // index of a current subcontact
 +	MCONTACT _hContact = 0;    // handle to the owning contact
 +	LPCSTR   _pszProto = 0;    // owning contact's protocol 
 +	LPCSTR   _pszPrefix = 0;   // name prefix for treeitem settings
 +	CPsTreeItem** _pPages = 0; // the pages
 +	WORD     _numPages = 0;    // number of pages
 +	DWORD    _dwFlags = 0;     // some option flags
 +	HIMAGELIST _hImages = 0;   // the imagelist with all tree item icons
 +	LIST<wchar_t> _ignore;     // list of skipped items when adding metasubcontacts pages
 +	int      _nSubContact = 0; // index of a current subcontact
  	CPsHdr();
  	~CPsHdr();
 @@ -250,6 +251,8 @@ struct TPropSheet  	HANDLE hProtoAckEvent;  // eventhook for protocol acks
  	HANDLE hSettingChanged; // eventhook searching for changed contact information
  	HANDLE hIconsChanged;   // eventhook for changed icons in icolib
 +	HANDLE hModuleUnloaded; // eventhook for unloading modules
 +
  	HFONT hCaptionFont;
  	HFONT hBoldFont;
  	RECT rcDisplay;
 | 
