Unverified Commit ead5b1c2 authored by Gary Qian's avatar Gary Qian Committed by GitHub

Retire v1 embedding compatibility from automatic multidex support (#100685)

parent 1a072f9a
...@@ -25,25 +25,35 @@ File _getMultiDexApplicationFile(Directory projectDir) { ...@@ -25,25 +25,35 @@ File _getMultiDexApplicationFile(Directory projectDir) {
void ensureMultiDexApplicationExists(final Directory projectDir) { void ensureMultiDexApplicationExists(final Directory projectDir) {
final File applicationFile = _getMultiDexApplicationFile(projectDir); final File applicationFile = _getMultiDexApplicationFile(projectDir);
if (applicationFile.existsSync()) { if (applicationFile.existsSync()) {
// This checks for instances of legacy versions of this file. Legacy versions maintained
// compatibility with v1 embedding by extending FlutterApplication. If we detect this,
// we replace the file with the modern v2 embedding version.
if (applicationFile.readAsStringSync().contains('android.app.Application;')) {
return; return;
} }
}
applicationFile.createSync(recursive: true); applicationFile.createSync(recursive: true);
final StringBuffer buffer = StringBuffer(); final StringBuffer buffer = StringBuffer();
buffer.write(''' buffer.write('''
// Generated file. // Generated file.
//
// If you wish to remove Flutter's multidex support, delete this entire file. // If you wish to remove Flutter's multidex support, delete this entire file.
//
// Modifications to this file should be done in a copy under a different name
// as this file may be regenerated.
package io.flutter.app; package io.flutter.app;
import android.app.Application;
import android.content.Context; import android.content.Context;
import androidx.annotation.CallSuper; import androidx.annotation.CallSuper;
import androidx.multidex.MultiDex; import androidx.multidex.MultiDex;
/** /**
* Extension of {@link io.flutter.app.FlutterApplication}, adding multidex support. * Extension of {@link android.app.Application}, adding multidex support.
*/ */
public class FlutterMultiDexApplication extends FlutterApplication { public class FlutterMultiDexApplication extends Application {
@Override @Override
@CallSuper @CallSuper
protected void attachBaseContext(Context base) { protected void attachBaseContext(Context base) {
......
...@@ -14,7 +14,7 @@ import '../../src/common.dart'; ...@@ -14,7 +14,7 @@ import '../../src/common.dart';
import '../../src/context.dart'; import '../../src/context.dart';
void main() { void main() {
testUsingContext('ensureMultidexUtilsExists returns when exists', () async { testUsingContext('ensureMultidexUtilsExists patches file when invalid', () async {
final Directory directory = globals.fs.currentDirectory; final Directory directory = globals.fs.currentDirectory;
final File applicationFile = directory.childDirectory('android') final File applicationFile = directory.childDirectory('android')
.childDirectory('app') .childDirectory('app')
...@@ -32,7 +32,33 @@ void main() { ...@@ -32,7 +32,33 @@ void main() {
ensureMultiDexApplicationExists(directory); ensureMultiDexApplicationExists(directory);
// File should remain untouched // File should remain untouched
expect(applicationFile.readAsStringSync(), 'hello'); expect(applicationFile.readAsStringSync(), '''
// Generated file.
//
// If you wish to remove Flutter's multidex support, delete this entire file.
//
// Modifications to this file should be done in a copy under a different name
// as this file may be regenerated.
package io.flutter.app;
import android.app.Application;
import android.content.Context;
import androidx.annotation.CallSuper;
import androidx.multidex.MultiDex;
/**
* Extension of {@link android.app.Application}, adding multidex support.
*/
public class FlutterMultiDexApplication extends Application {
@Override
@CallSuper
protected void attachBaseContext(Context base) {
super.attachBaseContext(base);
MultiDex.install(this);
}
}
''');
}, overrides: <Type, Generator>{ }, overrides: <Type, Generator>{
FileSystem: () => MemoryFileSystem.test(), FileSystem: () => MemoryFileSystem.test(),
ProcessManager: () => FakeProcessManager.any(), ProcessManager: () => FakeProcessManager.any(),
......
...@@ -298,18 +298,23 @@ class MultidexProject extends Project { ...@@ -298,18 +298,23 @@ class MultidexProject extends Project {
String get appMultidexApplication => r''' String get appMultidexApplication => r'''
// Generated file. // Generated file.
//
// If you wish to remove Flutter's multidex support, delete this entire file. // If you wish to remove Flutter's multidex support, delete this entire file.
//
// Modifications to this file should be done in a copy under a different name
// as this file may be regenerated.
package io.flutter.app; package io.flutter.app;
import android.app.Application;
import android.content.Context; import android.content.Context;
import androidx.annotation.CallSuper; import androidx.annotation.CallSuper;
import androidx.multidex.MultiDex; import androidx.multidex.MultiDex;
/** /**
* Extension of {@link io.flutter.app.FlutterApplication}, adding multidex support. * Extension of {@link android.app.Application}, adding multidex support.
*/ */
public class FlutterMultiDexApplication extends FlutterApplication { public class FlutterMultiDexApplication extends Application {
@Override @Override
@CallSuper @CallSuper
protected void attachBaseContext(Context base) { protected void attachBaseContext(Context base) {
......
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