build.py 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. import os
  2. import subprocess
  3. import sys
  4. from ..utils.compat import decode
  5. from ..utils.deps import APPIMAGETOOL, ensure_appimagetool
  6. from ..utils.docker import docker_run
  7. from ..utils.fs import copy_tree
  8. from ..utils.log import debug, log
  9. from ..utils.tmp import TemporaryDirectory
  10. __all__ = ['build_appimage']
  11. def build_appimage(appdir=None, destination=None):
  12. '''Build an AppImage from an AppDir
  13. '''
  14. if appdir is None:
  15. appdir = 'AppDir'
  16. log('BUILD', appdir)
  17. ensure_appimagetool()
  18. cmd = [APPIMAGETOOL, appdir]
  19. if destination is not None:
  20. cmd.append(destination)
  21. cmd = ' '.join(cmd)
  22. debug('SYSTEM', cmd)
  23. p = subprocess.Popen(cmd, shell=True, stdout=subprocess.PIPE,
  24. stderr=subprocess.STDOUT)
  25. stdout = []
  26. while True:
  27. out = decode(p.stdout.readline())
  28. stdout.append(out)
  29. if out == '' and p.poll() is not None:
  30. break
  31. elif out:
  32. out = out.replace('%', '%%')[:-1]
  33. for line in out.split(os.linesep):
  34. if line.startswith('WARNING'):
  35. log('WARNING', line[9:])
  36. elif line.startswith('Error'):
  37. raise RuntimeError(line)
  38. else:
  39. debug('APPIMAGE', line)
  40. rc = p.poll()
  41. if rc != 0:
  42. print(''.join(stdout))
  43. sys.stdout.flush()
  44. raise RuntimeError('Could not build AppImage')