mcopy/cli/index.js

89 lines
1.7 KiB
JavaScript
Raw Normal View History

'use strict'
const program = require('commander')
const uuid = require('uuid')
const moment = require('moment')
const events = require('events')
const ee = new events.EventEmitter()
const cfg = require('../app/data/cfg.json')
const pkg = require('./package.json')
const delay = require('delay')
const intval = require('intval')
const arduino = require('arduino')(cfg, ee)
2019-02-24 13:22:59 +00:00
const Mscript = require('mscript')
const mscript = new Mscript()
const dev = require('device')
let log
let readline
async function command () {
return new Promise ((resolve, reject) => {
return readline.question(`Input:`, (str) => {
log.info(str)
2019-02-24 13:22:59 +00:00
console.dir(mscript.interpret(str))
//interpret string
2019-02-24 13:22:59 +00:00
//readline.close()
return resolve(true)
})
})
}
async function live () {
readline = require('readline').createInterface({
input: process.stdin,
output: process.stdout
})
log.info('Starting live control mode')
while (true) {
try {
await command()
} catch (err) {
log.error('Error executing command', err)
}
}
}
function parsePattern () {
}
async function main (arg) {
log = require('log')(arg)
log.info('mcopy-cli')
try {
await arduino.enumerate()
} catch (err) {
log.error('Error enumerating devices')
log.error(err)
}
if (arg.pattern) {
}
if (arg.live) {
try {
await live()
} catch (err) {
log.error('Error running in live control mode', err)
}
}
}
program
.version(pkg.version)
.option('-l, --live', 'Live control mode')
.option('-f, --frames', 'Number of frames to capture with camera')
.option('-p, --pattern', 'Pattern of sequence to be repeated')
.option('-m, --mscript', 'Execute an mscript file')
.option('-q, --quiet', 'Suppresses all log messages')
.parse(process.argv)
main(program)