Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pkgxdev/pkgx
run anything
https://github.com/pkgxdev/pkgx
environment-manager package-manager package-runner
Last synced: 3 days ago
JSON representation
run anything
- Host: GitHub
- URL: https://github.com/pkgxdev/pkgx
- Owner: pkgxdev
- License: apache-2.0
- Created: 2021-11-20T18:44:53.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2024-11-25T17:48:28.000Z (18 days ago)
- Last Synced: 2024-12-01T09:32:17.454Z (12 days ago)
- Topics: environment-manager, package-manager, package-runner
- Language: TypeScript
- Homepage: https://pkgx.sh
- Size: 1.39 MB
- Stars: 9,024
- Watchers: 78
- Forks: 1,362
- Open Issues: 55
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
- Support: docs/support.md
Awesome Lists containing this project
- Awesome - Pkgx - “run anything” from the creator of `brew` (Development / VoIP)
- awesome-version-managers - pkgx - A blazingly fast, standalone, cross‐platform binary that runs anything in any version with zero system impact. (Version Managers / Generic)
- project-awesome - pkgxdev/pkgx - run anything (TypeScript)
- awesome-starred - pkgxdev/pkgx - “run anything” from the creator of `brew` (package-manager)
README
![pkgx.dev](https://pkgx.dev/banner.png)
`pkgx` is a single, *standalone binary* that can *run anything*.
[![coverage][]][coveralls] [![teaRank][]](https://tea.xyz)
### Quickstart
```sh
brew install pkgxdev/made/pkgx
```> * [docs.pkgx.sh/installing-w/out-brew]
> * [Migrating from v0](https://blog.pkgx.dev/pkgx-1-0-0-alpha-1/)
# Run Anything
```sh
$ deno
command not found: deno$ pkgx deno
Deno 1.36.3
> ^D$ deno
command not found: deno
# ^^ nothing was installed; your system remains untouched
```## Run *Any Version* of Anything
```sh
$ pkgx node@14 --version
Node.js v14.21.3$ pkgx python@2 --version
Python 2.7.18
```## Run Anywhere
* macOS
* macOS >= 11
* x86-64 & Apple Silicon
* Linux* glibc >=2.28 [repology](https://repology.org/project/glibc/versions)
* `x86_64` & `arm64`
* WindowsWSL2; x86-64. *Native windows is planned.*
* Docker```sh
$ pkgx docker run -it pkgxdev/pkgx(docker) $ pkgx node@16
Welcome to Node.js v16.20.1.
Type ".help" for more information.
>
```Or in a `Dockerfile`:
```Dockerfile
FROM pkgxdev/pkgx
RUN pkgx [email protected] task start
```Or in any image:
```Dockerfile
FROM ubuntu
RUN curl https://pkgx.sh | sh
RUN pkgx [email protected] -m http.server 8000
```> [docs.pkgx.sh/docker]
* CI/CD```yaml
- uses: pkgxdev/setup@v1
- run: pkgx shellcheck
```Or in other CI/CD providers:
```sh
$ curl https://pkgx.sh | sh
$ pkgx shellcheck
```> [docs.pkgx.sh/ci-cd]
* Scripts```sh
#!/usr/bin/env -S pkgx +git [email protected]# python 3.12 runs the script and `git` is available during its execution
```> [docs.pkgx.sh/scripts]
* Editors```sh
$ cd myprojmyproj $ env +cargo
(+cargo) myproj $ code .
```Or use [`dev`][dev]; a separate tool that uses the pkgx primitives to
automatically determine and utilize your dependencies based on your
project’s keyfiles.```sh
$ cd myprojmyproj $ dev
env +cargo +rust(+cargo+rust) my-rust-project $ code .
```> [docs.pkgx.sh/editors]
# Shell Integration
`pkgx` puts the whole open source ecosystem at your fingertips and its
***optional*** shell integration makes workflows with that open source
even more seamless.```sh
$ env [email protected] # do `pkgx integrate --dry-run` first
added ~/.pkgx/go.dev/v1.16 to environment(+go) $ go
Go is a tool for managing Go source code.
#…(+go) $ env | grep go
PATH=~/.pkgx/go.dev/v1.16.15/bin:$PATH
LIBRARY_PATH=~/.pkgx/go.dev/v1.16.15/lib(+go) $ env -go
removed ~/.pkgx/go.dev/v1.16 from environment$ go
command not found: go
```Tools are available for the duration of your terminal session.
If you need them for longer, eg. `pkgx install go`.> [docs.pkgx.sh/shell-integration] \
> [docs.pkgx.sh/pkgx-install]## `dev`
`dev` is a separate tool that leverages pkgx's core
features to auto-detect and install project dependencies, seamlessly
integrating them into your shell and editor.```sh
my-rust-proj $ dev # do `pkgx integrate --dry-run` first
dev: found Cargo.toml; env +cargo +rust(+cargo+rust) my-rust-proj $ cargo build
Compiling my-rust-proj v0.1.0
#…
```The `dev` tool requires our shell integration to work.
> [docs.pkgx.sh/dev][dev]
# Getting Started
```sh
brew install pkgxdev/made/pkgx
```> no `brew`? [docs.pkgx.sh/installing-w/out-brew]
### Integrating with your Shell
```sh
pkgx integrate --dry-run # docs.pkgx.sh/shell-integration
```## Further Reading
[docs.pkgx.sh][docs] is a comprehensive manual and user guide for `pkgx`.
# Contributing
* To add packages see the [pantry README]
* To hack on `pkgx` itself; clone it and then `pkgx deno task` to list
entrypoints for hackersIf you have questions or feedback:
* [github.com/orgs/pkgxdev/discussions][discussions]
* [x.com/pkgxdev](https://x.com/pkgxdev) (DMs are open)[docs]: https://docs.pkgx.sh
[pantry README]: ../../../pantry#contributing
[discussions]: ../../discussions
[docs.pkgx.sh/pkgx-install]: https://docs.pkgx.sh/pkgx-install
[docs.pkgx.sh/ci-cd]: https://docs.pkgx.sh/ci-cd
[docs.pkgx.sh/scripts]: https://docs.pkgx.sh/scripts
[docs.pkgx.sh/editors]: https://docs.pkgx.sh/editors
[docs.pkgx.sh/docker]: https://docs.pkgx.sh/docker
[docs.pkgx.sh/installing-w/out-brew]: https://docs.pkgx.sh/installing-w/out-brew
[docs.pkgx.sh/shell-integration]: https://docs.pkgx.sh/shell-integration
[dev]: https://docs.pkgx.sh/dev[coverage]: https://coveralls.io/repos/github/pkgxdev/pkgx/badge.svg?branch=main
[coveralls]: https://coveralls.io/github/pkgxdev/pkgx?branch=main
[teaRank]: https://img.shields.io/endpoint?url=https%3A%2F%2Fchai.tea.xyz%2Fv1%2FgetTeaRankBadge%3FprojectId%3D79e9363b-862c-43e0-841d-4d4eaad1fc95