2018-06-08 13:14:26 -06:00
|
|
|
import * as childProcess from 'child_process';
|
2018-08-13 17:21:25 -06:00
|
|
|
import * as Deque from 'double-ended-queue';
|
2018-06-08 13:14:26 -06:00
|
|
|
import Xev from 'xev';
|
|
|
|
|
|
|
|
const ev = new Xev();
|
|
|
|
|
2018-07-14 04:49:21 -06:00
|
|
|
export default function() {
|
2018-08-13 17:21:25 -06:00
|
|
|
const log = new Deque<any>();
|
2018-06-08 13:14:26 -06:00
|
|
|
|
|
|
|
const p = childProcess.fork(__dirname + '/notes-stats-child.js');
|
|
|
|
|
|
|
|
p.on('message', stats => {
|
|
|
|
ev.emit('notesStats', stats);
|
|
|
|
log.push(stats);
|
2018-08-15 05:20:46 -06:00
|
|
|
if (log.length > 100) log.shift();
|
2018-06-08 13:14:26 -06:00
|
|
|
});
|
|
|
|
|
|
|
|
ev.on('requestNotesStatsLog', id => {
|
2018-09-01 08:12:51 -06:00
|
|
|
ev.emit(`notesStatsLog:${id}`, log.toArray());
|
2018-06-08 13:14:26 -06:00
|
|
|
});
|
2018-07-13 09:39:39 -06:00
|
|
|
|
|
|
|
process.on('exit', code => {
|
|
|
|
process.kill(p.pid);
|
|
|
|
});
|
|
|
|
|
2018-06-08 13:14:26 -06:00
|
|
|
}
|