aboutsummaryrefslogtreecommitdiff
path: root/sandbox/testAppNevena/Front/node_modules/promise-inflight/inflight.js
diff options
context:
space:
mode:
authorDanijel Andjelkovic <adanijel99@gmail.com>2022-03-01 20:21:29 +0000
committerDanijel Andjelkovic <adanijel99@gmail.com>2022-03-01 20:21:29 +0000
commit61cb1570a3410c85a4489b97c172e3a50715f36c (patch)
tree8fe4a5b77ea54bba80abc817ce2c9ef0e79e7e66 /sandbox/testAppNevena/Front/node_modules/promise-inflight/inflight.js
parent21a53d349788c99d2007cba91a923db982353b31 (diff)
parenta9ee9e0a500a4a15bd0b5dcaf041f827228ed309 (diff)
Merge branch 'researchML' into 'dev'
Research ml See merge request igrannonica/neuronstellar!6
Diffstat (limited to 'sandbox/testAppNevena/Front/node_modules/promise-inflight/inflight.js')
-rw-r--r--sandbox/testAppNevena/Front/node_modules/promise-inflight/inflight.js36
1 files changed, 36 insertions, 0 deletions
diff --git a/sandbox/testAppNevena/Front/node_modules/promise-inflight/inflight.js b/sandbox/testAppNevena/Front/node_modules/promise-inflight/inflight.js
new file mode 100644
index 00000000..ce054d34
--- /dev/null
+++ b/sandbox/testAppNevena/Front/node_modules/promise-inflight/inflight.js
@@ -0,0 +1,36 @@
+'use strict'
+module.exports = inflight
+
+let Bluebird
+try {
+ Bluebird = require('bluebird')
+} catch (_) {
+ Bluebird = Promise
+}
+
+const active = {}
+inflight.active = active
+function inflight (unique, doFly) {
+ return Bluebird.all([unique, doFly]).then(function (args) {
+ const unique = args[0]
+ const doFly = args[1]
+ if (Array.isArray(unique)) {
+ return Bluebird.all(unique).then(function (uniqueArr) {
+ return _inflight(uniqueArr.join(''), doFly)
+ })
+ } else {
+ return _inflight(unique, doFly)
+ }
+ })
+
+ function _inflight (unique, doFly) {
+ if (!active[unique]) {
+ active[unique] = (new Bluebird(function (resolve) {
+ return resolve(doFly())
+ }))
+ active[unique].then(cleanup, cleanup)
+ function cleanup() { delete active[unique] }
+ }
+ return active[unique]
+ }
+}