Skip to content

clercjs/clerc

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Clerc Card

Clerc is a full-featured library (tool set) for building CLI Apps in Node.js, Deno or Bun.

Version CI Downloads/week License


Note

This package is ESM-only.

✨ Features

  • Lightweight - Dependencies are bundled.
  • Plugin system - Add rich features on demand.
  • Chainable APIs - Composable.
  • Developer friendly - Strongly typed, converts flags and parameters to camelCase.
  • Parses parameters - No need to read them by yourself.

😊 The simplest CLI example

Install clerc, and create a file named cli.mjs:

import { Clerc } from "clerc";

Clerc.create() // Create a new Clerc instance
	.scriptName("foo") // CLI Script Name
	.description("A foo CLI") // CLI Description
	.version("0.0.0") // CLI Version
	.command(
		"bar", // Command name
		"A bar command", // Command description
	)
	.on(
		"bar",
		(
			_ctx, // The command context, but we haven't used it yet
		) => {
			console.log("Hello, world from Clerc!");
		},
	)
	.parse(); // Parse the arguments and run!

Then run: node cli.mjs bar. It should log in your shell: Hello, world from Clerc!

πŸ“– Documentation

Please see https://clerc.so1ve.dev.

πŸ¦„ Examples

Check the examples made with Clerc:

πŸ€” More...

Why using Clerc?

Clerc uses @clerc/parser to parse arguments. It is strongly-typed, which brings you better DX. It is powerful(supports custom type) and quite small and performant!

Clerc has a plugin system, which means you can add features on demand (e.g. auto completions, help text generation...). It also provides chainable APIs for better composability.

Clerc's flexible architecture and plugin system offer vast potential for further exploration and customization in diverse CLI application scenarios. There are more and more opportunities to leverage Clerc's capabilities to create unique and powerful command-line tools!

πŸ“ License

MIT. Made with ❀️ by Ray