29
29
action='store', type='string', dest='module')
30
30
optparser.add_option('-v', help="Specify the DKMS version to find the package for",
31
31
action='store', type='string', dest='version')
32
optparser.add_option('-k', help="Specify the kernel version",
33
action='store', type='string', dest='kernel')
32
34
options=optparser.parse_args()[0]
34
36
if not options.module or not options.version:
35
print >> sys.stderr, 'ERROR, both -m and -v are required'
37
print >> sys.stderr, 'ERROR (dkms apport): both -m and -v are required'
38
40
package=packaging.get_file_package('/usr/src/' + options.module + '-' + options.version)
39
41
if package is None:
40
print >> sys.stderr, 'ERROR: binary package for %s: %s not found' % (options.module,options.version)
42
print >> sys.stderr, 'ERROR (dkms apport): binary package for %s: %s not found' % (options.module,options.version)
46
# TODO: Ubuntu specific
47
kernel_package = "linux-headers-" + options.kernel
49
if not apport.packaging.is_distro_package(kernel_package):
50
print >> sys.stderr, 'ERROR (dkms apport): kernel package %s is not supported' % (kernel_package,)
43
53
make_log=os.path.join('/var','lib','dkms',options.module,options.version,'build','make.log')
45
55
report = apport.Report('Package')
46
56
report['Package'] = package
47
report['SourcePackage'] = apport.packaging.get_source(package)
48
report['ErrorMessage'] = "%s kernel module failed to build" % options.module
58
report['SourcePackage'] = apport.packaging.get_source(package)
60
print >> sys.stderr, 'ERROR (dkms apport): unable to determine source package for %s' % package
50
63
version = packaging.get_version(package)
65
version = '(not installed)'
53
66
if version is None:
67
version = '(not installed)'
69
if report['SourcePackage'] == 'fglrx-installer':
70
fglrx_make_log = os.path.join('/var','lib','dkms',options.module,options.version,'build','make.sh.log')
71
attach_file_if_exists(report, fglrx_make_log, 'FglrxBuildLog')
55
73
report['PackageVersion'] = version
74
report['Title'] = "%s %s: %s kernel module failed to build" % (package, version, options.module)
56
75
attach_file_if_exists(report, make_log, 'DKMSBuildLog')
77
report['DKMSKernelVersion'] = options.kernel
57
78
report.write(open(apport.fileutils.make_report_path(report), 'w'))