Files
alpha-builds-site/lib/import_revs.php

221 lines
5.4 KiB
PHP
Executable File

#!/usr/bin/php
<?php
if (PHP_SAPI != "cli") {
print "Utility script 0x55424523.";
die();
}
// create table revs(id integer, hash varchar, author varchar, time timestamp, message text, diff text, primary key(id));
// create index hash_index on revs(hash);
define("SITE_ROOT", realpath(dirname(__file__) . "/.."));
require_once SITE_ROOT . "/lib/init.php";
function import_rev($raw, $chan)
{
global $DB;
$log = explode("\n", rtrim($raw));
$hash = $log[0];
$author = "";
$date = "";
$msg = "";
$inMsg = false;
$nrLog = count($log);
for ($i=0; $i<$nrLog; $i++) {
if ($inMsg) {
$msg .= substr($log[$i], 4);
if ($i<$nrLog-1) {
$msg .= "\n";
}
} else {
if (preg_match("|^author\\s*([^>]*>)\\s*([\\d]+)\\s*(.*)|i", $log[$i], $m)) {
$author = $m[1];
$date = (int)$m[2];
} else if (!trim($log[$i])) {
$inMsg = true;
}
}
}
$DB->query(
kl_str_sql(
"insert into revs (hash, chan, author, time, message) values (!s, !s, !s, !t, !s)",
$hash, $chan, $author, $date, $msg));
}
function save_build_changes($changes, $chan)
{
global $DB;
$DB->query("begin transaction");
foreach ($changes as $buildNr => $revs) {
$DB->query(kl_str_sql("insert into changes (build, chan, revisions) values (!i, !s, !s)", $buildNr, $chan, implode(",", $revs)));
}
$DB->query("commit");
}
function update_revs()
{
global $DB, $CHANS;
$DB->query("begin transaction");
if (!($res = $DB->query("delete from revs"))) {
$DB->query("create table revs(hash varchar, chan varchar, author varchar, time timestamp, message text, diff text, primary key(hash))");
}
$DB->query("commit");
$DB->query("begin transaction");
if (!($res = $DB->query("delete from changes"))) {
$DB->query("create table changes (build integer, chan varchar, revisions text, primary key(build, chan))");
}
$DB->query("commit");
foreach ($CHANS as $chan => $branch) {
exec("git fetch --all 2>&1");
if ($branch == "HEAD") {
$branch = "FETCH_HEAD";
}
exec("git reset --soft $branch 2>&1");
$DB->query("begin transaction");
$revs = array_reverse(explode(chr(0), rtrim(`git rev-list HEAD --header`)));
$nrRevs = count($revs);
print "Importing $nrRevs revisions for $chan\n";
for ($i=0; $i<$nrRevs; $i++) {
import_rev($revs[$i], $chan);
}
$res = $DB->query("commit");
$revs = explode("\n", rtrim(`git rev-list HEAD`));
$res = 0;
$c =0;
$changesAt = array();
while (true) {
exec("git reset --soft HEAD^ 2>&1", $out, $res);
if ($res != 0) {
break;
} else {
$c++;
$newRevs = explode("\n", rtrim(`git rev-list HEAD`));
$changes = array_diff($revs, $newRevs);
$nrChanges = count($changes);
$build = count($revs);
$revs = $newRevs;
$changesAt[$build] = $changes;
print $nrChanges . " changes in build $build\n";
if ($build < 2883) break; // this is when we started building
}
}
save_build_changes($changesAt, $chan);
}
print "Number resets: $c\n";
exec("git fetch --all 2>&1");
exec("git reset --soft $branch 2>&1");
}
function update_builds()
{
global $DB;
$builds = glob(SITE_ROOT . "/*_*_Setup.exe");
$latest = 0;
// check if table exists
if (!($res = $DB->query("select count(*) as c from builds"))) {
$DB->query("create table builds(nr integer, chan varchar, version varchar, hash varchar, file varchar, modified timestamp, primary key(nr, chan))");
}
for ($i=0; $i<count($builds); $i++) {
$file = basename($builds[$i]);
if (preg_match("|^(\w+)_(\d+)-(\d+)-(\d+)-(\d+)_|", $file, $m)) {
$chan = $m[1];
$major = $m[2];
$minor = $m[3];
$maintenance = $m[4];
$build = $m[5];
$modified = filemtime(SITE_ROOT . "/" . $file);
$version = "$major.$minor.$maintenance.$build";
$res = $DB->query(kl_str_sql("select count(*) as c from builds where nr=!i and chan=!s", $build, $chan));
$row = $DB->fetchRow($res);
if ($row["c"] === "0") {
$DB->query(kl_str_sql("insert into builds (nr, chan, version, file, modified) ".
"values (!i, !s, !s, !s, !t)",
$build, $chan, $version, $file, $modified));
}
}
}
}
function add_build($build, $chan, $version, $hash)
{
global $DB;
// check if table exists
if (!($res = $DB->query("select count(*) as c from builds"))) {
$DB->query("create table builds(nr integer, chan varchar, version varchar, hash varchar, file varchar, modified timestamp, primary key(nr, chan))");
}
$res = $DB->query(kl_str_sql("select count(*) as c from builds where nr=!i and chan=!s", $build, $chan));
$row = $DB->fetchRow($res);
if ($row["c"] === "0") {
$DB->query(kl_str_sql("insert into builds (nr, chan, version, hash, modified) ".
"values (!i, !s, !s, !s, !t)",
$build, $chan, $version, $hash, time()));
}
}
/* main */
if ($_SERVER['argc'] < 4) {
print "Too few arguments.\nUsage: import_revs.php <channel> <version> <hash>\n";
exit(1);
}
$CHAN = $_SERVER['argv'][1];
$VERSION = $_SERVER['argv'][2];
$HASH = $_SERVER['argv'][3];
$build_parts = explode(".", $VERSION);
if (count($build_parts) != 4) {
print "Wrong version format, expected x.y.z.build\n";
die();
}
$BUILD = $build_parts[3];
print "$CHAN $VERSION $HASH $BUILD\n";
add_build($BUILD, $CHAN, $VERSION, $HASH);
$DB->query("PRAGMA synchronous = OFF");
chdir(SITE_ROOT . "/lib/source");
exec("git fetch --all");
update_revs();
chdir(SITE_ROOT);
update_builds();
/*
* Local variables:
* tab-width: 4
* c-basic-offset: 4
* End:
* vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4
*/