diff options
author | Alexander Lantsev <aunsane@gmail.com> | 2014-08-21 20:25:28 +0000 |
---|---|---|
committer | Alexander Lantsev <aunsane@gmail.com> | 2014-08-21 20:25:28 +0000 |
commit | 3c9026fef3ebe0e80855b51351b5c1bad05d9f0d (patch) | |
tree | 2cd27952146fff32c2e43f1ebd57c790c355dcbd /protocols/Tox/src/tox_proto.cpp | |
parent | 518a4b2226ca1904a39dca7a77a5afaa8984c011 (diff) |
Tox:
- fixed own nick changing
- reworked search/add dialog
git-svn-id: http://svn.miranda-ng.org/main/trunk@10268 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'protocols/Tox/src/tox_proto.cpp')
-rw-r--r-- | protocols/Tox/src/tox_proto.cpp | 60 |
1 files changed, 39 insertions, 21 deletions
diff --git a/protocols/Tox/src/tox_proto.cpp b/protocols/Tox/src/tox_proto.cpp index 18af6e9a73..0c96ffdff9 100644 --- a/protocols/Tox/src/tox_proto.cpp +++ b/protocols/Tox/src/tox_proto.cpp @@ -40,7 +40,7 @@ DWORD_PTR __cdecl CToxProto::GetCaps(int type, MCONTACT hContact) switch (type)
{
case PFLAGNUM_1:
- return PF1_IM | PF1_AUTHREQ | PF1_BASICSEARCH | PF1_SEARCHBYEMAIL;
+ return PF1_IM | PF1_AUTHREQ | PF1_EXTSEARCH;
case PFLAGNUM_2:
return PF2_ONLINE | PF2_SHORTAWAY | PF2_LIGHTDND;
case PFLAGNUM_4:
@@ -129,33 +129,54 @@ int __cdecl CToxProto::FileResume(HANDLE hTransfer, int* action, const PROTOCHAR int __cdecl CToxProto::GetInfo(MCONTACT hContact, int infoType) { return 0; }
-HANDLE __cdecl CToxProto::SearchBasic(const PROTOCHAR* id)
-{
- if (!this->IsOnline())
- {
- return 0;
- }
+HANDLE __cdecl CToxProto::SearchBasic(const PROTOCHAR* id) { return 0; }
- ForkThread(&CToxProto::SearchByIdAsync, mir_tstrdup(id));
+HANDLE __cdecl CToxProto::SearchByEmail(const PROTOCHAR* email) { return 0; }
- return (HANDLE)1;
-}
+HANDLE __cdecl CToxProto::SearchByName(const PROTOCHAR* nick, const PROTOCHAR* firstName, const PROTOCHAR* lastName) { return 0; }
-HANDLE __cdecl CToxProto::SearchByEmail(const PROTOCHAR* email)
+HWND __cdecl CToxProto::SearchAdvanced(HWND owner)
{
- if (!this->IsOnline())
+ if (IsDlgButtonChecked(owner, IDC_SEARCH_TOXMESE))
{
- return 0;
+ TCHAR address[MAX_PATH];
+ GetDlgItemText(owner, IDC_SEARCH, address, SIZEOF(address));
+
+ ForkThread(&CToxProto::SearchByNameAsync, mir_tstrdup(address));
}
+ else
+ {
+ ADDCONTACTSTRUCT acs = { 0 };
- ForkThread(&CToxProto::SearchByNameAsync, mir_tstrdup(email));
+ PROTOSEARCHRESULT psr = { 0 };
+ psr.cbSize = sizeof(psr);
+ psr.flags = PSR_TCHAR;
- return (HANDLE)1;
+ TCHAR toxId[TOX_MAX_NAME_LENGTH];
+ GetDlgItemText(owner, IDC_SEARCH, toxId, TOX_MAX_NAME_LENGTH);
+ psr.id = toxId;
+
+ acs.psr = &psr;
+ acs.szProto = m_szModuleName;
+
+ acs.handleType = HANDLE_SEARCHRESULT;
+ CallService(MS_ADDCONTACT_SHOW, (WPARAM)owner, (LPARAM)&acs);
+
+ ForkThread(&CToxProto::SearchByIdAsync, mir_tstrdup(toxId));
+ }
+
+ return (HWND)1;
}
-HANDLE __cdecl CToxProto::SearchByName(const PROTOCHAR* nick, const PROTOCHAR* firstName, const PROTOCHAR* lastName) { return 0; }
-HWND __cdecl CToxProto::SearchAdvanced(HWND owner) { return 0; }
-HWND __cdecl CToxProto::CreateExtendedSearchUI(HWND owner) { return 0; }
+HWND __cdecl CToxProto::CreateExtendedSearchUI(HWND owner)
+{
+ return CreateDialogParam(
+ g_hInstance,
+ MAKEINTRESOURCE(IDD_SEARCH),
+ owner,
+ SearchDlgProc,
+ (LPARAM)this);
+}
int __cdecl CToxProto::RecvContacts(MCONTACT hContact, PROTORECVEVENT*) { return 0; }
int __cdecl CToxProto::RecvFile(MCONTACT hContact, PROTOFILEEVENT*) { return 0; }
@@ -269,9 +290,6 @@ int __cdecl CToxProto::OnEvent(PROTOEVENTTYPE iEventType, WPARAM wParam, LPARAM case EV_PROTO_ONCONTACTDELETED:
return OnContactDeleted(wParam, lParam);
- case EV_PROTO_DBSETTINGSCHANGED:
- return OnSettingsChanged(wParam, lParam);
-
case EV_PROTO_ONEXIT:
return OnPreShutdown(wParam, lParam);
}
|