https://github.com/a1ecbr0wn/pshell
Works out if this is running from inside a shell, and if so, which one.
https://github.com/a1ecbr0wn/pshell
bash ksh rust rust-lang shell
Last synced: about 1 year ago
JSON representation
Works out if this is running from inside a shell, and if so, which one.
- Host: GitHub
- URL: https://github.com/a1ecbr0wn/pshell
- Owner: a1ecbr0wn
- License: apache-2.0
- Created: 2022-04-13T09:58:11.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2025-04-01T18:30:50.000Z (about 1 year ago)
- Last Synced: 2025-04-13T16:06:13.715Z (about 1 year ago)
- Topics: bash, ksh, rust, rust-lang, shell
- Language: Rust
- Homepage: https://crates.io/crates/pshell
- Size: 54.7 KB
- Stars: 2
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
README
# pshell
[](https://github.com/a1ecbr0wn/pshell/blob/main/LICENSE) [](https://crates.io/crates/pshell) [](https://github.com/a1ecbr0wn/pshell/actions/workflows/build.yml) [](https://docs.rs/pshell) [](https://deps.rs/repo/github/a1ecbr0wn/pshell)
`pshell` answers the question "Is my application running in a shell, and if so, which one?".
Example: you are installing something and want to make changes to the shell and you want to know what changes are required to which shell script.
[Usage](#usage) - [Contribute](#contribute)
## Usage
Just a simple function that tells you whether the application is run from inside a shell:
``` rust
use pshell;
fn main() {
// `find` returns the name of the shell in a string and the pid as a u32
let (sh, pid) = pshell::find().unwrap_or(("unknown".to_string(), 0));
println!("This application has been run from pid `{}`, which is a {} shell", pid, sh);
}
```
To try this out, and check it works OK on your OS/shell combination run the following from your shell:
``` bash
cargo run --example what_shell
```
## Why should you use this crate?
It is a small, simple crate that adds very little to your application size for discovering what shell this is running under by inspecting the name of the parent processes against a limited list of known shells.
## Why should you not use this crate?
You want an all-singing, all-dancing crate that identifies any knowns shell.
## Contribute
I have created a list of shells where this could be run from, it is not exhaustive, if your shell is not supported, feel free to raise an issue or a PR.