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

Add typing for Console module #1033

Open
wants to merge 2 commits into
base: public
Choose a base branch
from

Conversation

chigix
Copy link
Contributor

@chigix chigix commented Feb 14, 2023

No description provided.

@chigix chigix force-pushed the work-console-typing branch from 725e244 to dacd5a0 Compare February 14, 2023 11:43
@phoddie
Copy link
Collaborator

phoddie commented Feb 14, 2023

Thanks for the PR. There are a couple of corrections:

  • receive returns a number (receive(): number)
  • write accepts one or more strings (line(...items: string): void)

Would you be willing to update the PR? If not, we can apply the changes after merging.

@chigix
Copy link
Contributor Author

chigix commented Feb 15, 2023

@phoddie Thanks for you advice. I pushed new fix on to the Console type definition file.

@chigix
Copy link
Contributor Author

chigix commented Feb 15, 2023

Additionally, is it possible to request more details in the usage example of Console class?
https://github.com/Moddable-OpenSource/moddable/blob/public/examples/base/console/main.js
In the existing example code, it seems the usage of Console class itself is not well presented, where why CLI would be used in the Console example seems also not comprehensible.

@phoddie
Copy link
Collaborator

phoddie commented Feb 15, 2023

Thanks for the update. We've merged that.

The CLI Class is a way to build commands that are executed from some kind of terminal interface. The CLI is transport independent. The CLI is used in many places:

  • the base/console example with a simple serial transport
  • the javascript/repl example with different transports (serial on microcontrollers, terminal on macOS, etc)
  • the network/telnet example with the telnet protocol to allow remote commands
    There is no requirement to use the CLI for these. You can rewrite them anyway you like. ;) The CLI class is just a convenient way to organize commands so that they can be re-used in different environments.

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