summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohann Klähn <kljohann@gmail.com>2010-09-08 23:24:39 +0200
committerJohann Klähn <kljohann@gmail.com>2010-09-08 23:24:39 +0200
commit6c0ccd5ffd0a9ac1f97adeca1dc22a7c9db844c5 (patch)
tree0ce8f39044ce6bc7bb4a11cff0e86914a7b2a55d
parent58fcb0f30f850f1e3140b42419c280a5dd731e30 (diff)
downloadfork-ledger-6c0ccd5ffd0a9ac1f97adeca1dc22a7c9db844c5.tar.gz
fork-ledger-6c0ccd5ffd0a9ac1f97adeca1dc22a7c9db844c5.tar.bz2
fork-ledger-6c0ccd5ffd0a9ac1f97adeca1dc22a7c9db844c5.zip
vim. add LedgerToggleTransactionState()
By using call LedgerToggleTransactionState(line('.'), ' *?') the state of the transaction will toggle through: no state -> * -> ? -> no state -> … beginning at what ever state it currently has. Adjust to your liking. Thanks to Chad Voegele for the suggestion.
-rw-r--r--contrib/vim/ftplugin/ledger.vim37
1 files changed, 31 insertions, 6 deletions
diff --git a/contrib/vim/ftplugin/ledger.vim b/contrib/vim/ftplugin/ledger.vim
index 1cced35c..623b0795 100644
--- a/contrib/vim/ftplugin/ledger.vim
+++ b/contrib/vim/ftplugin/ledger.vim
@@ -268,6 +268,26 @@ function! LedgerGetTags() "{{{1
return alltags
endf "}}}
+function! LedgerToggleTransactionState(lnum, ...)
+ if a:0 == 1
+ let chars = a:1
+ else
+ let chars = ' *'
+ endif
+ let trans = s:transaction.from_lnum(a:lnum)
+ if empty(trans)
+ return
+ endif
+
+ let old = has_key(trans, 'state') ? trans['state'] : ' '
+ let i = stridx(chars, old) + 1
+ let new = chars[i > len(chars) ? 0 : i]
+
+ call trans.set_state(new)
+
+ call setline(trans['head'], trans.format_head())
+endf
+
function! LedgerSetTransactionState(lnum, char) "{{{1
" modifies or sets the state of the transaction at the cursor,
" removing the state alltogether if a:char is empty
@@ -276,11 +296,7 @@ function! LedgerSetTransactionState(lnum, char) "{{{1
return
endif
- if empty(a:char) && has_key(trans, 'state')
- call remove(trans, 'state')
- else
- let trans['state'] = a:char
- endif
+ call trans.set_state(a:char)
call setline(trans['head'], trans.format_head())
endf "}}}
@@ -351,7 +367,8 @@ function! s:transaction.from_lnum(lnum) dict "{{{2
let trans['date'] = part
elseif ! has_key(trans, 'code') && part =~ '^([^)]*)$'
let trans['code'] = part[1:-2]
- elseif ! has_key(trans, 'state') && part =~ '^[!?*]$'
+ elseif ! has_key(trans, 'state') && part =~ '^.$'
+ " the first character by itself is assumed to be the state of the transaction.
let trans['state'] = part
else
call add(description, part)
@@ -361,6 +378,14 @@ function! s:transaction.from_lnum(lnum) dict "{{{2
return trans
endf "}}}
+function! s:transaction.set_state(char) dict "{{{2
+ if has_key(self, 'state') && a:char =~ '^\s*$'
+ call remove(self, 'state')
+ else
+ let self['state'] = a:char
+ endif
+endf "}}}
+
function! s:transaction.parse_body(...) dict "{{{2
if a:0 == 2
let head = a:1