Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/proffapt/code-runner
Implementation of code-runner in bash for compiling code files and executing them with one and only command
https://github.com/proffapt/code-runner
autmate-compilation automate-execution automation bash c-cpp code code-runner compile-and-run compile-and-run-code compile-code compile-run execute-code hacktoberfest java-runner python-version-selector run-code runner
Last synced: 26 days ago
JSON representation
Implementation of code-runner in bash for compiling code files and executing them with one and only command
- Host: GitHub
- URL: https://github.com/proffapt/code-runner
- Owner: proffapt
- License: agpl-3.0
- Created: 2022-03-28T09:57:49.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2024-04-12T13:22:00.000Z (9 months ago)
- Last Synced: 2024-12-15T10:23:19.270Z (about 1 month ago)
- Topics: autmate-compilation, automate-execution, automation, bash, c-cpp, code, code-runner, compile-and-run, compile-and-run-code, compile-code, compile-run, execute-code, hacktoberfest, java-runner, python-version-selector, run-code, runner
- Language: Shell
- Homepage:
- Size: 1.12 MB
- Stars: 19
- Watchers: 1
- Forks: 6
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: .github/CONTRIBUTING.md
- License: LICENSE.txt
- Code of conduct: .github/CODE_OF_CONDUCT.md
- Security: .github/SECURITY.md
Awesome Lists containing this project
README
[![Contributors][contributors-shield]][contributors-url]
[![Forks][forks-shield]][forks-url]
[![Stargazers][stars-shield]][stars-url]
[![Issues][issues-shield]][issues-url]
[![MIT License][license-shield]][license-url]
[![LinkedIn][linkedin-shield]][linkedin-url]
code-runner
execute code files with ease
Explore the docs ยป
Report Bug
ยท
Request Feature
Table of Contents
About The Project
Getting Started
Usage
- Integrating with vscode
- Integrating with vim
- Contact
- Acknowledgments
- Miscelleneous
## About The Project
This is a script, which compiles the code file and run it for you and delete other _junk_ files if created during the process of compilation, all this with one command for all the languages supported by it. No more remembering different arguments for different compilers to compile, execut and debug the code.
### Why this Code Runner?
- Can detect correct version of python with 90% accuracy.
- Has inbuilt debugger support.
- Custom made keybindings for [vim](#integrating-with-vim) and [vscode](#integrating-with-vscode).
- Robust code, deals with all possible cases.
- Can execute files with spaces in their names.
- Can execute from any location.
- Automatically cleans executable files by default.
- Highest number of languages supported compared to its alternatives.## Getting Started
### Installation
_To install and configure the project on your system locally, use suitable method:_
- [Using curl](#install-using-curl)
- [Using brew](#install-using-brew)#### Install using CURL
1. Copy and run the following command to install the run binary on your system.
```sh
curl https://raw.githubusercontent.com/proffapt/code-runner/main/.setup/install.sh | bash
```
2. Run the code
```sh
run my_code.c
```
OR
```sh
run ~/path/to/my_code.c
```#### Install using BREW
```bash
brew tap proffapt/brewtap
brew install code-runner
```### Uninstallation
_To uninstall the tool from your system execute the following command, depending upon your installation_
- [Using curl](#uninstall-using-curl)
- [Using brew](#uninstall-using-brew)#### Uninstall using CURL
```sh
curl https://raw.githubusercontent.com/proffapt/code-runner/main/.setup/uninstall.sh | bash
```
#### Uninstall using BREW
```bash
brew uninstall code-runner
```## Usage
### Examples
* Compilation and Execution
* Debugging
* Python
## Integrating with vscode
Create custom keybindings for `vscode` to use this script more conveniently in vscode, you can copy my keybindings from [vscode-keybindings](https://github.com/proffapt/code-runner/blob/main/keybindings/vscode-keybindings) into your keybindings.json
* `alt+space`
- **If there is no instance of terminal**: Spawns a new terminal `>` shifts the focus to it.
- **If the instance already exists and focus is on editor pane**: Focuses the terminal.
- **If the focus is on terminal**: Focuses the editor pane keeping the terminal at it's place.* `cmd+contextmenu` -- use twice for execution
- **If there is no terminal instance**: Spawns a new terminal `>` shifts focus to it(DOESN"T EXECUTE THE CODE, press again to execute the code).
- **If instance exists and focus is on editor pane**: Shifts focus to terminal(DOESN"T EXECUTE THE CODE, press again to execute the code).
- **If the focus is on terminal**: Executes the code.^ **NOTE**: Code execution is also possible even if the code file is not directly inside the folder opened in vscode.
>> _Stores previous execution history, as there is no new terminal created everytime, it's created only when not present else uses the same terminal_
https://user-images.githubusercontent.com/86282911/204466533-977280fc-a1a7-492f-bf91-9090d5c70cf4.mp4
## Integrating with vim
Create custom keybindings for `{Neo}vim` to use this script more conveniently in `{Neo}vim`, you can copy my keybindings from the following files to your vim configuration file.
- [For .{n}vimrc type configs](https://github.com/proffapt/code-runner/blob/main/keybindings/vim-keybindings-rc)
- [For lua type configs](https://github.com/proffapt/code-runner/blob/main/keybindings/vim-keybindings-lua)* `rr`
- In NORMAL mode: Saves the file `>` creates a new floaterm buffer `>` shifts focus to it `>` runs the code(CLOSE the buffer with any key after completion of execution).
>> _Doesn't store previous execution history, as there is a new buffer created everytime_
* `ff`
- **In NORMAL mode with no existing floaterm buffer**: Saves the file `>` creates a new floaterm buffer `>` shifts focus to it `>` runs the code.
- **In NORMAL mode with existing floaterm buffer but focus on code buffer**: Saves the file `>` shifts focus to floaterm buffer `>` runs the code.
- **In NORMAL mode with existing floaterm buffer and focus on flaoterm buffer**: Hides the floaterm buffer `>` focuses on the working file's buffer.
- **In TERMINAL mode**: Hides active floaterm buffer `>` focuses on the working file's buffer.>> _Stores previous execution history, as there is no new buffer created everytime, it's created only when not present else uses the same buffer_
https://user-images.githubusercontent.com/86282911/204343876-fa160388-ba4c-47be-88a0-16c6f7e7c1cb.mp4
## Contact
๐ซ Arpit Bhardwaj ( aka proffapt ) -## Acknowledgments
* [Choose an Open Source License](https://choosealicense.com)
* [Img Shields](https://shields.io)
* [Bash filename manipulation](https://stackoverflow.com/a/965069)## Miscelleneous
Do consider looking at other paradigms of this documentation
- [Change-logs](CHANGELOG.md)
- [License used](LICENSE.txt)
- [Code Of Conduct](CODE_OF_CONDUCT.md)
- [How to contribute?](CONTRIBUTING.md)[contributors-shield]: https://img.shields.io/github/contributors/proffapt/code-runner.svg?style=for-the-badge
[contributors-url]: https://github.com/proffapt/code-runner/graphs/contributors
[forks-shield]: https://img.shields.io/github/forks/proffapt/code-runner.svg?style=for-the-badge
[forks-url]: https://github.com/proffapt/code-runner/network/members
[stars-shield]: https://img.shields.io/github/stars/proffapt/code-runner.svg?style=for-the-badge
[stars-url]: https://github.com/proffapt/code-runner/stargazers
[issues-shield]: https://img.shields.io/github/issues/proffapt/code-runner.svg?style=for-the-badge
[issues-url]: https://github.com/proffapt/code-runner/issues
[license-shield]: https://img.shields.io/github/license/proffapt/code-runner.svg?style=for-the-badge
[license-url]: https://github.com/proffapt/code-runner/blob/master/LICENSE.txt
[linkedin-shield]: https://img.shields.io/badge/-LinkedIn-black.svg?style=for-the-badge&logo=linkedin&colorB=555
[linkedin-url]: https://linkedin.com/in/proffapt