
Security News
The Changelog Podcast: Practical Steps to Stay Safe on npm
Learn the essential steps every developer should take to stay secure on npm and reduce exposure to supply chain attacks.
@code-engine/cli
Advanced tools
This is the command-line interface for CodeEngine. It exports the CodeEngineCLI class, which runs CodeEngine as instructed by the command-line arguments and environment variables.
NOTE: This is an internal library that is only intended to be used by CodeEngine. Using it outside of CodeEngine is discouraged. Use the code-engine npm package instead.
CodeEngineCLI classThis is the programmatic interface to the CodeEngine CLI.
import CodeEngineCLI from "@code-engine/cli";
// Create a new CodeEngineCLI instance
let cli = new CodeEngineCLI();
// Run it with some command-line arguments
await cli.main(["--debug", "my-generator"]);
CodeEngineCLI constructorThe constructor accepts an optional Config object.
import CodeEngineCLI from "@code-engine/cli";
// Create a new CodeEngineCLI instance with a custom config
let cli = new CodeEngine({
  process: {
    ...process,
    stdout: new WriteStream(),
    stderr: new WriteStream(),
  }
});
| Config setting | Type | Default | Description | 
|---|---|---|---|
process | Process object | process (Node.js global)  | A custom Process object to use instead of the Node.js global process object. This allows you to completely control all inputs and outputs. | 
CodeEngineCLI.log(message)Writes a message to the stdout stream.
import CodeEngineCLI from "@code-engine/cli";
let cli = new CodeEngineCLI();
cli.log("Hello, world");
CodeEngineCLI.error(message)Writes a message to the stderr stream.
import CodeEngineCLI from "@code-engine/cli";
let cli = new CodeEngineCLI();
cli.error("Something went wrong");
CodeEngineCLI.crash(error)Immediately terminates the CLI with the given error.
Error objectNOTE: This method calls
process.exit()internally. By default this will terminate the entire Node.js process. You can override this behavior by providing your ownprocessobject in the constructor and implementing theexit()method however you choose.
import CodeEngineCLI from "@code-engine/cli";
let cli = new CodeEngineCLI();
cli.crash(new SyntaxError("Something went wrong"));
CodeEngineCLI.awaitExit()Waits for the CLI to exit. This function returns a Promise that only resolves when the "exit" event is emitted.
NOTE: This method calls
process.on("exit")internally. By default this will wait for the Node.js process to exit. You can override this behavior by providing your ownprocessobject in the constructor and implementing theon()method however you choose.
import CodeEngineCLI from "@code-engine/cli";
let cli = new CodeEngineCLI();
await cli.awaitExit();
Contributions, enhancements, and bug-fixes are welcome! File an issue on GitHub and submit a pull request.
To build the project locally on your computer:
Clone this repo
git clone https://github.com/CodeEngineOrg/code-engine-cli.git
Install dependencies
npm install
Build the code
npm run build
Run the tests
npm test
@code-engine/cli is 100% free and open-source, under the MIT license. Use it however you want.
Thanks to these awesome companies for their support of Open Source developers ❤
FAQs
build tool | code generator | static site builder
The npm package @code-engine/cli receives a total of 8 weekly downloads. As such, @code-engine/cli popularity was classified as not popular.
We found that @code-engine/cli demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
Learn the essential steps every developer should take to stay secure on npm and reduce exposure to supply chain attacks.

Security News
Experts push back on new claims about AI-driven ransomware, warning that hype and sponsored research are distorting how the threat is understood.

Security News
Ruby's creator Matz assumes control of RubyGems and Bundler repositories while former maintainers agree to step back and transfer all rights to end the dispute.