# search for qmake if qt == "": qm = findqt(cross) else: qm = checkqt(qt) if qm == "": print "ERROR: No suitable Qt installation found." sys.exit(1) # create working folder. Use current directory if -p option used. if proj == "": w = tempfile.mkdtemp() # make sure the path doesn't contain backslashes to prevent issues # later when running on windows. workfolder = re.sub(r'\\', '/', w) revision = gitscraper.describe_treehash(gitrepo, treehash) # try to find a version number from describe output. # WARNING: this is broken and just a temporary workaround! v = re.findall('([\d\.a-f]+)', revision) if v: if v[-1].find('.') >= 0: revision = "v" + v[-1] else: revision = v[-1] if buildid == None: versionextra = "" else: versionextra = "-" + buildid sourcefolder = workfolder + "/" + program + "-" + str( revision) + versionextra + "/" archivename = program + "-" + str(
def deploy(): startup = time.time() try: opts, args = getopt.getopt(sys.argv[1:], "q:p:t:a:n:sbdkx:i:h", [ "qmake=", "project=", "tag=", "add=", "makensis=", "source-only", "binary-only", "dynamic", "keep-temp", "cross=", "buildid=", "help" ]) except getopt.GetoptError as err: print(str(err)) usage(sys.argv[0]) sys.exit(1) qt = "" proj = "" svnbase = svnserver + "trunk/" tag = "" addfiles = [] cleanup = True binary = True source = True keeptemp = False makensis = "" cross = "" buildid = None platform = sys.platform treehash = gitscraper.get_refs(gitrepo)['refs/remotes/origin/HEAD'] if sys.platform != "darwin": static = True else: static = False for o, a in opts: if o in ("-q", "--qmake"): qt = a if o in ("-p", "--project"): proj = a cleanup = False if o in ("-a", "--add"): addfiles.append(a) if o in ("-n", "--makensis"): makensis = a if o in ("-s", "--source-only"): binary = False if o in ("-b", "--binary-only"): source = False if o in ("-d", "--dynamic") and sys.platform != "darwin": static = False if o in ("-k", "--keep-temp"): keeptemp = True if o in ("-t", "--tree"): treehash = a if o in ("-x", "--cross") and sys.platform != "win32": cross = a platform = "win32" if o in ("-i", "--buildid"): buildid = a if o in ("-h", "--help"): usage(sys.argv[0]) sys.exit(0) if source == False and binary == False: print( "Building build neither source nor binary means nothing to do. Exiting." ) sys.exit(1) print("Building " + progexe[platform] + " for " + platform) # search for qmake if qt == "": qm = findqt(cross) else: qm = checkqt(qt) if qm == "": print("ERROR: No suitable Qt installation found.") sys.exit(1) # create working folder. Use current directory if -p option used. if proj == "": w = tempfile.mkdtemp() # make sure the path doesn't contain backslashes to prevent issues # later when running on windows. workfolder = re.sub(r'\\', '/', w) revision = gitscraper.describe_treehash(gitrepo, treehash) # try to find a version number from describe output. # WARNING: this is broken and just a temporary workaround! v = re.findall(b'([\d\.a-f]+)', revision) if v: if v[-1].decode().find('.') >= 0: revision = "v" + v[-1].decode() else: revision = v[-1].decode() if buildid == None: versionextra = "" else: versionextra = "-" + buildid sourcefolder = workfolder + "/" + program + "-" + str( revision) + versionextra + "/" archivename = program + "-" + str( revision) + versionextra + "-src.tar.bz2" ver = str(revision) os.mkdir(sourcefolder) print("Version: %s" % revision) else: workfolder = "." sourcefolder = "." archivename = "" # check if project file explicitly given. If yes, don't get sources from svn if proj == "": proj = sourcefolder + project # get sources and pack source tarball if getsources(treehash, svnpaths, sourcefolder) != 0: tempclean(workfolder, cleanup and not keeptemp) sys.exit(1) # replace version strings. print("Updating version information in sources") for f in regreplace: infile = open(sourcefolder + "/" + f, "r") incontents = infile.readlines() infile.close() outfile = open(sourcefolder + "/" + f, "w") for line in incontents: newline = line for r in regreplace[f]: # replacements made on the replacement string: # %REVISION% is replaced with the revision number replacement = re.sub("%REVISION%", str(revision), r[1]) newline = re.sub(r[0], replacement, newline) # %BUILD% is replaced with buildid as passed on the command line if buildid != None: replacement = re.sub("%BUILDID%", "-" + str(buildid), replacement) else: replacement = re.sub("%BUILDID%", "", replacement) newline = re.sub(r[0], replacement, newline) outfile.write(newline) outfile.close() if source == True: print("Creating source tarball %s\n" % archivename) tf = tarfile.open(archivename, mode='w:bz2') tf.add(sourcefolder, os.path.basename(re.subn('/$', '', sourcefolder)[0])) tf.close() if binary == False: shutil.rmtree(workfolder) sys.exit(0) else: # figure version from sources. Need to take path to project file into account. versionfile = re.subn('[\w\.]+$', "version.h", proj)[0] ver = findversion(versionfile) + "-dev" + datetime.now().strftime( '%Y%m%d%H%M%S') # append buildid if any. if buildid != None: ver += "-" + buildid # check project file if not os.path.exists(proj): print("ERROR: path to project file wrong.") sys.exit(1) # copy specified (--add) files to working folder for f in addfiles: shutil.copy(f, sourcefolder) buildstart = time.time() header = "Building %s %s" % (program, ver) print(header) print(len(header) * "=") # build it. if not qmake(qm, proj, platform, sourcefolder, static, cross) == 0: tempclean(workfolder, cleanup and not keeptemp) sys.exit(1) if not build(sourcefolder, platform, cross) == 0: tempclean(workfolder, cleanup and not keeptemp) sys.exit(1) buildtime = time.time() - buildstart progfiles = programfiles progfiles.append(progexe[platform]) if platform == "win32": if useupx == True: if not upxfile(sourcefolder, platform) == 0: tempclean(workfolder, cleanup and not keeptemp) sys.exit(1) dllfiles = finddlls(sourcefolder + "/" + progexe[platform], \ [os.path.dirname(qm)], cross) if len(dllfiles) > 0: progfiles.extend(dllfiles) archive = zipball(progfiles, ver, sourcefolder, platform) # only when running native right now. if nsisscript != "" and makensis != "": nsisfileinject(sourcefolder + "/" + nsisscript, sourcefolder \ + "/" + nsisscript + ".tmp", dllfiles) runnsis(ver, makensis, nsisscript + ".tmp", sourcefolder) elif platform == "darwin": archive = macdeploy(ver, sourcefolder, platform) else: if platform in ['linux', 'linux2']: for p in progfiles: prog = sourcefolder + "/" + p output = subprocess.Popen(["file", prog], stdout=subprocess.PIPE) res = output.communicate() if re.findall("ELF 64-bit", res[0]): ver += "-64bit" break archive = tarball(progfiles, ver, sourcefolder) # remove temporary files tempclean(workfolder, cleanup) # display summary headline = "Build Summary for %s" % program print("\n%s\n%s" % (headline, "=" * len(headline))) if archivename != "": filestats(archivename) filestats(archive) duration = time.time() - startup durmins = (int)(duration / 60) dursecs = (int)(duration % 60) buildmins = (int)(buildtime / 60) buildsecs = (int)(buildtime % 60) print("Overall time %smin %ssec, building took %smin %ssec." % \ (durmins, dursecs, buildmins, buildsecs))
# search for qmake if qt == "": qm = findqt(cross) else: qm = checkqt(qt) if qm == "": print "ERROR: No suitable Qt installation found." sys.exit(1) # create working folder. Use current directory if -p option used. if proj == "": w = tempfile.mkdtemp() # make sure the path doesn't contain backslashes to prevent issues # later when running on windows. workfolder = re.sub(r'\\', '/', w) revision = gitscraper.describe_treehash(gitrepo, treehash) # try to find a version number from describe output. # WARNING: this is broken and just a temporary workaround! v = re.findall('([\d\.a-f]+)', revision) if v: if v[-1].find('.') >= 0: revision = "v" + v[-1] else: revision = v[-1] if buildid == None: versionextra = "" else: versionextra = "-" + buildid sourcefolder = workfolder + "/" + program + "-" + str(revision) + versionextra + "/" archivename = program + "-" + str(revision) + versionextra + "-src.tar.bz2" ver = str(revision)