ubuntu-dev-tools/check-mir

159 lines
5.5 KiB
Plaintext
Raw Normal View History

#!/usr/bin/python
#
# Check components of build dependencies and warn about universe/multiverse
# ones, for a package destined for main/restricted
#
# Copyright (C) 2011 Canonical
#
# Authors:
# Martin Pitt
#
# This program is free software; you can redistribute it and/or modify it under
# the terms of the GNU General Public License as published by the Free Software
# Foundation; version 3.
#
# 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 General Public License for more
# details.
#
# You should have received a copy of the GNU General Public License along with
# this program; if not, write to the Free Software Foundation, Inc.,
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
from __future__ import print_function
2011-01-14 11:09:21 +01:00
import sys
import optparse
2011-01-14 11:09:21 +01:00
import os.path
import apt
2011-01-14 11:09:21 +01:00
def check_support(apt_cache, pkgname, alt=False):
'''Check if pkgname is in main or restricted.
This prints messages if a package is not in main/restricted, or only
2011-01-14 11:09:21 +01:00
partially (i. e. source in main, but binary in universe).
'''
if alt:
prefix = ' ... alternative ' + pkgname
else:
prefix = ' * ' + pkgname
try:
pkg = apt_cache[pkgname]
except KeyError:
print(prefix, 'does not exist (pure virtual?)', file=sys.stderr)
return False
2011-05-23 23:44:45 +02:00
section = pkg.candidate.section
if section.startswith('universe') or section.startswith('multiverse'):
# check if the source package is in main and thus will only need binary
# promotion
2011-01-14 11:09:21 +01:00
source_records = apt.apt_pkg.SourceRecords()
if not source_records.lookup(pkg.candidate.source_name):
print('ERROR: Cannot lookup source package for', pkg.name,
file=sys.stderr)
print(prefix, 'package is in', section.split('/')[0])
return False
2011-01-14 11:09:21 +01:00
src = apt.apt_pkg.TagSection(source_records.record)
if (src['Section'].startswith('universe') or
src['Section'].startswith('multiverse')):
print(prefix, 'binary and source package is in',
section.split('/')[0])
return False
else:
print(prefix, 'is in', section.split('/')[0] + ', but its source',
pkg.candidate.source_name,
'is already in main; file an ubuntu-archive bug for '
'promoting the current preferred alternative')
return True
if alt:
print(prefix, 'is already in main; consider preferring it')
return True
2011-01-14 11:09:21 +01:00
def check_build_dependencies(apt_cache, control):
print('Checking support status of build dependencies...')
2011-01-14 11:09:21 +01:00
any_unsupported = False
2011-01-14 11:09:21 +01:00
for field in ('Build-Depends', 'Build-Depends-Indep'):
if field not in control.section:
continue
2011-01-14 11:09:21 +01:00
for or_group in apt.apt_pkg.parse_src_depends(control.section[field]):
pkgname = or_group[0][0]
2011-01-14 11:09:21 +01:00
if not check_support(apt_cache, pkgname):
# check non-preferred alternatives
for altpkg in or_group[1:]:
2011-01-14 11:09:21 +01:00
if check_support(apt_cache, altpkg[0], alt=True):
break
else:
any_unsupported = True
2011-01-14 11:09:21 +01:00
return any_unsupported
2011-01-14 11:09:21 +01:00
def check_binary_dependencies(apt_cache, control):
any_unsupported = False
print('\nChecking support status of binary dependencies...')
2011-01-14 11:09:21 +01:00
while True:
try:
control.next()
except StopIteration:
break
for field in ('Depends', 'Pre-Depends', 'Recommends'):
if field not in control.section:
continue
for or_group in apt.apt_pkg.parse_src_depends(
control.section[field]):
2011-01-14 11:09:21 +01:00
pkgname = or_group[0][0]
if pkgname.startswith('$'):
continue
if not check_support(apt_cache, pkgname):
# check non-preferred alternatives
for altpkg in or_group[1:]:
if check_support(apt_cache, altpkg[0], alt=True):
break
else:
any_unsupported = True
return any_unsupported
2011-01-14 11:09:21 +01:00
def main():
2012-05-27 00:46:24 +02:00
description = "Check if any of a package's build or binary " + \
"dependencies are in universe or multiverse. " + \
"Run this inside an unpacked source package"
parser = optparse.OptionParser(description=description)
parser.parse_args()
2011-01-14 11:09:21 +01:00
apt_cache = apt.Cache()
if not os.path.exists('debian/control'):
print('debian/control not found. You need to run this tool in a '
'source package directory', file=sys.stderr)
2011-01-14 11:09:21 +01:00
sys.exit(1)
# get build dependencies from debian/control
control = apt.apt_pkg.TagFile(open('debian/control'))
control.next()
unsupported_build_deps = check_build_dependencies(apt_cache, control)
unsupported_binary_deps = check_binary_dependencies(apt_cache, control)
if unsupported_build_deps or unsupported_binary_deps:
print('\nPlease check https://wiki.ubuntu.com/MainInclusionProcess if '
'this source package needs to get into in main/restricted, or '
'reconsider if the package really needs above dependencies.')
2011-01-14 11:09:21 +01:00
else:
print('All dependencies are supported in main or restricted.')
2011-01-14 11:09:21 +01:00
2017-05-01 00:20:03 +02:00
2011-01-14 11:09:21 +01:00
if __name__ == '__main__':
main()