commit: eed2243011824ddb3525a75409fae1398a11fb11
Author: Pawel Hajdan, Jr <phajdan.jr <AT> gentoo <DOT> org>
AuthorDate: Sun Jul 9 14:42:21 2017 +0000
Commit: Paweł Hajdan <phajdan.jr <AT> gentoo <DOT> org>
CommitDate: Sun Jul 9 14:42:21 2017 +0000
URL: https://gitweb.gentoo.org/proj/arch-tools.git/commit/?id=eed22430
stabilization-candidates: update for git
stabilization-candidates.py | 24 +++++++++++-------------
1 file changed, 11 insertions(+), 13 deletions(-)
diff --git a/stabilization-candidates.py b/stabilization-candidates.py
index d324bdb..2537ab4 100755
--- a/stabilization-candidates.py
+++ b/stabilization-candidates.py
@@ -20,7 +20,7 @@ if __name__ == "__main__":
parser = optparse.OptionParser()
parser.add_option("--arch", dest="arch", action="append", help="Gentoo
arch to use, e.g. x86, amd64, ... Can be passed multiple times.")
parser.add_option("--days", dest="days", type=int, default=30,
help="Number of days in the tree after stabilization is possible.")
- parser.add_option("--repo", dest="repo", help="Path to portage CVS
repository")
+ parser.add_option("--repo", dest="repo", help="Path to portage git
repository")
parser.add_option("--category", dest="category", help="Portage category
filter (default is all categories)")
parser.add_option("--exclude", dest="exclude",
default=".*(kde-base|sci|lisp|perl-core|virtual|gnome|ruby|x11|mono|dotnet|games|xfce|xfburn|mousepad|orage|xfbib|thunar|ristretto|pragha|xfmpc|parole|midori|gigolo|rodent|xfwm|girara|zathura|leechcraft).*",
help="Regular expression for excluded packages.")
parser.add_option("-o", "--output", dest="output_filename",
default="stabilization-candidates.txt", help="Output filename for generated
stabilization candidates list.")
@@ -116,18 +116,16 @@ if __name__ == "__main__":
pv = portage.versions.catsplit(best_candidate)[1]
try:
- with open(os.path.join(options.repo, cp, 'ChangeLog'))
as changelog_file:
- regex = '\*%s \((.*)\)' % re.escape(pv)
- match = re.search(regex, changelog_file.read())
- if not match:
- print('error parsing ChangeLog')
- continue
- changelog_date =
datetime.datetime.strptime(match.group(1), '%d %b %Y')
- if now - changelog_date <
datetime.timedelta(days=options.days):
- print('not old enough')
- continue
- except IOError as e:
- print(e)
+ git_log = subprocess.check_output(
+ ['git', 'log', '--date-order', '--date=short',
'--format=%cd', '%s.ebuild' % pv],
+ cwd=os.path.join(options.repo, cp))
+ changelog_date_str =
git_log.splitlines()[0].decode('utf-8')
+ changelog_date =
datetime.datetime.strptime(changelog_date_str, '%Y-%m-%d')
+ if now - changelog_date <
datetime.timedelta(days=options.days):
+ print('not old enough')
+ continue
+ except subprocess.CalledProcessError as ex:
+ print('git error: ' + ex.output)
continue
keywords =
portage.db["/"]["porttree"].dbapi.aux_get(best_candidate, ['KEYWORDS'])[0]