Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/myzhang1029/psh
A shell implementation
https://github.com/myzhang1029/psh
c shell-implementation
Last synced: 28 days ago
JSON representation
A shell implementation
- Host: GitHub
- URL: https://github.com/myzhang1029/psh
- Owner: myzhang1029
- License: gpl-3.0
- Created: 2018-02-07T01:54:11.000Z (almost 7 years ago)
- Default Branch: dev-redirect-handle
- Last Pushed: 2021-04-27T05:36:41.000Z (over 3 years ago)
- Last Synced: 2024-11-05T19:08:09.527Z (3 months ago)
- Topics: c, shell-implementation
- Language: C
- Homepage:
- Size: 774 KB
- Stars: 0
- Watchers: 3
- Forks: 1
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# psh
[![Build Status](https://travis-ci.com/myzhang1029/psh.svg)](https://travis-ci.com/myzhang1029/psh)
[![Gitpod Ready-to-Code](https://img.shields.io/badge/Gitpod-Ready--to--Code-blue?logo=gitpod)](https://gitpod.io/#https://github.com/myzhang1029/psh)## Description
Psh is a shell implementation. It tries to mimic most of bash's
and dash's behaviors.Psh started out as a vvy/wshell fork, but now all original contents
have been removed and re-implemented without referencing the original code,
and the shell is being worked on completely by me and other nice contributors.Psh aims to be able to compile on as many C99 systems as possible,
providing a highly emulated POSIX environment.
To reach this goal, psh juices out those platform-dependent parts, for
example, subprocess management and user data extraction, into
_backends_.Psh is now my UWC FP _free summer_ project.
## Usage
Psh is equipped with CMake build system as well as GNU autotools support.
```
mkdir build
cd build
cmake ..
make
```or
```
autoreconf -fi
./configure
make
```Now just run:
```
src/psh
```## Future Plans
Have a look at the GitHub projects
[Roadmap](https://github.com/myzhang1029/psh/projects/2) kanban!## Contributing
Issues and pull requests are always welcomed! However, please do take a note on
[licensing](https://www.gnu.org/licenses/#GPL) and this readme. For the code
style, following the existing code should work, it will be even better if the
style defined with the `.clang-format` file is used.