Apache/2.4.7 (Ubuntu) Linux sman1baleendah 3.13.0-24-generic #46-Ubuntu SMP Thu Apr 10 19:11:08 UTC 2014 x86_64 uid=33(www-data) gid=33(www-data) groups=33(www-data) safemode : OFF MySQL: ON | Perl: ON | cURL: OFF | WGet: ON > / usr / share / apport / | server ip : 172.67.156.115 your ip : 172.69.214.234 H O M E |
Filename | /usr/share/apport/java_uncaught_exception |
Size | 2.49 kb |
Permission | rwxr-xr-x |
Owner | root : root |
Create time | 27-Apr-2025 09:55 |
Last modified | 15-Apr-2014 23:38 |
Last accessed | 27-Apr-2025 09:55 |
Actions | edit | rename | delete | download (gzip) |
View | text | code | image |
#!/usr/bin/python3
'''Receive details from ApportUncaughtExceptionHandler.
This generates and saves a problem report.
'''
# Copyright 2010 Canonical Ltd.
# Author: Matt Zimmerman <[email protected]>
#
# 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; either version 2 of the License, or (at your
# option) any later version. See http://www.gnu.org/copyleft/gpl.html for
# the full text of the license.
import sys
if sys.version_info.major < 3:
from urlparse import urlparse
urlparse # pyflakes
else:
from urllib.parse import urlparse
def make_title(report):
lines = report['StackTrace'].split('\n')
message = lines[0].strip()
stackframe = lines[1].strip()
return '%s in %s' % (message, stackframe)
def main():
from apport.packaging_impl import impl as packaging
if not packaging.enabled():
return -1
# read from the JVM process a sequence of key, value delimited by null
# bytes
items = sys.stdin.read().split('\0')
d = dict()
while items:
key = items.pop(0)
if not items:
break
value = items.pop(0)
d[key] = value
# create report
import apport.report
import os
report = apport.report.Report(type='Crash')
# assume our parent is the JVM process
report.pid = os.getppid()
report.add_os_info()
report.add_proc_info()
# these aren't relevant because the crash was in bytecode
del report['ProcMaps']
del report['ProcStatus']
report.add_user_info()
# add in data which was fed to us from the JVM process
for key, value in d.items():
report[key] = value
# Add an ExecutablePath pointing to the file where the main class resides
if 'MainClassUrl' in report:
url = report['MainClassUrl']
scheme, netloc, path, params, query, fragment = urlparse(url)
if scheme == 'jar':
# path is then a URL to the jar file
scheme, netloc, path, params, query, fragment = urlparse(path)
if '!/' in path:
path = path.split('!/', 1)[0]
if scheme == 'file':
report['ExecutablePath'] = path
else:
# Program at some non-file URL crashed. Give up.
return
report['Title'] = make_title(report)
with open(apport.fileutils.make_report_path(report), 'wb') as f:
report.write(f)
if __name__ == '__main__':
main()
'''Receive details from ApportUncaughtExceptionHandler.
This generates and saves a problem report.
'''
# Copyright 2010 Canonical Ltd.
# Author: Matt Zimmerman <[email protected]>
#
# 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; either version 2 of the License, or (at your
# option) any later version. See http://www.gnu.org/copyleft/gpl.html for
# the full text of the license.
import sys
if sys.version_info.major < 3:
from urlparse import urlparse
urlparse # pyflakes
else:
from urllib.parse import urlparse
def make_title(report):
lines = report['StackTrace'].split('\n')
message = lines[0].strip()
stackframe = lines[1].strip()
return '%s in %s' % (message, stackframe)
def main():
from apport.packaging_impl import impl as packaging
if not packaging.enabled():
return -1
# read from the JVM process a sequence of key, value delimited by null
# bytes
items = sys.stdin.read().split('\0')
d = dict()
while items:
key = items.pop(0)
if not items:
break
value = items.pop(0)
d[key] = value
# create report
import apport.report
import os
report = apport.report.Report(type='Crash')
# assume our parent is the JVM process
report.pid = os.getppid()
report.add_os_info()
report.add_proc_info()
# these aren't relevant because the crash was in bytecode
del report['ProcMaps']
del report['ProcStatus']
report.add_user_info()
# add in data which was fed to us from the JVM process
for key, value in d.items():
report[key] = value
# Add an ExecutablePath pointing to the file where the main class resides
if 'MainClassUrl' in report:
url = report['MainClassUrl']
scheme, netloc, path, params, query, fragment = urlparse(url)
if scheme == 'jar':
# path is then a URL to the jar file
scheme, netloc, path, params, query, fragment = urlparse(path)
if '!/' in path:
path = path.split('!/', 1)[0]
if scheme == 'file':
report['ExecutablePath'] = path
else:
# Program at some non-file URL crashed. Give up.
return
report['Title'] = make_title(report)
with open(apport.fileutils.make_report_path(report), 'wb') as f:
report.write(f)
if __name__ == '__main__':
main()