summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--protocols/FacebookRM/src/constants.h1
-rw-r--r--protocols/FacebookRM/src/contacts.cpp48
2 files changed, 23 insertions, 26 deletions
diff --git a/protocols/FacebookRM/src/constants.h b/protocols/FacebookRM/src/constants.h
index 89576afe3d..e120a4e277 100644
--- a/protocols/FacebookRM/src/constants.h
+++ b/protocols/FacebookRM/src/constants.h
@@ -51,6 +51,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// Various constants
#define FACEBOOK_NOTIFICATIONS_CHATROOM "_notifications"
+#define FACEBOOK_CHATROOM_NAMES_COUNT 3 // number of participant names to use for chatrooms without specific name (on website it's 2)
// Limits
#define FACEBOOK_MESSAGE_LIMIT 200000 // this is guessed limit, in reality it is bigger
diff --git a/protocols/FacebookRM/src/contacts.cpp b/protocols/FacebookRM/src/contacts.cpp
index fdc8f5e2a0..23a6768638 100644
--- a/protocols/FacebookRM/src/contacts.cpp
+++ b/protocols/FacebookRM/src/contacts.cpp
@@ -276,11 +276,14 @@ void FacebookProto::LoadChatInfo(facebook_chatroom *fbc)
http::response resp = facy.flap(REQUEST_THREAD_INFO, &data);
- if (resp.code == HTTP_CODE_OK) {
+ if (resp.code != HTTP_CODE_OK) {
+ facy.handle_error("LoadChatInfo");
+ return;
+ }
- CODE_BLOCK_TRY
+ CODE_BLOCK_TRY
- facebook_json_parser* p = new facebook_json_parser(this);
+ facebook_json_parser* p = new facebook_json_parser(this);
p->parse_chat_info(&resp.data, fbc);
delete p;
@@ -289,32 +292,30 @@ void FacebookProto::LoadChatInfo(facebook_chatroom *fbc)
// If chat has no name, create name from participants list
if (fbc->chat_name.empty()) {
- unsigned int namesCount = 3; // how many names should be in room name; max. 5
+ unsigned int namesUsed = 0;
for (std::map<std::string, std::string>::iterator it = fbc->participants.begin(); it != fbc->participants.end(); ++it) {
std::string participant = it->second;
- if (participant.empty())
+ // Ignore empty and numeric only participant names
+ if (participant.empty() || participant.find_first_not_of("0123456789") == std::string::npos)
continue;
- if (!fbc->chat_name.empty())
+ if (namesUsed > 0)
fbc->chat_name += _T(", ");
- std::string name;
- std::string::size_type pos;
- if ((pos = participant.find(" ")) != std::string::npos) {
- name = participant.substr(0, pos);
- }
- else {
- name = participant;
- }
+ std::string::size_type pos = participant.find(" ");
+ std::string name = (pos != std::string::npos ? participant.substr(0, pos) : participant);
- fbc->chat_name += _A2T(name.c_str());
+ fbc->chat_name += _A2T(name.c_str(), CP_UTF8);
+
+ if (++namesUsed >= FACEBOOK_CHATROOM_NAMES_COUNT)
+ break;
}
- if (fbc->participants.size() > namesCount) {
+ if (fbc->participants.size() > namesUsed) {
TCHAR more[200];
- mir_sntprintf(more, SIZEOF(more), TranslateT("%s and more (%d)"), fbc->chat_name.c_str(), fbc->participants.size() - namesCount);
+ mir_sntprintf(more, SIZEOF(more), TranslateT("%s and more (%d)"), fbc->chat_name.c_str(), fbc->participants.size() - namesUsed);
fbc->chat_name = more;
}
@@ -327,18 +328,13 @@ void FacebookProto::LoadChatInfo(facebook_chatroom *fbc)
debugLogA("*** Chat thread info processed");
- CODE_BLOCK_CATCH
-
- debugLogA("*** Error processing chat thread info: %s", e.what());
+ CODE_BLOCK_CATCH
- CODE_BLOCK_END
+ debugLogA("*** Error processing chat thread info: %s", e.what());
- facy.handle_success("LoadChatInfo");
- }
- else {
- facy.handle_error("LoadChatInfo");
- }
+ CODE_BLOCK_END
+ facy.handle_success("LoadChatInfo");
}
MCONTACT FacebookProto::AddToContactList(facebook_user* fbu, ContactType type, bool force_add, bool add_temporarily)