Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yuk7/wsldl
Advanced WSL launcher / installer. (Win10 FCU x64/arm64 or later.)
https://github.com/yuk7/wsldl
linux windows-10 windows-11 windows-subsystem-linux windows-terminal wsl wsldl
Last synced: 3 days ago
JSON representation
Advanced WSL launcher / installer. (Win10 FCU x64/arm64 or later.)
- Host: GitHub
- URL: https://github.com/yuk7/wsldl
- Owner: yuk7
- License: mit
- Created: 2017-10-17T10:04:09.000Z (about 7 years ago)
- Default Branch: main
- Last Pushed: 2024-12-09T16:48:09.000Z (about 1 month ago)
- Last Synced: 2025-01-02T05:06:04.780Z (10 days ago)
- Topics: linux, windows-10, windows-11, windows-subsystem-linux, windows-terminal, wsl, wsldl
- Language: Go
- Homepage: https://git.io/wsldl
- Size: 2.32 MB
- Stars: 1,774
- Watchers: 33
- Forks: 131
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- stars - yuk7/wsldl
- jimsghstars - yuk7/wsldl - Advanced WSL launcher / installer. (Win10 FCU x64/arm64 or later.) (Go)
README
# wsldl
Advanced WSL Distribution Launcher / Installer![wsldl logo](https://github.com/yuk7/wsldl/assets/29954265/8c8804f7-29a2-43c7-a9ed-c763a2196100)
[![GitHub Workflow Status](https://img.shields.io/github/actions/workflow/status/yuk7/wsldl/ci.yml?style=flat-square)](https://github.com/yuk7/wsldl/actions/workflows/ci.yml)
[![Github All Releases](https://img.shields.io/github/downloads/yuk7/wsldl/total.svg?style=flat-square)](https://github.com/yuk7/wsldl/releases/latest)
[![PRs Welcome](https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=flat-square)](http://makeapullrequest.com)
![License](https://img.shields.io/github/license/yuk7/wsldl.svg?style=flat-square)### [Detailed documentation is here](https://git.io/wsldl-doc)
## đź’»Requirements
* Windows 10 1709 Fall Creators Update or later(x64/arm64).
* Windows Subsystem for Linux feature is enabled.## 📦Install with Prebuilt Packages
[**You can see List on docs**](https://wsldl-pg.github.io/docs/Using-wsldl/#distros)**Note:**
Exe filename is using to the instance name to register.
If you rename it, you can register with a different name.## 🔧Install with any rootfs tarball
**Note:**
The filesystem needs to be in the root of the tarball, some rootfs tarballs may need to be repacked.#### 1. [Download wsldl.exe](https://github.com/yuk7/wsldl/releases/latest)
(wsldl.exe is x86_64, wsldl_arm64.exe is ARM64 build)
#### 2. Rename it for distribution name to register.
(Ex: Rename to Arch.exe if you want to use "Arch" for the Instance name)
#### 3. Put your install.tar(.gz) in same directory as exe (Installation directory)
#### 4. Run exe to install. This process may take a few minutes.## 🔧Install with any ext4 vhdx disk images (WSL2 only)
#### 1. [Download wsldl.exe](https://github.com/yuk7/wsldl/releases/latest)
(wsldl.exe is x86_64, wsldl_arm64.exe is ARM64 build)
#### 2. Rename it for distribution name to register.
(Ex: Rename to Arch.exe if you want to use "Arch" for the Instance name)
#### 3. Put your install.ext4.vhdx(.gz) in same directory as exe (Installation directory)
#### 4. Run exe to install. This process may take a few minutes.## đź”—Use as a Launcher for already installed distribution
#### 1. [Download wsldl.exe](https://github.com/yuk7/wsldl/releases/latest)
(wsldl.exe is x86_64, wsldl_arm64.exe is ARM64 build)
#### 2. Rename it for registerd instance name.
Please check the registered instance name of the distribution with `wslconfig /l` command.
(Ex: If the instance name is "Ubuntu-20.04", rename `wsldl.exe` to `Ubuntu-20.04.exe`)
#### 4. Run exe to Launch instance or configuration.
For details, please see the help. (`{InstanceName}.exe help`)Note: You can distribute your distribution including wsldl exe.
## đź“ťHow-to-Use(for Installed Instance)
#### exe Usage
```
Usage :
- Open a new shell with your default settings.run
- Run the given command line in that instance. Inherit current directory.runp
- Run the given command line in that instance after converting its path.config [setting [value]]
- `--default-user `: Set the default user of this instance to .
- `--default-uid `: Set the default user uid of this instance to .
- `--append-path `: Switch of Append Windows PATH to $PATH
- `--mount-drive `: Switch of Mount drives
- `--wsl-version <1|2>`: Set the WSL version of this instance to <1 or 2>
- `--default-term `: Set default type of terminal window.get [setting]
- `--default-uid`: Get the default user uid in this instance.
- `--append-path`: Get true/false status of Append Windows PATH to $PATH.
- `--mount-drive`: Get true/false status of Mount drives.
- `--wsl-version`: Get the version os the WSL (1/2) of this instance.
- `--default-term`: Get Default Terminal type of this instance launcher.
- `--lxguid`: Get WSL GUID key for this instance.backup [contents]
- `--tar`: Output backup.tar to the current directory.
- `--tgz`: Output backup.tar.gz to the current directory.
- `--vhdx`: Output backup.ext4.vhdx to the current directory. (WSL2 only)
- `--vhdxgz`: Output backup.ext4.vhdx.gz to the current directory. (WSL2 only)
- `--reg`: Output settings registry file to the current directory.clean
- Uninstall that instance.help
- Print this usage message.
```#### Just Run exe
```cmd
>{InstanceName}.exe
[root@PC-NAME user]#
```#### Run with command line
```cmd
>{InstanceName}.exe run uname -r
4.4.0-43-Microsoft
```#### Run with command line with path translation
```cmd
>{InstanceName}.exe runp echo C:\Windows\System32\cmd.exe
/mnt/c/Windows/System32/cmd.exe
```#### Change Default User(id command required)
```cmd
>{InstanceName}.exe config --default-user user>{InstanceName}.exe
[user@PC-NAME dir]$
```#### Set "Windows Terminal" as default terminal
```cmd
>{InstanceName}.exe config --default-term wt
```#### How to uninstall instance
```cmd
>{InstanceName}.exe clean```
#### How-to-backup
export to backup.tar.gz (WSL1 or 2)
```cmd
>{InstanceName}.exe backup --tgz
```
export to backup.ext4.vhdx.gz (WSL2 only)
```cmd
>{InstanceName}.exe backup --vhdxgz
```#### How-to-import
.tar(.gz) (WSL1 or 2)
```cmd
>{InstanceName}.exe install backup.tar.gz
```
.ext4.vhdx(.gz) (WSL2 only)
```cmd
>{InstanceName}.exe install backup.ext4.vhdx.gz
```## đź› How-to-Build
Please see [DEVELOPERS.md](DEVELOPERS.md)## đź“„License
[MIT](LICENSES.md)Copyright (c) 2017-2021 [yuk7](https://github.com/yuk7)