Unverified Commit 0f6e4e61 authored by stuartmorgan's avatar stuartmorgan Committed by GitHub

Add macosPrefix to the pubspec schema for plugins (#33287)

Adds a new macosPrefix, which serves the same purpose as iosPrefix but
for macOS plugins.

It is not yet used by the tooling, but this allows for plugins to start
to be written using it in preparation for tooling support for plugins.

Part of #32718
parent daa70608
...@@ -371,7 +371,10 @@ void _validateFlutter(YamlMap yaml, List<String> errors) { ...@@ -371,7 +371,10 @@ void _validateFlutter(YamlMap yaml, List<String> errors) {
errors.add('The "androidPackage" must either be null or a string.'); errors.add('The "androidPackage" must either be null or a string.');
} }
if (kvp.value['iosPrefix'] != null && kvp.value['iosPrefix'] is! String) { if (kvp.value['iosPrefix'] != null && kvp.value['iosPrefix'] is! String) {
errors.add('The "iosPrefix" must eithe rbe null or a string.'); errors.add('The "iosPrefix" must either be null or a string.');
}
if (kvp.value['macosPrefix'] != null && kvp.value['macosPrefix'] is! String) {
errors.add('The "macosPrefix" must either be null or a string.');
} }
if (kvp.value['pluginClass'] != null && kvp.value['pluginClass'] is! String) { if (kvp.value['pluginClass'] != null && kvp.value['pluginClass'] is! String) {
errors.add('The "pluginClass" must either be null or a string..'); errors.add('The "pluginClass" must either be null or a string..');
......
...@@ -27,16 +27,19 @@ class Plugin { ...@@ -27,16 +27,19 @@ class Plugin {
this.path, this.path,
this.androidPackage, this.androidPackage,
this.iosPrefix, this.iosPrefix,
this.macosPrefix,
this.pluginClass, this.pluginClass,
}); });
factory Plugin.fromYaml(String name, String path, dynamic pluginYaml) { factory Plugin.fromYaml(String name, String path, dynamic pluginYaml) {
String androidPackage; String androidPackage;
String iosPrefix; String iosPrefix;
String macosPrefix;
String pluginClass; String pluginClass;
if (pluginYaml != null) { if (pluginYaml != null) {
androidPackage = pluginYaml['androidPackage']; androidPackage = pluginYaml['androidPackage'];
iosPrefix = pluginYaml['iosPrefix'] ?? ''; iosPrefix = pluginYaml['iosPrefix'] ?? '';
macosPrefix = pluginYaml['macosPrefix'] ?? '';
pluginClass = pluginYaml['pluginClass']; pluginClass = pluginYaml['pluginClass'];
} }
return Plugin( return Plugin(
...@@ -44,6 +47,7 @@ class Plugin { ...@@ -44,6 +47,7 @@ class Plugin {
path: path, path: path,
androidPackage: androidPackage, androidPackage: androidPackage,
iosPrefix: iosPrefix, iosPrefix: iosPrefix,
macosPrefix: macosPrefix,
pluginClass: pluginClass, pluginClass: pluginClass,
); );
} }
...@@ -52,6 +56,7 @@ class Plugin { ...@@ -52,6 +56,7 @@ class Plugin {
final String path; final String path;
final String androidPackage; final String androidPackage;
final String iosPrefix; final String iosPrefix;
final String macosPrefix;
final String pluginClass; final String pluginClass;
} }
......
...@@ -58,6 +58,7 @@ ...@@ -58,6 +58,7 @@
"properties": { "properties": {
"androidPackage": { "type": "string" }, "androidPackage": { "type": "string" },
"iosPrefix": { "type": "string" }, "iosPrefix": { "type": "string" },
"macosPrefix": { "type": "string" },
"pluginClass": { "type": "string" } "pluginClass": { "type": "string" }
} }
} }
......
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