diff options
| author | Justin M. Keyes <justinkz@gmail.com> | 2017-01-04 17:34:17 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2017-01-04 17:34:17 +0100 |
| commit | e21aef1e1002581dc653176eb3d7d4f2b06424f8 (patch) | |
| tree | bfce3ac9ee2db2a9627653b340abdb8c6f7e69c0 /runtime/autoload | |
| parent | 695703ca97e9330e3dbbeb3153b57b4ca565d045 (diff) | |
| parent | 24b3b938e888bd053aaa1265266a5b0deaa3a0a6 (diff) | |
| download | rneovim-e21aef1e1002581dc653176eb3d7d4f2b06424f8.tar.gz rneovim-e21aef1e1002581dc653176eb3d7d4f2b06424f8.tar.bz2 rneovim-e21aef1e1002581dc653176eb3d7d4f2b06424f8.zip | |
Merge #5874 from ZyX-I/fix-5482
Fix plugin which opens ShaDa files
Diffstat (limited to 'runtime/autoload')
| -rw-r--r-- | runtime/autoload/msgpack.vim | 8 | ||||
| -rw-r--r-- | runtime/autoload/shada.vim | 13 |
2 files changed, 14 insertions, 7 deletions
diff --git a/runtime/autoload/msgpack.vim b/runtime/autoload/msgpack.vim index 2e2697c57f..a10ac32469 100644 --- a/runtime/autoload/msgpack.vim +++ b/runtime/autoload/msgpack.vim @@ -665,11 +665,15 @@ function msgpack#eval(s, special_objs) abort call add(expr, ']}') let s = s[1:] elseif s[0] is# '''' - let char = matchstr(s, '\m\C^''\zs.\ze''') + let char = matchstr(s, '\v\C^\''\zs%(\\\d+|.)\ze\''') if empty(char) throw 'char-invalid:Invalid integer character literal format: ' . s endif - call add(expr, char2nr(char)) + if char[0] is# '\' + call add(expr, +char[1:]) + else + call add(expr, char2nr(char)) + endif let s = s[len(char) + 2:] else throw 'unknown:Invalid non-space character: ' . s diff --git a/runtime/autoload/shada.vim b/runtime/autoload/shada.vim index 9be85b6f2e..cf27ee608a 100644 --- a/runtime/autoload/shada.vim +++ b/runtime/autoload/shada.vim @@ -241,8 +241,6 @@ function s:shada_check_type(type, val) abort if msg isnot# 0 return msg endif - if a:val > 0 || a:val < 1 - endif return 0 elseif a:type is# 'binarray' if type isnot# 'array' @@ -359,9 +357,14 @@ function s:shada_string(type, v) abort if (has_key(s:SHADA_ENUMS, a:type) && type(a:v) == type(0) \&& has_key(s:SHADA_REV_ENUMS[a:type], a:v)) return s:SHADA_REV_ENUMS[a:type][a:v] - elseif (a:type is# 'intchar' && type(a:v) == type(0) - \&& strtrans(nr2char(a:v)) is# nr2char(a:v)) - return "'" . nr2char(a:v) . "'" + " Restricting a:v to be <= 127 is not necessary, but intchar constants are + " normally expected to be either ASCII printable characters or NUL. + elseif a:type is# 'intchar' && type(a:v) == type(0) && a:v >= 0 && a:v <= 127 + if a:v > 0 && strtrans(nr2char(a:v)) is# nr2char(a:v) + return "'" . nr2char(a:v) . "'" + else + return "'\\" . a:v . "'" + endif else return msgpack#string(a:v) endif |