2016-04-12 03:05:05 +00:00
|
|
|
var serialport = require('serialport'),
|
|
|
|
SerialPort = serialport.SerialPort,
|
|
|
|
exec = require('child_process').exec,
|
|
|
|
mcopy = {};
|
|
|
|
|
|
|
|
/******
|
|
|
|
Arduino handlers
|
|
|
|
*******/
|
|
|
|
mcopy.arduino = {
|
|
|
|
path : '',
|
|
|
|
known: [
|
|
|
|
'/dev/tty.usbmodem1a161',
|
|
|
|
'/dev/tty.usbserial-A800f8dk',
|
|
|
|
'/dev/tty.usbserial-A900cebm',
|
|
|
|
'/dev/tty.usbmodem1a131',
|
|
|
|
'/dev/tty.usbserial-a900f6de',
|
|
|
|
'/dev/tty.usbmodem1a141'
|
|
|
|
],
|
|
|
|
serial : {},
|
|
|
|
baud : 57600,
|
|
|
|
queue : {},
|
|
|
|
timer : 0,
|
|
|
|
lock : false
|
|
|
|
};
|
|
|
|
mcopy.arduino.init = function (callback) {
|
|
|
|
'use strict';
|
|
|
|
console.log('Searching for devices...');
|
|
|
|
var cmd = 'ls /dev/tty.*';
|
|
|
|
exec(cmd, function (e, std) {
|
|
|
|
var devices = std.split('\n'),
|
|
|
|
matches = [];
|
|
|
|
devices.pop();
|
|
|
|
for (var i = 0; i < devices.length; i++) {
|
|
|
|
if (devices[i].indexOf('usbserial') !== -1
|
|
|
|
||devices[i].indexOf('usbmodem') !== -1){
|
|
|
|
matches.push(devices[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (matches.length === 0) {
|
2016-04-13 03:14:27 +00:00
|
|
|
//console.log('No USB devices found.');
|
|
|
|
if (callback) { callback('No USB devices found'); }
|
2016-04-12 03:05:05 +00:00
|
|
|
} else if (matches.length > 0) {
|
2016-04-13 03:14:27 +00:00
|
|
|
//console.log('Found ' + matches[0]);
|
2016-04-12 03:05:05 +00:00
|
|
|
mcopy.arduino.path = matches[0];
|
|
|
|
//once connected to the arduino
|
|
|
|
//start user interface
|
2016-04-13 03:14:27 +00:00
|
|
|
if (callback) { callback(null, mcopy.arduino.path); }
|
2016-04-12 03:05:05 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
|
|
|
//commands which respond to a sent char
|
|
|
|
mcopy.arduino.send = function (cmd, res) {
|
|
|
|
'use strict';
|
|
|
|
if (!mcopy.arduino.lock) {
|
|
|
|
mcopy.arduino.lock = true;
|
|
|
|
mcopy.arduino.queue[cmd] = res;
|
|
|
|
setTimeout(function () {
|
|
|
|
mcopy.arduino.serial.write(cmd, function (err, results) {
|
|
|
|
if (err) { console.log(err); }
|
|
|
|
mcopy.arduino.lock = false;
|
|
|
|
mcopy.arduino.timer = new Date().getTime();
|
|
|
|
});
|
|
|
|
}, mcopy.cfg.arduino.serialDelay);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
//send strings, after char triggers firmware to accept
|
|
|
|
mcopy.arduino.string = function (str) {
|
|
|
|
'use strict';
|
|
|
|
setTimeout(function () {
|
|
|
|
mcopy.arduino.serial.write(str, function (err, results) {
|
|
|
|
if (err) { console.log(err); }
|
|
|
|
//console.log('sent: ' + str);
|
|
|
|
});
|
|
|
|
}, mcopy.cfg.arduino.serialDelay);
|
|
|
|
};
|
|
|
|
//with same over serial when done
|
|
|
|
mcopy.arduino.end = function (data) {
|
|
|
|
'use strict';
|
|
|
|
var end = new Date().getTime(),
|
|
|
|
ms = end - mcopy.arduino.timer;
|
|
|
|
if (mcopy.arduino.queue[data] !== undefined) {
|
|
|
|
mcopy.arduino.lock = false;
|
|
|
|
console.log('Command ' + data + ' took ' + ms + 'ms');
|
|
|
|
mcopy.arduino.queue[data](ms);
|
|
|
|
delete mcopy.arduino.queue[data]; //add timestamp?
|
|
|
|
} else {
|
|
|
|
console.log('Received stray "' + data + '" from ' + mcopy.arduino.path); //silent to user
|
|
|
|
}
|
|
|
|
};
|
|
|
|
mcopy.arduino.connect = function (callback) {
|
|
|
|
'use strict';
|
|
|
|
console.log('Connecting to ' + mcopy.arduino.path + '...');
|
|
|
|
mcopy.arduino.serial = new SerialPort(mcopy.arduino.path, {
|
|
|
|
baudrate: mcopy.cfg.arduino.baud,
|
|
|
|
parser: serialport.parsers.readline("\n")
|
|
|
|
}, false);
|
|
|
|
mcopy.arduino.serial.open(function (error) {
|
|
|
|
if (error) {
|
|
|
|
return console.log('failed to open: '+ error);
|
|
|
|
} else {
|
|
|
|
console.log('Opened connection with ' + mcopy.arduino.path);
|
|
|
|
mcopy.arduino.serial.on('data', function (data) {
|
|
|
|
data = data.replace('\r', '');
|
|
|
|
mcopy.arduino.end(data);
|
|
|
|
});
|
|
|
|
setTimeout(function () {
|
|
|
|
console.log('Verifying firmware...');
|
|
|
|
mcopy.arduino.send(mcopy.cfg.arduino.cmd.connect, function () {
|
|
|
|
console.log('Firmware verified');
|
|
|
|
console.log('Optical printer ready!');
|
|
|
|
if (callback) { callback(); }
|
|
|
|
});
|
|
|
|
}, 2000);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2016-04-14 04:17:42 +00:00
|
|
|
mcopy.arduino.fakeConnect = function (callback) {
|
|
|
|
console.log('Connecting to fake arduino...');
|
|
|
|
mcopy.arduino.serial = {
|
|
|
|
write : function (cmd, res) {
|
|
|
|
var t = {
|
|
|
|
c : mcopy.cfg.arduino.cam.time + mcopy.cfg.arduino.cam.delay,
|
|
|
|
p : mcopy.cfg.arduino.proj.time + mcopy.cfg.arduino.proj.delay
|
|
|
|
},
|
|
|
|
timeout = t[cmd];
|
|
|
|
if (typeof timeout === 'undefined') timeout = 500;
|
|
|
|
mcopy.arduino.timer = +new Date();
|
|
|
|
setTimeout(function () {
|
|
|
|
mcopy.arduino.end(cmd);
|
|
|
|
}, timeout);
|
|
|
|
},
|
|
|
|
string : function (str) {
|
|
|
|
//do nothing
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
console.log('Connected to fake arduino! Not real! Doesn\'t exist!');
|
|
|
|
if (callback) callback();
|
|
|
|
};
|
|
|
|
|
2016-04-12 06:19:35 +00:00
|
|
|
if (typeof module !== 'undefined' && module.parent) {
|
2016-04-12 03:05:05 +00:00
|
|
|
module.exports = function (cfg) {
|
|
|
|
mcopy.cfg = cfg;
|
|
|
|
return mcopy.arduino;
|
|
|
|
}
|
|
|
|
}
|