xref: /OK3568_Linux_fs/yocto/bitbake/bin/bitbake-server (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun#!/usr/bin/env python3
2*4882a593Smuzhiyun#
3*4882a593Smuzhiyun# SPDX-License-Identifier: GPL-2.0-only
4*4882a593Smuzhiyun#
5*4882a593Smuzhiyun# Copyright (C) 2020        Richard Purdie
6*4882a593Smuzhiyun#
7*4882a593Smuzhiyun
8*4882a593Smuzhiyunimport os
9*4882a593Smuzhiyunimport sys
10*4882a593Smuzhiyunimport warnings
11*4882a593Smuzhiyunwarnings.simplefilter("default")
12*4882a593Smuzhiyunimport logging
13*4882a593Smuzhiyunsys.path.insert(0, os.path.join(os.path.dirname(os.path.dirname(sys.argv[0])), 'lib'))
14*4882a593Smuzhiyun
15*4882a593Smuzhiyunif sys.getfilesystemencoding() != "utf-8":
16*4882a593Smuzhiyun    sys.exit("Please use a locale setting which supports UTF-8 (such as LANG=en_US.UTF-8).\nPython can't change the filesystem locale after loading so we need a UTF-8 when Python starts or things won't work.")
17*4882a593Smuzhiyun
18*4882a593Smuzhiyun# Users shouldn't be running this code directly
19*4882a593Smuzhiyunif len(sys.argv) != 10 or not sys.argv[1].startswith("decafbad"):
20*4882a593Smuzhiyun    print("bitbake-server is meant for internal execution by bitbake itself, please don't use it standalone.")
21*4882a593Smuzhiyun    sys.exit(1)
22*4882a593Smuzhiyun
23*4882a593Smuzhiyunimport bb.server.process
24*4882a593Smuzhiyun
25*4882a593Smuzhiyunlockfd = int(sys.argv[2])
26*4882a593Smuzhiyunreadypipeinfd = int(sys.argv[3])
27*4882a593Smuzhiyunlogfile = sys.argv[4]
28*4882a593Smuzhiyunlockname = sys.argv[5]
29*4882a593Smuzhiyunsockname = sys.argv[6]
30*4882a593Smuzhiyuntimeout = float(sys.argv[7])
31*4882a593Smuzhiyunxmlrpcinterface = (sys.argv[8], int(sys.argv[9]))
32*4882a593Smuzhiyunif xmlrpcinterface[0] == "None":
33*4882a593Smuzhiyun    xmlrpcinterface = (None, xmlrpcinterface[1])
34*4882a593Smuzhiyun
35*4882a593Smuzhiyun# Replace standard fds with our own
36*4882a593Smuzhiyunwith open('/dev/null', 'r') as si:
37*4882a593Smuzhiyun    os.dup2(si.fileno(), sys.stdin.fileno())
38*4882a593Smuzhiyun
39*4882a593Smuzhiyunso = open(logfile, 'a+')
40*4882a593Smuzhiyunos.dup2(so.fileno(), sys.stdout.fileno())
41*4882a593Smuzhiyunos.dup2(so.fileno(), sys.stderr.fileno())
42*4882a593Smuzhiyun
43*4882a593Smuzhiyun# Have stdout and stderr be the same so log output matches chronologically
44*4882a593Smuzhiyun# and there aren't two seperate buffers
45*4882a593Smuzhiyunsys.stderr = sys.stdout
46*4882a593Smuzhiyun
47*4882a593Smuzhiyunlogger = logging.getLogger("BitBake")
48*4882a593Smuzhiyun# Ensure logging messages get sent to the UI as events
49*4882a593Smuzhiyunhandler = bb.event.LogHandler()
50*4882a593Smuzhiyunlogger.addHandler(handler)
51*4882a593Smuzhiyun
52*4882a593Smuzhiyunbb.server.process.execServer(lockfd, readypipeinfd, lockname, sockname, timeout, xmlrpcinterface)
53*4882a593Smuzhiyun
54