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


TypeScript neovim.attach函數代碼示例

本文整理匯總了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;未經允許,請勿轉載。