mirror of
https://github.com/overleaf/overleaf.git
synced 2024-10-31 21:21:03 -04:00
f0a3eeeb32
Remove logger.log in favour of logger.info GitOrigin-RevId: e305ae8adf19ecf144cee123b6837f35d5d45bed
64 lines
1.8 KiB
JavaScript
64 lines
1.8 KiB
JavaScript
// TODO: This file was created by bulk-decaffeinate.
|
|
// Fix any style issues and re-enable lint.
|
|
/*
|
|
* decaffeinate suggestions:
|
|
* DS101: Remove unnecessary use of Array.from
|
|
* DS102: Remove unnecessary code created because of implicit returns
|
|
* DS103: Rewrite code to no longer use __guard__
|
|
* DS205: Consider reworking code to avoid use of IIFEs
|
|
* DS207: Consider shorter variations of null checks
|
|
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
|
|
*/
|
|
const app = require('../../../../app')
|
|
const { waitForDb } = require('../../../../app/js/mongodb')
|
|
const logger = require('@overleaf/logger')
|
|
const Settings = require('@overleaf/settings')
|
|
|
|
module.exports = {
|
|
running: false,
|
|
initing: false,
|
|
callbacks: [],
|
|
ensureRunning(callback) {
|
|
if (callback == null) {
|
|
callback = function () {}
|
|
}
|
|
if (this.running) {
|
|
return callback()
|
|
} else if (this.initing) {
|
|
return this.callbacks.push(callback)
|
|
}
|
|
this.initing = true
|
|
this.callbacks.push(callback)
|
|
waitForDb().then(() => {
|
|
return app.listen(
|
|
__guard__(
|
|
Settings.internal != null
|
|
? Settings.internal.trackchanges
|
|
: undefined,
|
|
x => x.port
|
|
),
|
|
'localhost',
|
|
error => {
|
|
if (error != null) {
|
|
throw error
|
|
}
|
|
this.running = true
|
|
logger.info('track changes running in dev mode')
|
|
|
|
return (() => {
|
|
const result = []
|
|
for (callback of Array.from(this.callbacks)) {
|
|
result.push(callback())
|
|
}
|
|
return result
|
|
})()
|
|
}
|
|
)
|
|
})
|
|
},
|
|
}
|
|
function __guard__(value, transform) {
|
|
return typeof value !== 'undefined' && value !== null
|
|
? transform(value)
|
|
: undefined
|
|
}
|