diff options
author | Brion Vibber <brion@pobox.com> | 2010-01-05 15:04:08 -0800 |
---|---|---|
committer | Brion Vibber <brion@pobox.com> | 2010-01-05 16:10:00 -0800 |
commit | 92154969029e15673b84f5cc228099f2f5c1b942 (patch) | |
tree | 7a5d4c947842a6785f86e1b39f3a4fa600bf612c /classes | |
parent | aff78e51216e09a6e5c95c775d636530c85736fc (diff) |
Ticket 2135: trim overlong repeats with ellipsis rather than failing.
In web interface and retweet/repeat API we show the original untrimmed text, but some back-compat API messages will still show the trimmed 'RT' version.
This matches Twitter's behavior on overlong retweets, though we're outputting the RT version in more API results than they do.
Diffstat (limited to 'classes')
-rw-r--r-- | classes/Notice.php | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/classes/Notice.php b/classes/Notice.php index e8bc509a6..299ed696c 100644 --- a/classes/Notice.php +++ b/classes/Notice.php @@ -1356,12 +1356,21 @@ class Notice extends Memcached_DataObject { $author = Profile::staticGet('id', $this->profile_id); - // FIXME: truncate on long repeats...? - $content = sprintf(_('RT @%1$s %2$s'), $author->nickname, $this->content); + $maxlen = common_config('site', 'textlimit'); + if (mb_strlen($content) > $maxlen) { + // Web interface and current Twitter API clients will + // pull the original notice's text, but some older + // clients and RSS/Atom feeds will see this trimmed text. + // + // Unfortunately this is likely to lose tags or URLs + // at the end of long notices. + $content = mb_substr($content, 0, $maxlen - 4) . ' ...'; + } + return self::saveNew($repeater_id, $content, $source, array('repeat_of' => $this->id)); } |