writeHostApi method
void
writeHostApi(
- SwiftOptions generatorOptions,
- Root root,
- Indent indent,
- AstHostApi api, {
- required String dartPackageName,
override
Write the swift code that represents a host Api, api
.
Example:
protocol Foo {
Int32 add(x: Int32, y: Int32)
}
Implementation
@override
void writeHostApi(
SwiftOptions generatorOptions,
Root root,
Indent indent,
AstHostApi api, {
required String dartPackageName,
}) {
final String apiName = api.name;
const List<String> generatedComments = <String>[
' Generated protocol from Pigeon that represents a handler of messages from Flutter.'
];
addDocumentationComments(indent, api.documentationComments, _docCommentSpec,
generatorComments: generatedComments);
indent.write('protocol $apiName ');
indent.addScoped('{', '}', () {
for (final Method method in api.methods) {
addDocumentationComments(
indent, method.documentationComments, _docCommentSpec);
indent.writeln(_getMethodSignature(
name: method.name,
parameters: method.parameters,
returnType: method.returnType,
errorTypeName: 'Error',
isAsynchronous: method.isAsynchronous,
swiftFunction: method.swiftFunction,
));
}
});
indent.newln();
indent.writeln(
'$_docCommentPrefix Generated setup class from Pigeon to handle messages through the `binaryMessenger`.');
indent.write('class ${apiName}Setup ');
indent.addScoped('{', '}', () {
indent.writeln(
'static var codec: FlutterStandardMessageCodec { ${_getMessageCodecName(generatorOptions)}.shared }');
indent.writeln(
'$_docCommentPrefix Sets up an instance of `$apiName` to handle messages through the `binaryMessenger`.');
indent.write(
'static func setUp(binaryMessenger: FlutterBinaryMessenger, api: $apiName?, messageChannelSuffix: String = "") ');
indent.addScoped('{', '}', () {
indent.writeln(
r'let channelSuffix = messageChannelSuffix.count > 0 ? ".\(messageChannelSuffix)" : ""');
for (final Method method in api.methods) {
_writeHostMethodMessageHandler(
indent,
name: method.name,
channelName:
'${makeChannelName(api, method, dartPackageName)}\\(channelSuffix)',
parameters: method.parameters,
returnType: method.returnType,
isAsynchronous: method.isAsynchronous,
swiftFunction: method.swiftFunction,
documentationComments: method.documentationComments,
);
}
});
});
}