- Set Dart SDK minimum version to 3.6.0.
- Upgrade dependency versions (source_gen --> 2.0.0, analyzers --> 7.1.0).
- Adapt source code where necessary.
- Revert version constraints for packages
source_gen
andanalyzer
.
- Update version constraints for package
analyzer
.
- Update version constraints for package
source_gen
. - Implement
terminate()
in disposable worker/worker pool. - Update examples.
- Fix pub.dev issues.
- Update serializers/deserializers when
Squadron.converter
is modified.
- Use marshalers for
TypedData
. - Update version number.
- Update version number.
- Don't use marshaller tear-offs when method implementations do not use
dynamic
(eg.GenericMarshaler<T>.marshal()
could be overridden to return something more specific thandynamic
).
- Don't generate converters for
dynamic
orvoid
. - Use tear-offs instead of lambdas for marshalers where pivot type is
dynamic
. - Add support for generating local workers / local worker clients.
- Declare the service activator as
const
instead offinal
.
- Make sure no code is emitted when no worker code was generated.
- Update managed type cache asap in
handleDartType()
(fixes a stack overflow exception). - Read value of boolean flags in annotations -- fixes d-markey/squadron#44
- Added log messages.
- Implemented a cache for TypeManagers -- credits go to https://github.com/jpohhhh, thanks!
- Reworked initialization of imported types.
- Do not initialize the type manager before a Squadron annotation is effectively found -- fixes d-markey/squadron#40
- squadron_builder for Squadron version >= 6.0. Please note there are no versions 3.x-5.x in order to align squadron_builder version numbers with that of Squadron.
- Removed support for 'useLogger' and 'SerializeWith' annotations.
- Added support for libraries imported with a prefix -- fixes #14
- Added support for record types.
- Intentionaly missing versions (fastforward to 6.0 to match Squadron versions).
- Fix bug for async service method decorated with a marshaler: the service method was called twice if the return value is nullable!
- Remove debug output leftovers.
- Fix bug when generating code for generic service methods -- type arguments were lost in the process.
- Fix bug when a service method argument has no associated element per Dart's analyzer -- such arguments will always be marshalled as-is.
- These two corrections fix d-markey/squadron#26.
- Added example
json
.
- Fix bug when service method returns
FutureOr<void>
orFuture<void>
. - Make the generated operations map unmodifiable.
- PR #7 by guid-empty: Minor changes to support required fields and fix to have Iterable parameters
- PR #8 by techouse: Allow usage of analyzer v6
- Updated examples.
- Added topics and funding information to pubspec.
- Added example/README.md to comply with pub.dev checks.
- Reorganized example folder and updated README.
- Revised code generation strategy for operations map: previously, the operations map was generated in a mixin class and the (user-developed) service class had to derive from
WorkerService
and mix in with the generated mixin class. This is no longer required and the generated code now implements a private service class (deriving from the user's service class) which implementsWorkerService
with the generated operations map. This removes several constraints on service implementation and enables support of "plain old Dart objects" as Squadron services. User-developped service classes must be public and concrete (non-abstract, non-final, non-sealed...) and must provide an unnamed constructor which will be called by the associated generatedWorkerService
class. - Service method/constructor parameters whose type implement
marshal()
/unmarshal()
ormarshall()
/unmarshall()
methods will be automatically serialized using these methods if no explicit marshaler is provided.marshal()
/unmarshal()
have priority overmarshall()
/unmarshall()
. These methods also have priority over automatic JSON serialization available since version 0.9.0. The marshaling method must be an instance method taking no arguments; the unmarshaling method must be static and accept one argument.squadron_builder
will not verify parameter or return types of these methods, but obviously if the marshaling method of classT
returns typeU
, the unmarshaling method must accept aU
argument and return an instance ofT
. Failure to comply with this contract may lead to Dart compilation errors.
- Eliminate async code generation for additional assets.
- Properly resolve Squadron's main library.
- Properly handle platform worker thread parameter + getter in generated worker/worker pool when
with_finalizers
is enabled (fix for #5). - Refactored service/method parameter management.
- Enable code generation for libraries that define several services. This will run as expected on native platforms where worker entrypoints are top-level static methods. It will not work on Web platforms where worker entrypoints are URLs: each worker needs its own URL, hence its own library.
- Automatically discover Squadron capabilities (
WorkerRequest
/WorkerResponse
serialization type + availability ofEntryPoint
andPlatformWorkerHook
). - Retire option
serialization_type
as it is now discovered automatically.
- Downgrade version for
analyzer
(fix for #4).
- Downgrade version for
analyzer
(fix for #4).
- Enable support of Dart 3.
- Fix issues reported by
pub.dev
score. - Add option
serialization_type
to configure the serialization type used for worker request/response (Map
for Squadron < 5.0.0,List
for Squadron >= 5.0.0).
- Breaking changes: several renamings, in particular the builder name which is now
squadron_builder:worker_builder
. - Generate appropriate code for fields used as parameters in the constructor of the service class. In previous versions, the generated code for constructors did not map parameters with fields, and fields were overriden with getters/setters throwing an
UnimplementedError
. Please note that if the field is not final or if its value is mutable, updates will not be propagated to/from the platform worker. This is by design, because the service fields and the worker/pool fields are different instances living in different threads, and threads do not share memory in Dart and browsers. - Support
UseLogger
annotation to generate associated code during worther thread initialization. - Take builder options into account. In previous versions, builder options were ignored. Also upgraded
source_gen
to 1.3.0 (see pull request dart-lang/source_gen#647 related to builders that produce multiple files). - Added explicit option
with_finalizers
to force or disable code generation for finalization, and make finalization actually work. - Split
build.yaml
in two to avoid interfering with the build process of client packages. - Reorganized the source code to make it more readable and maintainable.
- Upgrade packages.
- Switch from deprecated
element2
/enclosingElement3
toelement
/enclosingElement
.
- Specify platform support in
pubspec.yaml
.
- Marshal data to/from workers according to
SerializeWith
annotations.
- Upgrade dependencies.
- Serialize arguments/return values when
toJson()
/fromJson()
is available.
- Annotations
SquadronService
+SquadronMethod
. - Support of cancellation tokens.
- Package upgrade.
- Sample code.
- Initial version. Still experimental yet functional on simple use cases.