- Updates minimum supported SDK version to Flutter 3.7/Dart 2.19.
- Fixes generation failures when an output file is in a directory that doesn't already exist.
- Fixes import in generated Dart test output when overriding package name.
- Adds package name to method channel strings to avoid potential collisions between plugins.
- Adds dartPackageName option to
pigeonOptions
.
- Adds generic
Object
field support to data classes.
- [swift] Fixes a crash when passing
null
for nested nullable classes.
- Updates README to better reflect modern usage.
- [objc] Adds macOS support to facilitate code sharing with existing iOS plugins.
- Requires
analyzer 5.13.0
and replaces use of deprecated APIs.
- [swift] Avoids using
Any
to representOptional
in Swift. - [swift] Breaking Change A raw
List
(without generic type argument) in Dart will be translated into[Any?]
(rather than[Any]
) in Swift. - [swift] Breaking Change A raw
Map
(without generic type argument) in Dart will be translated into[AnyHashable:Any?]
(rather than[AnyHashable:Any]
) in Swift. - Adds an example application that uses Pigeon directly, rather than in a plugin.
- Reports an error when trying to use an enum directly in a
List
orMap
argument.
- [objc] Fixes a warning due to a C++-style function signature in the codec getter's definition.
- [java] Fixes
UnknownNullability
andSyntheticAccessor
warnings.
- [cpp] Minor changes to output style.
- [swift] Fixes NSNull casting crash.
- [cpp] Removes experimental tags.
- Migrates off deprecated
BinaryMessenger
API.
- [cpp] Requires passing any non-nullable fields of generated data classes as constructor arguments, similar to what is done in other languages. This may require updates to existing code that creates data class instances on the native side.
- [cpp] Adds a convenience constructor to generated data classes to set all fields during construction.
- [cpp] Fixes class parameters to Flutter APIs.
- Updates minimum Flutter version to 3.3.
- [swift] Removes experimental tags.
- [kotin] Removes experimental tags.
- [java] Adds a
GeneratedApi.FlutterError
exception for passing custom error details (code, message, details). - [kotlin] Adds a
FlutterError
exception for passing custom error details (code, message, details). - [kotlin] Adds an
errorClassName
option inKotlinOptions
for custom error class names. - [java] Removes legacy try catch from async apis.
- [java] Removes legacy null check on non-nullable method arguments.
- [cpp] Fixes wrong order of items in
FlutterError
. - Adds
FlutterError
handling integration tests for all platforms.
- [swift] Changes all ints to int64. May require code updates to existing code.
- Adds integration tests for int64.
- [kotlin] Removes safe casting from decode process.
- [swift] Removes safe casting from decode process.
- Removes the unnecessary Flutter constraint.
- Removes an unnecessary null check.
- Aligns Dart and Flutter SDK constraints.
- Adds parameter to generate Kotlin code in example README.
- [kotlin] Fixes compiler warnings in generated output.
- [swift] Fixes compiler warnings in generated output.
- [swift] Removes safe casting from decode process.
- [kotlin] Removes safe casting from decode process.
- Updates links for the merge of flutter/plugins into flutter/packages.
- Breaking Change Updates
DartOptions
to be immutable and adds const to the constructor. - [java] Reverts
final
changes to Flutter Api classes.
- [objc] BREAKING CHANGE: FlutterApi calls now return a
FlutterError
, rather than anNSError
, on failure. - [objc] Fixes an unused function warning when only generating FlutterApi.
- [kotlin] Fixes Flutter api int errors with updated casting.
- [swift] Changes async method completion types. May require code updates to existing code.
- [swift] Adds error handling to async methods.
- [kotlin] Changes async method completion types. May require code updates to existing code.
- [kotlin] Adds error handling to async methods.
- Adds async error handling integration tests for all platforms.
- Updates code to fix strict-cast violations.
- [java] Fixes raw types lint issues.
- [objc] Removes unused function.
- [swift] Adds error handling to sync host api methods.
- [c++] Fixes handling of the
cpp*
options in@ConfigurePigeon
annotations.
- Adds
@SwiftFunction
annotation for specifying custom swift function signature.
- Requires analyzer 5.0.0 and replaces use of deprecated APIs.
- [c++] Fixes minor output formatting issues.
- Updates scoped methods to prevent symbol-less use.
- [kotlin] Fixes a missed casting of not nullable Dart 'int' to Kotlin 64bit long.
- [generator_tools] adds
newln
method for adding empty lines and ending lines. - Updates generators to more closely match Flutter formatter tool output.
- [java] BREAKING CHANGE: Makes data classes final. Updates generators for 1p linters.
- [docs] Updates README.md.
- [kotlin] Fixes a bug with a missed line break between generated statements in the
fromList
function of the companion object.
- [c++] Fixes most non-class arguments and return values in Flutter APIs. The types of arguments and return values have changed, so this may require updates to existing code.
- Creates StructuredGenerator class and implements it on all platforms.
- [c++] Fixes undefined behavior in
@async
methods.
- Creates new Generator classes for each language.
- [swift] Fixes warnings with
Object
parameters. - [dart] Fixes warnings with
Object
return values. - [c++] Generation of APIs that use
Object
no longer fails.
- Relocates generator classes. (Reverted)
- [c++] Fixes reply sending non EncodableValue wrapped lists.
- Add documentation comment support for Enum members.
- Updates serialization to use lists instead of maps to improve performance.
- [swift] Fixes compressed list data types.
- Changes generated Java enum field to be final.
- [kotlin] Fixes a bug with some methods that return
void
.
- Adds the ability to use
runWithOptions
entrypoint to allow external libraries to use the pigeon easier.
- [swift] Fixes a bug when calling methods that return
void
.
- Fixes bug with parsing documentation comments that start with '/'.
- [dart] Fixes enum parameter handling in Dart test API class.
- [kotlin] Fixes Kotlin generated sync host api error.
- [java] Adds assert
args != null
. - [java] Changes the args of a single element to
ArrayList
fromArrays.asList
toCollections.singletonList
. - [java] Removes cast for
Object
.
- Removes unneeded custom codecs for all languages.
- Adds documentation comment support for Kotlin.
- Adds experimental support for Kotlin generation.
- [java] Adds missing
@NonNull
annotations to some methods.
- Adds documentation comment support for all currently supported languages.
- [swift] Makes swift output work on macOS.
- Fixes lint warnings.
- Exposes
SwiftOptions
.
- [java] BREAKING CHANGE: Changes style for enum values from camelCase to snake_case. Generated java enum values will now always be in upper snake_case.
- Updates text theme parameters to avoid deprecation issues.
- [dart] Deduces the correct import statement for Dart test files made with
dartHostTestHandler
instead of relying on relative imports.
- Requires
analyzer 4.4.0
, and replaces use of deprecated APIs.
- [java] Fixes returning int values from FlutterApi methods that fit in 32 bits.
- [c++] Fixes style issues in
FlutterError
andErrorOr
. The names and visibility of some members have changed, so this may require updates to existing code.
- [c++] Fixes most non-class arguments and return values in host APIs. The types of arguments and return values have changed, so this may require updates to existing code.
- Adds
unnecessary_import
to linter ignore list in generated dart tests.
- Adds
unnecessary_import
to linter ignore list forpackage:flutter/foundation.dart
.
- Removes
@dart = 2.12
from generated Dart code.
- Adds experimental support for Swift generation.
- [java] Adds option to add javax.annotation.Generated annotation.
- Supports newer versions of
analyzer
.
- Fixes potential crash bug when using a nullable nested type that has nonnull fields in ObjC.
- [c++] Adds support for non-nullable fields, and fixes some issues with nullable fields. The types of some getters and setter have changed, so this may require updates to existing code.
- Adds support for enums in arguments to methods for HostApis.
- [c++] Fixes minor style issues in generated code. This includes the naming of generated methods and arguments, so will require updates to existing code.
- Updates for non-nullable bindings.
- [c++] Adds C++ code generator.
- [objc] Simplified some code output, including avoiding Xcode warnings about
using
NSNumber*
directly as boolean value. - [tests] Moved test script to enable CI.
- Adds ability for generators to do AST validation. This can help generators without complete implementations to report gaps in coverage.
- Fixes non-nullable classes and enums as fields.
- Fixes nullable collections as return types.
- Enables NNBD for the Pigeon tool itself.
- [tests] Updates legacy Dart commands.
- BREAKING CHANGE: Removes the
--dart_null_safety
flag. Generated Dart now always uses nullability annotations, and thus requires Dart 2.12 or later.
- Fixes bug where Dart
FlutterApi
s would assert that a nullable argument was nonnull.
- Makes the generated Java Builder class final.
- Fixes Java crash for nullable nested type.
- Adds support for TaskQueues for serial background execution.
- Implements nullable parameters.
- BREAKING CHANGE - Nonnull parameters to async methods on HostApis for ObjC now have the proper nullability hints.
- Implements nullable return types.
- [front-end] Fix error caused by parsing
copyrightHeaders
passed to options in@ConfigurePigeon
.
- [dart_test] Adds missing linter ignores.
- [objc] Factors out helper function for reading from NSDictionary's.
- [objc] Renames static variables to match Google style.
- Updates behavior of run_tests.dart with no arguments.
- [debugging] Adds
ast_out
to help with debugging the compiler front-end. - [front-end, dart] Adds support for non-null fields in data classes in the front-end parser and the Dart generator (unsupported languages ignore the designation currently).
- [front-end, dart, objc, java] Adds support for non-null fields in data classes.
- [java] Fix too little information when having an exception
- [tests] Port several generator tests to run in Dart over bash
- [style] Fixes new style rules for Dart analyzer.
- [java] Fixes enum support for null values.
- [ci] Starts transition to a Dart test runner, adds windows support.
- [front-end] Starts issuing an error if enums are used in type arguments.
- [front-end] Passes through all enums, referenced or not so they can be used as a work around for direct enum support.
- [front-end] Made sure that explicit use of Object actually creates the codec that can represent custom classes.
- [dart] Fixed cast exception that can happen with primitive data types with type arguments in FlutterApi's.
- [front-end] Started accepting explicit Object references in type arguments.
- [codecs] Fixed nuisance where duplicate entries could show up in custom codecs.
- [front-end] Fixed bug where nested classes' type arguments aren't included in the output (generated class and codec).
- Updated example README for set up steps.
- [java] Fixed bug when using Integer arguments to methods declared with 'int' arguments.
- [front-end] Fixed bug where codecs weren't generating support for types that only show up in type arguments.
- [objc] Updated assert message for incomplete implementations of protocols.
- [java] Made it so
@async
handlers in@HostApi()
can report errors explicitly.
- [front-end] Fixed bug where classes only referenced as type arguments for generics weren't being generated.
- Started allowing primitive data types as arguments and return types.
- Generics support.
- Support for functions with more than one argument.
- [command-line] Added
one_language
flag for allowing Pigeon to only generate code for one platform. - [command-line] Added the optional sdkPath parameter for specifying Dart SDK path.
- [dart] Fixed copyright headers for Dart test output.
- [front-end] Added more errors for incorrect usage of Pigeon (previously they were just ignored).
- [generators] Moved Pigeon to using a custom codec which allows collection types to contain custom classes.
- [java] Fixed NPE in Java generated code for nested types.
- [objc] BREAKING CHANGE: logic for generating Objective-C selectors has
changed.
void add(Input value)
will now translate to-(void)addValue:(Input*)value
, methods with no arguments will translate to...WithError:
or...WithCompletion:
. - [objc] Added
@ObjCSelector
for specifying custom objc selectors.
- Updated the front-end parser to use dart
analyzer
instead ofdart:mirrors
.dart:mirrors
doesn't support null-safe code so there were a class of features we couldn't implement without this migration. - BREAKING CHANGE - the
configurePigeon
function has been migrated to a@ConfigurePigeon
annotation. See./pigeons/message.dart
for an example. The annotation can be attached to anything in the file to take effect. - BREAKING CHANGE - Now Pigeon files must be in one file per invocation of Pigeon. For example, the classes your APIs use must be in the same file as your APIs. If your Pigeon file imports another source file, it won't actually import it.
- bugfix in front-end parser for recursively referenced datatypes.
- bugfix in iOS async handlers of functions with no arguments.
- Added support for enums.
- Java: Fixed issue where multiple async HostApis can generate multiple Result interfaces.
- Dart: Made it so you can specify the BinaryMessenger of the generated APIs.
- BREAKING CHANGE - Pigeon files must be null-safe now. That means the fields inside of the classes must be declared nullable ( non-null fields aren't yet supported). Migration example:
// Version 0.1.x
class Foo {
int bar;
String baz;
}
// Version 0.2.x
class Foo {
int? bar;
String? baz;
}
- BREAKING CHANGE - The default output from Pigeon is now null-safe. If you
want non-null-safe code you must provide the
--no-dart_null_safety
flag. - The Pigeon source code is now null-safe.
- Fixed niladic non-value returning async functions in the Java generator.
- Made
runCommandLine
return an the status code.
- Moved logic from bin/ to lib/ to help customers wrap up the behavior.
- Added some more linter ignores for Dart.
- More Java linter and linter fixes.
- Java code generator enhancements:
- Added linter tests to CI.
- Fixed some linter issues in the Java code.
- Fixed decode method on generated Flutter classes that use null-safety and have null values.
- Implemented
@async
HostApi's for iOS. - Fixed async FlutterApi methods with void return.
- Fixed a bug introduced in 0.1.17 where methods without arguments were no longer being called.
- Null safe requires Dart 2.12.
- Split out test code generation for Dart into a separate file via the --dart_test_out flag.
- Fixed running in certain environments where NNBD is enabled by default.
- Added support for running in versions of Dart that support NNBD.
- [Windows] Fixed executing from drives other than C:.
- Fixed execution on Windows with certain setups where Dart didn't allow
backslashes in
import
statements.
- Fixed assert failure with creating a PlatformException as a result of an exception in Java handlers.
- Added flag to generate null safety annotated Dart code
--dart_null_safety
. - Made it so Dart API setup methods can take null.
- Updated the examples page.
- Fixed bug that prevented running
pigeon
on Windows (introduced in0.1.8
).
- Fixed bug where executing pigeon without arguments would crash (introduced in 0.1.8).
- Started spawning pigeon_lib in an isolate instead of a subprocess. The subprocess could have lead to errors if the dart version on $PATH didn't match the one that comes with flutter.
- Fixed Dart compilation for later versions that support null safety, opting out of it for now.
- Fixed nested types in the Java runtime.
- Fixed unused variable linter warning in Dart code under certain conditions.
- Made array datatypes correctly get imported and exported avoiding the need to add extra imports to generated code.
- Fixed nullability for NSError's in generated objc code.
- Fixed nullability of nested objects in the Dart generator.
- Added test to make sure the pigeon version is correct in generated code headers.
- Added error message if supported datatypes are used as arguments or return types directly, without an enclosing class.
- Added support for List and Map datatypes in Java and Objective-C targets.
- Updated the Readme.md.
- Removed static analysis warnings from generated Java code.
- Fixed issue where nested types didn't work if they weren't present in the Api.
- Added pigeon.dart.
- Fixed some Obj-C linter problems.
- Added the ability to generate a mock handler in Dart.
- Fixed setting an api to null in Java.
- Added support for void argument functions.
- Added nullability annotations to generated objc code.
- Added e2e tests for iOS.
- Renamed
setupPigeon
toconfigurePigeon
.
- Suppressed or got rid of warnings in generated Dart code.
- Added support for void return types.
- Fixed runtime exception in Android with values of ints less than 2^32.
- Incremented codegen version warning.
- Fixed primitive types for Android Java.
- Added support for Android Java.
- Added Host->Flutter calls for Objective-C
- Fixed warning in the README.md
- Initial release.