| // Copyright (c) 2014, 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. |
| |
| library analysis.logger; |
| |
| import 'package:analyzer/src/generated/engine.dart'; |
| import 'package:analyzer/src/generated/java_engine.dart'; |
| import 'package:logging/logging.dart' as logging; |
| |
| /** |
| * Instances of the class [AnalysisLogger] translate from the analysis engine's |
| * API to the logging package's API. |
| */ |
| class AnalysisLogger implements Logger { |
| /** |
| * The underlying logger that is being wrapped. |
| */ |
| final logging.Logger baseLogger = new logging.Logger('analysis.server'); |
| |
| AnalysisLogger() { |
| logging.Logger.root.onRecord.listen((logging.LogRecord record) { |
| AnalysisEngine.instance.instrumentationService.logLogEntry( |
| record.level.name, record.time, record.message); |
| }); |
| } |
| |
| @override |
| void logError(String message, [CaughtException exception]) { |
| if (exception == null) { |
| baseLogger.severe(message); |
| } else { |
| baseLogger.severe(message, exception.exception, exception.stackTrace); |
| } |
| } |
| |
| @override |
| void logError2(String message, Object exception) { |
| baseLogger.severe(message, exception); |
| } |
| |
| @override |
| void logInformation(String message, [CaughtException exception]) { |
| if (exception == null) { |
| baseLogger.info(message); |
| } else { |
| baseLogger.info(message, exception.exception, exception.stackTrace); |
| } |
| } |
| |
| @override |
| void logInformation2(String message, Object exception) { |
| baseLogger.info(message, exception); |
| } |
| } |