本文整理汇总了TypeScript中state-switch.StateSwitch.off方法的典型用法代码示例。如果您正苦于以下问题:TypeScript StateSwitch.off方法的具体用法?TypeScript StateSwitch.off怎么用?TypeScript StateSwitch.off使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类state-switch.StateSwitch
的用法示例。
在下文中一共展示了StateSwitch.off方法的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的TypeScript代码示例。
示例1: quit
public async quit (): Promise<void> {
log.verbose('IoClient', 'quit()')
if (this.state.off() === 'pending') {
log.warn('IoClient', 'quit() with state.off() = `pending`, skipped')
throw new Error('quit() with state.off() = `pending`')
}
this.state.off('pending')
try {
if (this.options.wechaty) {
await this.options.wechaty.stop()
// this.wechaty = null
} else { log.warn('IoClient', 'quit() no this.wechaty') }
if (this.io) {
await this.io.stop()
// this.io = null
} else { log.warn('IoClient', 'quit() no this.io') }
} catch (e) {
log.error('IoClient', 'exception: %s', e.message)
throw e
} finally {
this.state.off(true)
}
return
}
示例2: start
public async start (): Promise<void> {
log.verbose('IoClient', 'init()')
if (this.state.pending()) {
log.warn('IoClient', 'start() with a pending state, not the time')
const e = new Error('state.pending() when start()')
throw e
}
this.state.on('pending')
try {
await this.startIo()
await this.hookWechaty(this.options.wechaty)
this.state.on(true)
} catch (e) {
log.error('IoClient', 'init() exception: %s', e.message)
this.state.off(true)
throw e
}
return
}
示例3: stop
public async stop (): Promise<void> {
log.verbose('IoClient', 'stop()')
this.state.off('pending')
// XXX
if (!this.io) {
log.warn('IoClient', 'stop() without this.io')
this.state.off(true)
return
}
await this.io.stop()
this.state.off(true)
// XXX 20161026
// this.io = null
return
}
示例4: stop
public async stop(): Promise<void> {
log.verbose('PuppetPadchatManager', `stop()`)
this.state.off('pending')
if (this.delayQueueExecutorSubscription) {
this.delayQueueExecutorSubscription.unsubscribe()
this.delayQueueExecutorSubscription = undefined
} else {
log.warn('PuppetPadchatManager', 'stop() subscript not exist')
}
await this.stopCheckScan()
await super.stop()
await this.releaseCache()
this.userId = undefined
this.loginScanQrcode = undefined
this.loginScanStatus = undefined
this.state.off(true)
}
示例5: hookWechaty
private async hookWechaty (wechaty: Wechaty): Promise<void> {
log.verbose('IoClient', 'initWechaty()')
if (this.state.off()) {
const e = new Error('state.off() is true, skipped')
log.warn('IoClient', 'initWechaty() %s', e.message)
throw e
}
wechaty
.on('login' , user => log.info('IoClient', `${user.name()} logined`))
.on('logout' , user => log.info('IoClient', `${user.name()} logouted`))
.on('scan', (url, code) => log.info('IoClient', `[${code}] ${url}`))
.on('message' , msg => this.onMessage(msg))
return
}
示例6: startIo
private async startIo (): Promise<void> {
log.verbose('IoClient', 'startIo() with token %s', this.options.token)
if (this.state.off()) {
const e = new Error('startIo() state.off() is true, skipped')
log.warn('IoClient', e.message)
throw e
}
try {
await this.io.start()
} catch (e) {
log.verbose('IoClient', 'startIo() init fail: %s', e.message)
throw e
}
return
}