refactoring using async/await and new interrupt class code based on pigpio. Handler keeps proper scope. Interrupts working!!!

This commit is contained in:
David Kebler 2017-05-20 22:23:24 -07:00
parent 1d659aeb58
commit 832a507204

View file

@ -44,16 +44,29 @@ class MCP23008 extends Device {
}
async start() {
console.log(`begin starting ${ this.id }`)
// console.log(`starting ${ this.id }`)
for (let port in this.ports) {
// if there are interrupts being used then start them and listeners
if (this.inter(port)) {
await this.read(portReg(0x08, port))
await pause(200) // give enough time for mcp to reset its interupt
this.inter(port).start()
await this.interruptReset(port)
await this.inter(port).start()
// bind handler to the chip to handler can read/write to chip/bank when interrupt is emitted
let ihandler = this.inter(port).handler.bind(this)
// inside the listener `this` is the interrupt not the chip/bank
this.inter(port).on('fired', function () {
console.log(`interrupt from ${this.pin_number}`)
ihandler(port)
})
}
}
}
async interruptReset(port = 'A') {
await this.read(portReg(0x08, port))
await pause(300) // give enough time for mcp to reset its interupt
console.log(`interrupt reset on ${this.id} port ${port}`)
}
// start() {
// let starts = []
// for (let port in this.ports) {
@ -82,6 +95,10 @@ class MCP23008 extends Device {
// return Promise.all(starts)
// }
portByInterPin(pin) {
return 'A'
}
pin(id) { return this.ports.A.pin(id) } // get a reference to a particular pin's object
pid(address) { return this.ports.A.pid(address) } // return pin id for a given address on a port
@ -222,6 +239,12 @@ class MCP23017 extends MCP23008 {
return this.ports[port].pid(address)
}
portByInterPin(pin) {
if (this.ports.A.interrupt.pin_number === pin) { return 'A' }
if (this.ports.B.interrupt.pin_number === pin) { return 'B' }
return false
}
portByPin(id) {
console.log('pin id in portbypin', id)
if (this.ports.A.pin(id)) { return 'A' }