summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/core/stdchat/src/services.cpp1
-rw-r--r--src/mir_app/src/chat_manager.cpp1
-rw-r--r--src/mir_app/src/chat_svc.cpp36
3 files changed, 18 insertions, 20 deletions
diff --git a/src/core/stdchat/src/services.cpp b/src/core/stdchat/src/services.cpp
index 5fe0c9c70e..119830d217 100644
--- a/src/core/stdchat/src/services.cpp
+++ b/src/core/stdchat/src/services.cpp
@@ -38,7 +38,6 @@ void ShowRoom(SESSION_INFO *si, WPARAM wp, BOOL bSetForeground)
g_TabSession.pLog = si->pLog;
g_TabSession.pLogEnd = si->pLogEnd;
g_TabSession.pMe = si->pMe;
- g_TabSession.dwFlags = si->dwFlags;
g_TabSession.pStatuses = si->pStatuses;
g_TabSession.ptszID = si->ptszID;
g_TabSession.pszModule = si->pszModule;
diff --git a/src/mir_app/src/chat_manager.cpp b/src/mir_app/src/chat_manager.cpp
index ccfa6c14a9..b602a42bc4 100644
--- a/src/mir_app/src/chat_manager.cpp
+++ b/src/mir_app/src/chat_manager.cpp
@@ -1123,7 +1123,6 @@ MIR_APP_DLL(CHAT_MANAGER*) Chat_GetInterface(CHAT_MANAGER_INITDATA *pInit, int _
chatApi.LM_TrimLog = LM_TrimLog;
chatApi.LM_RemoveAll = LM_RemoveAll;
- chatApi.AddRoom = AddRoom;
chatApi.SetOffline = SetOffline;
chatApi.SetAllOffline = SetAllOffline;
chatApi.AddEvent = AddEvent;
diff --git a/src/mir_app/src/chat_svc.cpp b/src/mir_app/src/chat_svc.cpp
index 3734f29379..f3862b4140 100644
--- a/src/mir_app/src/chat_svc.cpp
+++ b/src/mir_app/src/chat_svc.cpp
@@ -153,12 +153,12 @@ EXTERN_C MIR_APP_DLL(int) Chat_GetInfo(GC_INFO *gci)
MIR_APP_DLL(int) Chat_Register(const GCREGISTER *gcr)
{
if (gcr == NULL)
- return GC_REGISTER_ERROR;
+ return GC_ERROR;
mir_cslock lck(csChat);
MODULEINFO *mi = chatApi.MM_AddModule(gcr->pszModule);
if (mi == NULL)
- return GC_REGISTER_ERROR;
+ return GC_ERROR;
mi->ptszModDispName = mir_wstrdup(gcr->ptszDispName);
mi->bBold = (gcr->dwFlags & GC_BOLD) != 0;
@@ -187,18 +187,20 @@ MIR_APP_DLL(int) Chat_Register(const GCREGISTER *gcr)
/////////////////////////////////////////////////////////////////////////////////////////
// starts new chat session
-EXTERN_C MIR_APP_DLL(int) Chat_NewSession(const GCSESSION *gcw)
+EXTERN_C MIR_APP_DLL(int) Chat_NewSession(
+ int iType, // Use one of the GCW_* flags above to set the type of session
+ const char *pszModule, // The name of the protocol owning the session (the same as pszModule when you register)
+ const wchar_t *ptszID, // The unique identifier for the session.
+ const wchar_t *ptszName, // The name of the session as it will be displayed to the user
+ void *pItemData) // Set user defined data for this session. Retrieve it by using the Chat_GetUserInfo() call
{
- if (gcw == NULL)
- return GC_NEWSESSION_ERROR;
-
mir_cslockfull lck(csChat);
- MODULEINFO *mi = chatApi.MM_FindModule(gcw->pszModule);
+ MODULEINFO *mi = chatApi.MM_FindModule(pszModule);
if (mi == NULL)
- return GC_NEWSESSION_ERROR;
+ return GC_ERROR;
// try to restart a session first
- SESSION_INFO *si = chatApi.SM_FindSession(gcw->ptszID, gcw->pszModule);
+ SESSION_INFO *si = chatApi.SM_FindSession(ptszID, pszModule);
if (si != NULL) {
chatApi.UM_RemoveAll(&si->pUsers);
chatApi.TM_RemoveAll(&si->pStatuses);
@@ -215,8 +217,8 @@ EXTERN_C MIR_APP_DLL(int) Chat_NewSession(const GCSESSION *gcw)
// create a new session
si = (SESSION_INFO*)mir_calloc(g_cbSession);
- si->ptszID = mir_wstrdup(gcw->ptszID);
- si->pszModule = mir_strdup(gcw->pszModule);
+ si->ptszID = mir_wstrdup(ptszID);
+ si->pszModule = mir_strdup(pszModule);
if (chatApi.wndList == NULL) // list is empty
chatApi.wndList = si;
@@ -227,13 +229,11 @@ EXTERN_C MIR_APP_DLL(int) Chat_NewSession(const GCSESSION *gcw)
lck.unlock();
// set the defaults
- si->pItemData = gcw->pItemData;
- if (gcw->iType != GCW_SERVER)
+ si->pItemData = pItemData;
+ if (iType != GCW_SERVER)
si->wStatus = ID_STATUS_ONLINE;
- si->iType = gcw->iType;
- si->dwFlags = gcw->dwFlags;
- si->ptszName = mir_wstrdup(gcw->ptszName);
- si->ptszStatusbarText = mir_wstrdup(gcw->ptszStatusbarText);
+ si->iType = iType;
+ si->ptszName = mir_wstrdup(ptszName);
si->iSplitterX = g_Settings->iSplitterX;
si->iSplitterY = g_Settings->iSplitterY;
si->iLogFilterFlags = db_get_dw(NULL, CHAT_MODULE, "FilterFlags", 0x03E0);
@@ -254,7 +254,7 @@ EXTERN_C MIR_APP_DLL(int) Chat_NewSession(const GCSESSION *gcw)
mir_snwprintf(szTemp, L"Server: %s", si->ptszName);
else
wcsncpy_s(szTemp, si->ptszName, _TRUNCATE);
- si->hContact = chatApi.AddRoom(gcw->pszModule, gcw->ptszID, szTemp, si->iType);
+ si->hContact = AddRoom(pszModule, ptszID, szTemp, si->iType);
db_set_s(si->hContact, si->pszModule, "Topic", "");
db_unset(si->hContact, "CList", "StatusMsg");
if (si->ptszStatusbarText)