'''
TODO:
- * more flexible build paths
- * cleanup previous tree
- * flexible build command
- * show only?
+
+ * use urllib iso ftplib
+
+ * more flexible build/ftp/patches/releases paths
+
+
+ show only: --command='echo "latest is: %n-%v"'
'''
-import os
+import ftplib
import fnmatch
+import getopt
+import re
+import operator
+import os
+import tempfile
import stat
import string
-import re
-import getopt
import sys
import __main__
-import operator
-import tempfile
+try:
+ import gettext
+ gettext.bindtextdomain ('lilypond', '@localedir@')
+ gettext.textdomain('lilypond')
+ _ = gettext.gettext
+except:
+ def _ (s):
+ return s
sys.path.append ('@datadir@/python')
import gettext
program_name = 'build-lily'
package_name = 'lilypond'
help_summary = _("Fetch and rebuild from latest source package")
-build_root = os.environ ['HOME'] + '/usr/src'
+build_root = os.path.join (os.environ ['HOME'], 'usr', 'src')
release_dir = build_root + '/releases'
patch_dir = build_root + '/patches'
+notify = 0
+
+build_command = '''
+set -x
+cd %b &&
+[ -d %n-%v ] && exit 1 || true;
+mkdir -p %n-%v
+(
+tar xzf %r/%t &&
+rm -f building &&
+ln -s %n-%v building &&
+cd %n-%v &&
+./configure --prefix=$HOME/usr && make all web
+) >> %n-%v/log.txt 2>&1 &&
+rm -f %n &&
+ln -s %n-%v %n
+'''
+
url = 'file:/home/ftp/pub/gnu/LilyPond/development/lilypond-*.tar.gz'
url = 'ftp://appel.lilypond.org/pub/gnu/LilyPond/development/lilypond-*.tar.gz'
url = 'ftp://ftp.cs.uu.nl/pub/GNU/LilyPond/development/lilypond-*.tar.gz'
+#arg
+url = 'ftp://ftp.cs.uu.nl/pub/GNU/LilyPond/v1.3/lilypond-*.tar.gz'
+
+remove_previous_p = 0
# lily_py.py -- options and stuff
def cleanup_temp ():
if not keep_temp_dir_p:
if verbose_p:
- progress (_ ('Cleaning up `%s\'') % temp_dir)
+ progress (_ ("Cleaning `%s'...") % temp_dir)
system ('rm -rf %s' % temp_dir)
option_definitions = [
('DIR', 'b', 'build-root', _ ("unpack and build in DIR [%s]") % build_root),
+ ('COMMAND', 'c', 'command', _ ("execute COMMAND, subtitute:") \
+ + '\n ' + _ ("%b: build root") \
+ + '\n ' + _ ("%n: package name") \
+ + '\n ' + _ ("%r: release directory") \
+ + '\n ' + _ ("%t: tarball") \
+ + '\n ' + _ ("%v: package version") \
+ ),
('', 'h', 'help', _ ("this help")),
('', 'k', 'keep', _ ("keep all output, and name the directory %s") % temp_dir),
+ ('EMAIL', 'n', 'notify', _ ("upon failure notify EMAIL[,EMAIL]")),
+ ('', 'r', 'remove-previous', _ ("remove previous build")),
('', 'V', 'verbose', _ ("verbose")),
('', 'v', 'version', _ ("print version number")),
('URL', 'u', 'url', _ ("fetch and build URL [%s]") % url),
if passwd == 'None':
passwd = program_name
- command = '''
-open -u%s,%s -p21 %s
-set passive-mode off
-cd "%s"
-ls -1 "%s"
-''' % (user, passwd, host, dir, file)
- temp = tempfile.mktemp (program_name)
- f = open (temp, 'w')
- f.write (command)
- f.close ()
- p = os.popen ('lftp -f %s' % temp, 'r')
- s = p.read ()
- status = p.close ()
- return string.split (s[:-1], '\n')
+ ftp = ftplib.FTP (host)
+ ftp.login (user, passwd)
+ ftp.set_pasv (1)
+ ftp.cwd (dir)
+ list = ftp.nlst (file)
+ try:
+ ftp.quit ()
+ except:
+ ftp.close ()
+ return list
def split_url (url):
m = re.match ('([^:/]*)(:)?(/*([^:]*):)?(/*([^@]*)@)?(//([^/]*))?(.*)/(.*)',
if passwd == 'None':
passwd = program_name
- command = '''
-open -u%s,%s -p21 %s
-set passive-mode off
-cd "%s"
-get "%s"
-''' % (user, passwd, host, dir, file)
- temp = tempfile.mktemp (program_name)
- f = open (temp, 'w')
- f.write (command)
- f.close ()
- p = os.popen ('lftp -f %s' % temp, 'r')
- s = p.read ()
- status = p.close ()
+ ftp = ftplib.FTP (host)
+ ftp.login (user, passwd)
+ ftp.set_pasv (1)
+ t = tempfile.mktemp (program_name)
+ try:
+ f = open (t, 'w')
+ ftp.retrbinary ('RETR %s/%s' % (dir, file),
+ lambda x, f=f: f.write (x))
+ f.close ()
+ # huh? Invalid cross-device link
+ # os.rename (t, file)
+ system ('mv %s %s' % (t, file))
+ except:
+ os.remove (t)
+ raise 'Foo'
+ try:
+ ftp.quit ()
+ except:
+ ftp.close ()
+ return list
+
+
def copy_url (url, dir):
os.chdir (dir)
s = "copy_%s ('%s', '%s', '%s', '%s', '%s')" % split_url (url)
def find_latest (url):
- progress (_ ("listing %s...") % url)
+ progress (_ ("Listing `%s'...") % url)
list = map (split_package, list_url (url))
list.sort ()
return join_package (list[-1])
def build (p):
- os.chdir (build_root)
- system ('tar xzf %s/%s.tar.gz' % (release_dir, p))
- os.chdir (p)
- return system ('./configure; make web')
+ tar_ball = p + '.tar.gz'
+ (tar_name, tar_version) = split_package (tar_ball)
+
+ expand = {
+ '%b' : build_root,
+ '%n' : tar_name,
+ '%r' : release_dir,
+ '%v' : version_tuple_to_str (tar_version),
+ '%t' : tar_ball,
+ }
+
+ c = build_command
+ for i in expand.keys ():
+ c = re.sub (i, expand[i], c)
+ return system (c, 1)
(sh, long) = getopt_args (__main__.option_definitions)
try:
- (options, files) = getopt.getopt(sys.argv[1:], sh, long)
+ (options, files) = getopt.getopt (sys.argv[1:], sh, long)
except:
help ()
sys.exit (2)
help ()
elif o == '--buid-root' or o == '-b':
build_root = a
+ elif o == '--command' or o == '-c':
+ build_command = a
+ elif o == '--notify' or o == '-n':
+ notify = a
+ elif o == '--remove-previous' or o == '-r':
+ remove_previous_p = 1
elif o == '--url' or o == '-u':
url = a
elif o == '--verbose' or o == '-V':
if 1:
latest = find_latest (url)
- if os.path.isdir ('%s/%s' % (build_root, latest)):
- progress (_ ("latest is %s") % latest)
+ # if os.path.isdir ('%s/%s' % (build_root, latest)):
+ if os.path.exists ('%s/%s/index.html' % (build_root, latest)):
+ progress (_ ("latest is: %s") % latest)
progress (_ ("relax, %s is up to date" % package_name))
sys.exit (0)
- get_base = url[:string.rindex (url, '/')] + '/' + latest
+ get_base = url[:string.rindex (url, '/')] + '/'
if os.path.isdir (patch_dir):
os.chdir (patch_dir)
- get = get_base + '.diff.tar.gz'
- progress (_ ("fetching %s...") % get)
- copy_url (get, '.')
+ if not os.path.isfile (latest + '.diff.gz'):
+ get = get_base + latest + '.diff.gz'
+ progress (_ ("Fetching `%'s...") % get)
+ copy_url (get, '.')
- if not os.path.isdir (build_dir):
- build_dir = temp_dir
+ if not os.path.isdir (build_root):
+ build_root = temp_dir
+
if not os.path.isdir (release_dir):
release_dir = temp_dir
setup_temp ()
- os.chdir (temp_dir)
- get = get_base + '.tar.gz'
- progress (_ ("fetching %s...") % get)
- copy_url (get, '.')
-
+ os.chdir (release_dir)
+ if not os.path.isfile (latest + '.tar.gz'):
+ get = get_base + latest + '.tar.gz'
+ progress (_ ("Fetching `%s'...") % get)
+ copy_url (get, '.')
+
+ if os.path.isdir (os.path.join (build_root, package_name)):
+ os.chdir (os.path.join (build_root, package_name))
+ previous = os.getcwd ()
+ else:
+ previous = 0
+
+ progress (_ ("Building `%s'...") % latest)
+ os.chdir (build_root)
if not build (latest):
- os.link ('%s/%s package_name' % (package_name, build_root, latest))
- previous = 'hairy'
- if os.path.isdir ('%s/%s' % (build_root, previous)):
- system ('rm -rf %s/%s' % (build_root, previous))
+ if previous and remove_previous_p:
+ system ('rm -rf %s' % os.path.join (build_root, previous))
+ else:
+ if notify:
+ system ('(date; uname -a) | mail -s "%s failed" %s' % (program_name, notify))
+ sys.exit (1)
os.chdir (original_dir)
if release_dir != temp_dir: