import logging
import signal
+import sys
import time
import bb
import bb.event
from bb.cooker import BBCooker
logger = logging.getLogger('BitBake')
+NULL = open('/dev/null', 'a')
class ServerCommunicator():
def __init__(self, connection):
self._idlefunctions[function] = data
def run(self):
+ """Run the server, killing off stdin/stdout/stderr"""
+ with bb.utils.redirected_fds([sys.stdin, sys.stdout, sys.stderr],
+ [NULL, NULL, NULL]):
+ return self.main()
+
+ def main(self):
+ """Server main loop"""
# Ensure logging messages get sent to the UI as events
logger.addHandler(bb.event.LogHandler())
self.event_queue.cancel_join_thread()
bb.event.unregister_UIHhandler(self.event_handle)
self.command_channel.close()
- return
def idle_commands(self, delay):
nextsleep = delay
if debug_domains:
bb.msg.set_debug_domains(debug_domains)
+
+@contextmanager
+def redirected_fds(from_files, to_files):
+ assert len(from_files) == len(to_files), 'from_files / to_files length mismatch'
+
+ old_fds = []
+ for position, fobj in enumerate(from_files):
+ fd = fobj.fileno()
+ old_fds.append(os.dup(fd))
+ os.dup2(to_files[position].fileno(), fd)
+
+ yield
+
+ for position, fd in enumerate(old_fds):
+ os.dup2(fd, from_files[position].fileno())