Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refactor(waku): prettify cli using commander.js #339

Closed
wants to merge 5 commits into from

Conversation

himself65
Copy link
Member

@himself65 himself65 commented Jan 1, 2024

now the CLI has growing complex, I think we need a standard library to handle the thing

Copy link

vercel bot commented Jan 1, 2024

The latest updates on your projects. Learn more about Vercel for Git ↗︎

Name Status Preview Updated (UTC)
waku ✅ Ready (Inspect) Visit Preview Jan 1, 2024 9:04pm

Copy link

codesandbox-ci bot commented Jan 1, 2024

This pull request is automatically built and testable in CodeSandbox.

To see build info of the built libraries, click here or the icon next to each commit SHA.

Latest deployment of this branch, based on commit ba230a0:

Sandbox Source
Vanilla Typescript Configuration
React Configuration
React TypeScript Configuration

@dai-shi
Copy link
Member

dai-shi commented Jan 1, 2024

now the CLI has growing complex, I think we need a standard library to handle the thing

Yeah, I was thinking about it too. But, I have a few concerns:

  • The diff doesn't seem to improve so much. Maybe it's too early at this point.
  • I used commander.js before, and found it somewhat traditional. Is it still widely used?
  • It must be an optional peer dependency and it requires to add a dependency in the templates. That's a huge motivation to avoid using libraries unless it's very helpful.

@himself65
Copy link
Member Author

now the CLI has growing complex, I think we need a standard library to handle the thing

Yeah, I was thinking about it too. But, I have a few concerns:

  • The diff doesn't seem to improve so much. Maybe it's too early at this point.
  • I used commander.js before, and found it somewhat traditional. Is it still widely used?
  • It must be an optional peer dependency and it requires to add a dependency in the templates. That's a huge motivation to avoid using libraries unless it's very helpful.

There are some options:

arg: https://github.com/huozhi/bunchee/blob/main/src/bin/index.ts
commander.js: https://github.com/vercel/next.js/blob/canary/packages/create-next-app/index.ts
clipanion: https://github.com/napi-rs/napi-rs/blob/main/cli/src/cli.ts

@himself65
Copy link
Member Author

@dai-shi
Copy link
Member

dai-shi commented Jan 2, 2024

Thanks.

I would like to hold this for the moment, and revisit it in the future. There might be more hidden requirements in cli.ts and we can't decide it now.

@himself65 himself65 marked this pull request as draft January 2, 2024 23:58
@dai-shi
Copy link
Member

dai-shi commented Jan 5, 2024

It must be an optional peer dependency and it requires to add a dependency in the templates. That's a huge motivation to avoid using libraries unless it's very helpful.

This limitation is gone with #355.

@dai-shi
Copy link
Member

dai-shi commented Feb 25, 2024

I'm still interested in using commander.js or some alternatives (maybe commander.js is fine.)

Maybe some time later, maybe before v1-alpha. Let's start over anyway.

@dai-shi
Copy link
Member

dai-shi commented Mar 28, 2025

#1319 should be a follow-up.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants