diff options
-rwxr-xr-x | bitbake/bin/bitbake | 6 | ||||
-rw-r--r-- | bitbake/lib/bb/server/none.py | 203 |
2 files changed, 3 insertions, 206 deletions
diff --git a/bitbake/bin/bitbake b/bitbake/bin/bitbake index ac35b94e3b..a868557a1a 100755 --- a/bitbake/bin/bitbake +++ b/bitbake/bin/bitbake | |||
@@ -167,7 +167,7 @@ class BitBakeConfigParameters(cookerdata.ConfigParameters): | |||
167 | parser.add_option("-u", "--ui", help = "userinterface to use", | 167 | parser.add_option("-u", "--ui", help = "userinterface to use", |
168 | action = "store", dest = "ui") | 168 | action = "store", dest = "ui") |
169 | 169 | ||
170 | parser.add_option("-t", "--servertype", help = "Choose which server to use, none, process or xmlrpc", | 170 | parser.add_option("-t", "--servertype", help = "Choose which server to use, process or xmlrpc", |
171 | action = "store", dest = "servertype") | 171 | action = "store", dest = "servertype") |
172 | 172 | ||
173 | parser.add_option("", "--revisions-changed", help = "Set the exit code depending on whether upstream floating revisions have changed or not", | 173 | parser.add_option("", "--revisions-changed", help = "Set the exit code depending on whether upstream floating revisions have changed or not", |
@@ -191,7 +191,7 @@ def main(): | |||
191 | 191 | ||
192 | ui_main = get_ui(configuration) | 192 | ui_main = get_ui(configuration) |
193 | 193 | ||
194 | # Server type can be xmlrpc, process or none currently, if nothing is specified, | 194 | # Server type can be xmlrpc or process currently, if nothing is specified, |
195 | # the default server is process | 195 | # the default server is process |
196 | if configParams.servertype: | 196 | if configParams.servertype: |
197 | server_type = configParams.servertype | 197 | server_type = configParams.servertype |
@@ -203,7 +203,7 @@ def main(): | |||
203 | server = getattr(module, server_type) | 203 | server = getattr(module, server_type) |
204 | except AttributeError: | 204 | except AttributeError: |
205 | sys.exit("FATAL: Invalid server type '%s' specified.\n" | 205 | sys.exit("FATAL: Invalid server type '%s' specified.\n" |
206 | "Valid interfaces: xmlrpc, process [default], none." % servertype) | 206 | "Valid interfaces: xmlrpc, process [default]." % servertype) |
207 | 207 | ||
208 | if configParams.server_only: | 208 | if configParams.server_only: |
209 | if configParams.servertype != "xmlrpc": | 209 | if configParams.servertype != "xmlrpc": |
diff --git a/bitbake/lib/bb/server/none.py b/bitbake/lib/bb/server/none.py deleted file mode 100644 index f5fd4d4f7b..0000000000 --- a/bitbake/lib/bb/server/none.py +++ /dev/null | |||
@@ -1,203 +0,0 @@ | |||
1 | # | ||
2 | # BitBake 'dummy' Passthrough Server | ||
3 | # | ||
4 | # Copyright (C) 2006 - 2007 Michael 'Mickey' Lauer | ||
5 | # Copyright (C) 2006 - 2008 Richard Purdie | ||
6 | # | ||
7 | # This program is free software; you can redistribute it and/or modify | ||
8 | # it under the terms of the GNU General Public License version 2 as | ||
9 | # published by the Free Software Foundation. | ||
10 | # | ||
11 | # This program is distributed in the hope that it will be useful, | ||
12 | # but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
13 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
14 | # GNU General Public License for more details. | ||
15 | # | ||
16 | # You should have received a copy of the GNU General Public License along | ||
17 | # with this program; if not, write to the Free Software Foundation, Inc., | ||
18 | # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | ||
19 | |||
20 | """ | ||
21 | This module implements a passthrough server for BitBake. | ||
22 | |||
23 | Use register_idle_function() to add a function which the server | ||
24 | calls from within idle_commands when no requests are pending. Make sure | ||
25 | that those functions are non-blocking or else you will introduce latency | ||
26 | in the server's main loop. | ||
27 | """ | ||
28 | |||
29 | import time | ||
30 | import bb | ||
31 | import signal | ||
32 | |||
33 | DEBUG = False | ||
34 | |||
35 | import inspect, select | ||
36 | |||
37 | class BitBakeServerCommands(): | ||
38 | def __init__(self, server): | ||
39 | self.server = server | ||
40 | |||
41 | def runCommand(self, command): | ||
42 | """ | ||
43 | Run a cooker command on the server | ||
44 | """ | ||
45 | #print "Running Command %s" % command | ||
46 | return self.cooker.command.runCommand(command) | ||
47 | |||
48 | def terminateServer(self): | ||
49 | """ | ||
50 | Trigger the server to quit | ||
51 | """ | ||
52 | self.server.server_exit() | ||
53 | #print "Server (cooker) exitting" | ||
54 | return | ||
55 | |||
56 | def ping(self): | ||
57 | """ | ||
58 | Dummy method which can be used to check the server is still alive | ||
59 | """ | ||
60 | return True | ||
61 | |||
62 | eventQueue = [] | ||
63 | |||
64 | class BBUIEventQueue: | ||
65 | class event: | ||
66 | def __init__(self, parent): | ||
67 | self.parent = parent | ||
68 | @staticmethod | ||
69 | def send(event): | ||
70 | bb.server.none.eventQueue.append(event) | ||
71 | @staticmethod | ||
72 | def quit(): | ||
73 | return | ||
74 | |||
75 | def __init__(self, BBServer): | ||
76 | self.eventQueue = bb.server.none.eventQueue | ||
77 | self.BBServer = BBServer | ||
78 | self.EventHandle = bb.event.register_UIHhandler(self) | ||
79 | |||
80 | def __popEvent(self): | ||
81 | if len(self.eventQueue) == 0: | ||
82 | return None | ||
83 | return self.eventQueue.pop(0) | ||
84 | |||
85 | def getEvent(self): | ||
86 | if len(self.eventQueue) == 0: | ||
87 | self.BBServer.idle_commands(0) | ||
88 | return self.__popEvent() | ||
89 | |||
90 | def waitEvent(self, delay): | ||
91 | event = self.__popEvent() | ||
92 | if event: | ||
93 | return event | ||
94 | self.BBServer.idle_commands(delay) | ||
95 | return self.__popEvent() | ||
96 | |||
97 | def queue_event(self, event): | ||
98 | self.eventQueue.append(event) | ||
99 | |||
100 | def system_quit( self ): | ||
101 | bb.event.unregister_UIHhandler(self.EventHandle) | ||
102 | |||
103 | # Dummy signal handler to ensure we break out of sleep upon SIGCHLD | ||
104 | def chldhandler(signum, stackframe): | ||
105 | pass | ||
106 | |||
107 | class BitBakeNoneServer(): | ||
108 | # remove this when you're done with debugging | ||
109 | # allow_reuse_address = True | ||
110 | |||
111 | def __init__(self): | ||
112 | self._idlefuns = {} | ||
113 | self.commands = BitBakeServerCommands(self) | ||
114 | |||
115 | def addcooker(self, cooker): | ||
116 | self.cooker = cooker | ||
117 | self.commands.cooker = cooker | ||
118 | |||
119 | def register_idle_function(self, function, data): | ||
120 | """Register a function to be called while the server is idle""" | ||
121 | assert hasattr(function, '__call__') | ||
122 | self._idlefuns[function] = data | ||
123 | |||
124 | def idle_commands(self, delay): | ||
125 | #print "Idle queue length %s" % len(self._idlefuns) | ||
126 | #print "Idle timeout, running idle functions" | ||
127 | #if len(self._idlefuns) == 0: | ||
128 | nextsleep = delay | ||
129 | for function, data in self._idlefuns.items(): | ||
130 | try: | ||
131 | retval = function(self, data, False) | ||
132 | #print "Idle function returned %s" % (retval) | ||
133 | if retval is False: | ||
134 | del self._idlefuns[function] | ||
135 | elif retval is True: | ||
136 | nextsleep = None | ||
137 | elif nextsleep is None: | ||
138 | continue | ||
139 | elif retval < nextsleep: | ||
140 | nextsleep = retval | ||
141 | except SystemExit: | ||
142 | raise | ||
143 | except: | ||
144 | import traceback | ||
145 | traceback.print_exc() | ||
146 | self.commands.runCommand(["stateShutdown"]) | ||
147 | pass | ||
148 | if nextsleep is not None: | ||
149 | #print "Sleeping for %s (%s)" % (nextsleep, delay) | ||
150 | signal.signal(signal.SIGCHLD, chldhandler) | ||
151 | time.sleep(nextsleep) | ||
152 | signal.signal(signal.SIGCHLD, signal.SIG_DFL) | ||
153 | |||
154 | def server_exit(self): | ||
155 | # Tell idle functions we're exiting | ||
156 | for function, data in self._idlefuns.items(): | ||
157 | try: | ||
158 | retval = function(self, data, True) | ||
159 | except: | ||
160 | pass | ||
161 | |||
162 | class BitBakeServerConnection(): | ||
163 | def __init__(self, server): | ||
164 | self.server = server.server | ||
165 | self.connection = self.server.commands | ||
166 | self.events = bb.server.none.BBUIEventQueue(self.server) | ||
167 | for event in bb.event.ui_queue: | ||
168 | self.events.queue_event(event) | ||
169 | |||
170 | def terminate(self): | ||
171 | try: | ||
172 | self.events.system_quit() | ||
173 | except: | ||
174 | pass | ||
175 | try: | ||
176 | self.connection.terminateServer() | ||
177 | except: | ||
178 | pass | ||
179 | |||
180 | class BitBakeServer(object): | ||
181 | def initServer(self): | ||
182 | self.server = BitBakeNoneServer() | ||
183 | |||
184 | def addcooker(self, cooker): | ||
185 | self.cooker = cooker | ||
186 | self.server.addcooker(cooker) | ||
187 | |||
188 | def getServerIdleCB(self): | ||
189 | return self.server.register_idle_function | ||
190 | |||
191 | def saveConnectionDetails(self): | ||
192 | return | ||
193 | |||
194 | def detach(self): | ||
195 | return | ||
196 | |||
197 | def establishConnection(self): | ||
198 | self.connection = BitBakeServerConnection(self) | ||
199 | return self.connection | ||
200 | |||
201 | def launchUI(self, uifunc, *args): | ||
202 | return bb.cooker.server_main(self.cooker, uifunc, *args) | ||
203 | |||