- 2201.10.0 (Swan Lake Update 10)
- 2201.9.3 (Swan Lake Update 9)
- 2201.9.2 (Swan Lake Update 9)
- 2201.9.1 (Swan Lake Update 9)
- 2201.9.0 (Swan Lake Update 9)
- 2201.8.8 (Swan Lake Update 8)
- 2201.8.7 (Swan Lake Update 8)
- 2201.8.6 (Swan Lake Update 8)
- 2201.8.5 (Swan Lake Update 8)
- 2201.8.4 (Swan Lake Update 8)
- 2201.8.3 (Swan Lake Update 8)
- 2201.8.2 (Swan Lake Update 8)
- 2201.8.1 (Swan Lake Update 8)
- 2201.8.0 (Swan Lake Update 8)
- 2201.7.5 (Swan Lake Update 7)
- 2201.7.4 (Swan Lake Update 7)
- 2201.7.3 (Swan Lake Update 7)
- 2201.7.2 (Swan Lake Update 7)
- 2201.7.1 (Swan Lake Update 7)
- 2201.7.0 (Swan Lake Update 7)
- 2201.6.3 (Swan Lake Update 6)
- 2201.6.2 (Swan Lake Update 6)
- 2201.6.1 (Swan Lake Update 6)
- 2201.6.0 (Swan Lake Update 6)
- 2201.5.5 (Swan Lake Update 5)
- 2201.5.4 (Swan Lake Update 5)
- 2201.5.3 (Swan Lake Update 5)
- 2201.5.2 (Swan Lake Update 5)
- 2201.5.1 (Swan Lake Update 5)
- 2201.5.0 (Swan Lake Update 5)
- 2201.4.3 (Swan Lake Update 4)
- 2201.4.2 (Swan Lake Update 4)
- 2201.4.1 (Swan Lake Update 4)
- 2201.4.0 (Swan Lake Update 4)
- 2201.3.5 (Swan Lake Update 3)
- 2201.3.4 (Swan Lake Update 3)
- 2201.3.3 (Swan Lake Update 3)
- 2201.3.2 (Swan Lake Update 3)
- 2201.3.1 (Swan Lake Update 3)
- 2201.3.0 (Swan Lake Update 3)
- 2201.2.4 (Swan Lake Update 2)
- 2201.2.3 (Swan Lake Update 2)
- 2201.2.2 (Swan Lake Update 2)
- 2201.2.1 (Swan Lake Update 2)
- 2201.2.0 (Swan Lake Update 2)
- 2201.1.2 (Swan Lake Update 1)
- 2201.1.1 (Swan Lake Update 1)
- 2201.1.0 (Swan Lake Update 1)
- 2201.0.5 (Swan Lake)
- 2201.0.4 (Swan Lake)
- 2201.0.3 (Swan Lake)
- 2201.0.2 (Swan Lake)
- 2201.0.1 (Swan Lake)
- 2201.0.0 (Swan Lake)
- Swan Lake Beta6
- Swan Lake Beta5
- Swan Lake Beta4
- Swan Lake Beta3
- Swan Lake Beta2
- Swan Lake Beta1
- Swan Lake Alpha5
- Swan Lake Alpha4
- Swan Lake Alpha3
- Swan Lake Alpha2
- Swan Lake Alpha1
- Swan Lake Preview 8
- Swan Lake Preview 7
- Swan Lake Preview 6
- Swan Lake Preview 5
- Swan Lake Preview 4
- Swan Lake Preview 3
- Swan Lake Preview 2
- Swan Lake Preview 1
- 1.2.54
- 1.2.53
- 1.2.52
- 1.2.51
- 1.2.50
- 1.2.49
- 1.2.48
- 1.2.47
- 1.2.46
- 1.2.45
- 1.2.44
- 1.2.43
- 1.2.42
- 1.2.41
- 1.2.40
- 1.2.39
- 1.2.38
- 1.2.37
- 1.2.36
- 1.2.35
- 1.2.34
- 1.2.33
- 1.2.32
- 1.2.31
- 1.2.30
- 1.2.29
- 1.2.28
- 1.2.27
- 1.2.26
- 1.2.25
- 1.2.24
- 1.2.23
- 1.2.22
- 1.2.21
- 1.2.20
- 1.2.19
- 1.2.18
- 1.2.17
- 1.2.16
- 1.2.15
- 1.2.14
- 1.2.13
- 1.2.12
- 1.2.11
- 1.2.10
- 1.2.9
- 1.2.8
- 1.2.7
- 1.2.6
- 1.2.5
- 1.2.4
- 1.2.3
- 1.2.2
- 1.2.1
- 1.2.0
Overview of Ballerina Swan Lake 2201.4.0
2201.4.0 (Swan Lake Update 4) is the fourth update release of Ballerina Swan Lake, and it includes a new set of features and significant improvements to the compiler, runtime, standard library, and developer tooling. It is based on the 2022R4 version of the Language Specification.
Update Ballerina
Update your current Ballerina installation directly to 2201.4.0 using the Ballerina Update Tool as follows.
- Run
bal update
to get the latest version of the Update Tool. - Run
bal dist pull 2201.4.0
to update to this latest distribution.
Install Ballerina
If you have not installed Ballerina, download the installers to install.
Language updates
New features
Support for annotations on tuple members
Annotations are now supported on tuple members. Tuple members can be annotated using annotations declared with the field
attachment point.
annotation annot on field; type T [int, @annot string];
Annotations are not allowed on the tuple rest descriptor.
Bug fixes
Annotation values of fields of record type descriptors that are not defined with a type definition are now accessible at runtime.
To view other bug fixes, see the GitHub milestone for 2201.4.0 (Swan Lake).
Runtime updates
New features
Get the strand dump during bal test
When running the tests in a Ballerina package or a file using the bal test
command, the strand dump can be obtained by sending the SIGTRAP
signal to that process.
Improvements
Get the user-defined type name on singleton types
Calling getName()
on the FiniteType
runtime class will return the user-defined type name if it is available.
For example, if a constant is defined in the following way, the getName()
method on the FiniteType
will return the "OPEN"
string.
const OPEN = "open";
Type-reference type support in runtime Java APIs
The following runtime APIs are now modified to return the type-reference type instances according to the type definitions.
Runtime API | Java class |
---|---|
getElementType | io.ballerina.runtime.api.types.ArrayType |
getDetailType | io.ballerina.runtime.api.types.ErrorType |
getFieldType | io.ballerina.runtime.api.types.Field |
getParameterTypes | io.ballerina.runtime.api.types.FunctionType |
getReturnType | io.ballerina.runtime.api.types.FunctionType |
getReturnParameterType | io.ballerina.runtime.api.types.FunctionType |
getRestType | io.ballerina.runtime.api.types.FunctionType |
getParameters (The Parameter.type field can be a type-reference type.) | io.ballerina.runtime.api.types.FunctionType |
getConstituentTypes | io.ballerina.runtime.api.types.IntersectionType |
getEffectiveType | io.ballerina.runtime.api.types.IntersectionType |
getConstrainedType | io.ballerina.runtime.api.types.MapType |
getParamValueType | io.ballerina.runtime.api.types.ParameterizedType |
getRestFieldType | io.ballerina.runtime.api.types.RecordType |
getReferredType | io.ballerina.runtime.api.types.ReferenceType |
getConstrainedType | io.ballerina.runtime.api.types.StreamType |
getCompletionType | io.ballerina.runtime.api.types.StreamType |
getConstrainedType | io.ballerina.runtime.api.types.TableType |
getTupleTypes | io.ballerina.runtime.api.types.TupleType |
getRestType | io.ballerina.runtime.api.types.TupleType |
getConstraint | io.ballerina.runtime.api.types.TypedescType |
getMemberTypes | io.ballerina.runtime.api.types.UnionType |
getOriginalMemberTypes | io.ballerina.runtime.api.types.UnionType |
getElementType | io.ballerina.runtime.api.values.BArray |
getConstraintType | io.ballerina.runtime.api.values.BStream |
getCompletionType | io.ballerina.runtime.api.values.BStream |
getKeyType | io.ballerina.runtime.api.values.BTable |
getDescribingType | io.ballerina.runtime.api.values.BTypedesc |
getType | io.ballerina.runtime.api.values.BValue |
getType | io.ballerina.runtime.api.utils.TypeUtils |
For example, if the type-reference types are defined in the following way,
type Integer int; type IntegerArray Integer[]; IntegerArray arr = [1, 2, 3, 4];
the results of the runtime API calls will be as follows.
Runtime API call | Result |
---|---|
arr.getType() | This will return a ReferenceType with the IntegerArray name. |
getReferredType() on IntegerArray | This will return an ArrayType with the IntegerArray name. |
getElementType() on IntegerArray array type | This will return a ReferenceType with the Integer name. |
Bug fixes
To view bug fixes, see the GitHub milestone for 2201.4.0 (Swan Lake).
Standard library updates
New features
constraint
package
- Added constraint validation support for
readonly
types.
oauth2
package
- Allowed the use of inferred values for refreshing tokens through the password grant type.
- Allowed the use of string values for the
scopes
field in the client grant configuration.
graphql
package
- Added support for multiplexing in GraphQL subscriptions.
- Added support to access the GraphQL field information from resolvers.
nats
package
- Added support for the new NATS JetStream client with publishing and subscribing functionalities.
persist
package
-
Added support for the Ballerina persistent layer. This functionality is provided with the newly introduced
persist
package.The Ballerina persistent layer provides the functionality of storing and querying data conveniently.
Info: This is an experimental feature. APIs might change in future releases.
Improvements
graphql
package
- Removed the limitation on the parameter order of the GraphQL
context
object.
Bug fixes
To view bug fixes, see the GitHub milestone for 2201.4.0 (Swan Lake).
Code to Cloud updates
New features
- Added the ability to disable the thin JAR file generation by setting
settings.thinJar = false
inCloud.toml
.
Improvements
- Improved the main class name generation in
CMD
to support complex package names.
Bug fixes
To view bug fixes, see the GitHub milestone for 2201.4.0 (Swan Lake).
Developer tools updates
New features
Test Framework
-
Added support for executing tests using a GraalVM native image (experimental).
Info: Introduced the
--native
flag to thebal test
command, which executes tests using a GraalVM native executable.
Language Server
- Added the
Create variable with Type
code action. - Added rename popup support to the
Extract to constant
,Extract to local variable
, andExtract to function
code actions.
Info: This feature will be available from the Ballerina VS Code extension version
4.0.0
.
- Added quick pick support for selecting expressions in the
Extract to constant
code action.
GraphQL Tool
- Added support for GraphQL SDL schema file generation.
OpenAPI Tool
- Added support to generate Ballerina client and service declarations from Swagger 2.0 (i.e., OpenAPI 2.0) definitions.
Persist Tool
-
Added a new
persist
command for users to enable the Ballerina persistence layer in a Ballerina project conveniently.With this support, users can define an entity data model, validate the model, and generate
persist
clients. This provides convenient APIs to store and query data in a data store.Info: This is an experimental feature. The commands associated with the tool might change in future releases.
Improvements
CLI
-
Improved the
bal format
CLI command by introducing new command options to format modules or single files selectively with a provided Ballerina package. The updated format of thebal format
command is shown below.bal format [OPTIONS] [<package>|<module>|<source-file>]
OPTIONS --module <module-name> Format only a specific module in the Package --file <file-name> Format only a specific file in the Package -d, --dry-run Perform a dry run of the formatter and see which files will be formatted after the execution.
JSON-to-record converter
- Improved the JSON-to-record converter tool to be more context-aware and generate records with non-conflicting names.
Language Server
- Improved the completion and code action support for pulled modules.
- Improved sorting of module-level completion items.
- Used the code action resolve request for compiler plugin code actions.
OpenAPI Tool
- Added support for the
additionalProperties
attribute in OpenAPI object schemas. With this support, the generated Ballerina records can be either open or closed records based on theadditionalProperties
details.Info: Thereby, some of your already generated open records may change into closed records when re-generating using 2201.4.0 (and above) versions.
- Improved the behaviour for the
nullable:true
property in OpenAPI schemas, to generate record fields with default values (e.g.,string? name = ();
), instead of making the field both nilable and optional (e.g.,string? name?;
). - Changed the default request and response types of the generated Ballerina resource/remote methods from
json
tohttp:Request
andhttp:Response
respectively.
Bug fixes
To view bug fixes, see the GitHub milestone for 2201.4.0 (Swan Lake) of the repositories below.
Ballerina packages updates
New features
Added support for maintaining generated code in a Ballerina package.
Backward-incompatible changes
-
Modified the definitions of the
getType
API in theBObject
runtime class to the following.Type getType();
Also, modified the behavior of the runtime Java APIs to support the type-reference type.
Note: The modules that use these APIs that are compiled with older Ballerina versions will break now due to these modifications. Deleting the
Dependencies.toml
file, clearing the internal cache, and republishing these modules will be required to resolve this. -
Fixed a bug that incorrectly resolved the result type of a query action that would complete normally to
error?
instead of()
. Now, the result type includeserror
only in instances where an error can be generated during the execution of the query pipeline (from
clause/join
clause).public function main() returns error? { from int i in 1 ... 3 // now valid do { }; } function iterateStream(stream<int, error?> numberStream) returns error? { check from int num in numberStream do { }; }
-
Fixed a bug that incorrectly propagated errors returned in a
do
clause of a query action to the result of the query action. Now, if the execution of a statement within ado
clause fails with an error, it will be propagated to the nearest enclosing failure-handling statement.public function main() { error? queryActResult = from int i in 1 ... 3 do { check validateAndGetError(); // error: invalid usage of the 'check' expression operator; // no matching error return type(s) in the enclosing invokable }; } function validateAndGetError() returns error? { return error("Invalid error"); }
-
Fixed a bug that resulted in variables that may or may not be initialized in an
on fail
clause not being identified as potentially uninitialized variables.public function main() { int resultInt; transaction { resultInt = check maybeProvideInt(true); check commit; } on fail { io:println("Failed to initialize resultInt"); } resultInt += 1; // error: resultInt may not have been initialized }
-
Made the column headers mandatory in CSV files to ensure the order of fields while mapping CSV files to records. This is only applicable for the case where the expected type is
record[]
. -
Made the column headers automatically be written to the CSV file to ensure the order of fields while writing a
record[]
to a CSV. -
Added new improvements to the
bal format
command to address some of the existing limitations may break the CLI usages of thebal format <module-name>
option.Info: In such instances, the
bal format <package-path> --module <module-name>
option can be used for the same purpose from the Swan Lake Update 4 release onwards.