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.
This commit is contained in:
parent
aff78e5121
commit
9215496902
@ -1356,12 +1356,21 @@ class Notice extends Memcached_DataObject
|
|||||||
{
|
{
|
||||||
$author = Profile::staticGet('id', $this->profile_id);
|
$author = Profile::staticGet('id', $this->profile_id);
|
||||||
|
|
||||||
// FIXME: truncate on long repeats...?
|
|
||||||
|
|
||||||
$content = sprintf(_('RT @%1$s %2$s'),
|
$content = sprintf(_('RT @%1$s %2$s'),
|
||||||
$author->nickname,
|
$author->nickname,
|
||||||
$this->content);
|
$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,
|
return self::saveNew($repeater_id, $content, $source,
|
||||||
array('repeat_of' => $this->id));
|
array('repeat_of' => $this->id));
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user