"=============================================================================
" remote.vim --- remote command for git.vim
" Copyright (c) 2016-2022 Wang Shidong & Contributors
" Author: Wang Shidong < wsdjeg@outlook.com >
" License: GPLv3
"=============================================================================

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

let s:NOTI.notify_max_width = &columns * 0.50
let s:NOTI.timeout = 5000

function! git#remote#run(...) abort

  let cmd = ['git', 'remote']
  if len(a:1) > 0
    let cmd += a:1
  endif
  call s:JOB.start(cmd,
        \ {
          \ 'on_stdout' : function('s:on_stdout'),
          \ 'on_stderr' : function('s:on_stderr'),
          \ 'on_exit' : function('s:on_exit'),
          \ }
          \ )

endfunction

function! s:on_exit(...) abort
  let data = get(a:000, 2)
  if data != 0
    echo 'failed!'
  else
    echo 'done!'
  endif
endfunction


function! s:on_stdout(id, data, event) abort
  for line in filter(a:data, '!empty(v:val)')
    call s:NOTI.notify(line, 'Normal')
  endfor
endfunction

function! s:on_stderr(id, data, event) abort
  for line in filter(a:data, '!empty(v:val)')
    call s:NOTI.notify(line, 'WarningMsg')
  endfor
endfunction

function! s:options() abort
  return [
        \ '-v',
        \ ]
endfunction

function! s:sub_cmd() abort
  return [
        \ 'rename', 'add', 'remove', 'set-branchs', 'set-url', 'show'
        \ ]
endfunction

function! git#remote#complete(ArgLead, CmdLine, CursorPos) abort
  let str = a:CmdLine[:a:CursorPos-1]
  if str =~# '^Git\s\+remote\s\+-$'
    return join(s:options(), "\n")
  elseif str =~# '^Git\s\+remote\s\+[^ ]*$'
    return join(s:options() + s:sub_cmd(), "\n")
  elseif str =~# '^Git\s\+remote\s\+set-url\s\+-\+$'
    return join(['--add', '--delete'], "\n")
  elseif str =~# '^Git\s\+remote\s\+rename\s\+[^ ]*$'
        \ || str =~# '^Git\s\+remote\s\+\('
        \ . join(['add', 'rename', 'set-head', 'show', 'set-url', 'set-branchs'], '\|')
        \ . '\)\s\+[^ ]*$'
    return join(s:remotes(), "\n")
  else
    let remote = matchstr(str, '\(Git\s\+remote\s\+\)\@<=[^ ]*')
    return s:remote_branch(remote)
  endif
endfunction

function! s:remotes() abort
  return map(systemlist('git remote'), 'trim(v:val)')
endfunction

function! s:remote_branch(remote) abort
  let branchs = systemlist('git branch -a')
  if v:shell_error
    return ''
  else
    let branchs = join(map(filter(branchs, 'v:val =~ "\s*remotes/" . a:remote . "/[^ ]*$"'), 'trim(v:val)[len(a:remote) + 9:]'), "\n")
    return branchs
  endif
endfunction