Unverified Commit 4e68b7c7 authored by Siva's avatar Siva Committed by GitHub

Add support for experimental flags during hot reload. (#27252)

* Add support for experimental flags during hot reload.
parent dd86f70f
...@@ -339,6 +339,12 @@ class RunCommand extends RunCommandBase { ...@@ -339,6 +339,12 @@ class RunCommand extends RunCommandBase {
throwToolExit('Error: --train is only allowed when running as --dynamic --profile ' throwToolExit('Error: --train is only allowed when running as --dynamic --profile '
'(recommended) or --debug (may include unwanted debug symbols).'); '(recommended) or --debug (may include unwanted debug symbols).');
List<String> expFlags;
if (argParser.options.containsKey(FlutterOptions.kEnableExperiment) &&
argResults[FlutterOptions.kEnableExperiment].isNotEmpty) {
expFlags = argResults[FlutterOptions.kEnableExperiment];
}
final List<FlutterDevice> flutterDevices = devices.map<FlutterDevice>((Device device) { final List<FlutterDevice> flutterDevices = devices.map<FlutterDevice>((Device device) {
return FlutterDevice( return FlutterDevice(
device, device,
...@@ -347,6 +353,7 @@ class RunCommand extends RunCommandBase { ...@@ -347,6 +353,7 @@ class RunCommand extends RunCommandBase {
fileSystemRoots: argResults['filesystem-root'], fileSystemRoots: argResults['filesystem-root'],
fileSystemScheme: argResults['filesystem-scheme'], fileSystemScheme: argResults['filesystem-scheme'],
viewFilter: argResults['isolate-filter'], viewFilter: argResults['isolate-filter'],
experimentalFlags: expFlags,
); );
}).toList(); }).toList();
......
...@@ -341,7 +341,8 @@ class ResidentCompiler { ...@@ -341,7 +341,8 @@ class ResidentCompiler {
CompilerMessageConsumer compilerMessageConsumer = printError, CompilerMessageConsumer compilerMessageConsumer = printError,
String initializeFromDill, String initializeFromDill,
TargetModel targetModel = TargetModel.flutter, TargetModel targetModel = TargetModel.flutter,
bool unsafePackageSerialization bool unsafePackageSerialization,
List<String> experimentalFlags,
}) : assert(_sdkRoot != null), }) : assert(_sdkRoot != null),
_trackWidgetCreation = trackWidgetCreation, _trackWidgetCreation = trackWidgetCreation,
_packagesPath = packagesPath, _packagesPath = packagesPath,
...@@ -351,7 +352,8 @@ class ResidentCompiler { ...@@ -351,7 +352,8 @@ class ResidentCompiler {
_stdoutHandler = StdoutHandler(consumer: compilerMessageConsumer), _stdoutHandler = StdoutHandler(consumer: compilerMessageConsumer),
_controller = StreamController<_CompilationRequest>(), _controller = StreamController<_CompilationRequest>(),
_initializeFromDill = initializeFromDill, _initializeFromDill = initializeFromDill,
_unsafePackageSerialization = unsafePackageSerialization { _unsafePackageSerialization = unsafePackageSerialization,
_experimentalFlags = experimentalFlags {
// This is a URI, not a file path, so the forward slash is correct even on Windows. // This is a URI, not a file path, so the forward slash is correct even on Windows.
if (!_sdkRoot.endsWith('/')) if (!_sdkRoot.endsWith('/'))
_sdkRoot = '$_sdkRoot/'; _sdkRoot = '$_sdkRoot/';
...@@ -367,6 +369,7 @@ class ResidentCompiler { ...@@ -367,6 +369,7 @@ class ResidentCompiler {
final StdoutHandler _stdoutHandler; final StdoutHandler _stdoutHandler;
String _initializeFromDill; String _initializeFromDill;
bool _unsafePackageSerialization; bool _unsafePackageSerialization;
final List<String> _experimentalFlags;
final StreamController<_CompilationRequest> _controller; final StreamController<_CompilationRequest> _controller;
...@@ -479,6 +482,10 @@ class ResidentCompiler { ...@@ -479,6 +482,10 @@ class ResidentCompiler {
if (_unsafePackageSerialization == true) { if (_unsafePackageSerialization == true) {
command.add('--unsafe-package-serialization'); command.add('--unsafe-package-serialization');
} }
if ((_experimentalFlags != null) && _experimentalFlags.isNotEmpty) {
final String expFlags = _experimentalFlags.join(',');
command.add('--enable-experiment=$expFlags');
}
printTrace(command.join(' ')); printTrace(command.join(' '));
_server = await processManager.start(command); _server = await processManager.start(command);
_server.stdout _server.stdout
......
...@@ -35,6 +35,7 @@ class FlutterDevice { ...@@ -35,6 +35,7 @@ class FlutterDevice {
this.fileSystemScheme, this.fileSystemScheme,
this.viewFilter, this.viewFilter,
TargetModel targetModel = TargetModel.flutter, TargetModel targetModel = TargetModel.flutter,
List<String> experimentalFlags,
ResidentCompiler generator, ResidentCompiler generator,
}) : assert(trackWidgetCreation != null), }) : assert(trackWidgetCreation != null),
generator = generator ?? ResidentCompiler( generator = generator ?? ResidentCompiler(
...@@ -43,6 +44,7 @@ class FlutterDevice { ...@@ -43,6 +44,7 @@ class FlutterDevice {
fileSystemRoots: fileSystemRoots, fileSystemRoots: fileSystemRoots,
fileSystemScheme: fileSystemScheme, fileSystemScheme: fileSystemScheme,
targetModel: targetModel, targetModel: targetModel,
experimentalFlags: experimentalFlags,
); );
final Device device; final Device device;
......
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