A powerful Zig-based tool to manage all your GitHub repositories with ease
β
Choose your platform and run the installation command:
π§ Linux
curl -fsSL https://raw.githubusercontent.com/gaskam/workspace/refs/heads/main/install.sh | bashπͺ Windows PowerShell
irm raw.githubusercontent.com/gaskam/workspace/refs/heads/main/install.ps1 | iexThis script will:
Workspace can be called with the following arguments:
For cloning repositories from a GitHub organization or user:
workspace clone <organization/user> [destination] [--flags]Flags:
| Flag | Description | 
|---|---|
| --limit,-l | Limit the number of repositories to clone | 
| --processes,-p | Limit the number of concurrent processes -> Default is the number of logical CPUs - 1 | 
| --prune | Delete repositories that do not belong to current user | 
For showing help:
workspace helpFor showing the version:
workspace versionFor updating Workspace:
workspace updateFor uninstalling Workspace:
workspace uninstallClone repositories from an organization
# Clone first 10 repos from ziglang
workspace clone ziglang ./workspace -l 10
# Clone all repos with 8 concurrent processes
workspace clone microsoft ./code -p 8
# Clone and clean up old repos
workspace clone gaskam ./projects --prune[!NOTE] Note that if you provide
--limitand--pruneflags, weβll delete the repositories that no longer exist once the limit is reached.This is useful for keeping your workspace clean and up-to-date.
[!WARNING] If you use the
--processesflag with a number higher than your number of CPU threads, you may experience performance issues.This can be useful if you want to override the default number of simultaneous processes, in order to go faster. It will be faster than the default value, but at the cost of a higher ressource usage.
This benchmark was run on a GitHub codespaces instance with 4 vCPUs and 16GB of RAM.
[!NOTE] GitHub Codespaces is quite slow, since it clones with just one process.
Weβre using hyperfine to measure the time taken to clone each repositories from the specified organization.
Realized on 2024-12-03 with the 1.2.2 version of Workspace.
| Organization | Repositories Cloned | Time Taken [s] | 
|---|---|---|
| ziglang | 24 | 103.458 Β± 4.833 | 
| gaskam | 11 | 3.454 Β± 0.185 | 
For developers who want to contribute or build Workspace from source:
| Tool | Purpose | Installation | 
|---|---|---|
| β‘ Zig | Building the application | Download | 
| π GitHub CLI | Interacting with GitHub | Download | 
| π¦ Git | Git, forever and ever | Download | 
git clone https://github.com/gaskam/workspace.git
cd workspacezig build./zig-out/bin/workspace -hContributions are welcome! Feel free to:
Workspace is licensed under the MIT License. See the LICENSE file for more information.
Made with β€οΈ by Gaskam