*** empty log message ***

svn path=/trunk/boinc/; revision=2231
This commit is contained in:
Karl Chen 2003-09-03 08:17:11 +00:00
parent 9fb1b8bacc
commit 4aae290500
1 changed files with 67 additions and 65 deletions

View File

@ -22,7 +22,7 @@
# #
''' '''
add.py -- add items to the BOINC database. add items to the BOINC database.
Usages: Usages:
@ -51,12 +51,58 @@ add.py workunit (TODO)
add.py result (TODO) ''' add.py result (TODO) '''
import sys, getopt, md5 import sys, getopt, md5, time
sys.path.append('../py/') sys.path.append('../py/')
import database, db_mid import database, db_mid
from util import * from util import *
CREATE_TIME = ['?create_time', time.time()] CREATE_TIME = ['?create_time', int(time.time())]
class XCoreVersion(database.CoreVersion):
def __init__(**kwargs):
exec_file = kwargs['exec_file']
del kwargs['exec_file']
kwargs['xml_doc'] = process_executable_file(exec_file)
apply(database.CoreVersion.__init__,[],kwargs)
class XAppVersion(database.AppVersion):
def __init__(**kwargs):
signature_files = kwargs['signature_files']
exec_files = kwargs['exec_files']
if not exec_files:
raise Exception('internal error: no exec_files - should have caught this earlier')
del kwargs['signature_files']
del kwargs['exec_files']
del kwargs['exec_file']
xml_doc = ''
for exec_file in exec_files:
signature_file = signature_files.get(exec_file)
if signature_file:
signature_text = open(signature_file).read()
else:
signature_text = sign_executable(exec_file)
xml_doc += process_executable_file(exec_file, signature_text)
xml_doc += ('<app_version>\n'+
' <app_name>%s</app_name>\n'+
' <version_num>%d</version_num>\n') %(
self.name, self.version_num)
first = True
for exec_file in exec_files:
xml_doc += (' <file_ref>\n'+
' <file_name>%s</filename>\n') %(
os.path.basename(exec_file))
if first:
xml_doc += ' <main_program/>\n'
xml_doc += ' </file_ref>\n'
first = False
xml_doc += '</app_version>\n'
kwargs['xml_doc'] = xml_doc
apply(database.AppVersion.__init__,[],kwargs)
# format: [ database.Object, args, ...] # format: [ database.Object, args, ...]
# arg format: # arg format:
@ -67,14 +113,13 @@ list_objects_to_add = [
[ database.Project, 'name', '?long_name' ], [ database.Project, 'name', '?long_name' ],
[ database.Platform, 'name', 'user_friendly_name', CREATE_TIME ], [ database.Platform, 'name', 'user_friendly_name', CREATE_TIME ],
[ XCoreVersion, 'platform', 'version_num', 'exec_file', [ XCoreVersion, 'platform', 'version_num', 'exec_file',
['?message',''], ['?message_priority',''], ['?message',''], ['?message_priority','']],
[ database.App, 'name', 'min_version', CREATE_TIME], [ database.App, 'name', 'min_version', CREATE_TIME],
[ XAppVersion, 'app', 'platform', 'version_num', 'exec_file', '?signature_file' [ XAppVersion, 'app', 'platform', 'version_num', 'exec_file', '?signature_file',
],
CREATE_TIME ], CREATE_TIME ],
[ database.User, 'name', 'email_addr', 'authenticator', [ database.User, 'name', 'email_addr', 'authenticator',
['?country','United States'], ['?postal_code','94703'], ['?country','United States'], ['?postal_code','94703'],
'?global_prefs', '?global_prefs_file' '?global_prefs', '?global_prefs_file',
CREATE_TIME ], CREATE_TIME ],
# [ database.Workunit, 'zzzz' ], # [ database.Workunit, 'zzzz' ],
] ]
@ -124,59 +169,13 @@ def translate_database_arg(database_table, arg, value):
raise SystemExit('Too many %s match "%s"'%(arg,value)) raise SystemExit('Too many %s match "%s"'%(arg,value))
return results[0] return results[0]
class XCoreVersion(database.CoreVersion):
def __init__(**kwargs):
exec_file = kwargs['exec_file']
del kwargs['exec_file']
kwargs['xml_doc'] = process_executable_file(exec_file)
apply(database.CoreVersion.__init__,[],kwargs)
class XAppVersion(database.AppVersion):
def __init__(**kwargs):
signature_files = kwargs['signature_files']
exec_files = kwargs['exec_files']
if not exec_files:
raise Exception('internal error: no exec_files - should have caught this earlier')
del kwargs['signature_files']
del kwargs['exec_files']
del kwargs['exec_file']
xml_doc = ''
for exec_file in exec_files
signature_file = signature_files.get(exec_file)
if signature_file:
signature_text = open(signature_file).read()
else:
signature_text = sign_executable(exec_file)
xml_doc += process_executable_file(exec_file, signature_text)
xml_doc += ('<app_version>\n'+
' <app_name>%s</app_name>\n'+
' <version_num>%d</version_num>\n') %(
self.name, self.version_num)
first = True
for exec_file in exec_files:
xml_doc += (' <file_ref>\n'+
' <file_name>%s</filename>\n') %(
os.path.basename(exec_file))
if first:
xml_doc += ' <main_program/>\n'
xml_doc += ' </file_ref>\n'
first = False
xml_doc += '</app_version>\n'
kwargs['xml_doc'] = xml_doc
apply(database.AppVersion.__init__,[],kwargs)
def ambiguous_lookup(string, dict): def ambiguous_lookup(string, dict):
results = [] results = []
string = string.replace('_','') string = string.replace('_','')
for key in dict: for key in dict:
k = key.replace('_','') k = key.replace('_','')
if k == string: if k == string:
return [k] return [dict[key]]
if k.startswith(string): if k.startswith(string):
results.append(dict[key]) results.append(dict[key])
return results return results
@ -186,16 +185,16 @@ def parse_global_options(args):
pass pass
def dv(object,arg): def dv(object,arg):
if arg in object.default_args: if arg in object.default_values:
return ' --%s [%s]' %(arg, object.default_args[arg]) return ' --%s [%s]' %(arg, object.default_values[arg])
else: else:
return ' --%s' %arg return ' --%s' %arg
def help_object(object, msg=None): def help_object(object, msg=None):
if msg: if msg:
print >>sys.stderr, msg print >>sys.stderr, "add:", msg
print print
print >>sys.stderr, "Syntax: add %s"%object.name print >>sys.stderr, "Syntax: add.py %s"%object.name
for arg in object.args: for arg in object.args:
print >>sys.stderr, dv(object,arg) print >>sys.stderr, dv(object,arg)
print >>sys.stderr, " Optional:" print >>sys.stderr, " Optional:"
@ -210,8 +209,8 @@ def add_object(object, args):
map(lambda s: s+'=', map(lambda s: s+'=',
object.args + object.optional_args)) object.args + object.optional_args))
if placement_args: if placement_args:
raise 'Unknown args '+' '.join(placement_args) raise getopt.GetoptError('Unknown args '+' '.join(placement_args))
except Exception, e: except getopt.GetoptError, e:
help_object(object, e) help_object(object, e)
args_dict = {} args_dict = {}
for arg,value in parsed_opts: for arg,value in parsed_opts:
@ -257,15 +256,15 @@ for o in list_objects_to_add:
else: else:
optional = False optional = False
if optional: if optional:
objects.optional_args.append(arg) object.optional_args.append(arg)
else: else:
objects.args.append(arg) object.args.append(arg)
if default_value: if default_value:
object.default_values[arg] = default_value object.default_values[arg] = default_value
objects_to_add[object.name] = object objects_to_add[object.name] = object
if len(sys.argv) < 2: if len(sys.argv) < 2:
print >>sys.stderr, """Syntax: add <object_to_add> <options...> print >>sys.stderr, """Syntax: add.py <object_to_add> <options...>
Adds an object to the BOINC database. Adds an object to the BOINC database.
@ -274,9 +273,12 @@ Objects to add:"""
print >>sys.stderr, " ", object print >>sys.stderr, " ", object
print >>sys.stderr, """ print >>sys.stderr, """
Global options: Global options:
--config=config.xml Path to configuration file.
These override config.xml:
--db_name Database name --db_name Database name
--db_password Database password [optional] --db_password Database password
--db_user Database user [optional] --db_user Database user
For command-line help on a particular object, use add <object> without further For command-line help on a particular object, use add <object> without further
arguments. arguments.