Dart/Flutter
Introduction
https://en.wikipedia.org/wiki/Dart_(programming_language) is a language created by Google to replace Javascript. It is targetting a VM (DartVM).
https://en.wikipedia.org/wiki/Flutter_(software) is a framework to create native, web, or mobile apps (from the same code) written in Dart.
Status
Dart: It’s supported for Windows on Arm for Dev Channel and latest binaries are available here (or on this page: Dart SDK archive ).
Flutter: Build from source works, and flutter engine binaries are available. Compile natively flutter app is now supported (https://github.com/flutter/flutter/pull/141930 ). Cross compilation is not upstream, but you can use this PR if you’re interested: Enable cross compilation for windows-arm64 by pbo-linaro · Pull Request #142431 · flutter/flutter.
See this design document for details: https://docs.google.com/document/d/1yuexY-EtzeVhU3V6RGBII_kH-znLSkQCspzW70jayZk/edit?resourcekey=0-8pQRSXSHQlwOo7QtCVLvBA and open issues https://github.com/flutter/flutter/issues/62597.
Flutter App
Since Dart and Flutter engine are now built upstream, we document how to simply create, build and run a flutter App.
If you’re interested in manually building dart or flutter itself, you can follow other instructions on this page.
git clone https://github.com/flutter/flutter
flutter/bin/flutter.bat create app
cd app
../flutter/bin/flutter.bat build windows
file build/windows/arm64/runner/Release/app.exe
# on windows-x64, it will build an x64 app instead
If you’re interested in cross compilation, take a look at this PR: Enable cross compilation for windows-arm64 by pbo-linaro · Pull Request #142431 · flutter/flutter
Setup (common to both projects)
Note: This is needed only if you intend to build dart and flutter manually. Upstream artifacts are now available for windows-arm64, so there is no need to build this manually.
Those two projects are built using chromium build system (gn - Git at Google , a cmake like, and https://commondatastorage.googleapis.com/chrome-infra-docs/flat/depot_tools/docs/html/depot_tools_tutorial.html#_setting_up ). Both projects provide wrappers to build, without the need to call gn
directly.
get visual studio components
you need to install ATL libraries for your visual studio version.
get windows sdk debuggers
you need to install debuggers from Windows SDK - Windows app development . Dart/Flutter build search for dbgcore.dll and dbghelp.dll.
get python3
python3.exe
should be available on the PATH. arm64 version should be installed as it is used by depot_tools to identify cpu architecture.
When installing python on windows, only python.exe
is available. You need to copy it (duplicate it) as python3.exe
.
get depot_tools
First, you need to retrieve depot_tools from this URL, and unzip it
Then, add following directories to your PATH:
# contains ninja.exe and other binaries for windows
depot_tools/.cipd_bin
# main scripts (fetch, gsync, ...)
depot_tools/
set environment
# force to get local toolchain (needed when you're not a Google employee)
set DEPOT_TOOLS_WIN_TOOLCHAIN=0
Dart
Note: Dart artifacts are now built upstream, and it’s not needed to build this manually.
Clone
fetch dart
cd sdk
Build
python3 ./tools/build.py --arch arm64 --mode release create_sdk --no-goma
Test
python3 ./tools/test.py -mrelease --arch=arm64 --runtime=vm --compiler=none vm
# you can select other test suites than "vm"
Run
Create file named hw.dart with this content:
void main() {
print('Hello, World!');
}
You can run it using:
# execute directly
out/ReleaseXARM64/dart.exe run hw.dart
# compile it to bytecode
out/ReleaseXARM64/dart.exe compile kernel hw.dart -o hw.dill
# run from bytecode
out/ReleaseXARM64/dart.exe run hw.dill
Flutter
Note: Flutter artifacts are now built upstream, and it’s not needed to build this manually.
Clone
fetch flutter
cd src
Build engine
set GYP_MSVS_OVERRIDE_PATH='C:\Program Files (x86)\Microsoft Visual Studio\2019\Community'
# --no-goma: is google distributed build system (only for Googlers)
python3 ./flutter/tools/gn --no-goma --windows-cpu arm64 --target-dir host_debug
ninja -C out/host_debug
CI
Flutter uses GitHub Actions Workflow runs · flutter/flutter
Binary availability
Flutter (prebuilt) binaries are automatically downloaded first time flutter
command is run. Based on current cpu architecture, it will download native windows-x64 or windows-arm64 binaries.
git clone https://github.com/flutter/flutter
cd flutter
./bin/flutter --help
Â
Â