mirror of
https://we.phorge.it/source/phorge.git
synced 2024-12-24 14:30:56 +01:00
efb0fa739f
Summary: See T624. I originally wrote this to require an explicit remote, but this creates an ugly "origin:" in all the URIs and makes T270 more difficult. Treat all branch names as implying 'origin/'. Test Plan: - Pulled and imported a fresh copy of libphutil without issues. - Browsed various git repositories. - Browsed Javelin's various branches. - Ran upgrade script, got a bunch of clean 'origin/master' -> 'master' conversions. - Tried to specify an explicit remote in a default branch name. - Unit tests. Reviewers: nh, jungejason, btrahan Reviewed By: btrahan CC: aran, btrahan Maniphest Tasks: T624 Differential Revision: https://secure.phabricator.com/D1269
58 lines
1.5 KiB
PHP
58 lines
1.5 KiB
PHP
<?php
|
|
|
|
/*
|
|
* Copyright 2011 Facebook, Inc.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
echo "Stripping remotes from repository default branches...\n";
|
|
|
|
$table = new PhabricatorRepository();
|
|
$conn_w = $table->establishConnection('w');
|
|
|
|
$repos = queryfx_all(
|
|
$conn_w,
|
|
'SELECT id, name, details FROM %T WHERE versionControlSystem = %s',
|
|
$table->getTableName(),
|
|
'git');
|
|
|
|
foreach ($repos as $repo) {
|
|
$details = json_decode($repo['details'], true);
|
|
|
|
$old = idx($details, 'default-branch', '');
|
|
if (strpos($old, '/') === false) {
|
|
continue;
|
|
}
|
|
|
|
$parts = explode('/', $old);
|
|
$parts = array_filter($parts);
|
|
$new = end($parts);
|
|
|
|
$details['default-branch'] = $new;
|
|
$new_details = json_encode($details);
|
|
|
|
$id = $repo['id'];
|
|
$name = $repo['name'];
|
|
|
|
echo "Updating default branch for repository #{$id} '{$name}' from ".
|
|
"'{$old}' to '{$new}' to remove the explicit remote.\n";
|
|
queryfx(
|
|
$conn_w,
|
|
'UPDATE %T SET details = %s WHERE id = %d',
|
|
$table->getTableName(),
|
|
$new_details,
|
|
$id);
|
|
}
|
|
|
|
echo "Done.\n";
|