Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/s-a/ntcc
Last synced: 3 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/s-a/ntcc
- Owner: s-a
- License: other
- Created: 2016-04-14T00:16:29.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2016-04-20T07:44:37.000Z (almost 9 years ago)
- Last Synced: 2024-11-09T02:38:55.141Z (3 months ago)
- Language: JavaScript
- Size: 20.5 KB
- Stars: 6
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Namespaced Terminal Client Commands
[data:image/s3,"s3://crabby-images/3ae18/3ae18eeb32756c59ebfb8b5bdc80cc058fd2754b" alt="NPM Version"](https://www.npmjs.org/package/ntcc)
[data:image/s3,"s3://crabby-images/263a7/263a7e5ff1f1057945b7acaf313b248757a40ab8" alt="Build Status"](https://travis-ci.org/s-a/ntcc)
[data:image/s3,"s3://crabby-images/fc134/fc13466903cb179e3ee152ff88042ea647772a2d" alt="Coverage Status"](https://coveralls.io/github/s-a/ntcc?branch=master)
[data:image/s3,"s3://crabby-images/54563/54563c59e6c205c04bbde87aeaaa02487eff4083" alt="Codacy Badge"](https://www.codacy.com/app/stephanahlf/ntcc)
[data:image/s3,"s3://crabby-images/7d13d/7d13d8f95da269da5ea27a92d19e936ad6722980" alt="Dependency Status"](https://david-dm.org/s-a/ntcc)
[data:image/s3,"s3://crabby-images/93b06/93b061501fcef94a67155b291ebe94fe7bac1c9f" alt="devDependency Status"](https://david-dm.org/s-a/ntcc#info=devDependencies)
[data:image/s3,"s3://crabby-images/a022f/a022f2b1a6ea487565e1daaf37ae3c42487223fd" alt="NPM Downloads"](https://www.npmjs.org/package/ntcc)
[data:image/s3,"s3://crabby-images/9ead3/9ead34a855697fc6659f55f8f607dfed42efe805" alt="Massachusetts Institute of Technology (MIT)"](/LICENSE.md#mit)
[data:image/s3,"s3://crabby-images/d8f8d/d8f8d8e524f4ab1aed3cf0ca9802c9ec94de4525" alt="Donate"](http://s-a.github.io/donate/)This module aims to provide an easy and structured way to create modular commands for Node commandline clients and load them only on demand.
It extends a client object with an ```execute``` function which can execute modules created with a declared namespaced convention. Each namespaced module must contain a method called ```invoke```. This method runs always in context of the client object.## Usage
### Create a command with arguments
"test-client-commands/***clientcommand.***testcommand.open-with-arguments.js"
```javascript
"use strict";var Cmd = function() {
return this;
};Cmd.prototype.invoke = function(name1,name2,name3) {
// runs in context of client.
return "This testcommand is using open called from " + this.id + " (" + name1 + "," + name2 + "," + name3 + ")";
};module.exports = Cmd;
```### Extend a terminal client
```javascript
var NTCC = require("ntcc");
var ntcc = new NTCC();var TestClient = function() {
this.id = "A Testing Client";
return this;
};
var testClient = new TestClient();ntcc.extend({
client: testClient,
dir: path.join(__dirname, "..", "test-client-commands"),
namespacePrefix: "clientcommand."
});
``````console.log(testClient.__)``` yields:
- execute() | Method to exec a command.
- listCommands() | Usefull to provide a commandline help.
- getCommandFilename() | returns a filename for a given command namespace.### Invoke the test command
```javascript
it("should execute testcommand.open-with-arguments to pass custom arguments", function() {
var args = ["arg1", "arg2", "argN"];
var string = testClient.__.execute(["testcommand", "open-with-arguments"], args);
string.should.equal("This testcommand is using open called from " + testClient.id + " (" + args.join(",") + ")");
});
```For more examples see [the test-client-commands](/test-client-commands) and [the tests](test).
## A more realistic usecase
Human readable:
```javascript
testClient.__.execute(["open", "db", "connection"], ["connection-1"]);
testClient.__.execute(["close", "db", "connection"], ["connection-1"]);
testClient.__.execute(["new", "db", "connection"]);
testClient.__.execute(["remove", "db", "connection"], ["connection-1"]);
```Or straight namespaced:
```javascript
testClient.__.execute(["connection", "db", "open"], ["connection-1"]);
testClient.__.execute(["connection", "db", "close"], ["connection-1"]);
testClient.__.execute(["connection", "db", "new"]);
testClient.__.execute(["connection", "db", "remove"], ["connection-1"]);
```I prefer to use this module in association with [minimist](https://github.com/substack/minimist).