|  | Commit message (Collapse) | Author | Age | 
|---|
| ... |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| | Problem:    When creating a bufref, then using :bwipe and :new it might get
            the same memory and bufref_valid() returns true.
Solution:   Add br_fnum to check the buffer number didn't change.
https://github.com/vim/vim/commit/45e5fd135da5710f24a1acc142692f120f8b0b78 | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| | * Add api function get keymap
nvim_get_keymap(mode)
nvim_buf_get_keymap(buffer, mode) | 
| |\ |  | 
| | | |  | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | Also re-word some error messages:
- "Key does not exist: %s"
- "Invalid channel: %<PRIu64>"
- "Request array size must be 4 (request) or 3 (notification)"
- "String cannot contain newlines"
References #6150 | 
| | | |  | 
| | | |  | 
| | | |  | 
| | | 
| | 
| | 
| | | Closes #5984 | 
| | | |  | 
| | | 
| | 
| | 
| | 
| | | Should not really change anything, but code should be more efficient by using 
more optimized libc functions (memchrsub is not libc, but it uses memchr) in 
place of a cycle. | 
| |\| |  | 
| | | |  | 
| | | 
| | 
| | 
| | | Also fixed an error in path_fnamecmp(). | 
| |/  
|   
|   
|   
|   
| | Reasoning; currently INTERNAL_CALL is mostly used to determine whether it is 
needed to deal with NL-used-as-NUL problem. This code is useful for nvim_… API 
calls done from VimL, but not for API calls done from lua, yet lua needs to 
supply something as channel_id. | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | When the buffer that nvim_buf_set_lines() is changing is not in any vim
window, fix_cursor() leads to calling ml_get_buf() with an invalid line
number. The condition that fix_cursor() was called on was (buf ==
curbuf), but this is always true because of the call to
switch_to_win_for_buf() earlier in the function.
Instead this should be predicated on (save_curbuf.br_buf == NULL) | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | It's important that users have a single, easy-to-remember place for
reading about the API. So this commit changes gen_api_vimdoc.py so that
the generated section is appended to api.txt instead of creating
a separate document.
Also remove the section numbering and ToC: it's a maintenance cost, and
it will be unnecessary when #5169 is integrated. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Reasonings:
1. It is not used for anything, but scope dictionaries currenly. So there is no 
   need to generalize and split it into dict_set_var (which will contain some 
   scope-dictionary-specific checks) and dict_set_value (which will work for any 
   dictionary).
2. Check for key size is no longer valid for non-scope dictionaries: you *can* 
   use empty keys there. In scope dictionaries also, but you actually are not 
   supposed to store there anything, but variables.
Note that actually one may still do
    let b:[''] = 1
and “bypass” check for variable name. It won’t change what `echo b:` will show, 
but it may affect code which iterates over scope dictionary keys and sets them 
to something (if there is such code). | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| | v7.4.2024 changed a few function signatures of functions that we use in
Neovim-specific code, e.g. the API.
Due to that the commit for 7.4.2024 doesn't build on its own, only together with
this commit. | 
| | 
| 
| 
| | Clarify behavior of v:errmsg and the Error object. | 
| | 
| 
| 
| | remove unused response_id parameter of handle_nvim_... helpers | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | move `call_shell` to misc1.c
Move some fns to state.c
Move some fns to option.c
Move some fns to memline.c
Move `vim_chdir*` fns to file_search.c
Move some fns to new module, bytes.c
Move some fns to fileio.c | 
| | |  | 
| | 
| 
| 
| | Blacklist deprecated functions and functions depending on channel_id | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| | -1 is index past the end, and -2 is the index of the last element.
This eliminates the need for include_start/include_end.
Allow the handling of out-of-bounds to be configurable. | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| | We want to switch include_start/end when the index is positive or
negative. | 
| | 
| 
| 
| 
| 
| 
| 
| | buffer_insert calls buffer_set_line_slice excluding the start
line number and including the end, but it should be the opposite.
Closes https://github.com/neovim/neovim/issues/3212
Closes https://github.com/neovim/python-client/issues/103 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | API functions exposed via msgpack-rpc now fall into two categories:
- async functions, which are executed as soon as the request is parsed
- sync functions, which are invoked in nvim main loop when processing the
  `K_EVENT special key
Only a few functions which can be safely executed in any context are marked as
async. | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| | We already use wrappers for allocation, the new `xfree` function is the
equivalent for deallocation and provides a way to fully replace the malloc
implementation used by Neovim. |