當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript async.auto函數代碼示例

本文整理匯總了TypeScript中async.auto函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript auto函數的具體用法?TypeScript auto怎麽用?TypeScript auto使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了auto函數的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: Promise

test.cb('async.auto full test', (t) => {
    async.auto(
        {
            a: (next) => { next(null, 1); },
            b: makeAsyncAutoTaskSpec(['a'], (a, next) => {
                next(null, a + 1);
            }),
            c: makeAsyncAutoTaskSpec(['b'], promiseToCallback((b) => {
                return new Promise((resolve) => {
                    resolve(b + 2);
                });
            })),
            d: makeAsyncAutoTaskSpecP(['c'], (c) => {
                return c + 4;
            }),
            e: makeAsyncAutoTaskSpecP(['c', 'd'], (c, d) => {
                return new Promise((resolve) => {
                    resolve(c + d);
                });
            })
        },
        9,
        makeAsyncAutoHandlerFunc(['c', 'd', 'e'], function(err, c, d, e) {
            t.is(err, null);
            t.is(c, 4);
            t.is(d, 8);
            t.is(e, 12);
            t.end();
        })
    );
});
開發者ID:forbesmyester,項目名稱:async-auto-funcs,代碼行數:31,代碼來源:index.ts

示例2: onActive

  public onActive(callback) {
    let state = { isActive: false, isDeleting: false }
    auto({
      isActive: done => {
        this.isActive((err, isActive) => {
          state.isActive = isActive
          done(err)
        })
      },

      isDeleting: ['isActive', done => {
        if (state.isActive) {
          return done()
        }

        this.isDeleting((err, isDeleting) => {
          state.isDeleting = isDeleting
          done(err)
        })
      }],
    }, err => {
      if (err) {
        return callback(err)
      }

      if (state.isActive) {
        return callback()
      }

      if (state.isDeleting) {
        return callback(new Error('Stream is deleting'))
      }

      let isActive
      doUntil(done => {
        this.isActive((err, _isActive) => {
          if (err) {
            return done(err)
          }

          isActive = _isActive
          done()
        })
      }, () => {
        return isActive
      }, callback)
    })
  }
開發者ID:evansolomon,項目名稱:nodejs-kinesis-client-library,代碼行數:48,代碼來源:Stream.ts

示例3: collectProfileData

function collectProfileData(uid, finalCallback) {
    async.auto({
        'user': [(callback) => {
            repo.getUser(uid, callback);
        }],
        'friends': [(callback) => {
            repo.getFriends(uid, callback);
        }],
        'subscriptions': [(callback) => {
            repo.getSubscriptions(uid, callback);
        }],
        'saveData': ['user', 'friends', 'subscriptions', (callback, results) => {
            fs.writeFile(tempFolder + uid + '.json', JSON.stringify(results), 'utf-8', callback);
        }],
        'profile': ['saveData', (callback, results) => {
            var profile = createProfile(results);
            callback(null, profile);
        }],
        'saveProfile': ['profile', (callback, results) => {
            fs.writeFile(tempFolder + uid + '-profile.json', JSON.stringify(results.profile), 'utf-8', callback);
        }]
    }, finalCallback);
}
開發者ID:soramusoka,項目名稱:social-data-analysis,代碼行數:23,代碼來源:index.ts

示例4: _crop

  /**
   * Smart cropping routine
   */
  private _crop(inImage: string, inWidth: number, inHeight: number, outImage: string, done: DoneCallback) {
    const gmImage   = gm(inImage);
    const gmInImage = gm(inImage);

    async.auto({
      size(cb: DoneCallback) {
        gmImage.size((err: any, val: ImageSize) => {
          cb(err, val);
        });
      },

      createEdgedImage: ['size', (cb: DoneCallback, results: AutoFlowResult) => {
        if ((inWidth > results.size.width) || (inHeight > results.size.height)) {
          return cb('Target dimensions must be smaller or equal to source dimensions.');
        }

        const edgeFilterRadius = 1;
        gmImage.edge(edgeFilterRadius)
        .modulate(100, 0, 100)
        .blackThreshold(15, 15, 15)
        .write(outImage, (err: any) => {
          cb(err, {resultFile: outImage});
        });
      }],

      calculateCenter: ['size', 'createEdgedImage', (cb: DoneCallback, results: AutoFlowResult) => {
        this._createGdImage(results.createEdgedImage.resultFile, (err, gdImage) => {
          if (err) {
            return cb(err);
          }

          let n = 100000;
          let xcenter = 0;
          let ycenter = 0;
          let sum = 0;

          for (let k = 0; k < n; k++) {
            const i = this._random(0, results.size.width - 1);
            const j = this._random(0, results.size.height - 1);
            // get blue (why blue???) channels value
            const val = gdImage.imageColorAt(i, j) & 0xFF;
            sum += val;
            xcenter += (i + 1) * val;
            ycenter += (j + 1) * val;
          }

          xcenter /= sum;
          ycenter /= sum;

          // crop source img to target AR
          const targetAspectRatio = inWidth / inHeight;
          let wcrop0 = 0;
          let hcrop0 = 0;
          if ((results.size.width / results.size.height) > targetAspectRatio) {
            // source AR wider than target
            // crop width to target AR
            wcrop0 = Math.round(targetAspectRatio * results.size.height);
            hcrop0 = results.size.height;
          } else {
            // crop height to target AR
            wcrop0 = results.size.width;
            hcrop0 = Math.round(results.size.width / targetAspectRatio);
          }


          ///////////////////////////
          // crop at different scales
          ///////////////////////////

          // scale count: number of crop sizes to try
          const nk: number = 9;
          const hgap = hcrop0 - inHeight;
          const hinc = (nk === 1) ? 0 : hgap / (nk - 1);
          const wgap = wcrop0 - inWidth;
          const winc = (nk === 1) ? 0 : wgap / (nk - 1);

          // find window with highest normalized edginess
          n = 10000;
          let maxbetanorm = 0;
          const maxparam = {w: 0, h: 0, x: 0, y: 0};
          const w0 = results.size.width;
          const h0 = results.size.height;

          // for k in [0...nk]
          for (let k = 0; k < nk; k++) {
            const hcrop = Math.round(hcrop0 - k * hinc);
            const wcrop = Math.round(wcrop0 - k * winc);
            let xcrop = xcenter - wcrop / 2;
            let ycrop = ycenter - hcrop / 2;

            if (xcrop < 0) {
              xcrop = 0;
            }
            if ((xcrop + wcrop) > w0) {
              xcrop = w0 - wcrop;
            }
            if (ycrop < 0) {
//.........這裏部分代碼省略.........
開發者ID:apedyashev,項目名稱:opticrop-node,代碼行數:101,代碼來源:opticrop.ts

示例5: function


//.........這裏部分代碼省略.........
              });
              if (theTranslation) {
                doATranslate(columnTranslation, theTranslation);
              } else {
                cb('Invalid ref property of ' + columnTranslation.ref + ' in columnTranslations ' + columnTranslation.field);
              }
            }
          });
          cb(null, null);
        }];

        var callFuncs = false;
        for (var i = 0; i < schema.columnTranslations.length; i++) {
          var thisColumnTranslation = schema.columnTranslations[i];

          if (thisColumnTranslation.field) {
            // if any of the column translations are adhoc funcs, set up the tasks to perform them
            if (thisColumnTranslation.fn) { callFuncs = true; }

            // if this column translation is a "ref", set up the tasks to look up the values and populate the translations
            if (thisColumnTranslation.ref) {
              var lookup = self.getResource(thisColumnTranslation.ref);
              if (lookup) {
                if (!toDo[thisColumnTranslation.ref]) {
                  var getFunc = function (ref) {
                    var lookup = ref;
                    return function (cb) {
                      var translateObject = {ref: lookup.resourceName, translations: [] };
                      translations.push(translateObject);
                      lookup.model.find({}, {}, {lean: true}, function (err, findResults) {
                        if (err) {
                          cb(err);
                        } else {
                          // TODO - this ref func can probably be done away with now that list fields can have ref
                          var j = 0;
                          async.whilst(
                            function() { return j < findResults.length; },
                            function(cbres) {
                              var theResult = findResults[j];
                              translateObject.translations[j] = translateObject.translations[j] || {};
                              var theTranslation = translateObject.translations[j];
                              j++;
                              self.getListFields(lookup, theResult, function(err, description) {
                                if (err) {
                                  cbres(err);
                                } else {
                                  theTranslation.value = theResult._id;
                                  theTranslation.display = description;
                                  cbres(null);
                                }
                              })
                            },
                            cb
                          );
                        }
                      });
                    };
                  };
                  toDo[thisColumnTranslation.ref] = getFunc(lookup);
                  toDo.applyTranslations.unshift(thisColumnTranslation.ref);  // Make sure we populate lookup before doing translation
                }
              } else {
                return callback('Invalid ref property of ' + thisColumnTranslation.ref + ' in columnTranslations ' + thisColumnTranslation.field);
              }
            }
            if (!thisColumnTranslation.translations && !thisColumnTranslation.ref && !thisColumnTranslation.fn) {
              return callback('A column translation needs a ref, fn or a translations property - ' + thisColumnTranslation.field + ' has neither');
            }
          } else {
            return callback('A column translation needs a field property');
          }
        }
        if (callFuncs) {
          toDo['callFunctions'] = ['runAggregation', function (cb, results) {
            async.each(results.runAggregation, function (row, cb) {
              for (var i = 0; i < schema.columnTranslations.length; i++) {
                var thisColumnTranslation = schema.columnTranslations[i];

                if (thisColumnTranslation.fn) {
                  thisColumnTranslation.fn(row, cb);
                }
              }
            }, function () {
              cb(null);
            });
          }];
          toDo.applyTranslations.unshift('callFunctions');  // Make sure we do function before translating its result
        }
      }

      async.auto(toDo, function (err, results) {
        if (err) {
          callback(err);
        } else {
          // TODO: Could loop through schema.params and just send back the values
          callback(null, {success: true, schema: schema, report: results.runAggregation, paramsUsed: schema.params});
        }
      });
    }
  });
開發者ID:zettacristiano,項目名稱:forms-angular,代碼行數:101,代碼來源:data_form.ts

示例6: authenticate

async.auto({
    "configAuth": (cb) => {
        authenticate({
            secret: new Buffer(config.get<string>("auth0.clientSecret"), "base64"),
            audience: config.get<string>("auth0.clientId")
        });
        cb();
    },
    "configPermissions": (cb) => {
        permissions.init();
        cb();
    },
    "app": (cb) => {
        let app = express();

        app.set("port", config.get<string>("server.port"));

        app.use(cors());

        app.set("views", path.join(__dirname, "api", "views"));
        app.set("view engine", "jade");

        app.use(logger("dev"));
        app.use(bodyParser.json());
        app.use(bodyParser.urlencoded({
            extended: false
        }));
        // app.use(cookieParser());

        cb(null, app);
    },
    "routes": ["app", (results, cb) => {
        results.app.use("/api", apiRoute);
        results.app.use("/api/users", usersRoute({
          apiUrl: config.get<string>("auth0.apiUrl"),
          tokens: {
            userManagement: config.get<string>("auth0.tokens.userManagement")
          }
        }));

        results.app.use("/bower_components", express.static(path.join(__dirname,
            "bower_components")));

        results.app.use("/resources", express.static(path.join(__dirname, "resources")));


        // Hack to get configs into the client. Angular doesn't like loading
        // external files via $http before/during the config step.
        results.app.use("/config.js", (req, res) => {
            res.send("var LOADED_CONFIG = " + JSON.stringify(config.get("client")));
        });

        results.app.use("/config.json", (req, res) => {
            res.send(config.get("client"));
        });

        results.app.use("/", express.static(path.join(__dirname, "dashboard")));

        cb();
    }],
    "server": ["configAuth", "app", "routes", (results, cb) => {
        cb(null, http.createServer(results.app));
    }],
    "listen": ["server", (results, cb) => {
        results.server.listen(results.app.get("port"), () => {
            console.info("Express server listening", { port: results.app.get("port") });
            cb(null);
        });
    }],
}, (err: Error, result) => {
    console.info("Setup completed", { err: err });
});
開發者ID:MrHen,項目名稱:hen-auth,代碼行數:72,代碼來源:server.ts


注:本文中的async.auto函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。