bitbake-server 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. #!/usr/bin/env python3
  2. #
  3. # SPDX-License-Identifier: GPL-2.0-only
  4. #
  5. # Copyright (C) 2020 Richard Purdie
  6. #
  7. import os
  8. import sys
  9. import warnings
  10. warnings.simplefilter("default")
  11. import logging
  12. sys.path.insert(0, os.path.join(os.path.dirname(os.path.dirname(sys.argv[0])), 'lib'))
  13. import bb
  14. bb.utils.check_system_locale()
  15. # Users shouldn't be running this code directly
  16. if len(sys.argv) != 11 or not sys.argv[1].startswith("decafbad"):
  17. print("bitbake-server is meant for internal execution by bitbake itself, please don't use it standalone.")
  18. sys.exit(1)
  19. import bb.server.process
  20. lockfd = int(sys.argv[2])
  21. readypipeinfd = int(sys.argv[3])
  22. logfile = sys.argv[4]
  23. lockname = sys.argv[5]
  24. sockname = sys.argv[6]
  25. timeout = float(sys.argv[7])
  26. profile = bool(int(sys.argv[8]))
  27. xmlrpcinterface = (sys.argv[9], int(sys.argv[10]))
  28. if xmlrpcinterface[0] == "None":
  29. xmlrpcinterface = (None, xmlrpcinterface[1])
  30. # Replace standard fds with our own
  31. with open('/dev/null', 'r') as si:
  32. os.dup2(si.fileno(), sys.stdin.fileno())
  33. so = open(logfile, 'a+')
  34. os.dup2(so.fileno(), sys.stdout.fileno())
  35. os.dup2(so.fileno(), sys.stderr.fileno())
  36. # Have stdout and stderr be the same so log output matches chronologically
  37. # and there aren't two seperate buffers
  38. sys.stderr = sys.stdout
  39. logger = logging.getLogger("BitBake")
  40. # Ensure logging messages get sent to the UI as events
  41. handler = bb.event.LogHandler()
  42. logger.addHandler(handler)
  43. bb.server.process.execServer(lockfd, readypipeinfd, lockname, sockname, timeout, xmlrpcinterface, profile)