Attempt to make skydb more user-friendly

Automatically shut-down the sky_server when quitting.
Always start the skyserver at the mojo-root
instead of the parent directory to the path.
Log when starting a sky_server outside the mojo root.
Re-use already running sky_servers when possible.

R=esprehn@chromium.org, abarth@chromium.org

Review URL: https://codereview.chromium.org/679333005
This commit is contained in:
Eric Seidel 2014-10-31 10:32:31 -07:00
parent 3687a4515b
commit 3d7beea154

View File

@ -8,13 +8,16 @@ import os
import subprocess import subprocess
import sys import sys
import urlparse import urlparse
import logging
import socket;
BUILD_DIRECTORY = 'out' OUT_DIR = 'out'
CONFIG_DIRECTORY = 'Debug' CONFIG_NAME = 'Debug'
SKY_TOOLS_DIRECTORY = os.path.abspath(os.path.join(__file__, os.pardir)) SKY_TOOLS_DIRECTORY = os.path.abspath(os.path.join(__file__, os.pardir))
MOJO_SHELL_PATH = os.path.abspath(os.path.join(SKY_TOOLS_DIRECTORY, os.pardir, MOJO_ROOT = os.path.abspath(os.path.join(SKY_TOOLS_DIRECTORY, os.pardir,
os.pardir, BUILD_DIRECTORY, CONFIG_DIRECTORY, 'mojo_shell')) os.pardir))
MOJO_SHELL_PATH = os.path.join(MOJO_ROOT, OUT_DIR, CONFIG_NAME, 'mojo_shell')
SUPPORTED_MIME_TYPES = [ SUPPORTED_MIME_TYPES = [
'text/html', 'text/html',
@ -22,47 +25,77 @@ SUPPORTED_MIME_TYPES = [
'text/plain', 'text/plain',
] ]
def start_http_server_for_file(path): class SkyDebugger(object):
HTTP_PORT = 9999 @staticmethod
server_command = [ def _port_in_use(port):
os.path.join(SKY_TOOLS_DIRECTORY, 'sky_server'), sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
os.path.dirname(os.path.abspath(path)), return sock.connect_ex(('localhost', port)) == 0
str(HTTP_PORT),
]
subprocess.Popen(server_command)
return 'http://localhost:%s/%s' % (HTTP_PORT, os.path.basename(path))
def _start_http_server_for_file(self, path):
HTTP_PORT = 9999
def main(): path = os.path.abspath(path)
parser = argparse.ArgumentParser(description='Sky launcher/debugger') if os.path.commonprefix([path, MOJO_ROOT]) == MOJO_ROOT:
parser.add_argument('--gdb', action='store_true') server_root = MOJO_ROOT
parser.add_argument('url', nargs='?', type=str) else:
args = parser.parse_args() server_root = os.path.dirname(path)
logging.warn(
'%s is outside of mojo root, using %s as server root' %
(path, server_root))
relative_path = os.path.relpath(path, server_root)
content_handlers = ['%s,%s' % (mime_type, 'mojo://sky_viewer/') if self._port_in_use(HTTP_PORT):
for mime_type in SUPPORTED_MIME_TYPES] logging.warn(
shell_command = [ 'Port %s already in use, assuming custom sky_server started.')
MOJO_SHELL_PATH, else:
'--v=1', server_command = [
'--content-handlers=%s' % ','.join(content_handlers), os.path.join(SKY_TOOLS_DIRECTORY, 'sky_server'),
'--url-mappings=mojo:window_manager=mojo:sky_debugger', server_root,
'mojo:window_manager', str(HTTP_PORT),
] ]
if args.url: self._sky_server = subprocess.Popen(server_command)
url = args.url return 'http://localhost:%s/%s' % (HTTP_PORT, relative_path)
if not urlparse.urlparse(url).scheme:
url = start_http_server_for_file(url)
prompt_args = '--args-for=mojo://sky_debugger_prompt/ %s' % url def main(self):
shell_command.append(prompt_args) logging.basicConfig(level=logging.INFO)
if args.gdb:
shell_command = ['gdb', '--args'] + shell_command
subprocess.check_call(shell_command) parser = argparse.ArgumentParser(description='Sky launcher/debugger')
parser.add_argument('--gdb', action='store_true')
parser.add_argument('url', nargs='?', type=str)
args = parser.parse_args()
content_handlers = ['%s,%s' % (mime_type, 'mojo://sky_viewer/')
for mime_type in SUPPORTED_MIME_TYPES]
shell_command = [
MOJO_SHELL_PATH,
'--v=1',
'--content-handlers=%s' % ','.join(content_handlers),
'--url-mappings=mojo:window_manager=mojo:sky_debugger',
'mojo:window_manager',
]
if args.url:
url = args.url
if not urlparse.urlparse(url).scheme:
url = self._start_http_server_for_file(url)
prompt_args = '--args-for=mojo://sky_debugger_prompt/ %s' % url
shell_command.append(prompt_args)
if args.gdb:
shell_command = ['gdb', '--args'] + shell_command
subprocess.check_call(shell_command)
def shutdown(self):
print "Quitting"
if self._sky_server:
self._sky_server.terminate()
if __name__ == '__main__': if __name__ == '__main__':
skydb = SkyDebugger()
try: try:
main() skydb.main()
except (KeyboardInterrupt, SystemExit): except (KeyboardInterrupt, SystemExit):
print "Quitting" pass
finally:
skydb.shutdown()