DevContainer Tauri
Dev Container
Wiki
Commands
Getting started
Before you can get started using dev containers you first need to set up your environment. Make sure you first read the official guide on the topic.
Read this: https://code.visualstudio.com/docs/devcontainers/containers
Alternative 1: Submodule
This approach offers easy updates from upstream since you can just pull the latest version from Github.
Then in order to update the module you can simply do the following:
Git submodules are pinned to a specific commit, which is why you’re going to have to checkout the appropriate branch each time. Submodules aren’t always the easiest to work with, but once you get the hang of them the issues, in my opinon, are worth the added benefits.
Alternative 2: Clone
With this approach you clone the project and then remove the .git
folder in order to effectively copy the folder from Github. This has the benefit of you not having to learn how submodules work and you won’t have another dependency in your project, but it doesn’t offer easy updates.
Important notes
Tauri
Use cargo tauri
instead of e.g. pnpm tauri
I still haven’t found the cause of it but for me pnpm tauri
doesn’t work properly. So I’ve packaged a version of the CLI that does work for me, and it should work for you too.
Android
Accessing devices on your host is a WIP
- Get ADB to connect to the host: Using port forwarding I’ve already figured out how to connect your running ADB instance on the host to the one running in the container. Thanks to this you’re able to connect to any devices you can find on your host as per usual, both emulators and physical devices
- Get the frontend running in the container to the device: Currently I have only figured out how to get the app to install. Exposing the frontend to the device however is another story and I haven’t quite figured that one out yet
- Forward a USB connected device straight to the container: Since running an ADB server on the host requires you to set up your host, it’d be even better if you can just access your physical device straight in the container, and to do that the best solution would be to get your USB device to be forwarded, but I haven’t figured that one out yet
The in-container emulator has poor performance
The solution to this is to run the emulator on your host, or even connecting to a physical device. This however is a work in progress.
Performance
Windows
Use WSL
If you don’t use WSL you will have a massive performance drop related to disk I/O which is caused by differing filesystems. Make sure your project resides in e.g. ~/projects/my-app
Allocate sufficient RAM (recommend >16GB)
If you don’t have enoug RAM accessible to WSL then VSCode has a nasty habit of crashing. I’m not sure exactly where the line is drawn, but I’m using 16GB.
I’ve added the Mold linker to the system
This will speed up desktop builds (not Android builds). It’s something to be aware of because while it can drastically enhance the speed of which your project is built it’s not necessarily suitable for production builds. You have been warned.