• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

TypeScript neovim.attach函数代码示例

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

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



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

示例1: createNvim

export function createNvim(): Neovim {
  let p = which.sync('nvim')
  let proc = cp.spawn(p, ['-u', 'NORC', '-i', 'NONE', '--embed', '--headless'], {
    shell: false
  })
  return attach({ proc })
}
开发者ID:illarionvk,项目名称:dotfiles,代码行数:7,代码来源:index.ts


示例2: Promise

 return new Promise(async resolve => {
   if (!env) {
     env = await workspace.nvim.call('coc#util#highlight_options') as Env
     if (!env) resolve([])
     let paths = env.runtimepath.split(',')
     let dirs = paths.filter(p => {
       if (env.colorscheme) {
         let schemeFile = path.join(p, `colors/${env.colorscheme}.vim`)
         if (fs.existsSync(schemeFile)) return true
       }
       if (fs.existsSync(path.join(p, 'syntax'))) return true
       if (fs.existsSync(path.join(p, 'after/syntax'))) return true
       return false
     })
     env.runtimepath = dirs.join(',')
   }
   let proc = cp.spawn('nvim', ['-u', 'NORC', '-i', 'NONE', '--embed', uuid()], {
     shell: false,
     cwd: os.tmpdir(),
     env: omit(process.env, ['NVIM_LISTEN_ADDRESS'])
   })
   let timer: NodeJS.Timer
   let exited = false
   const exit = () => {
     if (exited) return
     exited = true
     if (timer) clearTimeout(timer)
     if (nvim) {
       nvim.command('qa!').catch(() => {
         let killed = terminate(proc)
         if (!killed) {
           setTimeout(() => {
             terminate(proc)
           }, 50)
         }
       })
     }
   }
   try {
     proc.once('exit', () => {
       if (exited) return
       logger.info('highlight nvim exited.')
       resolve([])
     })
     timer = setTimeout(() => {
       exit()
       resolve([])
     }, 500)
     nvim = attach({ proc }, null, false)
     const callback = (method, args) => {
       if (method == 'redraw') {
         for (let arr of args) {
           let [name, ...list] = arr
           if (name == 'hl_attr_define') {
             for (let item of list) {
               let id = item[0]
               let { hi_name } = item[item.length - 1][0]
               hlMap.set(id, hi_name)
             }
           }
           if (name == 'grid_line') {
             // logger.debug('list:', JSON.stringify(list, null, 2))
             for (let def of list) {
               let [, line, col, cells] = def
               if (line >= lines.length) continue
               let colStart = 0
               let hlGroup = ''
               let currId = 0
               // tslint:disable-next-line: prefer-for-of
               for (let i = 0; i < cells.length; i++) {
                 let cell = cells[i]
                 let [ch, hlId, repeat] = cell as [string, number?, number?]
                 repeat = repeat || 1
                 let len = byteLength(ch.repeat(repeat))
                 // append result
                 if (hlId == 0 || (hlId > 0 && hlId != currId)) {
                   if (hlGroup) {
                     res.push({
                       line,
                       hlGroup,
                       colStart: colStart + 1,
                       colEnd: col + 1,
                       isMarkdown: filetype == 'markdown'
                     })
                   }
                   colStart = col
                   hlGroup = hlId == 0 ? '' : hlMap.get(hlId)
                 }
                 if (hlId != null) currId = hlId
                 col = col + len
               }
               if (hlGroup) {
                 res.push({
                   hlGroup,
                   line,
                   colStart: colStart + 1,
                   colEnd: col + 1,
                   isMarkdown: filetype == 'markdown'
                 })
               }
//.........这里部分代码省略.........
开发者ID:illarionvk,项目名称:dotfiles,代码行数:101,代码来源:highlight.ts


示例3: default

export default (opts: Attach): Plugin => {
  const nvim: NeovimClient = attach(opts)
  const plugin = new Plugin(nvim)
  let initialized = false
  nvim.on('notification', async (method, args) => {
    switch (method) {
      case 'VimEnter': {
        if (!initialized) {
          initialized = true
          await plugin.init()
        }
        break
      }
      case 'OptionSet':
        await events.fire('OptionSet', args)
        break
      case 'InputChar':
        await events.fire('InputChar', args)
        break
      case 'GlobalChange':
        await events.fire('GlobalChange', args)
        break
      case 'CocAutocmd':
        await events.fire(args[0], args.slice(1))
        break
      default:
        const m = method[0].toLowerCase() + method.slice(1)
        if (typeof plugin[m] == 'function') {
          try {
            await Promise.resolve(plugin[m].apply(plugin, args))
          } catch (e) {
            // tslint:disable-next-line:no-console
            console.error(`error on notification '${method}': ${e}`)
          }
        }
    }
  })

  nvim.on('request', async (method: string, args, resp) => {
    try {
      if (method == 'CocAutocmd') {
        await events.fire(args[0], args.slice(1))
        resp.send()
        return
      }
      let m = method[0].toLowerCase() + method.slice(1)
      if (typeof plugin[m] !== 'function') {
        return resp.send(`Method ${m} not found`, true)
      }
      let res = await Promise.resolve(plugin[m].apply(plugin, args))
      resp.send(res)
    } catch (e) {
      logger.error(`Error on "${method}": ` + e.stack)
      resp.send(e.message, true)
    }
  })

  nvim.channelId.then(async channelId => {
    if (isTest) nvim.command(`let g:coc_node_channel_id = ${channelId}`, true)
    let json = require('../package.json')
    let { major, minor, patch } = semver.parse(json.version)
    nvim.setClientInfo('coc', { major, minor, patch }, 'remote', {}, {})
    let entered = await nvim.getVvar('vim_did_enter')
    if (entered && !initialized) {
      initialized = true
      await plugin.init()
    }
  }).catch(e => {
    console.error(`Channel create error: ${e.message}`) // tslint:disable-line
  })
  return plugin
}
开发者ID:demelev,项目名称:coc.nvim,代码行数:72,代码来源:attach.ts



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


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
TypeScript neovim.Neovim类代码示例发布时间:2022-05-28
下一篇:
TypeScript bitcoin-regtest-service.RegtestService类代码示例发布时间:2022-05-28
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap