summaryrefslogtreecommitdiff
path: root/protocols/Twitter/src/twitter.cpp
diff options
context:
space:
mode:
authorTobias Weimer <wishmaster51@googlemail.com>2012-11-07 20:49:14 +0000
committerTobias Weimer <wishmaster51@googlemail.com>2012-11-07 20:49:14 +0000
commit83f57f5092fd96fef29fd2784ed5d7701b52378b (patch)
tree42f85c51ecf856fd1e59b413608dff0e969d325e /protocols/Twitter/src/twitter.cpp
parentff3ae414e0f1ed93e480129eddea59f9748d51a3 (diff)
Merged with original Twitter:
v1.1.0.0 - fixed some memory leaks (thx borkra) - fixed up some API v1.1 preferences - avatars now work for users that tweet - fixed the retweet truncation issue finally (properly this time), i test for the "retweeted_status" attribute now instead of flailing around blindly. git-svn-id: http://svn.miranda-ng.org/main/trunk@2239 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'protocols/Twitter/src/twitter.cpp')
-rw-r--r--protocols/Twitter/src/twitter.cpp67
1 files changed, 28 insertions, 39 deletions
diff --git a/protocols/Twitter/src/twitter.cpp b/protocols/Twitter/src/twitter.cpp
index f5c3d1a8b3..ffba858f7a 100644
--- a/protocols/Twitter/src/twitter.cpp
+++ b/protocols/Twitter/src/twitter.cpp
@@ -349,53 +349,42 @@ std::vector<twitter_user> twitter::get_statuses(int count,twitter_id id)
{
const js::object &one = boost::any_cast<js::object>(**i);
const js::object &user = retrieve<js::object>(one,"user");
- //size_t RTcount = retrieve<size_t>(one,"retweet_count", true); // why doesn't this work?? it can't cast the output into an int even though twitter api says it's an int
twitter_user u;
u.username = retrieve<std::string>(user,"screen_name");
-
- std::string rawText = retrieve<std::string>(one,"text");
- bool foundTruncatedRT = false;
- if (rawText.length() == 140) { // might be a truncated tweet
- if (rawText.substr(0, 4) == "RT @") { // starting to look like a RT...
- if (rawText.substr(136, 4) == " ...") { // ok this is the best I can do. it starts with "RT @", ends with " ...", and is the full 140 chars
-
-
- //if (RTcount > 0) { // the tweet will be truncated unless we take action. i hate you twitter API
- //MessageBox(NULL, L"retweeted: TRUE", L"long tweets", MB_OK);
- // here we grab the "retweeted_status" um.. section? it's in here that all the info we need is
- // at this point the user will get no tweets and an error popup if the tweet happens to be exactly 140 chars, start with
- // "RT @", end in " ...", and notactually be a real retweet. it's possible but unlikely, wish i knew how to get
- // the retweet_count variable to work :(
- const js::object &Retweet = retrieve<js::object>(one,"retweeted_status");
- const js::object &RTUser = retrieve<js::object>(Retweet,"user");
-
- std::string retweeteesName = retrieve<std::string>(RTUser,"screen_name"); // the user that is being retweeted
- std::string retweetText = retrieve<std::string>(Retweet,"text"); // their tweet in all it's untruncated glory
-
- // fix "&amp;" in the tweets :(
- size_t pos = 0;
- while((pos = retweetText.find("&amp;", pos)) != std::string::npos) {
- retweetText.replace(pos, 5, "&");
- pos += 1;
- }
-
- u.status.text = "RT @" + retweeteesName + " " + retweetText; // mash it together in some format people will understand
- foundTruncatedRT = true;
- }
+ u.profile_image_url = retrieve<std::string>(user,"profile_image_url");
+
+ // the tweet will be truncated unless we take action. i hate you twitter API
+ if(one.find("retweeted_status") != one.end())
+ {
+ //MessageBox(NULL, L"retweeted: TRUE", L"long tweets", MB_OK);
+ // here we grab the "retweeted_status" um.. section? it's in here that all the info we need is
+ // at this point the user will get no tweets and an error popup if the tweet happens to be exactly 140 chars, start with
+ // "RT @", end in " ...", and notactually be a real retweet. it's possible but unlikely, wish i knew how to get
+ // the retweet_count variable to work :(
+ const js::object &Retweet = retrieve<js::object>(one,"retweeted_status");
+ const js::object &RTUser = retrieve<js::object>(Retweet,"user");
+
+ std::string retweeteesName = retrieve<std::string>(RTUser,"screen_name"); // the user that is being retweeted
+ std::string retweetText = retrieve<std::string>(Retweet,"text"); // their tweet in all it's untruncated glory
+
+ // fix "&amp;" in the tweets :(
+ for(size_t pos = 0;(pos = retweetText.find("&amp;", pos)) != std::string::npos;pos++)
+ {
+ retweetText.replace(pos, 5, "&");
}
- }
-
- if (foundTruncatedRT == false) { // if it's not truncated, then the twitter API returns the native RT correctly anyway,
-
- //std::string twt = retrieve<std::string>(one,"text"); // no need to do this anymore, we already grabbed it above in rawText
+ u.status.text = "RT @" + retweeteesName + " " + retweetText; // mash it together in some format people will understand
+ }
+ else
+ {
+ // if it's not truncated, then the twitter API returns the native RT correctly anyway,
+ std::string rawText = retrieve<std::string>(one,"text");
// ok here i'm trying some way to fix all the "&amp;" things that are showing up
// i dunno why it's happening, so i'll just find and replace each occurance :/
- size_t pos = 0;
- while((pos = rawText.find("&amp;", pos)) != std::string::npos) {
+ for(size_t pos = 0;(pos = rawText.find("&amp;", pos)) != std::string::npos;pos++)
+ {
rawText.replace(pos, 5, "&");
- pos += 1;
}
u.status.text = rawText;