当前位置: 首页>>代码示例>>TypeScript>>正文


TypeScript Logger.RecordingLogger类代码示例

本文整理汇总了TypeScript中common/Logger.RecordingLogger的典型用法代码示例。如果您正苦于以下问题:TypeScript RecordingLogger类的具体用法?TypeScript RecordingLogger怎么用?TypeScript RecordingLogger使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


在下文中一共展示了RecordingLogger类的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的TypeScript代码示例。

示例1: performLaunch

export async function performLaunch(
  ctx: Context,
  logger: RecordingLogger,
  cave: Cave,
  game: Game
) {
  ctx.emitProgress({ progress: -1, stage: "configure" });

  const { store } = ctx;
  const taskId = ctx.getTaskId();
  store.dispatch(
    actions.taskProgress({
      id: taskId,
      progress: -1,
      stage: "prepare",
    })
  );

  // TODO: have butler check morphing and queue a heal if needed
  const { appVersion } = store.getState().system;
  logger.info(`itch ${appVersion} launching '${game.title}' (#${game.id})`);

  const { preferences } = store.getState();
  const prereqsDir = paths.prereqsPath();

  // TODO: extract that to another module
  let prereqsModal: TypedModal<any, any>;
  let prereqsStateParams: PrereqsStateParams;

  function closePrereqsModal() {
    if (!prereqsModal) {
      return;
    }

    store.dispatch(
      actions.closeModal({
        wind: "root",
        id: prereqsModal.id,
      })
    );
    prereqsModal = null;
  }

  let powerSaveBlockerId: number = null;

  let cancelled = false;
  let launchConvo: Conversation;
  await ctx.withStopper({
    work: async () => {
      try {
        await mcall(
          messages.Launch,
          {
            caveId: cave.id,
            prereqsDir,
            sandbox: preferences.isolateApps,
          },
          convo => {
            launchConvo = convo;
            hookLogging(convo, logger);

            convo.on(messages.PickManifestAction, async ({ actions }) => {
              const index = await pickManifestAction(store, actions, game);
              return { index };
            });

            convo.on(messages.AcceptLicense, async ({ text }) => {
              const res = await promisedModal(
                store,
                modals.naked.make({
                  wind: "root",
                  title: ["prompt.sla.title"],
                  message: ["prompt.sla.message"],
                  detail: text,
                  widgetParams: {} as any,
                  buttons: [
                    {
                      label: ["prompt.sla.accept"],
                      action: actions.modalResponse({}),
                    },
                    "cancel",
                  ],
                })
              );

              if (res) {
                return { accept: true };
              }
              return { accept: false };
            });

            convo.on(messages.HTMLLaunch, async params => {
              return await performHTMLLaunch({
                ctx,
                logger,
                game,
                params,
              });
            });

//.........这里部分代码省略.........
开发者ID:itchio,项目名称:itch,代码行数:101,代码来源:perform-launch.ts

示例2: async

 stop: async () => {
   logger.debug(`Asked to stop, cancelling butler process`);
   cancelled = true;
   if (launchConvo) {
     await launchConvo.cancel();
   }
 },
开发者ID:itchio,项目名称:itch,代码行数:7,代码来源:perform-launch.ts


注:本文中的common/Logger.RecordingLogger类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。