Mar 24, 2023

Records and Patterns in Dart — Flutter Forward Extended, Bangalore @ GeekyAnts

Learn about the latest language features, Records and Patterns in Dart 3 alpha, in Vivek Yadav’s latest talk at Flutter Forward Extended, GeekyAnts, Bangalore.
Ahona Das
Ahona DasTechnical Content Writer
lines

Speaker:

  • Vivek Yadav, Mobile Team Lead at ZestMoney, Google Developer Expert, Flutter community leader.

This article covers Vivek Yadav’s recent talk at the Flutter Forward Extended Bangalore meetup at GeekyAnts. The talk discusses everything new and experimental in Dart 3α, with a detailed focus on the latest language feature, Records and Patterns.

Introduction

We all know Flutter is an open-source, portable UI toolkit designed to enable beautiful experiences on any platform. Beautiful, fast, productive, portable, and open are the features we generally associate with Flutter.

So what is new?

Dart 3 is the latest version of the Dart language. It is expected to stabilize by June or July 2023. Currently, it is available as Dart 3 alpha — if you want to test it out. Let us first take a look at the features of this latest version.

Features of Dart latest version (Dart 3 alpha)

If we have a null variable, we write a few extra steps to make sure that the code works right. In Dart 3, this will be removed. Now, Dart will know that our variable will not be null and will always have a type. While compiling, Dart 3 will remove a lot of codes. RISC-V is an architecture that Dart 3 will support. 

What are Records?

The following are some features of records:

Features of records

Let us look at a simple Dart code.

We have a list of objects as a function. The user information will pass our json, and it will give us a map.

Screenshot 2023-03-10 at 4.00.14 PM.png

But, we have an issue here. Refer to the image:

Screenshot 2023-03-10 at 4.05.31 PM.png

To get the information passed from the function userInfo, we will have to lose our type, because it was the type of an object. It is difficult to know if info[0] is a string or integer, or something else.

So as soon as the API changes, it will break. We can create a class userInfo where we can keep our type.

Screenshot 2023-03-10 at 4.12.18 PM.png

Record will give us something like this:

Screenshot 2023-03-10 at 4.13.37 PM.png

Depending on the use case, we can have multiple written types. A simple example is when we do an API call. We might return a response and a few more pieces of information that we do not want to store in a class. If we are creating a class, we are adding some memory bits to our allocated memory. We can use records here.

What are Patterns?

The Patterns feature is another fascinating Dart API. Using the same example, we can see that while importing, we are using $1, and $2 to get the data.

Screenshot 2023-03-10 at 5.47.06 PM.png
Screenshot 2023-03-10 at 5.49.00 PM.png

The above is a pattern in which our variable is initialized. So whatever data we will pass from user information, for example, name and age, we will pass this information in record data type and then using a pattern, we can give it a name and age

Screenshot 2023-03-10 at 5.52.52 PM.png

Note: If we do not want to use a variable, we can mark it as an underscore. We can also use the same underscore in multiple places. For instance:

Screenshot 2023-03-10 at 6.02.35 PM.png

The use case is something like the image added below, where we already have variables assigned. What we can do is create a simple pattern, as shown below. Whenever our function returns something, it will be populated in these variables.

Screenshot 2023-03-10 at 6.05.48 PM.png

Some Experimental Features

The following features are still experimental, and we must wait to see if they are included in Dart 3. We know we can use the if condition to show a UI element in a widget tree. This is a conditional thing.

Screenshot 2023-03-10 at 6.11.47 PM.png

If we want to use the same thing on the ListTile, we will have a variable, and then we will check. After the process. we will have a ternary operator, and then it is null if we don’t want to show:

Screenshot 2023-03-10 at 6.16.27 PM.png

But, we can do the following:

Screenshot 2023-03-10 at 6.19.36 PM.png

Some More Use Cases of Pattern

Screenshot 2023-03-10 at 8.45.30 PM.png

In the image above, we have a json which has a type user. In the type user, we have an array with Lily and 13. We can retrieve the data as shown in the above code snippet. 

The following is how we write a record:

Screenshot 2023-03-10 at 8.48.12 PM.png

It will take type automatically. We have the option to tell type as well. The first two variables (positional variables), if we are going to use them without a pattern, will be $1, and $2, and the next two will be x or y

Screenshot 2023-03-10 at 8.54.48 PM.png

This is an interesting use case of a pattern.

Now that we know what our variable will look like, we can create a pattern against this particular variable. We have a variable inside an array that will hold the value of name and age.

Screenshot 2023-03-10 at 8.59.33 PM.png

This is the variable we created.

Then we assign this variable to the pattern and the code looks like this:

Screenshot 2023-03-10 at 9.04.56 PM.png

We will first check if our json is of type Map, then if it contains a key user or not and if this key is List or not, and if it is List, whether it has some size or not. This can be removed with the pattern feature. 

Screenshot 2023-03-13 at 12.21.07 PM.png

Because we have already created a pattern, we can have a switch statement or if statement, where we can ask for values if a condition matches. This is the use case of the pattern feature. 

Switch Statement

Screenshot 2023-03-13 at 12.26.25 PM.png

The above is a simple switch statement. Using a pattern, we can convert it like this:

Screenshot 2023-03-13 at 12.27.28 PM.png

Using pattern, we can thus reduce the code in this manner, with the help of switch.

This same code can also be written as shown below. Note that this is code for compilers.

Screenshot 2023-03-13 at 12.35.08 PM.png

Use cases of Records and Patterns

Let us check out some use cases of records and patterns:

  • Records- There might be situations where you have to return multiple values. You can use records in such situations.
  • Patterns- If something is coming from an unknown source, you can use patterns to check if that particular output matches something. For example, you are getting multiple responses from an API call. The first response will be a success, the second error, and the third success with some other element. So you can have a switch statement with all these patterns, and patterns can match them, and you have your value.

New Directions for Flutter and Dart

In summary, both records and patterns represent improvements over the traditional way of storing data. The talk concludes with a brief overview of the latest developments in Flutter and Dart, as outlined below:

Screenshot 2023-03-13 at 12.48.32 PM.png

JNI gen and FFI gen are ways to directly interact with C code, Rust, or any other language. For instance, if we have a C library that is very efficient in doing image processing, with JNI and FFI gen, we can do direct integration instead of going through the platform channel and then Android, and so on for code generation.

All these updates mean better-performing apps and faster development timelines. It is also good news for developer experience.

For the full talk and additional resources on the latest Dart updates, check out the video of Vivek’s talk here.

Ref: https://github.com/dart-lang/language/blob/master/accepted/future-releases/records/records-feature-specification.md

Hire our Development experts.