diff options
Diffstat (limited to 'scripts')
-rw-r--r-- | scripts/make-release.php | 57 | ||||
-rw-r--r-- | scripts/restoreuser.php | 12 |
2 files changed, 65 insertions, 4 deletions
diff --git a/scripts/make-release.php b/scripts/make-release.php new file mode 100644 index 000000000..a62d2f448 --- /dev/null +++ b/scripts/make-release.php @@ -0,0 +1,57 @@ +#!/usr/bin/env php +<?php +/* + * StatusNet - the distributed open-source microblogging tool + * Copyright (C) 2010, StatusNet, Inc. + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + */ + +# Abort if called from a web server + +define('INSTALLDIR', realpath(dirname(__FILE__) . '/..')); + +require_once INSTALLDIR.'/scripts/commandline.inc'; + +$base = INSTALLDIR; +$encBase = escapeshellarg($base); + +$ver = STATUSNET_VERSION; + +// @fixme hack +if (preg_match('/^(\d+)\.(\d+)\.(\d+)/', $ver, $matches)) { + list(, $a, $b, $c) = $matches; + if ($c > '0') { + $cprime = $c - 1; + $prev = "$a.$b.$cprime"; + } else { + die("This is a .0 release; you need to provide a thingy.\n"); + } +} + +$tag = $ver; +$prefix = "statusnet-$tag"; +$target = "$prefix.tar.gz"; + +$cmd = <<<END +(cd $encBase && git archive --prefix=$prefix/ $tag | gzip > /tmp/$target) && \ +(cd /tmp && tar zxf $target && cd $prefix && make) && \ +(cd $encBase && git log --oneline {$prev}..{$tag} > /tmp/$prefix/Changelog) && \ +(cd /tmp && tar zcf $target $prefix) && \ +(cd /tmp && rm -rf $prefix) && \ +(mv /tmp/$target .) +END; + +echo $cmd; +echo "\n"; diff --git a/scripts/restoreuser.php b/scripts/restoreuser.php index 82eb9bbaa..b37e9db74 100644 --- a/scripts/restoreuser.php +++ b/scripts/restoreuser.php @@ -57,7 +57,8 @@ function getActivityStreamDocument() throw new Exception("File '$filename' not readable."); } - printfv(_("Getting backup from file '$filename'.")."\n"); + // TRANS: Commandline script output. %s is the filename that contains a backup for a user. + printfv(_("Getting backup from file '%s'.")."\n",$filename); $xml = file_get_contents($filename); @@ -79,19 +80,22 @@ function importActivityStream($user, $doc) if (!empty($subjectEl)) { $subject = new ActivityObject($subjectEl); - printfv(_("Backup file for user %s (%s)")."\n", $subject->id, Ostatus_profile::getActivityObjectNickname($subject)); + // TRANS: Commandline script output. %1$s is the subject ID, %2$s is the subject nickname. + printfv(_("Backup file for user %1$s (%2$s)")."\n", $subject->id, Ostatus_profile::getActivityObjectNickname($subject)); } else { throw new Exception("Feed doesn't have an <activity:subject> element."); } if (is_null($user)) { + // TRANS: Commandline script output. printfv(_("No user specified; using backup user.")."\n"); $user = userFromSubject($subject); } $entries = $feed->getElementsByTagNameNS(Activity::ATOM, 'entry'); - printfv(_("%d entries in backup.")."\n", $entries->length); + // TRANS: Commandline script output. %d is the number of entries in the activity stream in backup; used for plural. + printfv(_m("%d entry in backup.","%d entries in backup.",$entries->length)."\n", $entries->length); for ($i = $entries->length - 1; $i >= 0; $i--) { try { @@ -215,7 +219,7 @@ function postNote($user, $activity) $rendered = purify($sourceContent); $content = html_entity_decode(strip_tags($rendered), ENT_QUOTES, 'UTF-8'); - $shortened = common_shorten_links($content); + $shortened = $user->shortenLinks($content); $options = array('is_local' => Notice::LOCAL_PUBLIC, 'uri' => $sourceUri, |