- Generate code that formats faster with current "short" style. Both versions are fast with the coming "tall" style.
- Mark
@nullable
deprecated: it does nothing and should not be used.
- Improve build performance when there are lots of
built_value
classes.
- Fix for new warning about
operator==
param type.
- In
StandardJsonPlugin
, add support for specifying types that should be left asList
. - Allow non alphanumeric characters in
EnumClass
names.
- Fix codegen for enum wire keys when there is a
$
in the field name. - Remove support for generating legacy (<2.12) Dart code.
- Allow classes with record fields to be serialized if they use a typedef for
the record type and install a custom
Serializer
for it.
- Add
Int32
serializer.
- Bump version of
analyzer
.
- Remove JSON from
DeserializationError
message to prevent data accidentally leaking into logs. The JSON is still available on theDeserializationError
object. - Fix generation for fields that are
Function
types that are declared separately, for example in amixin
defined in another source file, and use named or positional parameters.
- Fix support for generating enum mixins for Dart 3. Instead of triggering
mixin generation with
abstract class TestEnumMixin = Object with _$TestEnumMixin
it must now be triggered withtypedef TestEnumMixin = _$TestEnumMixin
.
- Add support for value types with record fields. Serialization with records is not yet supported.
- Fix generator failure due to top level record field.
- Migrate benchmark and examples to null safety.
- Remove pre-null-safe test cases.
- Remove analyzer plugin.
- Remove reference to
@nullable
annotation from failure-to-instantiate message.
- Add
Uint8ListSerializer
. - Generate Dart-3-compatible code if needed.
- Stop using deprecated analyzer API.
- Fix codegen for optional fields with
$
in the name.
- Increase minimum version of
analyzer
. - Fix generation with the type
Never
.
- Fix generated deserialization code when there is a manually written builder with nullable fields.
- Drop dev dependency on
quiver
. - Disable all linting of generated code.
- Change generated hash code implementation so it formats better when there are many fields.
- Prepare for breaking analyzer changes.
- Bump version of
analyzer
.
- Bump version of
analyzer
.
- Fix custom builders in null safe code: allow nested builder fields to be nullable.
- Improve custom builders for null safe code: allow abstract setter/getter
pairs instead of fields. This allows nested builders to have a setter that
accepts
null
and a getter that guarantees not to returnnull
, which is what auto instantiation of nested builders already provides. - Allow use of super field initialization in
EnumClass
.
- Fix erroneously generated null check for fields with generic bounds.
- Migrate
built_value_test
to null safety.
- Fix generation support for optional generic bounds, e.g.
class Foo<T extends Object?>
. - Fix generation for classes with names starting
$
. - Ignore lint
unnecessary_lambdas
in generated code.
- Change generated
build
methods to return only public types, creating_build
methods that return the generated impl types. This means dartdoc will no longer reference the generated types. - Ignore the
no_leading_underscores_for_local_identifiers
lint in generated code. - Migrated
built_value_generator
to null safety. This is purely an internal change, the generator can still generate legacy code as and when needed.
- Bug fix: fix a corner case with generics that had incorrect serializer generation.
- Bug fix: remove a
print
from the enum generator.
- Fix deps: allow
built_value_generator
to usebuilt_value 8.2.0
.
- Allow writing final parameters in EnumClass constructor and valueOf method.
- Make generator output additional explicit null checks so the generated code complies with the
cast_nullable_to_non_nullable
lint. - Bump version of
analyzer
.
- Bump version of
analyzer
.
- Bump version of
analyzer
, fix deprecation warnings.
- Bump version of
analyzer
.
- Bug fix: allow constructors to have annotations. Previously, annotations would cause codegen to fail.
New features:
- Add
@BuiltValueHook
annotation. It provides the same functionality as_initializeBuilder
and_finalizeBuilder
, but in a more visible way: annotate a static method on the value class with@BuiltValueHook
to have it called on builder creation or finalization. - Add back
serializeNulls
toBuiltValueSerializer
annotation. By default generated serializers skip null fields instead of writing them; setserializeNulls
to write the nulls.
New minor functionality:
- Support use of nulls in collections when the key or value types are explicitly nullable.
- Allow
JsonObject
to be instantiated from aMap<dynamic, dynamic>
. - Mark nested builder getters in
instantiable: false
classes not nullable, to match the implementations. UseautoCreateNestedBuilders: false
to get the old behaviour. - Allow explicit nulls in JSON for nullable fields when deserializing.
- Specify annotation targets; the analyzer will now hint if a
built_value
annotation is used where it has no effect. - Support polymorphism with mixed in parent value type: generated builder now mixes in parent builder.
Bug fixes:
- Fix support for serializing and deserializing nulls.
- Fix
nestedBuilders: false
withinstantiable: false
. - Fix enum deserialization fallback for
int
. - Annotating a wrong type getter with
@SerializersFor
is now an error, instead of just generating nothing.
Cleanup:
- Removed Angular mixin from example, as this feature is no longer needed: Angular now directly supports using static members in templates.
- Bump versions of
build_config
andbuild_runner
.
- Bump version of
analyzer
.
- Bump version of
source_gen
.
- Fix error message for builder factory not installed.
- Bump version of
build
.
- Bump versions of
analyzer
,quiver
.
- Update
chat
example to webdev. - Allow nulls when serializing/deserializing for better JSON interop.
- Fix generation bugs around enum wire name and polymorphism.
- Fix generation with generics for analysis with
strict-raw-types
. - Add test coverage around generation for generic serialization.
- Add test coverage around initialization with generics.
- Stable null safe release.
- Add
toJson
andfromJson
convenience methods toSerializers
.
- Migrate to NNBD.
- Remove dependency on
package:quiver
. - Remove support for serializing nulls using
BuiltValueSerializer(serializeNulls: true)
. - Make installed plugins public in
Serializers
asserializerPlugins
. @memoized
fields can now memoizenull
; previously, nulls would not be cached, causing the computation to rerun.
- Support analyzer
^0.40.0
. - Workaround #941.
- Support private
Built
classes. Note that private classes cannot be made serializable. - Support serializing enums to ints: add
wireNumber
to@BuiltValueEnumConst
. - Support memoizing
hashCode
, so it's computed lazily once. Write an abstract getterint get hashCode;
then annotate it with@memoized
to turn this on for abuilt_value
class. - Trim
built_value_test
dependencies: depend onmatcher
instead oftest
. - Fix enum generator error messages when
value
andvalueOf
are missing.
- Fix unescaped string usages while generating
ValueSourceClass
. - Fix analyzer use: don't rely on
toString
on types.
- Fix
analyzer
lower bound: was0.39.0
, needs to be0.39.3
.
- Fix regression in a corner case when determining which fields to generate based on mixins.
- Tweak generation changes for
implicit-casts: false
andimplicit-dynamic: false
. Relax casts again where possible.
- Make generated code comply with analyzer option
strict-raw-types
. - Allow
Serialiers
declaration to comply withstrict-raw-types
, or to continue to use raw types as before. - Make generated code comply with analyzer options
implicit-casts: false
andimplicit-dynamic: false
.
- Internal: fix analyzer deprecation warnings.
- Split analysis plugin out into new package,
built_value_analyzer_plugin
. Bumpbuilt_value_generator
dependency onanalyzer
to0.39.0
so it supports extension methods.
- Add
example
folders withREADME.md
pointing to examples.
- Internal: cleanup for pedantic v1.9.0 lints.
- Internal: cleanup for pedantic v1.9.0 lints.
- Internal: clean up
built_value_generator
->built_value
dependency; depend on minor instead of major version so we can in future handle tight coupling between the two without a major version bump tobuilt_value
.
- Fix
_finalizeBuilder
generation so it uses the correct class name.
- Fix missing
README.md
inpackage:built_value
.
- Support
_initializeBuilder
hook in value types. If found, it's executed when aBuilder
is created and can be used to set defaults. - Support
_finalizeBuilder
hook in value types. If found, it's executed whenbuild
is called and can be used to apply processing to fields. - Add
defaultCompare
anddefaultSerialize
to@BuiltValue
. They control the defaults forcompare
andserialize
in@BuiltValueField
. - Add facility to merge
Serializers
instances viaSerializers.merge
,SerializersBuilder.merge
andSerializersBuilder.mergeAll
. - Bug fix: fix generated code with polymorphism and more than one level of non-instantiable classes.
- Bug fix: fix generated
operator==
when a field is calledother
. - Fix
num
deserialization so it does not always convert todouble
. - Bump version of
analyzer
. - Internal: replace analyzer's
DartType.displayName
with custom code generator.
- Fix codegen for custom builders when fields use types that have an import prefix.
- Bump version of
analyzer_plugin
.
- Generate code compatible with 'no raw types'.
- Allow providing your own
toString
via a mixin. - Fix
BuiltValueSerializer(serializeNulls: true)
for non-primitive fields. - Stop using old analyzer API; require analyzer
0.34.0
.
- Add
Iso8601DurationSerializer
for use when you want ISO8601 serialization instead of the default microseconds serialization. - Bump versions of
analyzer
,analyzer_plugin
andbuild_config
.
- Add
@BuiltValue(generateBuilderOnSetField: true)
which provides a way to listen forset
calls on generated builders. - Add
@BuiltValueEnumConst(fallback: true)
as a way to mark an enum const as the fallback whenvalueOf
or deserialization fails. - Add
@BuiltValueSerializer(serializeNulls: true
as a way to modify the wire format to explicitly containnull
values. - Make it possible to merge
Serializers
instances: add abuilderFactories
getter that returns installed builder factories. - Use new
Function
syntax everywhere. - Bug fix: only generate builder factories for fields that are
Built
types orbuilt_collection
collections.
- Allow
analyzer
0.35.0.
- Fix
BuiltList
serialization when usingStandardJsonPlugin
with unspecified type and when list length is 1.
- Allow custom builders to use setter/getter pairs instead of normal fields.
- Add an option to
@BuiltValue
to turn off auto instantiation of nested builders. - Add
@BuiltValueSerializer
annotation which gives the option to specify a custom serializer for a class. - Make it possible to merge
Serializers
instances: add aserializers
getter that returns the installed serializers. - Add serializer for
RegExp
fields. - Allow
analyzer
0.34.0.
New features:
- Add an option to
@BuiltValue
to generate comparable builders. - Add serializer for
Duration
fields. - Add
serializerForType
andserializerForWireName
methods toSerializers
.
Improvements:
- Add ignore for
avoid_as
lint to generated code. - Put ignored lints on a single line at the end of the generated output.
- Stop checking for import of
built_value.dart
whenEnumClass
is used; this was expensive.
Fixes:
- Fix tests following changes to source_gen error output.
- Fix generation when new
mixin
declarations are used. - Support dollar signs in enum value names.
- Fix nested collections when using a custom builder.
- Switch to new analyzer API in version
0.33.3
.
- Bump versions of
analyzer
,analyzer_plugin
,build
,build_runner
.
- Allow polymorphic base classes to omit implementing
Built
while still implementing any other interface(s). - Allow the dollar character in
wireName
settings. - Allow
build
version 1.0.
- Add
built_value_test
support for remaining built collections.
- Fix generated
operator==
when a type uses generic functions. - Fix generated code for
curly_braces_in_control_flow
lint.
- Allow
build_runner
0.10.0.
- Improve generation for
operator==
, don't usedynamic
. - Improve error message and documentation for missing builder factory.
- Allow built_collection 4.0.0.
- Fix code generation stack overflow when there is a loop in serializable types.
- Fix library name output in generation error messages.
- Add ignores for lints 'unnecessary_const' and 'unnecessary_new' to generated code.
- Update to the latest
source_gen
. This generator can now be used with other generators that want to write to.g.dart
files without a manual build script. - Breaking change: The "header" configuration on this builder is now ignored.
- Allow SDK 2.0.0.
- Add ignores for lints 'lines_longer_than_80_chars' and 'avoid_catches_without_on_clauses' to generated code.
- Bump version of quiver.
- Bump versions of build_runner, build_config and shelf.
- Fix violations of
prefer_equal_for_default_values
lint.
- Bump versions of
analyzer
,analyzer_plugin
.
- Support serializing
BuiltSet
withStandardJsonPlugin
. It's serialized to a JSON list. - Add
Iso8601DateTimeSerializer
for use when you want ISO8601 serialization instead of microseconds since epoch. - Fix code generation when inherited generic fields are made non-generic.
- Improve error message on failure to deserialize.
- Move check forbidding instantiation with
dynamic
type parameters from builder to value class. Previously, you could avoid the check by using the generated constructor called_
.
- Removed dependency on
build_config
frombuilt_value
and added it tobuilt_value_generator
.
- Allow source_gen 0.8.0.
- Make
StandardJsonPlugin
returnMap<String, Object>
, as the firebase libraries expect, instead ofMap<Object, Object>
.
- Fix analyzer plugin loading. It should now work, provided you modify your
analysis_options.yaml
as suggested.
- Add an experimental analyzer plugin that surfaces compile time generation
errors as suggestions in your IDE. Turn it on by modifying your
analysis_options.yaml
file to addplugins
entries, example.
- Support serializing
BigInt
. - Add support for setting the generated header in a
build.yaml
file in your project. Seeexample/build.yaml
for an example. - Explicitly forbid serialization of
Function
andtypedef
types; these fields need to be marked@BuiltValueField(serialize: false)
. - Fix generation when a field picked up via inheritance is a function type defined in another source file.
- Fail with a helpful error message if
@SerializersFor
annotation list contains an undefined symbol.
- Fix built_value_generator/build.yaml to run generator on self package.
- Fix end_to_end_test/pubspec.yaml to include build_runner.
- Fix internal use of deprecated SDK constants.
- Remove polymorphism examples that no longer work in Dart 2. Proper fix to come.
- Allow quiver 0.29.
- Type fixes for DDC.
- Upgrade to latest
built_runner
. You no longer needbuild.dart
orwatch.dart
. Instead, make sure you have a dev dependency onbuilt_value_generator
andbuild_runner
, then runpub run build_runner build
orpub run build_runner watch
. - Note: this version requires the pre release of the Dart 2 SDK.
- Generate simpler deserialization code for
built_collection
instances.
- Fix generated serialization code when a manually declared builder causes a field to not use a nested builder.
- Workaround for analyzer issue when
implement
ing multiple classes that use@BuiltValue(instantiable: false)
.
- Relax restriction on
extends
to allow for one special case: sharing of code betweenbuilt_value
andconst
classes. The base class in question must be abstract, have no fields, have no abstract getters and must not implementoperator==
,hashCode
ortoString
.
- Allow quiver 0.28.
Introduce restrictions on using built_value
in unsupported ways:
- Prohibit use of
extends
inbuilt_value
classes. Classes should inherit API usingimplements
and API+implementation usingextends Object with
. - Prohibit use of
show
oras
when importing 'package:built_value/built_value.dart'. The generated code needs access to all symbols in the package with no import prefix. - Prohibit use of the mutable collection types
List
,Set
,Map
,ListMultimap
andSetMultimap
. Suggestbuilt_collection
equivalents instead.
If any of these restrictions causes problem for you, please file an issue on github: https://github.com/google/built_value.dart/issues
- Allow hand-coded base builders, that is, builders for classes with
@BuiltValue(instantaible: false)
. They are now allowed to not implementBuilder
(as a workaround for a dart2js issue); they are allowed to omit fields; and they must omit constructor and factory.
- Add custom
Error
classes:BuiltValueNullFieldError
,BuiltValueMissingGenericsError
andBuiltValueNestedFieldError
. These provide clearer error messages on failure. In particular, errors in nested builders now report the enclosing class and field name, making them much more useful. - Fix serialization when using polymorphism with StandardJsonPlugin.
- Allow built_collection 3.0.0.
- Allow quiver 0.27.
- Fix generation when analyzing using summaries.
New features:
- Add
serialize
field to@BuiltValueField
. Use this to tag fields to skip when serializing. - Add
wireName
field to@BuiltValue
and@BuiltValueField
. Use this to override the wire name for classes and fields when serializing. - Add
@BuiltValueEnum
and@BuiltValueEnumConst
annotations for specifying settings for enums. AddwireName
field to these to override the wire names in enums when serializing. - Add support for polymorphism to
StandardJsonPlugin
. It will now specify type names as needed via adiscriminator
field, which by defualt is called$
. This can be changed in theStandardJsonPlugin
constructor. - Add
BuiltListAsyncDeserializer
. It provides a way to deserialize large responses without blocking, provided the top level serialized type isBuiltList
. - Add built in serializer for
Uri
.
Improvements:
- Allow declaration of multiple
Serializers
in the same file. - Explicitly disallow private fields; fail with an error during generation if one is found.
- Improve error message for field without type.
Fixes:
- Fix generated builder when fields hold function types.
- Fix checks and generated builder when manually maintained builder has generics.
- Fix name of classes generated from a private class.
- Fix builder and serializer generation when importing with a prefix.
- Use build 0.11.1 and build_runner 0.6.0.
- New annotation,
BuiltValueField
, for configuring fields. First setting available iscompare
. Set tofalse
to ignore a particular field foroperator==
andhashCode
. - Generator now has a
const
constructor.
- Fix for built_collection 2.0.0.
- Allow quiver 0.26.
- Fix generation when a field is found via two levels of inheritance.
- Fix generation when a field comes from an interface but is also implemented by a mixin.
- Support serializing Int64.
- Correct handling of import prefixes; fixes some corner cases in generation.
- Generated code ignores more lints.
- Add a workaround so "polymorphism" features can be used with dart2js. See example/lib/polymorphism.dart.
- Deal explicitly with the user defining their own operator==, hashCode and/or toString(). Previously, they would just not work. Now, custom operator== and hashCode are forbidden at compile time, but custom toString() is supported.
- Generated code now tells the analyzer to ignore prefer_expression_function_bodies and sort_constructors_first.
- Remove an unneeded use of computeNode in generator; improves generator performance.
- Improved annotation handling for corner cases.
- Pick up field declarations from mixins as well as interfaces.
- Fix generated polymorphic builders for the analyzer. Mark the
rebuild
method withcovariant
so the analyzer knows that, for example, aCatBuilder
cannot accept anAnimal
. - Update to build 0.10.0 and build_runner 0.4.0. Please update your
build.dart
andwatch.dart
as shown in the examples.
- Fix DateTime serialization; include microseconds. This is a breaking change to the JSON format.
- Add SerializersFor annotation. Classes to serialize are no longer found by scanning all available libraries, as this was slow and hard to control. Instead, specify which classes you need to serialize using the new annotation on your "serializers" declaration. You only need to specify the "root" classes; the classes needed for the fields of classes you specify are included, transitively.
- Add "nestedBuilders" setting. Defaults to true; set to false to stop using nested builders by default in fully generated builders.
- Allow fields to be called 'result'.
- Fix generation when a field is a noninstantiable built value: don't try to instantiate the abstract builder.
- Update to source_gen 0.7.0.
- Please make the following trivial update to your
build.dart
andwatch.dart
: replace the stringGeneratorBuilder
withPartBuilder
.
- Fix generated code when implementing generic non-instantiable Built class.
- Fix depending on a fully generated builder from a manually maintained builder.
- Pick up fields on implemented interfaces, so you don't have to @override them.
- Add BuiltValue annotation for specifying settings.
- Add "instantiable" setting. When false, no implementation is generated, only a builder interface.
- Polymorphism support: you can now "implement" a non-instantiable Built class. The generated builder will implement its builder, so the types all work.
- Require SDK 1.21 and use the non-comment syntax for generics again.
- Removed dependency on now-unneeded package:meta.
- Fixed a few lints/hints in enum generated code.
- Use comment syntax for generics; using the non-comment syntax requires SDK 1.21 which is not specified in pubspec.yaml.
- Significantly improve build performance by using @memoized instead of precomputed fields.
- Update analyzer and build dependencies.
- Add "built_value_test" library. It provides a matcher which gives good mismatch messages for built_value instances.
- Allow quiver 0.25.
- Version bump to 1.0.0. Three minor features are marked as experimental and may change without a major version increase: BuiltValueToStringHelper, JsonObject and SerializerPlugin.
- Made toString() output customizable.
- Made the default toString() output use indentation and omit nulls.
- Sort serializers in generated output.
- Ignore nulls when deserializing with StandardJsonPlugin.
- Add serializer for "DateTime" fields.
- Add JsonObject class and serializer.
- Add convenience methods Seralizers.serializeWith and deserializeWith.
- Add example for using StandardJsonPlugin.
- Support serializing NaN, INF and -INF for double and num.
- Add serializer for "num" fields.
- Better error message for missing serializer.
- Fix generation when there are nested multi-parameter generics.
- Use cascades in generated code as suggested by lint.
- Allow users to define any factory that references the generated implementation.
- Add example of a simpler factory for a one-field class.
- Enforce that serializer declarations refer to the right generated name.
- Streamline generation for classes with no fields.
- Add identical check to generated operator==.
- Make generated code compatible with strong mode implicit-dynamic:false and implicit-cast:false.
- Add null check to generated builder "replace" methods.
- Fail with error on abstract enum classes.
- Update to
build
0.7.0 ,build_runner
0.3.0, andbuild_test
0.4.0.
- Support "import ... as" for field types.
- Add @memoized. Annotate getters on built_value classes with @memoized to memoize their result. That means it's computed on first access then stored in the instance.
- Support generics, in value types and in serialization.
- Add support for "standard" JSON via StandardJsonPlugin.
- Update dependency on analyzer, build, quiver.
- Breaking change: your build.dart and watch.dart now need to import build_runner/build_runner.dart instead of build/build.dart.
- Fix builder getters to be available before a set is used.
- Fix lints.
- Allow "updates" in value type factory to have explicit void return type.
- Fix some analyzer hints.
- Fix exception from serializer generator if builder field is incorrect.
- Add benchmark for updating deeply nested data structures.
- Make builders copy lazily. This makes updates to deeply nested structures much faster: only the classes on the path to the update are copied, instead of the entire tree.
- Breaking change: if you hand-code the builder then you must mark the fields @virtual so they can be overriden in the generated code.
- Auto-create nested nullable builders when they're accessed. Fixes deserialization with nested nullable builder.
- Merged built_json and built_json_generator into built_value and built_value_generator. These are intended to be used together, and make more sense as a single package.
- Fix generation when class extends multiple interfaces.
- Add serialization of BuiltListMultimap and BuiltSetMultimap.
- Merged enum_class and enum_class_generator into built_value and built_value_generator. These are intended to be used together, and make more sense as a single package.
- Add checking for correct type arguments for Built and Builder interfaces.
- Generate empty constructor with semicolon instead of {}.
- Use ArgumentError.notNull for null errors.
- Reject dynamic fields.
- Add simple benchmark for hashing. Improve hashing performance.
- Allow quiver 0.23.
- Upgrade analyzer, build and source_gen dependencies.
- Generate builder if it's not written by hand.
- Make toString append commas for improved clarity.
- Improve examples and tests.
- Fix double null checking.
- Refactor generator to split into logical classes.
- Improve error output on failure to generate.
- Upgrade to source_gen 0.5.0.
- Breaking change; see example for required changes to build.dart.
- Move null checks to "build" method for compatibility with Strong Mode analyzer.
- Allow (and ignore) setters.
- Allow custom factories on value classes.
- Fix for changes to analyzer library.
- Support @nullable for fields using builders.
- Fix constraints for source_gen.
- Allow static fields in value class.
- Allow custom setters in builder.
- Fix error message for missing builder class.
- Allow non-abstract getters in value class.
- Generator, tests and example.