npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

the-magic-cli

v1.0.1

Published

<a name="readme-top"></a>

Downloads

2

Readme

Features

✅ Self-Repairing Code              [Runs a script in any language and fixes it upon crash]
✅ Generate Unit Tests              [Generates unit tests for a code file]
✅ Conduct Code Reviews             [Reviews a code file]
✅ Translate Programming Languages  [Converts a code file to another language]
✅ ELI5 Code                        [Generates an ELI5 explanation]
✅ Refactor Code                    [Refactors the code]
✅ Document Code                    [Adds documentation to the code]
✅ Best Practices                   [Converts the code to use the best practices]
✅ Arbitrary Input                  [Prompt GPT-4 anything]
🟨 Reflexion                        [GPT reflects on it's answers to improve the output quality]
🟨 Add new feature                  [Adds a new feature based on an input file]
🟨 Increase context window          [Increase context window with vector embeddings]
🟨 Process directories              [CLI can process directories and not only files]

Installation

You need to have Node.js installed.

  1. Get an OpenAI API Key at https://openai.com/

    ❗️ By default the model uses GPT-4. If you don't have access to GPT-4 yet, you have to use the -g3 flag. (It will then use the GPT-3.5 Turbo model)

  2. Install the CLI via npm

    npm install -g the-magic-cli
  3. The CLI can then simply be called by running:

    magic

    or

    magic-cli

    I'm going to use the latter in the following examples for the sake of brevity.

  4. Add your OpenAI API key (It's only stored on your device)

    magic -ak "sk-9jfoa..."

Examples

1. Self-Repair

This command will run a code file in any language and automatically try to fix it when it crashes or has a bug.

1.1 Self-Repair a Python file

Run the magic command in a directory with a file called test.py:

  magic -f test.py python3

This command will run the file test.py with the interpreter python3.

1.2 Self-Repair a TypeScript file

Run the magic command in a directory with a file called test.ts:

  magic -f test.py ts-node

This command will run the file test.ts with the interpreter ts-node.

2. Translate from Python to TypeScript

Run the magic command in a directory with a file called test.py. We also need to specify a file that we want to write to test.ts in this case (If not the CLI will only log to the console). Now Magic CLI will automatically translate the code to TypeScript.

  magic -l test.py TypeScript -o test.ts

3. Conduct a code review

Run the magic command in a directory with a file called test.py. In this case we might only want to view the output in the terminal, so we don't need to specify an output file. This command will review the code and give you feedback on how to improve it.

  magic -r test.py

4. Generate unit tests

Run the magic command in a directory with a file called hello.ts with the testing framework that we want to use (Jest in this case). We also need to specify the file that we want to write to hello.test.ts. Now Magic CLI will automatically generate unit tests for the code.

  magic -t hello.ts Jest -o hello.test.ts

4. Use custom prompt

Using a custom prompt is also really convenient.

You have two options:

  1. Use the -x flag. This flag accepts a file input and a custom prompt.
  magic -x hello.ts "Check this code for security vulnerabilities"
  1. Use the -z flag. This flag only accepts a custom prompt. (Without a file input)
  magic -z "Why is the answer to everything 42?"

These methods can also be used to generate entirely new features.

  magic -x hello.ts "Given the provided code, create new a functional React component, that implements a loading spinner. Only return the code." -o spinner.ts

The command above reads the "hello.ts" file, sends the code with your prompt to GPT-4 and writes the result to "spinner.ts".

Usage

Run magic -h to see all available commands

Options:
-v, --version                             output the current version
-r, --review  <filePath>                  code review for a file
-i, --improve  <filePath>                 refactor the code
-b, --best  <filePath>                    convert the code to the best practices
-f, --fix [filePath interpreter...]       fix the code recursively
-l, --lang [filePath targetLanguage...]   convert the code to a different language
-e, --eli5 <filePath>                     explain the code in simple terms
-t, --test [filePath framework...]        generate unit tests for the code
-d, --document <filePath>                 generate documentation for the code
-x, --arbitraryFile [filePath prompt...]  accepts any instruction (prompt needs to be in quotes)
-z, --arbitrary <prompt>                  accepts any instruction
-o, --output [filePath]                   the output file path
-s, --silent                              prevents logging the stream to the console
-g3, --gpt3                               only uses GPT-3.5
-ak, --addkey [apiKey]                    add your OpenAI API key to the the environment
-dk, --deletekey                          delete your OpenAI API key from the environment
-pk, --printkey                           print your OpenAI API key
-h, --help                                display help for command

Contact

Hi! Thanks for checking out and using this library. If you are interested in discussing your project, require mentorship, consider hiring me, or just wanna chat - I'm happy to talk.

You can send me an email to get in touch: [email protected] or message me on Twitter: @julianschoen

If you'd just want to give something back, I've got a Buy Me A Coffee account:

Thanks and have an awesome day 👋

Disclaimer

Magic CLI, is an experimental application and is provided "as-is" without any warranty, express or implied. By using this software, you agree to assume all risks associated with its use, including but not limited to data loss, system failure, or any other issues that may arise.

The developers and contributors of this project do not accept any responsibility or liability for any losses, damages, or other consequences that may occur as a result of using this software. You are solely responsible for any decisions and actions taken based on the information provided by Magic CLI.

Please note that the use of the GPT-4 language model can be expensive due to its token usage. By utilizing this project, you acknowledge that you are responsible for monitoring and managing your own token usage and the associated costs. It is highly recommended to check your OpenAI API usage regularly and set up any necessary limits or alerts to prevent unexpected charges.

By using Magic CLI, you agree to indemnify, defend, and hold harmless the developers, contributors, and any affiliated parties from and against any and all claims, damages, losses, liabilities, costs, and expenses (including reasonable attorneys' fees) arising from your use of this software or your violation of these terms.

License

Distributed under the MIT License. See LICENSE for more information.