forked from luna/vim-rana-local
fixed bug where time lost between Frequency and Away
This commit is contained in:
parent
eb0781688d
commit
56c2b365b1
1 changed files with 67 additions and 40 deletions
|
@ -33,12 +33,12 @@ let s:VERSION = '0.2.1'
|
||||||
|
|
||||||
" Set default away minutes
|
" Set default away minutes
|
||||||
if !exists("g:wakatime_AwayMinutes")
|
if !exists("g:wakatime_AwayMinutes")
|
||||||
let g:wakatime_AwayMinutes = 5
|
let g:wakatime_AwayMinutes = 10
|
||||||
endif
|
endif
|
||||||
|
|
||||||
" Set default action frequency in seconds
|
" Set default action frequency in minutes
|
||||||
if !exists("g:wakatime_ActionFrequency")
|
if !exists("g:wakatime_ActionFrequency")
|
||||||
let g:wakatime_ActionFrequency = 299
|
let g:wakatime_ActionFrequency = 5
|
||||||
endif
|
endif
|
||||||
|
|
||||||
" To be backwards compatible, rename config file
|
" To be backwards compatible, rename config file
|
||||||
|
@ -72,7 +72,7 @@ let s:VERSION = '0.2.1'
|
||||||
function! s:Api(targetFile, time, endtime, is_write, last)
|
function! s:Api(targetFile, time, endtime, is_write, last)
|
||||||
let targetFile = a:targetFile
|
let targetFile = a:targetFile
|
||||||
if targetFile == ''
|
if targetFile == ''
|
||||||
let targetFile = a:last[1]
|
let targetFile = a:last[2]
|
||||||
endif
|
endif
|
||||||
if targetFile != ''
|
if targetFile != ''
|
||||||
let cmd = ['python', s:plugin_directory . 'packages/wakatime/wakatime.py']
|
let cmd = ['python', s:plugin_directory . 'packages/wakatime/wakatime.py']
|
||||||
|
@ -97,18 +97,18 @@ let s:VERSION = '0.2.1'
|
||||||
|
|
||||||
function! s:GetLastAction()
|
function! s:GetLastAction()
|
||||||
if !filereadable(expand("$HOME/.wakatime.data"))
|
if !filereadable(expand("$HOME/.wakatime.data"))
|
||||||
return [0.0, '']
|
return [0.0, '', 0.0]
|
||||||
endif
|
endif
|
||||||
let last = readfile(expand("$HOME/.wakatime.data"), '', 2)
|
let last = readfile(expand("$HOME/.wakatime.data"), '', 2)
|
||||||
if len(last) != 2
|
if len(last) < 3
|
||||||
return [0.0, '']
|
return [0.0, '', 0.0]
|
||||||
endif
|
endif
|
||||||
return [str2float(last[0]), last[1]]
|
return [str2float(last[0]), str2float(last[1]), last[2]]
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! s:SetLastAction(time, targetFile)
|
function! s:SetLastAction(time, targetFile)
|
||||||
let s:fresh = 0
|
let s:fresh = 0
|
||||||
call writefile([printf('%f', a:time), a:targetFile], expand("$HOME/.wakatime.data"))
|
call writefile([printf('%f', a:time), printf('%f', s:GetCurrentTime()), a:targetFile], expand("$HOME/.wakatime.data"))
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! s:GetChar()
|
function! s:GetChar()
|
||||||
|
@ -119,39 +119,46 @@ let s:VERSION = '0.2.1'
|
||||||
return c
|
return c
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! s:EnoughTimePassed(now, prev)
|
function! s:EnoughTimePassed(now, last)
|
||||||
if a:now - a:prev >= g:wakatime_ActionFrequency
|
let prev = a:last[0]
|
||||||
|
if a:now - prev > g:wakatime_ActionFrequency * 60
|
||||||
return 1
|
return 1
|
||||||
endif
|
endif
|
||||||
return 0
|
return 0
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! s:Away(now, last)
|
function! s:ShouldPromptUser(now, last)
|
||||||
if s:fresh || a:last[0] < 1
|
let prev = a:last[1]
|
||||||
|
if s:fresh || prev[0] < 1
|
||||||
return 0
|
return 0
|
||||||
endif
|
endif
|
||||||
|
let duration = a:now - prev
|
||||||
let duration = a:now - a:last[0]
|
|
||||||
if duration > g:wakatime_AwayMinutes * 60
|
if duration > g:wakatime_AwayMinutes * 60
|
||||||
let units = 'seconds'
|
return 1
|
||||||
if duration > 59
|
|
||||||
let duration = round(duration / 60)
|
|
||||||
let units = 'minutes'
|
|
||||||
endif
|
|
||||||
if duration > 59
|
|
||||||
let duration = round(duration / 60)
|
|
||||||
let units = 'hours'
|
|
||||||
endif
|
|
||||||
if duration > 24
|
|
||||||
let duration = round(duration / 24)
|
|
||||||
let units = 'days'
|
|
||||||
endif
|
|
||||||
let answer = input(printf("You were away %.f %s. Add time to current file? (y/n)", duration, units))
|
|
||||||
if answer != "y"
|
|
||||||
return 1
|
|
||||||
endif
|
|
||||||
return 0
|
|
||||||
endif
|
endif
|
||||||
|
return 0
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:Away(now, prev)
|
||||||
|
let duration = a:now - a:prev
|
||||||
|
let units = 'seconds'
|
||||||
|
if duration > 59
|
||||||
|
let duration = round(duration / 60)
|
||||||
|
let units = 'minutes'
|
||||||
|
endif
|
||||||
|
if duration > 59
|
||||||
|
let duration = round(duration / 60)
|
||||||
|
let units = 'hours'
|
||||||
|
endif
|
||||||
|
if duration > 24
|
||||||
|
let duration = round(duration / 24)
|
||||||
|
let units = 'days'
|
||||||
|
endif
|
||||||
|
let answer = input(printf("You were away %.f %s. Add time to current file? (y/n)", duration, units))
|
||||||
|
if answer != "y"
|
||||||
|
return 1
|
||||||
|
endif
|
||||||
|
return 0
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
" }}}
|
" }}}
|
||||||
|
@ -163,18 +170,38 @@ let s:VERSION = '0.2.1'
|
||||||
let targetFile = s:GetCurrentFile()
|
let targetFile = s:GetCurrentFile()
|
||||||
let now = s:GetCurrentTime()
|
let now = s:GetCurrentTime()
|
||||||
let last = s:GetLastAction()
|
let last = s:GetLastAction()
|
||||||
"echo printf('%f %f %s', now, last[0], last[1])
|
if s:EnoughTimePassed(now, last) || targetFile != last[2]
|
||||||
if s:EnoughTimePassed(now, last[0]) || targetFile != last[1]
|
if s:ShouldPromptUser(now, last)
|
||||||
if s:Away(now, last)
|
if s:Away(now, last)
|
||||||
call s:Api(targetFile, last[0], now, 0, last)
|
call s:Api(targetFile, now, last[0], 0, last)
|
||||||
|
else
|
||||||
|
call s:Api(targetFile, now, 0.0, 0, last)
|
||||||
|
endif
|
||||||
else
|
else
|
||||||
call s:Api(targetFile, now, 0.0, 0, last)
|
call s:Api(targetFile, now, last[0], 0, last)
|
||||||
endif
|
endif
|
||||||
|
else
|
||||||
|
call s:SetLastAction(last[0], targetFile)
|
||||||
endif
|
endif
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! s:writeAction()
|
function! s:writeAction()
|
||||||
call s:Api(s:GetCurrentFile(), s:GetCurrentTime(), 0.0, 1, s:GetLastAction())
|
let targetFile = s:GetCurrentFile()
|
||||||
|
let now = s:GetCurrentTime()
|
||||||
|
let last = s:GetLastAction()
|
||||||
|
if s:EnoughTimePassed(now, last) || targetFile != last[2]
|
||||||
|
if s:ShouldPromptUser(now, last)
|
||||||
|
if s:Away(now, last)
|
||||||
|
call s:Api(targetFile, now, last[0], 1, last)
|
||||||
|
else
|
||||||
|
call s:Api(targetFile, now, 0.0, 1, last)
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
call s:Api(targetFile, now, last[0], 1, last)
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
call s:SetLastAction(last[0], targetFile)
|
||||||
|
endif
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
" }}}
|
" }}}
|
||||||
|
|
Loading…
Reference in a new issue