lutin/lutinTargetLinux.py

109 lines
5.0 KiB
Python
Raw Normal View History

#!/usr/bin/python
import lutinDebug as debug
import lutinTarget
import lutinTools
import os
import stat
2013-08-27 21:11:03 +02:00
import lutinMultiprocess
class Target(lutinTarget.Target):
def __init__(self, typeCompilator, debugMode, generatePackage):
lutinTarget.Target.__init__(self, "Linux", typeCompilator, debugMode, generatePackage, "", "")
2013-12-23 22:22:24 +01:00
def generate_list_separate_coma(self, list):
result = ""
fistTime = True
for elem in list:
if fistTime == True:
fistTime = False
else:
result += ","
result += elem
return result
2013-12-23 22:22:24 +01:00
def make_package(self, pkgName, pkgProperties, basePkgPath):
# http://alp.developpez.com/tutoriels/debian/creer-paquet/
debug.debug("------------------------------------------------------------------------")
2013-04-26 22:17:09 +02:00
debug.info("Generate package '" + pkgName + "' v"+pkgProperties["VERSION"])
debug.debug("------------------------------------------------------------------------")
2013-12-23 22:22:24 +01:00
self.get_staging_folder(pkgName)
targetOutFolderDebian=self.get_staging_folder(pkgName) + "/DEBIAN/"
finalFileControl = targetOutFolderDebian + "control"
finalFilepostRm = targetOutFolderDebian + "postrm"
# create the folders :
2013-12-23 22:22:24 +01:00
lutinTools.create_directory_of_file(finalFileControl)
lutinTools.create_directory_of_file(finalFilepostRm)
## Create the control file
tmpFile = open(finalFileControl, 'w')
tmpFile.write("Package: " + pkgName + "\n")
tmpFile.write("Version: " + pkgProperties["VERSION"] + "\n")
2013-12-23 22:22:24 +01:00
tmpFile.write("Section: " + self.generate_list_separate_coma(pkgProperties["SECTION"]) + "\n")
tmpFile.write("Priority: " + pkgProperties["PRIORITY"] + "\n")
tmpFile.write("Architecture: all\n")
tmpFile.write("Depends: bash\n")
2013-12-23 22:22:24 +01:00
tmpFile.write("Maintainer: " + self.generate_list_separate_coma(pkgProperties["MAINTAINER"]) + "\n")
tmpFile.write("Description: " + pkgProperties["DESCRIPTION"] + "\n")
tmpFile.write("\n")
tmpFile.flush()
tmpFile.close()
## Create the PostRm
tmpFile = open(finalFilepostRm, 'w')
tmpFile.write("#!/bin/bash\n")
tmpFile.write("touch ~/." + pkgName + "\n")
if pkgName != "":
tmpFile.write("touch ~/.local/share/" + pkgName + "\n")
tmpFile.write("rm -r ~/.local/share/" + pkgName + "\n")
tmpFile.write("\n")
tmpFile.flush()
tmpFile.close()
## Enable Execution in script
os.chmod(finalFilepostRm, stat.S_IRWXU + stat.S_IRGRP + stat.S_IXGRP + stat.S_IROTH + stat.S_IXOTH);
2013-08-27 21:11:03 +02:00
## Readme donumentation
2013-12-23 22:22:24 +01:00
readmeFileDest = self.get_staging_folder(pkgName) + "/usr/share/doc/"+ pkgName + "/README"
2013-09-19 09:19:01 +02:00
if os.path.exists(basePkgPath + "/os-Linux/README")==True:
2013-12-23 22:22:24 +01:00
lutinTools.copy_file(basePkgPath + "/os-Linux/README", readmeFileDest)
2013-09-19 09:19:01 +02:00
elif os.path.exists(basePkgPath + "/README")==True:
2013-12-23 22:22:24 +01:00
lutinTools.copy_file(basePkgPath + "/README", readmeFileDest)
2013-09-19 09:19:01 +02:00
elif os.path.exists(basePkgPath + "/README.md")==True:
2013-12-23 22:22:24 +01:00
lutinTools.copy_file(basePkgPath + "/README.md", readmeFileDest)
2013-08-27 21:11:03 +02:00
else:
debug.info("no file 'README', 'README.md' or 'os-Linux/README' ==> generate an empty one")
tmpFile = open(readmeFileDest, 'w')
tmpFile.write("No documentation for " + pkgName + "\n")
tmpFile.flush()
tmpFile.close()
## licence file
2013-12-23 22:22:24 +01:00
licenseFileDest = self.get_staging_folder(pkgName) + "/usr/share/doc/"+ pkgName + "/copyright"
2013-09-19 09:19:01 +02:00
if os.path.exists(basePkgPath + "/license.txt")==True:
2013-12-23 22:22:24 +01:00
lutinTools.copy_file(basePkgPath + "/license.txt", licenseFileDest)
2013-08-27 21:11:03 +02:00
else:
debug.info("no file 'license.txt' ==> generate an empty one")
tmpFile = open(licenseFileDest, 'w')
tmpFile.write("No license define by the developper for " + pkgName + "\n")
tmpFile.flush()
tmpFile.close()
##changeLog file
2013-12-23 22:22:24 +01:00
changeLogFileDest = self.get_staging_folder(pkgName) + "/usr/share/doc/"+ pkgName + "/changelog"
2013-09-19 09:19:01 +02:00
if os.path.exists(basePkgPath + "/changelog")==True:
2013-12-23 22:22:24 +01:00
lutinTools.copy_file(basePkgPath + "/changelog", changeLogFileDest)
2013-08-27 21:11:03 +02:00
else:
debug.info("no file 'changelog' ==> generate an empty one")
2013-12-23 22:22:24 +01:00
lutinMultiprocess.run_command("git log > " + changeLogFileDest)
2013-08-27 21:11:03 +02:00
## create the package :
2013-12-23 22:22:24 +01:00
debug.debug("pachage : " + self.get_staging_folder(pkgName) + "/" + pkgName + ".deb")
os.system("cd " + self.get_staging_folder("") + " ; dpkg-deb --build " + pkgName)
lutinTools.create_directory_of_file(self.get_final_folder())
lutinTools.copy_file(self.get_staging_folder("") + "/" + pkgName + self.suffix_package, self.get_final_folder() + "/" + pkgName + self.suffix_package)
2013-12-23 22:22:24 +01:00
def install_package(self, pkgName):
debug.debug("------------------------------------------------------------------------")
debug.info("Install package '" + pkgName + "'")
debug.debug("------------------------------------------------------------------------")
2013-12-23 22:22:24 +01:00
os.system("sudo dpkg -i " + self.get_final_folder() + "/" + pkgName + self.suffix_package)
2013-12-23 22:22:24 +01:00
def un_install_package(self, pkgName):
debug.debug("------------------------------------------------------------------------")
debug.info("Un-Install package '" + pkgName + "'")
debug.debug("------------------------------------------------------------------------")
2013-12-23 22:22:24 +01:00
os.system("sudo dpkg -r " + self.get_final_folder() + "/" + pkgName + self.suffix_package)