1
0
mirror of https://github.com/SpaceVim/SpaceVim.git synced 2025-01-24 02:50:03 +08:00
SpaceVim/docs/api/job.md
2023-07-13 00:53:03 +08:00

2.0 KiB

title description
job API job API provides some basic functions for running a job

Available APIs >> job

Intro

job api provides a async job control api for vim and neovim.

let s:JOB = SpaceVim#api#import('job')

function! s:on_stdout(id, data, event) abort
   " do something with stdout
endfunction

function! s:on_stderr(id, data, event) abort
  " do something with stderr
endfunction

function! s:on_exit(id, data, event) abort
  " handle exit code
endfunction

let cmd = ['python', 'test.py']

call s:JOB.start(cmd,
    \ {
    \ 'on_stdout' : function('s:on_stdout'),
    \ 'on_stderr' : function('s:on_stderr'),
    \ 'on_exit' : function('s:on_exit'),
    \ }
    \ )

The lua job api:

local job = require('spacevim.api.job')

local jobid = job.start({'lua53', '-'}, {
  -- the on_stdout and on_stderr function can be:
  -- fun(id, data) end or fun(id, data, event) end
  on_stdout = function(id, data)
    vim.print(id)
    vim.print(vim.inspect(data))
  end,
  on_stderr = function(id, data)
    vim.print(id)
    vim.print(vim.inspect(data))
  end,
  on_exit = function(id, code, signal)
    vim.print(id)
    vim.print('exit code', code)
    vim.print('exit signal', signal)
  end,
})


job.send(jobid, 'print(1)\n')
job.send(jobid, 'print(1)\n')
job.send(jobid, 'print(1)\n')
job.send(jobid, 'print(1)\n')
job.chanclose(jobid, 'stdin')
job.stop(jobid)

Functions

function name description
start(cmd, argv) start a job, return the job id
send(id, data) send data to a job
stop(id) stop a jobe with specific job id
status(id) check the status of a job with the specific job id
list() list all the jobs