blob: f3e5379d0517f9ba9a692010d44c8a646a95f8a9 [file] [log] [blame]
// Copyright (c) 2016, the Dart project authors. Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
import 'dart:io' as io;
import 'package:args/args.dart';
import 'log/log.dart';
import 'server.dart';
/// Start a web server that will allow an instrumentation log to be viewed.
void main(List<String> args) {
var driver = Driver();
driver.start(args);
}
/// The main driver that configures and starts the web server.
class Driver {
/// The flag used to specify that the user wants to have help text printed but
/// that no other work should be done.
static String helpFlag = 'help';
/// The option used to specify the port on which the server should listen for
/// requests.
static String portOption = 'port';
/// The port that will be used if no port number is provided on the command
/// line.
static int defaultPortNumber = 11000;
/// Initialize a newly created driver.
Driver();
/// Create and return the parser used to parse the command-line arguments.
ArgParser createParser() {
var parser = ArgParser();
parser.addFlag(helpFlag, help: 'Print this help text', negatable: false);
parser.addOption(portOption,
help: 'The port number on which the server should listen for requests',
defaultsTo: defaultPortNumber.toString());
return parser;
}
/// Print usage information.
void printUsage(ArgParser parser,
{String? error, Object? exception, StackTrace? stackTrace}) {
if (error != null) {
print(error);
print('');
}
print('log_viewer [options] logFile');
print('');
print('Usage:');
print('');
print(
'The "logFile" is the file containing the content of the log that is being viewed');
print('');
print('Options:');
print(parser.usage);
if (exception != null) {
print(exception);
}
if (stackTrace != null) {
print(stackTrace);
}
}
/// Use the given command-line [args] to configure and start the web server.
void start(List<String> args) {
var parser = createParser();
var options = parser.parse(args);
if (options[helpFlag]) {
printUsage(parser);
return;
}
var port = defaultPortNumber;
try {
port = int.parse(options[portOption]);
} catch (exception) {
printUsage(parser, error: 'Invalid port number');
return;
}
var arguments = options.rest;
if (arguments.length != 1) {
printUsage(parser, error: 'Missing log file');
return;
}
var fileName = arguments[0];
var logFile = io.File(fileName);
List<String> lines;
try {
lines = logFile.readAsLinesSync();
} catch (exception, stackTrace) {
printUsage(parser,
error: 'Could not read file "$fileName":',
exception: exception,
stackTrace: stackTrace);
return;
}
print('Log file contains ${lines.length} lines');
var log = InstrumentationLog(<String>[logFile.path], lines);
var server = WebServer(log);
server.serveHttp(port);
print('logViewer is listening on http://localhost:$port/log');
}
}