Commit 211aeabb authored by Devon Carew's avatar Devon Carew

review comments

parent ce6b330a
...@@ -9,6 +9,7 @@ import 'dart:developer'; ...@@ -9,6 +9,7 @@ import 'dart:developer';
import 'dart:ui' as ui; import 'dart:ui' as ui;
import 'package:flutter/painting.dart'; import 'package:flutter/painting.dart';
import 'package:flutter/rendering.dart';
import 'package:flutter/scheduler.dart'; import 'package:flutter/scheduler.dart';
import 'package:vector_math/vector_math_64.dart'; import 'package:vector_math/vector_math_64.dart';
...@@ -63,34 +64,43 @@ void initServiceExtensions() { ...@@ -63,34 +64,43 @@ void initServiceExtensions() {
if (_extensionsInitialized) if (_extensionsInitialized)
return; return;
_extensionsInitialized = true;
assert(() {
registerExtension('flutter', _flutter); registerExtension('flutter', _flutter);
// TODO: Expose debugDumpApp(). // TODO: Expose debugDumpApp().
// TODO: Expose StatisticsOverlay. // TODO: Expose StatisticsOverlay.
registerExtension('flutter.debugPaint', _debugPaint); registerExtension('flutter.debugPaint', _debugPaint);
registerExtension('flutter.timeDilation', _timeDilation); registerExtension('flutter.timeDilation', _timeDilation);
_extensionsInitialized = true;
// Emit an info level log message; this tells the debugger that the Flutter // Emit an info level log message; this tells the debugger that the Flutter
// service extensions are registered. // service extensions are registered.
log('Flutter initialized', name: 'flutter', level: 800); log('Flutter initialized', name: 'flutter', level: 800);
return true;
});
} }
/// Just respond to the request. Clients can use the existence of this call to /// Just respond to the request. Clients can use the existence of this call to
/// know that the debug client is a Flutter app. /// know that the debug client is a Flutter app.
Future<ServiceExtensionResponse> _flutter(String method, Map parameters) { Future<ServiceExtensionResponse> _flutter(String method, Map<String, dynamic> parameters) {
String result = JSON.encode({ 'type': '_extensionType', 'method': method }); String result = JSON.encode({ 'type': '_extensionType', 'method': method });
return new Future.value(new ServiceExtensionResponse.result(result)); return new Future<ServiceExtensionResponse>.value(new ServiceExtensionResponse.result(result));
} }
/// Toggle the [debugPaintSizeEnabled] setting. /// Toggle the [debugPaintSizeEnabled] setting.
Future<ServiceExtensionResponse> _debugPaint(String method, Map parameters) { Future<ServiceExtensionResponse> _debugPaint(String method, Map<String, dynamic> parameters) {
if (parameters.containsKey('enabled')) { if (parameters.containsKey('enabled')) {
// TODO: This is a work around for a VM bug: sdk/25208 - all params are // TODO: This is a work around for a VM bug: sdk/25208 - all params are coerced to strings.
// coerced to strings.
// bool enabled = parameters['enabled'] == true;
debugPaintSizeEnabled = parameters['enabled'].toString() == 'true'; debugPaintSizeEnabled = parameters['enabled'].toString() == 'true';
// TODO: How to cause a redraw?
// Redraw everything - mark the world as dirty.
RenderObjectVisitor visitor;
visitor = (RenderObject child) {
child.markNeedsPaint();
child.visitChildren(visitor);
};
Renderer.instance.renderView.visitChildren(visitor);
} }
String result = JSON.encode({ String result = JSON.encode({
...@@ -98,11 +108,11 @@ Future<ServiceExtensionResponse> _debugPaint(String method, Map parameters) { ...@@ -98,11 +108,11 @@ Future<ServiceExtensionResponse> _debugPaint(String method, Map parameters) {
'method': method, 'method': method,
'enabled': debugPaintSizeEnabled 'enabled': debugPaintSizeEnabled
}); });
return new Future.value(new ServiceExtensionResponse.result(result)); return new Future<ServiceExtensionResponse>.value(new ServiceExtensionResponse.result(result));
} }
/// Manipulate the scheduler's [timeDilation] field. /// Manipulate the scheduler's [timeDilation] field.
Future<ServiceExtensionResponse> _timeDilation(String method, Map parameters) { Future<ServiceExtensionResponse> _timeDilation(String method, Map<String, dynamic> parameters) {
if (parameters.containsKey('timeDilation')) { if (parameters.containsKey('timeDilation')) {
// TODO: Workaround for https://github.com/dart-lang/sdk/issues/25208. // TODO: Workaround for https://github.com/dart-lang/sdk/issues/25208.
dynamic param = parameters['timeDilation']; dynamic param = parameters['timeDilation'];
...@@ -119,9 +129,9 @@ Future<ServiceExtensionResponse> _timeDilation(String method, Map parameters) { ...@@ -119,9 +129,9 @@ Future<ServiceExtensionResponse> _timeDilation(String method, Map parameters) {
String result = JSON.encode({ String result = JSON.encode({
'type': '_extensionType', 'type': '_extensionType',
'method': method, 'method': method,
'timeDilation': '${timeDilation}' 'timeDilation': '$timeDilation'
}); });
return new Future.value(new ServiceExtensionResponse.result(result)); return new Future<ServiceExtensionResponse>.value(new ServiceExtensionResponse.result(result));
} }
/// Prints a message to the console, which you can access using the "flutter" /// Prints a message to the console, which you can access using the "flutter"
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment