Unverified Commit ab260bac authored by Jonah Williams's avatar Jonah Williams Committed by GitHub

Refactor BuildMode into class, add jit_release configuration (#42476)

parent 84299aeb
...@@ -113,35 +113,78 @@ class AndroidBuildInfo { ...@@ -113,35 +113,78 @@ class AndroidBuildInfo {
final Iterable<AndroidArch> targetArchs; final Iterable<AndroidArch> targetArchs;
} }
/// The type of build. /// A summary of the compilation strategy used for Dart.
enum BuildMode { class BuildMode {
const BuildMode._(this.name);
factory BuildMode.fromName(String value) {
switch (value) {
case 'debug':
return BuildMode.debug;
case 'profile':
return BuildMode.profile;
case 'release':
return BuildMode.release;
case 'jit_release':
return BuildMode.jitRelease;
}
throw ArgumentError('$value is not a supported build mode');
}
/// Built in JIT mode with no optimizations, enabled asserts, and an observatory.
static const BuildMode debug = BuildMode._('debug');
/// Built in AOT mode with some optimizations and an observatory.
static const BuildMode profile = BuildMode._('profile');
/// Built in AOT mode with all optimizations and no observatory.
static const BuildMode release = BuildMode._('release');
/// Built in JIT mode with all optimizations and no observatory.
static const BuildMode jitRelease = BuildMode._('jit_release');
static const List<BuildMode> values = <BuildMode>[
debug, debug,
profile, profile,
release, release,
} jitRelease,
];
static const Set<BuildMode> releaseModes = <BuildMode>{
release,
jitRelease,
};
static const Set<BuildMode> jitModes = <BuildMode>{
debug,
jitRelease,
};
const List<String> _kBuildModes = <String>[ /// Whether this mode is considered release.
'debug', ///
'profile', /// Useful for determining whether we should enable/disable asserts or
'release', /// other development features.
]; bool get isRelease => releaseModes.contains(this);
/// Whether this mode is using the jit runtime.
bool get isJit => jitModes.contains(this);
/// Whether this mode is using the precompiled runtime.
bool get isPrecompiled => !isJit;
/// The name for this build mode.
final String name;
@override
String toString() => name;
}
/// Return the name for the build mode, or "any" if null. /// Return the name for the build mode, or "any" if null.
String getNameForBuildMode(BuildMode buildMode) { String getNameForBuildMode(BuildMode buildMode) {
return _kBuildModes[buildMode.index]; return buildMode.name;
} }
/// Returns the [BuildMode] for a particular `name`. /// Returns the [BuildMode] for a particular `name`.
BuildMode getBuildModeForName(String name) { BuildMode getBuildModeForName(String name) {
switch (name) { return BuildMode.fromName(name);
case 'debug':
return BuildMode.debug;
case 'profile':
return BuildMode.profile;
case 'release':
return BuildMode.release;
}
return null;
} }
String validatedBuildNumberForPlatform(TargetPlatform targetPlatform, String buildNumber) { String validatedBuildNumberForPlatform(TargetPlatform targetPlatform, String buildNumber) {
......
...@@ -232,7 +232,6 @@ class KernelSnapshot extends Target { ...@@ -232,7 +232,6 @@ class KernelSnapshot extends Target {
} }
} }
/// Supports compiling a dart kernel file to an ELF binary. /// Supports compiling a dart kernel file to an ELF binary.
abstract class AotElfBase extends Target { abstract class AotElfBase extends Target {
const AotElfBase(); const AotElfBase();
......
...@@ -53,5 +53,29 @@ void main() { ...@@ -53,5 +53,29 @@ void main() {
buildName = validatedBuildNameForPlatform(TargetPlatform.android_arm, 'abc+-'); buildName = validatedBuildNameForPlatform(TargetPlatform.android_arm, 'abc+-');
expect(buildName, 'abc+-'); expect(buildName, 'abc+-');
}); });
test('build mode configuration is correct', () {
expect(BuildMode.debug.isRelease, false);
expect(BuildMode.debug.isPrecompiled, false);
expect(BuildMode.debug.isJit, true);
expect(BuildMode.profile.isRelease, false);
expect(BuildMode.profile.isPrecompiled, true);
expect(BuildMode.profile.isJit, false);
expect(BuildMode.release.isRelease, true);
expect(BuildMode.release.isPrecompiled, true);
expect(BuildMode.release.isJit, false);
expect(BuildMode.jitRelease.isRelease, true);
expect(BuildMode.jitRelease.isPrecompiled, false);
expect(BuildMode.jitRelease.isJit, true);
expect(BuildMode.fromName('debug'), BuildMode.debug);
expect(BuildMode.fromName('profile'), BuildMode.profile);
expect(BuildMode.fromName('jit_release'), BuildMode.jitRelease);
expect(BuildMode.fromName('release'), BuildMode.release);
expect(() => BuildMode.fromName('foo'), throwsA(isInstanceOf<ArgumentError>()));
});
}); });
} }
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