2017-01-29 20:50:36 +01:00
|
|
|
import * as plugins from './smartipc.plugins'
|
|
|
|
import * as q from 'smartq'
|
2017-01-18 16:54:39 +01:00
|
|
|
|
2017-01-29 23:41:26 +01:00
|
|
|
import { Pool } from './smartipc.classes.pool'
|
|
|
|
|
2017-01-29 20:50:36 +01:00
|
|
|
export let setWorkerBasePath = (basePathArg: string) => {
|
|
|
|
plugins.threads.config.set({
|
|
|
|
basepath: {
|
|
|
|
node: basePathArg
|
|
|
|
}
|
|
|
|
})
|
2017-01-18 16:54:39 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
export class Thread {
|
|
|
|
thread
|
2017-01-29 23:41:26 +01:00
|
|
|
workerPath: string
|
|
|
|
running: boolean = false
|
|
|
|
assignedPool: Pool = null
|
2017-01-29 20:50:36 +01:00
|
|
|
constructor(filePathArg: string) {
|
2017-01-29 23:41:26 +01:00
|
|
|
this.workerPath = filePathArg
|
2017-01-18 16:54:39 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* sends a message to the spawned process
|
|
|
|
*/
|
2017-01-29 20:50:36 +01:00
|
|
|
send<T>(message: any): Promise<T> {
|
|
|
|
let done = q.defer<T>()
|
2017-01-29 23:41:26 +01:00
|
|
|
this.checkSpawn()
|
|
|
|
this.thread.send(message)
|
|
|
|
this.thread.on('message', (message: T) => {
|
|
|
|
done.resolve(message)
|
|
|
|
})
|
|
|
|
this.thread.on('done', (job, message: T) => {
|
2017-01-29 20:50:36 +01:00
|
|
|
done.resolve(message)
|
2017-01-29 23:41:26 +01:00
|
|
|
})
|
|
|
|
this.thread.on('error', err => {
|
2017-01-29 20:50:36 +01:00
|
|
|
done.reject(err)
|
|
|
|
})
|
|
|
|
return done.promise
|
2017-01-18 16:54:39 +01:00
|
|
|
}
|
|
|
|
|
2017-01-29 20:50:36 +01:00
|
|
|
kill() {
|
|
|
|
this.thread.kill()
|
2017-01-29 23:41:26 +01:00
|
|
|
this.running = false
|
|
|
|
}
|
|
|
|
|
|
|
|
assignToPool(poolArg: Pool) {
|
|
|
|
this.assignedPool = poolArg
|
2017-01-29 20:50:36 +01:00
|
|
|
}
|
2017-01-29 23:41:26 +01:00
|
|
|
|
|
|
|
private checkSpawn() {
|
|
|
|
if (!this.running && !this.assignedPool) {
|
|
|
|
this.running = true
|
|
|
|
this.thread = plugins.threads.spawn(this.workerPath)
|
|
|
|
} else if (!this.running && this.assignedPool) {
|
|
|
|
this.running = true
|
|
|
|
this.thread = this.assignedPool.run(this.workerPath)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|