3 # update-lily.py -- lilypond autobuilder
5 # source file of the GNU LilyPond music typesetter
7 # download and rebuild latest lilypond or from specified url
12 * more flexible build/ftp/patches/releases paths
13 * flexible build command
30 gettext.bindtextdomain ('lilypond', '@localedir@')
31 gettext.textdomain('lilypond')
37 sys.path.append ('@datadir@/python')
39 gettext.bindtextdomain ('lilypond', '@localedir@')
40 gettext.textdomain('lilypond')
44 program_name = 'build-lily'
45 package_name = 'lilypond'
46 help_summary = _("Fetch and rebuild from latest source package")
47 obuild_command = '(./configure --prefix=$HOME/usr && make all web) >> log.txt 2>&1'
53 ln -s %n-%v building &&
55 ./configure --prefix=$HOME/usr && make all web
61 release_dir = build_root + '/releases'
62 patch_dir = build_root + '/patches'
64 url = 'file:/home/ftp/pub/gnu/LilyPond/development/lilypond-*.tar.gz'
65 url = 'ftp://appel.lilypond.org/pub/gnu/LilyPond/development/lilypond-*.tar.gz'
66 url = 'ftp://ftp.cs.uu.nl/pub/GNU/LilyPond/development/lilypond-*.tar.gz'
71 # lily_py.py -- options and stuff
73 # source file of the GNU LilyPond music typesetter
75 # BEGIN Library for these?
76 # cut-n-paste from ly2dvi
78 program_version = '@TOPLEVEL_VERSION@'
79 if program_version == '@' + 'TOPLEVEL_VERSION' + '@':
80 program_version = '1.3.142'
83 original_dir = os.getcwd ()
84 temp_dir = '%s.dir' % program_name
89 sys.stdout.write ('%s (GNU LilyPond) %s\n' % (program_name, program_version))
93 sys.stdout.write ('\n')
94 sys.stdout.write (_ ('Copyright (c) %s by' % ' 2001'))
95 sys.stdout.write ('\n')
96 sys.stdout.write (' Han-Wen Nienhuys')
97 sys.stdout.write (' Jan Nieuwenhuizen')
98 sys.stdout.write ('\n')
99 sys.stdout.write (_ (r'''
100 Distributed under terms of the GNU General Public License. It comes with
102 sys.stdout.write ('\n')
105 sys.stderr.write (s + '\n')
108 sys.stderr.write (_ ("warning: ") + s)
109 sys.stderr.write ('\n')
113 sys.stderr.write (_ ("error: ") + s)
114 sys.stderr.write ('\n')
115 raise _ ("Exiting ... ")
117 def getopt_args (opts):
118 '''Construct arguments (LONG, SHORT) for getopt from list of options.'''
133 def option_help_str (o):
134 '''Transform one option description (4-tuple ) into neatly formatted string'''
152 return ' ' + sh + sep + long + arg
155 def options_help_str (opts):
156 '''Convert a list of options into a neatly formatted string'''
162 s = option_help_str (o)
163 strs.append ((s, o[3]))
169 str = str + '%s%s%s\n' % (s[0], ' ' * (w - len(s[0]) + 3), s[1])
173 sys.stdout.write (_ ("Usage: %s [OPTION]... FILE") % program_name)
174 sys.stdout.write ('\n\n')
175 sys.stdout.write (help_summary)
176 sys.stdout.write ('\n\n')
177 sys.stdout.write (_ ("Options:"))
178 sys.stdout.write ('\n')
179 sys.stdout.write (options_help_str (option_definitions))
180 sys.stdout.write ('\n\n')
181 sys.stdout.write (_ ("Report bugs to %s") % 'bug-gnu-music@gnu.org')
182 sys.stdout.write ('\n')
188 if not keep_temp_dir_p:
189 temp_dir = tempfile.mktemp (program_name)
191 os.mkdir (temp_dir, 0777)
196 def system (cmd, ignore_error = 0):
198 progress (_ ("Invoking `%s\'") % cmd)
201 msg = ( _ ("error: ") + _ ("command exited with value %d") % st)
203 sys.stderr.write (msg + ' ' + _ ("(ignored)") + ' ')
211 if not keep_temp_dir_p:
213 progress (_ ("Cleaning %s...") % temp_dir)
214 system ('rm -rf %s' % temp_dir)
217 def set_setting (dict, key, val):
219 val = string.atof (val)
221 #warning (_ ("invalid value: %s") % `val`)
225 dict[key].append (val)
227 warning (_ ("no such setting: %s") % `key`)
232 option_definitions = [
233 ('DIR', 'b', 'build-root', _ ("unpack and build in DIR [%s]") % build_root),
234 ('COMMAND', 'c', 'command', _ ("execute COMMAND, subtitute:") \
235 + '\n ' + _ ("%%n: package name") \
236 + '\n ' + _ ("%%v: package version") \
237 + '\n ' + _ ("%%t: tarball") \
239 ('', 'h', 'help', _ ("this help")),
240 ('', 'k', 'keep', _ ("keep all output, and name the directory %s") % temp_dir),
241 ('', 'r', 'remove-previous', _ ("remove previous build")),
242 ('', 'V', 'verbose', _ ("verbose")),
243 ('', 'v', 'version', _ ("print version number")),
244 ('URL', 'u', 'url', _ ("fetch and build URL [%s]") % url),
245 ('', 'w', 'warranty', _ ("show warranty and copyright")),
248 def list_file (user, passwd, host, dir, file):
250 for i in os.listdir (dir):
251 if fnmatch.fnmatch (i, file):
258 # ugh: use ftp module.
260 def list_ftp (user, passwd, host, dir, file):
264 passwd = program_name
271 ''' % (user, passwd, host, dir, file)
272 temp = tempfile.mktemp (program_name)
276 p = os.popen ('lftp -f %s' % temp, 'r')
279 return string.split (s[:-1], '\n')
282 m = re.match ('([^:/]*)(:)?(/*([^:]*):)?(/*([^@]*)@)?(//([^/]*))?(.*)/(.*)',
285 error ("can't parse url: %s " % url)
286 return (m.group (1), m.group (4), m.group (6), m.group (8),
287 m.group (9), m.group (10))
290 s = "list_%s ('%s', '%s', '%s', '%s', '%s')" % split_url (url)
293 def version_tuple_to_str (t):
295 my = '.%s%d' % (t[3], t[4])
298 return ('%d.%d.%d' % t[0:3]) + my
300 def version_str_to_tuple (s):
301 t = string.split (s, '.')
304 my_number = string.atoi (t[3][-1])
308 return (string.atoi (t[0]), string.atoi (t[1]), string.atoi (t[2]),
311 def split_package (p):
312 m = re.match ('(.*)-([0-9]*.*).tar.gz', p)
313 return (m.group (1), version_str_to_tuple (m.group (2)))
315 def join_package (t):
316 return t[0] + '-' + version_tuple_to_str (t[1])
318 def copy_file (user, passwd, host, dir, file):
319 os.system ('cp %s/%s .' % (dir, file))
323 def copy_ftp (user, passwd, host, dir, file):
327 passwd = program_name
334 ''' % (user, passwd, host, dir, file)
335 temp = tempfile.mktemp (program_name)
339 p = os.popen ('lftp -f %s' % temp, 'r')
343 def copy_url (url, dir):
345 s = "copy_%s ('%s', '%s', '%s', '%s', '%s')" % split_url (url)
349 def find_latest (url):
350 progress (_ ("listing %s...") % url)
351 list = map (split_package, list_url (url))
353 return join_package (list[-1])
356 tar_ball = p + '.tar.gz'
357 (tar_name, tar_version) = split_package (tar_ball)
362 '%v' : version_tuple_to_str (tar_version),
366 for i in expand.keys ():
367 c = re.sub (i, expand[i], c)
370 (sh, long) = getopt_args (__main__.option_definitions)
372 (options, files) = getopt.getopt (sys.argv[1:], sh, long)
383 elif o == '--help' or o == '-h':
385 elif o == '--buid-root' or o == '-b':
387 elif o == '--command' or o == '-c':
389 elif o == '--remove-previous' or o == '-r':
390 remove_previous_p = 1
391 elif o == '--url' or o == '-u':
393 elif o == '--verbose' or o == '-V':
395 elif o == '--version' or o == '-v':
398 elif o == '--warranty' or o == '-w':
403 latest = find_latest (url)
405 if os.path.isdir ('%s/%s' % (build_root, latest)):
406 progress (_ ("latest is %s") % latest)
407 progress (_ ("relax, %s is up to date" % package_name))
410 get_base = url[:string.rindex (url, '/')] + '/'
411 if os.path.isdir (patch_dir):
413 if not os.path.isfile (latest + '.diff.gz'):
414 get = get_base + latest + '.diff.gz'
415 progress (_ ("fetching %s...") % get)
418 if not os.path.isdir (build_root):
419 build_root = temp_dir
420 if not os.path.isdir (release_dir):
421 release_dir = temp_dir
424 os.chdir (release_dir)
425 if not os.path.isfile (latest + '.tar.gz'):
426 get = get_base + latest + '.tar.gz'
427 progress (_ ("fetching %s...") % get)
430 if os.path.isdir (os.path.join (build_command, package_name)):
431 os.chdir (os.path.join (build_command, package_name))
432 previous = os.getcwd ()
436 progress (_ ("building %s...") % get)
437 os.chdir (build_root)
438 if not build (latest) and previous and remove_previous_p:
439 system ('rm -rf %s' % os.path.join (build_root, previous))
441 os.chdir (original_dir)
442 if release_dir != temp_dir: