mirror of
				https://github.com/neovim/neovim.git
				synced 2025-10-26 12:27:24 +00:00 
			
		
		
		
	The grand renaming
This commit is contained in:
		| @@ -242,44 +242,44 @@ the type codes, because a client may be built against one Nvim version but | ||||
| connect to another with different type codes. | ||||
|  | ||||
| ============================================================================== | ||||
| 6. Live Updates				      *live-updates* *rpc-live-updates* | ||||
| 6. Buffer Updates				      *buffer-updates* *rpc-buffer-updates* | ||||
|  | ||||
| A dedicated API has been created to allow co-processes to be notified  when a | ||||
| buffer is changed in any way. It is difficult and error-prone to try and do | ||||
| this with autocommands such as |TextChanged|. | ||||
|  | ||||
|                                                               *live-updates-api* | ||||
| LiveUpdate Functions~ | ||||
|                                                               *buffer-updates-api* | ||||
| BufferUpdates Functions~ | ||||
|  | ||||
| nvim_buf_live_updates_start({send_buffer})     *nvim_buf_live_updates_start()* | ||||
| nvim_buf_attach({send_buffer})                                *nvim_buf_attach()* | ||||
|               Register a plugin to receive notifications on buffer changes. An | ||||
|               initial |LiveUpdateStart| notification will be sent as a | ||||
|               confirmation. After that, |LiveUpdate| notifications will be | ||||
|               sent for buffer updates, and |LiveUpdateTick| notifications for | ||||
|               a new changedtick without buffer change. | ||||
|               initial |nvim_buf_updates_start| notification will be sent as a | ||||
|               confirmation. After that, |nvim_buf_update| notifications will be | ||||
|               sent for buffer updates, and |nvim_buf_update_tick| notifications | ||||
|               for a new changedtick without buffer change. | ||||
|  | ||||
|               Parameters:~ | ||||
|                   {send_buffer}  Bool. If `"True"`, the initial | ||||
|                   |LiveUpdateStart| notification will also send the full | ||||
|                   buffer's content. If `"False"`, the notification will | ||||
|                   contain an empty list instead. | ||||
|                   |nvim_buf_updates_start| notification will also send the full | ||||
|                   buffer's content. If `"False"`, the notification will contain | ||||
|                   an empty list instead. | ||||
|  | ||||
| nvim_buf_live_updates_stop()                    *nvim_buf_live_updates_stop()* | ||||
| nvim_buf_detach()                                            *nvim_buf_detach()* | ||||
|               Unregister a plugin from buffer change notifications. A final | ||||
|               |LiveUpdateEnd| notification will be sent as confirmation. | ||||
|               |nvim_buf_updates_end| notification will be sent as confirmation. | ||||
|  | ||||
|                                                            *live-updates-events* | ||||
| LiveUpdate Events~ | ||||
|                                                            *buffer-updates-events* | ||||
| BufferUpdates Events~ | ||||
|  | ||||
| The co-process will start receiving the following notification events: | ||||
|  | ||||
| LiveUpdateStart[{buf}, {changedtick}, {linedata}, {more}]	 *LiveUpdateStart* | ||||
| nvim_buf_updates_start[{buf}, {changedtick}, {linedata}, {more}]	 *nvim_buf_updates_start* | ||||
|  | ||||
|   Neovim will send at least one of these notifications to confirm that | ||||
|   liveupdates are registered for this plugin, and possibly send the buffer's | ||||
|   buffer updates are registered for this plugin, and possibly send the buffer's | ||||
|   contents. If the buffer is very large, neovim might send the contents through | ||||
|   in multiple events to avoid loading the entire buffer's contents into memory | ||||
|   at once. | ||||
|   in multiple events to avoid loading the entire buffer's contents into | ||||
|   memory at once. | ||||
|  | ||||
| 	{buf} is an API handle for the buffer. | ||||
|  | ||||
| @@ -288,27 +288,27 @@ LiveUpdateStart[{buf}, {changedtick}, {linedata}, {more}]	 *LiveUpdateStart* | ||||
| 	|b:changedtick| as part of your request to ensure that no other | ||||
| 	changes have been made.  | ||||
|  | ||||
| 	{linedata} is a list of strings containing the buffer's contents. If | ||||
| 	this list contains 100 strings, then they represent lines 1-100 of the | ||||
| 	buffer.  Newline characters are not included in the strings, so empty | ||||
| 	lines will be given as empty strings. If you receive another | ||||
| 	|LiveUpdateStart| notification with another {linedata} list, then | ||||
| 	these lines represent the next N lines of the buffer. I.e., a second | ||||
|   notification with another list of 100 strings will represent lines 101-200 | ||||
|   of the buffer. If you send the |nvim_buf_live_updates_start| request with | ||||
|   its argument set to `"False"`, this will be empty. | ||||
|   {linedata} is a list of strings containing the buffer's contents. If this | ||||
|   list contains 100 strings, then they represent lines 1-100 of the buffer. | ||||
|   Newline characters are not included in the strings, so empty lines will be | ||||
|   given as empty strings. If you receive another |nvim_buf_updates_start| | ||||
|   notification with another {linedata} list, then these lines represent the | ||||
|   next N lines of the buffer. I.e., a second notification with another list of | ||||
|   100 strings will represent lines 101-200 of the buffer. If you send the | ||||
|   |nvim_buf_updates_start| request with its argument set to `"False"`, this | ||||
|   will be empty. | ||||
|  | ||||
| 	{linedata} will always have at least 1 item, but the maximum length is | ||||
| 	determined by neovim and not guaranteed to be any particular size. | ||||
| 	Also the number of {linedata} items may vary between notifications, so | ||||
| 	your plugin must be prepared to receive the line data in whatever size | ||||
| 	lists neovim decides to split it into. | ||||
|   {linedata} will always have at least 1 item, but the maximum length is | ||||
|   determined by neovim and not guaranteed to be any particular size.  Also the | ||||
|   number of {linedata} items may vary between notifications, so your plugin | ||||
|   must be prepared to receive the line data in whatever size lists neovim | ||||
|   decides to split it into. | ||||
|  | ||||
|   {more} is a boolean which tells you whether or not to expect more | ||||
|   |LiveUpdateStart| notifications. When {more} is false, you can be certain | ||||
|   |nvim_buf_updates_start| notifications. When {more} is false, you can be certain | ||||
|   that you now have the entire buffer's contents. | ||||
|  | ||||
| LiveUpdate[{buf}, {changedtick}, {firstline}, {lastline}, {linedata}] *LiveUpdate* | ||||
| nvim_buf_update[{buf}, {changedtick}, {firstline}, {lastline}, {linedata}] *nvim_buf_update* | ||||
|  | ||||
|   Indicates that the lines between {firstline} and {lastline} (end-exclusive, | ||||
|   zero-indexed) have been replaced with the new line data contained in the | ||||
| @@ -327,24 +327,24 @@ LiveUpdate[{buf}, {changedtick}, {firstline}, {lastline}, {linedata}] *LiveUpdat | ||||
|   be less than or equal to the number of lines that were in the buffer before | ||||
|   the lines were replaced. | ||||
|  | ||||
|   {lastline} is the integer line number of the first line that was not | ||||
|   replaced (i.e. the range {firstline}, {lastline} is end-exclusive). Note | ||||
|   that {lastline} is zero-indexed, so if line numbers 2 to 5 were replaced, | ||||
|   this will be `5` instead of `6`. {lastline} is guaranteed to always be less | ||||
|   than or equal to the number of lines that were in the buffer before the | ||||
|   lines were replaced. | ||||
|   {lastline} is the integer line number of the first line that was not replaced | ||||
|   (i.e. the range {firstline}, {lastline} is end-exclusive). Note that | ||||
|   {lastline} is zero-indexed, so if line numbers 2 to 5 were replaced, this | ||||
|   will be `5` instead of `6`. {lastline} is guaranteed to always be less than | ||||
|   or equal to the number of lines that were in the buffer before the lines were | ||||
|   replaced. | ||||
|  | ||||
|   {linedata} is a list of strings containing the contents of the new buffer | ||||
|   lines. Newline characters are not included in the strings, so empty lines | ||||
|   will be given as empty strings.  | ||||
|  | ||||
|   Note: sometimes {changedtick} will be |v:null|, which means that the buffer | ||||
|   text *looks* like it has changed, but actually hasn't. In this case the | ||||
|   lines in {linedata} contain the modified text that is shown to the user, but | ||||
|   doesn't reflect the actual buffer contents. Currently this behaviour is only | ||||
|   used for the 'inccommand' option. | ||||
|   text *looks* like it has changed, but actually hasn't. In this case the lines | ||||
|   in {linedata} contain the modified text that is shown to the user, but | ||||
|   doesn't reflect the actual buffer contents. Currently this behaviour is | ||||
|   only used for the 'inccommand' option. | ||||
|  | ||||
| LiveUpdateTick[{buf}, {changedtick}]		                   *LiveUpdateTick* | ||||
| nvim_buf_update_tick[{buf}, {changedtick}]		                   *nvim_buf_update_tick* | ||||
|  | ||||
|   Indicates that |b:changedtick| was incremented for the buffer {buf}, but no | ||||
|   text was changed. This is currently only used by undo/redo. | ||||
| @@ -353,60 +353,60 @@ LiveUpdateTick[{buf}, {changedtick}]		                   *LiveUpdateTick* | ||||
|  | ||||
|   {changedtick} is the new value of |b:changedtick| for that buffer. | ||||
|  | ||||
| LiveUpdateEnd[{buf}]                                    		*LiveUpdateEnd* | ||||
| nvim_buf_updates_end[{buf}]                                    		*nvim_buf_updates_end* | ||||
|  | ||||
|   {buf} is an API handle for the buffer. | ||||
|  | ||||
|   Indicates that live updates for the nominated buffer have been disabled, | ||||
|   either by calling |nvim_buf_live_updates_stop| or because the buffer was | ||||
|   unloaded (see |live-updates-limitations| for more information). | ||||
|   Indicates that buffer updates for the nominated buffer have been disabled, | ||||
|   either by calling |nvim_buf_detach| or because the buffer was unloaded | ||||
|   (see |buffer-updates-limitations| for more information). | ||||
|  | ||||
|                                                       *live-updates-limitations* | ||||
|                                                       *buffer-updates-limitations* | ||||
| Limitations~ | ||||
|  | ||||
| Note that any of the following actions will also turn off live updates because | ||||
| Note that any of the following actions will also turn off buffer updates because | ||||
| the buffer contents are unloaded from memory: | ||||
|  | ||||
|   - Closing all a buffer's windows (unless 'hidden' is enabled). | ||||
|   - Using |:edit| to reload the buffer | ||||
|   - reloading the buffer after it is changed from outside neovim. | ||||
|  | ||||
|                                                        *live-updates-examples* | ||||
|                                                        *buffer-updates-examples* | ||||
| Example Events~ | ||||
|  | ||||
| If live updates are activated a new empty buffer, the following | ||||
| |LiveUpdateStart| event will be sent: > | ||||
| If buffer updates are activated a new empty buffer, the following | ||||
| |nvim_buf_updates_start| event will be sent: > | ||||
|  | ||||
|   rpcnotify({channel}, "LiveUpdateStart", [{buf}, [""], v:false]) | ||||
|   rpcnotify({channel}, "nvim_buf_updates_start", [{buf}, [""], v:false]) | ||||
|  | ||||
| If the user adds 2 new lines to the start of a buffer, the following event | ||||
| would be generated: > | ||||
|  | ||||
|   rpcnotify({channel}, "LiveUpdate", [{buf}, 0, 0, ["line1", "line2"]]) | ||||
|   rpcnotify({channel}, "nvim_buf_update", [{buf}, 0, 0, ["line1", "line2"]]) | ||||
|  | ||||
| If the puts the cursor on a line containing the text `"Hello world"` and adds | ||||
| a `!` character to the end using insert mode, the following event would be | ||||
| generated: > | ||||
|  | ||||
|   rpcnotify({channel}, "LiveUpdate", [{buf}, {linenr}, {linenr} + 1, ["Hello | ||||
|   rpcnotify({channel}, "nvim_buf_update", [{buf}, {linenr}, {linenr} + 1, ["Hello | ||||
|   world!"]]) | ||||
|  | ||||
| If the user moves their cursor to line 3 of a buffer and deletes 20 lines | ||||
| using `20dd`, the following event will be generated: > | ||||
|  | ||||
|   rpcnotify({channel}, "LiveUpdate", [{buf}, 2, 20, []]) | ||||
|   rpcnotify({channel}, "nvim_buf_update", [{buf}, 2, 20, []]) | ||||
|  | ||||
| If the user selects lines 3-5 of a buffer using |linewise-visual| mode and | ||||
| then presses `p` to paste in a new block of 6 lines, then the following event | ||||
| would be sent to the co-process: > | ||||
|  | ||||
|   rpcnotify({channel}, "LiveUpdate", [{buf}, 2, 5, ['pasted line 1', 'pasted | ||||
|   rpcnotify({channel}, "nvim_buf_update", [{buf}, 2, 5, ['pasted line 1', 'pasted | ||||
|   line 2', 'pasted line 3', 'pasted line 4', 'pasted line 5', 'pasted line | ||||
|   6']]) | ||||
|  | ||||
| If the user uses :edit to reload a buffer then the following event would be | ||||
| generated: > | ||||
|  | ||||
|   rpcnotify({channel}, "LiveUpdateEnd", [{buf}]) | ||||
|   rpcnotify({channel}, "nvim_buf_updates_end", [{buf}]) | ||||
|  | ||||
|  vim:tw=78:ts=8:ft=help:norl: | ||||
|   | ||||
| @@ -142,7 +142,7 @@ set(CONV_SOURCES | ||||
|   message.c | ||||
|   regexp.c | ||||
|   screen.c | ||||
|   liveupdate.c | ||||
|   buffer_updates.c | ||||
|   search.c | ||||
|   spell.c | ||||
|   spellfile.c | ||||
|   | ||||
| @@ -25,7 +25,7 @@ | ||||
| #include "nvim/window.h" | ||||
| #include "nvim/undo.h" | ||||
| #include "nvim/ex_docmd.h" | ||||
| #include "nvim/liveupdate.h" | ||||
| #include "nvim/buffer_updates.h" | ||||
|  | ||||
| #ifdef INCLUDE_GENERATED_DECLARATIONS | ||||
| # include "api/buffer.c.generated.h" | ||||
| @@ -76,18 +76,18 @@ String buffer_get_line(Buffer buffer, Integer index, Error *err) | ||||
|   return rv; | ||||
| } | ||||
|  | ||||
| /// Activate live updates from this buffer to the current channel. | ||||
| /// Activate updates from this buffer to the current channel. | ||||
| /// | ||||
| /// @param buffer The buffer handle | ||||
| /// @param send_buffer Set to true if the initial notification should contain | ||||
| ///        the whole buffer | ||||
| /// @param[out] err Details of an error that may have occurred | ||||
| /// @return False when live updates couldn't be enabled because the buffer isn't | ||||
| /// @return False when updates couldn't be enabled because the buffer isn't | ||||
| ///         loaded; otherwise True. | ||||
| Boolean nvim_buf_live_updates_start(uint64_t channel_id, | ||||
|                                     Buffer buffer, | ||||
|                                     Boolean send_buffer, | ||||
|                                     Error *err) | ||||
| Boolean nvim_buf_attach(uint64_t channel_id, | ||||
|                                  Buffer buffer, | ||||
|                                  Boolean send_buffer, | ||||
|                                  Error *err) | ||||
|   FUNC_API_SINCE(4) FUNC_API_REMOTE_ONLY | ||||
| { | ||||
|   buf_T *buf = find_buffer_by_handle(buffer, err); | ||||
| @@ -96,18 +96,18 @@ Boolean nvim_buf_live_updates_start(uint64_t channel_id, | ||||
|     return false; | ||||
|   } | ||||
|  | ||||
|   return liveupdate_register(buf, channel_id, send_buffer); | ||||
|   return buffer_updates_register(buf, channel_id, send_buffer); | ||||
| } | ||||
| // | ||||
| /// Deactivate live updates from this buffer to the current channel. | ||||
| /// Deactivate updates from this buffer to the current channel. | ||||
| /// | ||||
| /// @param buffer The buffer handle | ||||
| /// @param[out] err Details of an error that may have occurred | ||||
| /// @return False when live updates couldn't be disabled because the buffer | ||||
| /// @return False when updates couldn't be disabled because the buffer | ||||
| ///         isn't loaded; otherwise True. | ||||
| Boolean nvim_buf_live_updates_stop(uint64_t channel_id, | ||||
|                                    Buffer buffer, | ||||
|                                    Error *err) | ||||
| Boolean nvim_buf_detach(uint64_t channel_id, | ||||
|                                  Buffer buffer, | ||||
|                                  Error *err) | ||||
|   FUNC_API_SINCE(4) FUNC_API_REMOTE_ONLY | ||||
| { | ||||
|   buf_T *buf = find_buffer_by_handle(buffer, err); | ||||
| @@ -116,7 +116,7 @@ Boolean nvim_buf_live_updates_stop(uint64_t channel_id, | ||||
|     return false; | ||||
|   } | ||||
|  | ||||
|   liveupdate_unregister(buf, channel_id); | ||||
|   buffer_updates_unregister(buf, channel_id); | ||||
|   return true; | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -73,7 +73,7 @@ | ||||
| #include "nvim/os/os.h" | ||||
| #include "nvim/os/time.h" | ||||
| #include "nvim/os/input.h" | ||||
| #include "nvim/liveupdate.h" | ||||
| #include "nvim/buffer_updates.h" | ||||
|  | ||||
| typedef enum { | ||||
|   kBLSUnchanged = 0, | ||||
| @@ -576,7 +576,7 @@ void close_buffer(win_T *win, buf_T *buf, int action, int abort_if_last) | ||||
|   do_autochdir(); | ||||
|  | ||||
|   // disable live updates for the current buffer | ||||
|   liveupdate_unregister_all(buf); | ||||
|   buffer_updates_unregister_all(buf); | ||||
|  | ||||
|   /* | ||||
|    * Remove the buffer from the list. | ||||
| @@ -789,7 +789,7 @@ free_buffer_stuff ( | ||||
|   xfree(buf->b_start_fenc); | ||||
|   buf->b_start_fenc = NULL; | ||||
|  | ||||
|   liveupdate_unregister_all(buf); | ||||
|   buffer_updates_unregister_all(buf); | ||||
| } | ||||
|  | ||||
| /* | ||||
| @@ -1741,8 +1741,8 @@ buf_T * buflist_new(char_u *ffname, char_u *sfname, linenr_T lnum, int flags) | ||||
|   clrallmarks(buf);                     // clear marks | ||||
|   fmarks_check_names(buf);              // check file marks for this file | ||||
|   buf->b_p_bl = (flags & BLN_LISTED) ? true : false;    // init 'buflisted' | ||||
|   kv_destroy(buf->liveupdate_channels); | ||||
|   kv_init(buf->liveupdate_channels); | ||||
|   kv_destroy(buf->update_channels); | ||||
|   kv_init(buf->update_channels); | ||||
|   if (!(flags & BLN_DUMMY)) { | ||||
|     // Tricky: these autocommands may change the buffer list.  They could also | ||||
|     // split the window with re-using the one empty buffer. This may result in | ||||
|   | ||||
| @@ -774,9 +774,9 @@ struct file_buffer { | ||||
|  | ||||
|   kvec_t(BufhlLine *) b_bufhl_move_space;  // temporary space for highlights | ||||
|  | ||||
|   // array of channelids which have asked to receive live updates for this | ||||
|   // array of channelids which have asked to receive updates for this | ||||
|   // buffer. | ||||
|   kvec_t(uint64_t) liveupdate_channels; | ||||
|   kvec_t(uint64_t) update_channels; | ||||
| }; | ||||
|  | ||||
| /* | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| #include "nvim/liveupdate.h" | ||||
| #include "nvim/buffer_updates.h" | ||||
| #include "nvim/memline.h" | ||||
| #include "nvim/api/private/helpers.h" | ||||
| #include "nvim/msgpack_rpc/channel.h" | ||||
| @@ -6,7 +6,7 @@ | ||||
| // Register a channel. Return True if the channel was added, or already added.
 | ||||
| // Return False if the channel couldn't be added because the buffer is
 | ||||
| // unloaded.
 | ||||
| bool liveupdate_register(buf_T *buf, uint64_t channel_id, bool send_buffer) | ||||
| bool buffer_updates_register(buf_T *buf, uint64_t channel_id, bool send_buffer) | ||||
| { | ||||
|   // must fail if the buffer isn't loaded
 | ||||
|   if (buf->b_ml.ml_mfp == NULL) { | ||||
| @@ -14,10 +14,10 @@ bool liveupdate_register(buf_T *buf, uint64_t channel_id, bool send_buffer) | ||||
|   } | ||||
| 
 | ||||
|   // count how many channels are currently watching the buffer
 | ||||
|   size_t size = kv_size(buf->liveupdate_channels); | ||||
|   size_t size = kv_size(buf->update_channels); | ||||
|   if (size) { | ||||
|     for (size_t i = 0; i < size; i++) { | ||||
|       if (kv_A(buf->liveupdate_channels, i) == channel_id) { | ||||
|       if (kv_A(buf->update_channels, i) == channel_id) { | ||||
|         // buffer is already registered ... nothing to do
 | ||||
|         return true; | ||||
|       } | ||||
| @@ -25,7 +25,7 @@ bool liveupdate_register(buf_T *buf, uint64_t channel_id, bool send_buffer) | ||||
|   } | ||||
| 
 | ||||
|   // append the channelid to the list
 | ||||
|   kv_push(buf->liveupdate_channels, channel_id); | ||||
|   kv_push(buf->update_channels, channel_id); | ||||
| 
 | ||||
|   Array linedata = ARRAY_DICT_INIT; | ||||
|   if (send_buffer) { | ||||
| @@ -56,22 +56,22 @@ bool liveupdate_register(buf_T *buf, uint64_t channel_id, bool send_buffer) | ||||
|   args.items[2] = ARRAY_OBJ(linedata); | ||||
|   args.items[3] = BOOLEAN_OBJ(false); | ||||
| 
 | ||||
|   rpc_send_event(channel_id, "LiveUpdateStart", args); | ||||
|   rpc_send_event(channel_id, "nvim_buf_updates_start", args); | ||||
|   return true; | ||||
| } | ||||
| 
 | ||||
| void liveupdate_send_end(buf_T *buf, uint64_t channelid) | ||||
| void buffer_updates_send_end(buf_T *buf, uint64_t channelid) | ||||
| { | ||||
|     Array args = ARRAY_DICT_INIT; | ||||
|     args.size = 1; | ||||
|     args.items = xcalloc(sizeof(Object), args.size); | ||||
|     args.items[0] = BUFFER_OBJ(buf->handle); | ||||
|     rpc_send_event(channelid, "LiveUpdateEnd", args); | ||||
|     rpc_send_event(channelid, "nvim_buf_updates_end", args); | ||||
| } | ||||
| 
 | ||||
| void liveupdate_unregister(buf_T *buf, uint64_t channelid) | ||||
| void buffer_updates_unregister(buf_T *buf, uint64_t channelid) | ||||
| { | ||||
|   size_t size = kv_size(buf->liveupdate_channels); | ||||
|   size_t size = kv_size(buf->update_channels); | ||||
|   if (!size) { | ||||
|     return; | ||||
|   } | ||||
| @@ -81,12 +81,12 @@ void liveupdate_unregister(buf_T *buf, uint64_t channelid) | ||||
|   size_t j = 0; | ||||
|   size_t found = 0; | ||||
|   for (size_t i = 0; i < size; i++) { | ||||
|     if (kv_A(buf->liveupdate_channels, i) == channelid) { | ||||
|     if (kv_A(buf->update_channels, i) == channelid) { | ||||
|       found++; | ||||
|     } else { | ||||
|       // copy item backwards into prior slot if needed
 | ||||
|       if (i != j) { | ||||
|         kv_A(buf->liveupdate_channels, j) = kv_A(buf->liveupdate_channels, i); | ||||
|         kv_A(buf->update_channels, j) = kv_A(buf->update_channels, i); | ||||
|       } | ||||
|       j++; | ||||
|     } | ||||
| @@ -94,39 +94,39 @@ void liveupdate_unregister(buf_T *buf, uint64_t channelid) | ||||
| 
 | ||||
|   if (found) { | ||||
|     // remove X items from the end of the array
 | ||||
|     buf->liveupdate_channels.size -= found; | ||||
|     buf->update_channels.size -= found; | ||||
| 
 | ||||
|     // make a new copy of the active array without the channelid in it
 | ||||
|     liveupdate_send_end(buf, channelid); | ||||
|     buffer_updates_send_end(buf, channelid); | ||||
| 
 | ||||
|     if (found == size) { | ||||
|       kv_destroy(buf->liveupdate_channels); | ||||
|       kv_init(buf->liveupdate_channels); | ||||
|       kv_destroy(buf->update_channels); | ||||
|       kv_init(buf->update_channels); | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| void liveupdate_unregister_all(buf_T *buf) | ||||
| void buffer_updates_unregister_all(buf_T *buf) | ||||
| { | ||||
|   size_t size = kv_size(buf->liveupdate_channels); | ||||
|   size_t size = kv_size(buf->update_channels); | ||||
|   if (size) { | ||||
|     for (size_t i = 0; i < size; i++) { | ||||
|       liveupdate_send_end(buf, kv_A(buf->liveupdate_channels, i)); | ||||
|       buffer_updates_send_end(buf, kv_A(buf->update_channels, i)); | ||||
|     } | ||||
|     kv_destroy(buf->liveupdate_channels); | ||||
|     kv_init(buf->liveupdate_channels); | ||||
|     kv_destroy(buf->update_channels); | ||||
|     kv_init(buf->update_channels); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| void liveupdate_send_changes(buf_T *buf, linenr_T firstline, int64_t num_added, | ||||
| void buffer_updates_send_changes(buf_T *buf, linenr_T firstline, int64_t num_added, | ||||
|                              int64_t num_removed, bool send_tick) | ||||
| { | ||||
|   // if one the channels doesn't work, put its ID here so we can remove it later
 | ||||
|   uint64_t badchannelid = 0; | ||||
| 
 | ||||
|   // notify each of the active channels
 | ||||
|   for (size_t i = 0; i < kv_size(buf->liveupdate_channels); i++) { | ||||
|     uint64_t channelid = kv_A(buf->liveupdate_channels, i); | ||||
|   for (size_t i = 0; i < kv_size(buf->update_channels); i++) { | ||||
|     uint64_t channelid = kv_A(buf->update_channels, i); | ||||
| 
 | ||||
|     // send through the changes now channel contents now
 | ||||
|     Array args = ARRAY_DICT_INIT; | ||||
| @@ -162,9 +162,9 @@ void liveupdate_send_changes(buf_T *buf, linenr_T firstline, int64_t num_added, | ||||
|         } | ||||
|     } | ||||
|     args.items[4] = ARRAY_OBJ(linedata); | ||||
|     if (!rpc_send_event(channelid, "LiveUpdate", args)) { | ||||
|     if (!rpc_send_event(channelid, "nvim_buf_update", args)) { | ||||
|       // We can't unregister the channel while we're iterating over the
 | ||||
|       // liveupdate_channels array, so we remember its ID to unregister it at
 | ||||
|       // update_channels array, so we remember its ID to unregister it at
 | ||||
|       // the end.
 | ||||
|       badchannelid = channelid; | ||||
|     } | ||||
| @@ -175,15 +175,15 @@ void liveupdate_send_changes(buf_T *buf, linenr_T firstline, int64_t num_added, | ||||
|   // cleared up quickly.
 | ||||
|   if (badchannelid != 0) { | ||||
|     ELOG("Disabling live updates for dead channel %llu", badchannelid); | ||||
|     liveupdate_unregister(buf, badchannelid); | ||||
|     buffer_updates_unregister(buf, badchannelid); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| void liveupdate_send_tick(buf_T *buf) | ||||
| void buffer_updates_send_tick(buf_T *buf) | ||||
| { | ||||
|   // notify each of the active channels
 | ||||
|   for (size_t i = 0; i < kv_size(buf->liveupdate_channels); i++) { | ||||
|     uint64_t channelid = kv_A(buf->liveupdate_channels, i); | ||||
|   for (size_t i = 0; i < kv_size(buf->update_channels); i++) { | ||||
|     uint64_t channelid = kv_A(buf->update_channels, i); | ||||
| 
 | ||||
|     // send through the changes now channel contents now
 | ||||
|     Array args = ARRAY_DICT_INIT; | ||||
| @@ -197,6 +197,6 @@ void liveupdate_send_tick(buf_T *buf) | ||||
|     args.items[1] = INTEGER_OBJ(buf->b_changedtick); | ||||
| 
 | ||||
|     // don't try and clean up dead channels here
 | ||||
|     rpc_send_event(channelid, "LiveUpdateTick", args); | ||||
|     rpc_send_event(channelid, "nvim_buf_update_tick", args); | ||||
|   } | ||||
| } | ||||
							
								
								
									
										13
									
								
								src/nvim/buffer_updates.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								src/nvim/buffer_updates.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | ||||
| #ifndef BUFFER_UPDATES_H | ||||
| #define BUFFER_UPDATES_H | ||||
|  | ||||
| #include "nvim/buffer_defs.h" | ||||
|  | ||||
| bool buffer_updates_register(buf_T *buf, uint64_t channel_id, bool send_buffer); | ||||
| void buffer_updates_unregister(buf_T *buf, uint64_t channel_id); | ||||
| void buffer_updates_unregister_all(buf_T *buf); | ||||
| void buffer_updates_send_changes(buf_T *buf, linenr_T firstline, int64_t num_added, | ||||
|                              int64_t num_removed, bool send_tick); | ||||
| void buffer_updates_send_tick(buf_T *buf); | ||||
|  | ||||
| #endif  // NVIM_BUFFER_UPDATES_H | ||||
| @@ -35,7 +35,7 @@ | ||||
| #include "nvim/fold.h" | ||||
| #include "nvim/getchar.h" | ||||
| #include "nvim/indent.h" | ||||
| #include "nvim/liveupdate.h" | ||||
| #include "nvim/buffer_updates.h" | ||||
| #include "nvim/main.h" | ||||
| #include "nvim/mark.h" | ||||
| #include "nvim/mbyte.h" | ||||
| @@ -833,9 +833,9 @@ int do_move(linenr_T line1, linenr_T line2, linenr_T dest) | ||||
|                      -(last_line - dest - extra), 0L, true); | ||||
|   changed_lines(last_line - num_lines + 1, 0, last_line + 1, -extra, false); | ||||
|  | ||||
|   // send live update regarding the new lines that were added | ||||
|   if (kv_size(curbuf->liveupdate_channels)) { | ||||
|     liveupdate_send_changes(curbuf, dest + 1, num_lines, 0, true); | ||||
|   // send update regarding the new lines that were added | ||||
|   if (kv_size(curbuf->update_channels)) { | ||||
|     buffer_updates_send_changes(curbuf, dest + 1, num_lines, 0, true); | ||||
|   } | ||||
|  | ||||
|   /* | ||||
| @@ -872,9 +872,9 @@ int do_move(linenr_T line1, linenr_T line2, linenr_T dest) | ||||
|     changed_lines(dest + 1, 0, line1 + num_lines, 0L, false); | ||||
|   } | ||||
|  | ||||
|   // send LiveUpdate regarding lines that were deleted | ||||
|   if (kv_size(curbuf->liveupdate_channels)) { | ||||
|     liveupdate_send_changes(curbuf, line1 + extra, 0, num_lines, true); | ||||
|   // send nvim_buf_update regarding lines that were deleted | ||||
|   if (kv_size(curbuf->update_channels)) { | ||||
|     buffer_updates_send_changes(curbuf, line1 + extra, 0, num_lines, true); | ||||
|   } | ||||
|  | ||||
|   return OK; | ||||
| @@ -2442,7 +2442,7 @@ int do_ecmd( | ||||
|         goto theend; | ||||
|       } | ||||
|       u_unchanged(curbuf); | ||||
|       liveupdate_unregister_all(curbuf); | ||||
|       buffer_updates_unregister_all(curbuf); | ||||
|       buf_freeall(curbuf, BFA_KEEP_UNDO); | ||||
|  | ||||
|       // Tell readfile() not to clear or reload undo info. | ||||
| @@ -3170,7 +3170,7 @@ static char_u *sub_parse_flags(char_u *cmd, subflags_T *subflags, | ||||
| /// | ||||
| /// @return buffer used for 'inccommand' preview | ||||
| static buf_T *do_sub(exarg_T *eap, proftime_T timeout, | ||||
|                      bool send_liveupdate_changedtick) | ||||
|                      bool send_buffer_update_changedtick) | ||||
| { | ||||
|   long i = 0; | ||||
|   regmmatch_T regmatch; | ||||
| @@ -4018,11 +4018,11 @@ skip: | ||||
|     i = curbuf->b_ml.ml_line_count - old_line_count; | ||||
|     changed_lines(first_line, 0, last_line - i, i, false); | ||||
|  | ||||
|     if (kv_size(curbuf->liveupdate_channels)) { | ||||
|     if (kv_size(curbuf->update_channels)) { | ||||
|       int64_t num_added = last_line - first_line; | ||||
|       int64_t num_removed = num_added - i; | ||||
|       liveupdate_send_changes(curbuf, first_line, num_added, num_removed, | ||||
|                               send_liveupdate_changedtick); | ||||
|       buffer_updates_send_changes(curbuf, first_line, num_added, num_removed, | ||||
|                               send_buffer_update_changedtick); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   | ||||
| @@ -20,7 +20,7 @@ | ||||
| #include "nvim/ex_docmd.h" | ||||
| #include "nvim/func_attr.h" | ||||
| #include "nvim/indent.h" | ||||
| #include "nvim/liveupdate.h" | ||||
| #include "nvim/buffer_updates.h" | ||||
| #include "nvim/mark.h" | ||||
| #include "nvim/memline.h" | ||||
| #include "nvim/memory.h" | ||||
| @@ -746,14 +746,14 @@ deleteFold ( | ||||
|   if (last_lnum > 0) { | ||||
|     changed_lines(first_lnum, (colnr_T)0, last_lnum, 0L, false); | ||||
|  | ||||
|     // send one LiveUpdate at the end | ||||
|     if (kv_size(curbuf->liveupdate_channels)) { | ||||
|     // send one nvim_buf_update at the end | ||||
|     if (kv_size(curbuf->update_channels)) { | ||||
|       // last_lnum is the line *after* the last line of the outermost fold | ||||
|       // that was modified. Note also that deleting a fold might only require | ||||
|       // the modification of the *first* line of the fold, but we send through a | ||||
|       // notification that includes every line that was part of the fold | ||||
|       int64_t num_changed = last_lnum - first_lnum; | ||||
|       liveupdate_send_changes(curbuf, first_lnum, num_changed, | ||||
|       buffer_updates_send_changes(curbuf, first_lnum, num_changed, | ||||
|                               num_changed, true); | ||||
|     } | ||||
|   } | ||||
| @@ -1605,12 +1605,12 @@ static void foldCreateMarkers(linenr_T start, linenr_T end) | ||||
|    * changed when the start marker is inserted and the end isn't. */ | ||||
|   changed_lines(start, (colnr_T)0, end, 0L, false); | ||||
|  | ||||
|   if (kv_size(curbuf->liveupdate_channels)) { | ||||
|   if (kv_size(curbuf->update_channels)) { | ||||
|     // Note: foldAddMarker() may not actually change start and/or end if | ||||
|     // u_save() is unable to save the buffer line, but we send the LiveUpdate | ||||
|     // u_save() is unable to save the buffer line, but we send the nvim_buf_update | ||||
|     // anyway since it won't do any harm. | ||||
|     int64_t num_changed = 1 + end - start; | ||||
|     liveupdate_send_changes(curbuf, start, num_changed, num_changed, true); | ||||
|     buffer_updates_send_changes(curbuf, start, num_changed, num_changed, true); | ||||
|   } | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,13 +0,0 @@ | ||||
| #ifndef NVIM_LIVEUPDATE_H | ||||
| #define NVIM_LIVEUPDATE_H | ||||
|  | ||||
| #include "nvim/buffer_defs.h" | ||||
|  | ||||
| bool liveupdate_register(buf_T *buf, uint64_t channel_id, bool send_buffer); | ||||
| void liveupdate_unregister(buf_T *buf, uint64_t channel_id); | ||||
| void liveupdate_unregister_all(buf_T *buf); | ||||
| void liveupdate_send_changes(buf_T *buf, linenr_T firstline, int64_t num_added, | ||||
|                              int64_t num_removed, bool send_tick); | ||||
| void liveupdate_send_tick(buf_T *buf); | ||||
|  | ||||
| #endif  // NVIM_LIVEUPDATE_H | ||||
| @@ -28,7 +28,7 @@ | ||||
| #include "nvim/getchar.h" | ||||
| #include "nvim/indent.h" | ||||
| #include "nvim/indent_c.h" | ||||
| #include "nvim/liveupdate.h" | ||||
| #include "nvim/buffer_updates.h" | ||||
| #include "nvim/main.h" | ||||
| #include "nvim/mark.h" | ||||
| #include "nvim/mbyte.h" | ||||
| @@ -1822,8 +1822,8 @@ void changed_bytes(linenr_T lnum, colnr_T col) | ||||
|   changedOneline(curbuf, lnum); | ||||
|   changed_common(lnum, col, lnum + 1, 0L); | ||||
|   // notify any channels that are watching | ||||
|   if (kv_size(curbuf->liveupdate_channels)) { | ||||
|     liveupdate_send_changes(curbuf, lnum, 1, 1, true); | ||||
|   if (kv_size(curbuf->update_channels)) { | ||||
|     buffer_updates_send_changes(curbuf, lnum, 1, 1, true); | ||||
|   } | ||||
|  | ||||
|   /* Diff highlighting in other diff windows may need to be updated too. */ | ||||
| @@ -1920,9 +1920,9 @@ changed_lines( | ||||
|     colnr_T col,          // column in first line with change | ||||
|     linenr_T lnume,       // line below last changed line | ||||
|     long xtra,            // number of extra lines (negative when deleting) | ||||
|     bool send_liveupdate  // some callers like undo/redo call changed_lines() | ||||
|     bool send_update  // some callers like undo/redo call changed_lines() | ||||
|                           // and then increment b_changedtick *again*. This flag | ||||
|                           // allows these callers to send the LiveUpdate events | ||||
|                           // allows these callers to send the nvim_buf_update events | ||||
|                           // after they're done modifying b_changedtick. | ||||
| ) | ||||
| { | ||||
| @@ -1948,10 +1948,10 @@ changed_lines( | ||||
|  | ||||
|   changed_common(lnum, col, lnume, xtra); | ||||
|  | ||||
|   if (send_liveupdate && kv_size(curbuf->liveupdate_channels)) { | ||||
|   if (send_update && kv_size(curbuf->update_channels)) { | ||||
|     int64_t num_added = (int64_t)(lnume + xtra - lnum); | ||||
|     int64_t num_removed = lnume - lnum; | ||||
|     liveupdate_send_changes(curbuf, lnum, num_added, num_removed, true); | ||||
|     buffer_updates_send_changes(curbuf, lnum, num_added, num_removed, true); | ||||
|   } | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1234,7 +1234,7 @@ static void refresh_screen(Terminal *term, buf_T *buf) | ||||
|  | ||||
|   int change_start = row_to_linenr(term, term->invalid_start); | ||||
|   int change_end = change_start + changed; | ||||
|   // Note: don't send LiveUpdate event for a :terminal buffer | ||||
|   // Note: don't send nvim_buf_update event for a :terminal buffer | ||||
|   changed_lines(change_start, 0, change_end, added, false); | ||||
|   term->invalid_start = INT_MAX; | ||||
|   term->invalid_end = -1; | ||||
|   | ||||
| @@ -92,7 +92,7 @@ | ||||
| #include "nvim/eval.h" | ||||
| #include "nvim/fileio.h" | ||||
| #include "nvim/fold.h" | ||||
| #include "nvim/liveupdate.h" | ||||
| #include "nvim/buffer_updates.h" | ||||
| #include "nvim/mark.h" | ||||
| #include "nvim/memline.h" | ||||
| #include "nvim/message.h" | ||||
| @@ -1698,7 +1698,7 @@ bool u_undo_and_forget(int count) | ||||
|     count = 1; | ||||
|   } | ||||
|   undo_undoes = true; | ||||
|   // don't send a LiveUpdate for this undo is part of 'inccommand' playing with | ||||
|   // don't send a nvim_buf_update for this undo is part of 'inccommand' playing with | ||||
|   // buffer contents | ||||
|   u_doit(count, true, false); | ||||
|  | ||||
| @@ -1735,7 +1735,7 @@ bool u_undo_and_forget(int count) | ||||
| } | ||||
|  | ||||
| /// Undo or redo, depending on `undo_undoes`, `count` times. | ||||
| static void u_doit(int startcount, bool quiet, bool send_liveupdate) | ||||
| static void u_doit(int startcount, bool quiet, bool send_update) | ||||
| { | ||||
|   int count = startcount; | ||||
|  | ||||
| @@ -1771,7 +1771,7 @@ static void u_doit(int startcount, bool quiet, bool send_liveupdate) | ||||
|         break; | ||||
|       } | ||||
|  | ||||
|       u_undoredo(true, send_liveupdate); | ||||
|       u_undoredo(true, send_update); | ||||
|     } else { | ||||
|       if (curbuf->b_u_curhead == NULL || get_undolevel() <= 0) { | ||||
|         beep_flush();           /* nothing to redo */ | ||||
| @@ -1782,7 +1782,7 @@ static void u_doit(int startcount, bool quiet, bool send_liveupdate) | ||||
|         break; | ||||
|       } | ||||
|  | ||||
|       u_undoredo(false, send_liveupdate); | ||||
|       u_undoredo(false, send_update); | ||||
|  | ||||
|       /* Advance for next redo.  Set "newhead" when at the end of the | ||||
|        * redoable changes. */ | ||||
| @@ -2117,7 +2117,7 @@ void undo_time(long step, int sec, int file, int absolute) | ||||
|  * | ||||
|  * When "undo" is TRUE we go up in the tree, when FALSE we go down. | ||||
|  */ | ||||
| static void u_undoredo(int undo, bool send_liveupdate) | ||||
| static void u_undoredo(int undo, bool send_update) | ||||
| { | ||||
|   char_u      **newarray = NULL; | ||||
|   linenr_T oldsize; | ||||
| @@ -2245,7 +2245,7 @@ static void u_undoredo(int undo, bool send_liveupdate) | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     changed_lines(top + 1, 0, bot, newsize - oldsize, send_liveupdate); | ||||
|     changed_lines(top + 1, 0, bot, newsize - oldsize, send_update); | ||||
|  | ||||
|     /* set '[ and '] mark */ | ||||
|     if (top + 1 < curbuf->b_op_start.lnum) | ||||
| @@ -2281,10 +2281,10 @@ static void u_undoredo(int undo, bool send_liveupdate) | ||||
|   } | ||||
|  | ||||
|   // because the calls to changed()/unchanged() above will bump b_changedtick | ||||
|   // again, we need to send a LiveUpdate with just the new value of | ||||
|   // again, we need to send a nvim_buf_update with just the new value of | ||||
|   // b:changedtick | ||||
|   if (send_liveupdate && kv_size(curbuf->liveupdate_channels)) { | ||||
|     liveupdate_send_tick(curbuf); | ||||
|   if (send_update && kv_size(curbuf->update_channels)) { | ||||
|     buffer_updates_send_tick(curbuf); | ||||
|   } | ||||
|  | ||||
|   /* | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| local helpers = require('test.functional.helpers')(after_each) | ||||
| local eq, ok = helpers.eq, helpers.ok | ||||
| local buffer, command, eval, nvim, next_message = helpers.buffer, | ||||
|   helpers.command, helpers.eval, helpers.nvim, helpers.next_message | ||||
|   helpers.command, helpers.eval, helpers.nvim, helpers.next_msg | ||||
| 
 | ||||
| local origlines = {"original line 1", | ||||
|                    "original line 2", | ||||
| @@ -32,11 +32,11 @@ local function open(activate, lines) | ||||
|   -- what is the value of b:changedtick? | ||||
|   local tick = eval('b:changedtick') | ||||
| 
 | ||||
|   -- turn on live updates, ensure that the LiveUpdateStart messages | ||||
|   -- turn on live updates, ensure that the nvim_buf_updates_start messages | ||||
|   -- arrive as expectected | ||||
|   if activate then | ||||
|     ok(buffer('live_updates_start', b, true)) | ||||
|     expectn('LiveUpdateStart', {b, tick, lines, false}) | ||||
|     ok(buffer('attach', b, true)) | ||||
|     expectn('nvim_buf_updates_start', {b, tick, lines, false}) | ||||
|   end | ||||
| 
 | ||||
|   return b, tick, filename | ||||
| @@ -52,13 +52,13 @@ local function editoriginal(activate, lines) | ||||
| end | ||||
| 
 | ||||
| local function reopen(buf, expectedlines) | ||||
|   ok(buffer('live_updates_stop', buf)) | ||||
|   expectn('LiveUpdateEnd', {buf}) | ||||
|   ok(buffer('detach', buf)) | ||||
|   expectn('nvim_buf_updates_end', {buf}) | ||||
|   -- for some reason the :edit! increments tick by 2 | ||||
|   command('edit!') | ||||
|   local tick = eval('b:changedtick') | ||||
|   ok(buffer('live_updates_start', buf, true)) | ||||
|   expectn('LiveUpdateStart', {buf, tick, expectedlines, false}) | ||||
|   ok(buffer('attach', buf, true)) | ||||
|   expectn('nvim_buf_updates_start', {buf, tick, expectedlines, false}) | ||||
|   command('normal! gg') | ||||
|   return tick | ||||
| end | ||||
| @@ -73,13 +73,13 @@ local function reopenwithfolds(b) | ||||
|   -- add a fold | ||||
|   command('2,4fold') | ||||
|   tick = tick + 1 | ||||
|   expectn('LiveUpdate', {b, tick, 1, 4, {'original line 2/*{{{*/', | ||||
|   expectn('nvim_buf_update', {b, tick, 1, 4, {'original line 2/*{{{*/', | ||||
|                                           'original line 3', | ||||
|                                           'original line 4/*}}}*/'}}) | ||||
|   -- make a new fold that wraps lines 1-6 | ||||
|   command('1,6fold') | ||||
|   tick = tick + 1 | ||||
|   expectn('LiveUpdate', {b, tick, 0, 6, {'original line 1/*{{{*/', | ||||
|   expectn('nvim_buf_update', {b, tick, 0, 6, {'original line 1/*{{{*/', | ||||
|                                           'original line 2/*{{{*/', | ||||
|                                           'original line 3', | ||||
|                                           'original line 4/*}}}*/', | ||||
| @@ -95,30 +95,30 @@ describe('liveupdate', function() | ||||
|     -- add a new line at the start of the buffer | ||||
|     command('normal! GyyggP') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 0, 0, {'original line 6'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 0, 0, {'original line 6'}}) | ||||
| 
 | ||||
|     -- add multiple lines at the start of the file | ||||
|     command('normal! GkkyGggP') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 0, 0, {'original line 4', | ||||
|     expectn('nvim_buf_update', {b, tick, 0, 0, {'original line 4', | ||||
|                                            'original line 5', | ||||
|                                            'original line 6'}}) | ||||
| 
 | ||||
|     -- add one line to the middle of the file, several times | ||||
|     command('normal! ggYjjp') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 3, 3, {'original line 4'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 3, 3, {'original line 4'}}) | ||||
|     command('normal! p') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 4, 4, {'original line 4'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 4, 4, {'original line 4'}}) | ||||
|     command('normal! p') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 5, 5, {'original line 4'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 5, 5, {'original line 4'}}) | ||||
| 
 | ||||
|     -- add multiple lines to the middle of the file | ||||
|     command('normal! gg4Yjjp') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 3, 3, {'original line 4', | ||||
|     expectn('nvim_buf_update', {b, tick, 3, 3, {'original line 4', | ||||
|                                            'original line 5', | ||||
|                                            'original line 6', | ||||
|                                            'original line 4'}}) | ||||
| @@ -126,16 +126,16 @@ describe('liveupdate', function() | ||||
|     -- add one line to the end of the file | ||||
|     command('normal! ggYGp') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 17, 17, {'original line 4'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 17, 17, {'original line 4'}}) | ||||
| 
 | ||||
|     -- add one line to the end of the file, several times | ||||
|     command('normal! ggYGppp') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 18, 18, {'original line 4'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 18, 18, {'original line 4'}}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 19, 19, {'original line 4'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 19, 19, {'original line 4'}}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 20, 20, {'original line 4'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 20, 20, {'original line 4'}}) | ||||
| 
 | ||||
|     -- add several lines to the end of the file, several times | ||||
|     command('normal! gg4YGp') | ||||
| @@ -146,47 +146,47 @@ describe('liveupdate', function() | ||||
|                  'original line 6', | ||||
|                  'original line 4'} | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 21, 21, firstfour}) | ||||
|     expectn('nvim_buf_update', {b, tick, 21, 21, firstfour}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 25, 25, firstfour}) | ||||
|     expectn('nvim_buf_update', {b, tick, 25, 25, firstfour}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 29, 29, firstfour}) | ||||
|     expectn('nvim_buf_update', {b, tick, 29, 29, firstfour}) | ||||
| 
 | ||||
|     -- create a new empty buffer and wipe out the old one ... this will | ||||
|     -- turn off live updates | ||||
|     command('enew!') | ||||
|     expectn('LiveUpdateEnd', {b}) | ||||
|     expectn('nvim_buf_updates_end', {b}) | ||||
| 
 | ||||
|     -- add a line at the start of an empty file | ||||
|     command('enew') | ||||
|     tick = eval('b:changedtick') | ||||
|     local b2 = nvim('get_current_buf') | ||||
|     ok(buffer('live_updates_start', b2, true)) | ||||
|     expectn('LiveUpdateStart', {b2, tick, {""}, false}) | ||||
|     ok(buffer('attach', b2, true)) | ||||
|     expectn('nvim_buf_updates_start', {b2, tick, {""}, false}) | ||||
|     eval('append(0, ["new line 1"])') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b2, tick, 0, 0, {'new line 1'}}) | ||||
|     expectn('nvim_buf_update', {b2, tick, 0, 0, {'new line 1'}}) | ||||
| 
 | ||||
|     -- turn off live updates manually | ||||
|     buffer('live_updates_stop', b2) | ||||
|     expectn('LiveUpdateEnd', {b2}) | ||||
|     buffer('detach', b2) | ||||
|     expectn('nvim_buf_updates_end', {b2}) | ||||
| 
 | ||||
|     -- add multiple lines to a blank file | ||||
|     command('enew!') | ||||
|     local b3 = nvim('get_current_buf') | ||||
|     ok(buffer('live_updates_start', b3, true)) | ||||
|     ok(buffer('attach', b3, true)) | ||||
|     tick = eval('b:changedtick') | ||||
|     expectn('LiveUpdateStart', {b3, tick, {""}, false}) | ||||
|     expectn('nvim_buf_updates_start', {b3, tick, {""}, false}) | ||||
|     eval('append(0, ["new line 1", "new line 2", "new line 3"])') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b3, tick, 0, 0, {'new line 1', | ||||
|     expectn('nvim_buf_update', {b3, tick, 0, 0, {'new line 1', | ||||
|                                             'new line 2', | ||||
|                                             'new line 3'}}) | ||||
| 
 | ||||
|     -- use the API itself to add a line to the start of the buffer | ||||
|     buffer('set_lines', b3, 0, 0, true, {'New First Line'}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b3, tick, 0, 0, {"New First Line"}}) | ||||
|     expectn('nvim_buf_update', {b3, tick, 0, 0, {"New First Line"}}) | ||||
|   end) | ||||
| 
 | ||||
|   it('knows when you remove lines from a buffer', function() | ||||
| @@ -195,37 +195,37 @@ describe('liveupdate', function() | ||||
|     -- remove one line from start of file | ||||
|     command('normal! dd') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 0, 1, {}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 0, 1, {}}) | ||||
| 
 | ||||
|     -- remove multiple lines from the start of the file | ||||
|     command('normal! 4dd') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 0, 4, {}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 0, 4, {}}) | ||||
| 
 | ||||
|     -- remove multiple lines from middle of file | ||||
|     tick = reopen(b, origlines) | ||||
|     command('normal! jj3dd') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 2, 5, {}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 2, 5, {}}) | ||||
| 
 | ||||
|     -- remove one line from the end of the file | ||||
|     tick = reopen(b, origlines) | ||||
|     command('normal! Gdd') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 5, 6, {}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 5, 6, {}}) | ||||
| 
 | ||||
|     -- remove multiple lines from the end of the file | ||||
|     tick = reopen(b, origlines) | ||||
|     command('normal! 4G3dd') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 3, 6, {}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 3, 6, {}}) | ||||
| 
 | ||||
|     -- pretend to remove heaps lines from the end of the file but really | ||||
|     -- just remove two | ||||
|     tick = reopen(b, origlines) | ||||
|     command('normal! Gk5dd') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 4, 6, {}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 4, 6, {}}) | ||||
|   end) | ||||
| 
 | ||||
|   it('knows when you modify lines of text', function() | ||||
| @@ -234,53 +234,53 @@ describe('liveupdate', function() | ||||
|     -- some normal text editing | ||||
|     command('normal! A555') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 0, 1, {'original line 1555'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 0, 1, {'original line 1555'}}) | ||||
|     command('normal! jj8X') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 2, 3, {'origin3'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 2, 3, {'origin3'}}) | ||||
| 
 | ||||
|     -- modify multiple lines at once using visual block mode | ||||
|     tick = reopen(b, origlines) | ||||
|     command('normal! jjw') | ||||
|     sendkeys('\x16jjllx') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', | ||||
|     expectn('nvim_buf_update', | ||||
|             {b, tick, 2, 5, {'original e 3', 'original e 4', 'original e 5'}}) | ||||
| 
 | ||||
|     -- replace part of a line line using :s | ||||
|     tick = reopen(b, origlines) | ||||
|     command('3s/line 3/foo/') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 2, 3, {'original foo'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 2, 3, {'original foo'}}) | ||||
| 
 | ||||
|     -- replace parts of several lines line using :s | ||||
|     tick = reopen(b, origlines) | ||||
|     command('%s/line [35]/foo/') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 2, 5, {'original foo', | ||||
|     expectn('nvim_buf_update', {b, tick, 2, 5, {'original foo', | ||||
|                                            'original line 4', | ||||
|                                            'original foo'}}) | ||||
| 
 | ||||
|     -- type text into the first line of a blank file, one character at a time | ||||
|     command('enew!') | ||||
|     tick = 2 | ||||
|     expectn('LiveUpdateEnd', {b}) | ||||
|     expectn('nvim_buf_updates_end', {b}) | ||||
|     local bnew = nvim('get_current_buf') | ||||
|     ok(buffer('live_updates_start', bnew, true)) | ||||
|     expectn('LiveUpdateStart', {bnew, tick, {''}, false}) | ||||
|     ok(buffer('attach', bnew, true)) | ||||
|     expectn('nvim_buf_updates_start', {bnew, tick, {''}, false}) | ||||
|     sendkeys('i') | ||||
|     sendkeys('h') | ||||
|     sendkeys('e') | ||||
|     sendkeys('l') | ||||
|     sendkeys('l') | ||||
|     sendkeys('o\nworld') | ||||
|     expectn('LiveUpdate', {bnew, tick + 1, 0, 1, {'h'}}) | ||||
|     expectn('LiveUpdate', {bnew, tick + 2, 0, 1, {'he'}}) | ||||
|     expectn('LiveUpdate', {bnew, tick + 3, 0, 1, {'hel'}}) | ||||
|     expectn('LiveUpdate', {bnew, tick + 4, 0, 1, {'hell'}}) | ||||
|     expectn('LiveUpdate', {bnew, tick + 5, 0, 1, {'hello'}}) | ||||
|     expectn('LiveUpdate', {bnew, tick + 6, 0, 1, {'hello', ''}}) | ||||
|     expectn('LiveUpdate', {bnew, tick + 7, 1, 2, {'world'}}) | ||||
|     expectn('nvim_buf_update', {bnew, tick + 1, 0, 1, {'h'}}) | ||||
|     expectn('nvim_buf_update', {bnew, tick + 2, 0, 1, {'he'}}) | ||||
|     expectn('nvim_buf_update', {bnew, tick + 3, 0, 1, {'hel'}}) | ||||
|     expectn('nvim_buf_update', {bnew, tick + 4, 0, 1, {'hell'}}) | ||||
|     expectn('nvim_buf_update', {bnew, tick + 5, 0, 1, {'hello'}}) | ||||
|     expectn('nvim_buf_update', {bnew, tick + 6, 0, 1, {'hello', ''}}) | ||||
|     expectn('nvim_buf_update', {bnew, tick + 7, 1, 2, {'world'}}) | ||||
|   end) | ||||
| 
 | ||||
|   it('knows when you replace lines', function() | ||||
| @@ -289,23 +289,23 @@ describe('liveupdate', function() | ||||
|     -- blast away parts of some lines with visual mode | ||||
|     command('normal! jjwvjjllx') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 2, 3, {'original '}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 2, 3, {'original '}}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 3, 4, {}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 3, 4, {}}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 3, 4, {'e 5'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 3, 4, {'e 5'}}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 2, 3, {'original e 5'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 2, 3, {'original e 5'}}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 3, 4, {}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 3, 4, {}}) | ||||
| 
 | ||||
|     -- blast away a few lines using :g | ||||
|     tick = reopen(b, origlines) | ||||
|     command('global/line [35]/delete') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 2, 3, {}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 2, 3, {}}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 3, 4, {}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 3, 4, {}}) | ||||
|   end) | ||||
| 
 | ||||
|   it('knows when you filter lines', function() | ||||
| @@ -317,9 +317,9 @@ describe('liveupdate', function() | ||||
|     -- 1) addition of the new lines after the filtered lines | ||||
|     -- 2) removal of the original lines | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 5, 5, {"C", "E", "B", "D"}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 5, 5, {"C", "E", "B", "D"}}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 1, 5, {}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 1, 5, {}}) | ||||
|   end) | ||||
| 
 | ||||
|   it('sends a sensible event when you use "o"', function() | ||||
| @@ -329,37 +329,37 @@ describe('liveupdate', function() | ||||
|     -- use 'o' to start a new line from a line with no indent | ||||
|     command('normal! o') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 1, 1, {""}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 1, 1, {""}}) | ||||
| 
 | ||||
|     -- undo the change, indent line 1 a bit, and try again | ||||
|     command('undo') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 1, 2, {}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 1, 2, {}}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdateTick', {b, tick}) | ||||
|     expectn('nvim_buf_update_tick', {b, tick}) | ||||
|     command('set autoindent') | ||||
|     command('normal! >>') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 0, 1, {"\tAAA"}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 0, 1, {"\tAAA"}}) | ||||
|     command('normal! ommm') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 1, 1, {"\t"}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 1, 1, {"\t"}}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 1, 2, {"\tmmm"}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 1, 2, {"\tmmm"}}) | ||||
| 
 | ||||
|     -- undo the change, and try again with 'O' | ||||
|     command('undo') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 1, 2, {'\t'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 1, 2, {'\t'}}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 1, 2, {}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 1, 2, {}}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdateTick', {b, tick}) | ||||
|     expectn('nvim_buf_update_tick', {b, tick}) | ||||
|     command('normal! ggOmmm') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 0, 0, {"\t"}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 0, 0, {"\t"}}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 0, 1, {"\tmmm"}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 0, 1, {"\tmmm"}}) | ||||
|   end) | ||||
| 
 | ||||
|   it('deactivates when your buffer changes outside vim', function() | ||||
| @@ -369,12 +369,12 @@ describe('liveupdate', function() | ||||
| 
 | ||||
|     command('normal! x') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 0, 1, {'ine 1'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 0, 1, {'ine 1'}}) | ||||
|     command('undo') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 0, 1, {'Line 1'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 0, 1, {'Line 1'}}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdateTick', {b, tick}) | ||||
|     expectn('nvim_buf_update_tick', {b, tick}) | ||||
| 
 | ||||
|     -- change the file directly | ||||
|     local f = io.open(filename, 'a') | ||||
| @@ -384,7 +384,7 @@ describe('liveupdate', function() | ||||
| 
 | ||||
|     -- reopen the file and watch live updates shut down | ||||
|     command('edit') | ||||
|     expectn('LiveUpdateEnd', {b}) | ||||
|     expectn('nvim_buf_updates_end', {b}) | ||||
|   end) | ||||
| 
 | ||||
|   it('allows a channel to watch multiple buffers at once', function() | ||||
| @@ -405,32 +405,32 @@ describe('liveupdate', function() | ||||
|     command('b'..b1nr) | ||||
|     command('normal! x') | ||||
|     tick1 = tick1 + 1 | ||||
|     expectn('LiveUpdate', {b1, tick1, 0, 1, {'1'}}) | ||||
|     expectn('nvim_buf_update', {b1, tick1, 0, 1, {'1'}}) | ||||
|     command('undo') | ||||
|     tick1 = tick1 + 1 | ||||
|     expectn('LiveUpdate', {b1, tick1, 0, 1, {'A1'}}) | ||||
|     expectn('nvim_buf_update', {b1, tick1, 0, 1, {'A1'}}) | ||||
|     tick1 = tick1 + 1 | ||||
|     expectn('LiveUpdateTick', {b1, tick1}) | ||||
|     expectn('nvim_buf_update_tick', {b1, tick1}) | ||||
| 
 | ||||
|     command('b'..b2nr) | ||||
|     command('normal! x') | ||||
|     tick2 = tick2 + 1 | ||||
|     expectn('LiveUpdate', {b2, tick2, 0, 1, {'1'}}) | ||||
|     expectn('nvim_buf_update', {b2, tick2, 0, 1, {'1'}}) | ||||
|     command('undo') | ||||
|     tick2 = tick2 + 1 | ||||
|     expectn('LiveUpdate', {b2, tick2, 0, 1, {'B1'}}) | ||||
|     expectn('nvim_buf_update', {b2, tick2, 0, 1, {'B1'}}) | ||||
|     tick2 = tick2 + 1 | ||||
|     expectn('LiveUpdateTick', {b2, tick2}) | ||||
|     expectn('nvim_buf_update_tick', {b2, tick2}) | ||||
| 
 | ||||
|     command('b'..b3nr) | ||||
|     command('normal! x') | ||||
|     tick3 = tick3 + 1 | ||||
|     expectn('LiveUpdate', {b3, tick3, 0, 1, {'1'}}) | ||||
|     expectn('nvim_buf_update', {b3, tick3, 0, 1, {'1'}}) | ||||
|     command('undo') | ||||
|     tick3 = tick3 + 1 | ||||
|     expectn('LiveUpdate', {b3, tick3, 0, 1, {'C1'}}) | ||||
|     expectn('nvim_buf_update', {b3, tick3, 0, 1, {'C1'}}) | ||||
|     tick3 = tick3 + 1 | ||||
|     expectn('LiveUpdateTick', {b3, tick3}) | ||||
|     expectn('nvim_buf_update_tick', {b3, tick3}) | ||||
|   end) | ||||
| 
 | ||||
|   it('doesn\'t get confused when you turn watching on/off many times', | ||||
| @@ -439,22 +439,22 @@ describe('liveupdate', function() | ||||
|     local b, tick = editoriginal(false) | ||||
| 
 | ||||
|     -- turn on live updates many times | ||||
|     ok(buffer('live_updates_start', b, true)) | ||||
|     ok(buffer('live_updates_start', b, true)) | ||||
|     ok(buffer('live_updates_start', b, true)) | ||||
|     ok(buffer('live_updates_start', b, true)) | ||||
|     ok(buffer('live_updates_start', b, true)) | ||||
|     expectn('LiveUpdateStart', {b, tick, origlines, false}) | ||||
|     ok(buffer('attach', b, true)) | ||||
|     ok(buffer('attach', b, true)) | ||||
|     ok(buffer('attach', b, true)) | ||||
|     ok(buffer('attach', b, true)) | ||||
|     ok(buffer('attach', b, true)) | ||||
|     expectn('nvim_buf_updates_start', {b, tick, origlines, false}) | ||||
|     eval('rpcnotify('..channel..', "Hello There")') | ||||
|     expectn('Hello There', {}) | ||||
| 
 | ||||
|     -- turn live updates off many times | ||||
|     ok(buffer('live_updates_stop', b)) | ||||
|     ok(buffer('live_updates_stop', b)) | ||||
|     ok(buffer('live_updates_stop', b)) | ||||
|     ok(buffer('live_updates_stop', b)) | ||||
|     ok(buffer('live_updates_stop', b)) | ||||
|     expectn('LiveUpdateEnd', {b}) | ||||
|     ok(buffer('detach', b)) | ||||
|     ok(buffer('detach', b)) | ||||
|     ok(buffer('detach', b)) | ||||
|     ok(buffer('detach', b)) | ||||
|     ok(buffer('detach', b)) | ||||
|     expectn('nvim_buf_updates_end', {b}) | ||||
|     eval('rpcnotify('..channel..', "Hello Again")') | ||||
|     expectn('Hello Again', {}) | ||||
|   end) | ||||
| @@ -488,46 +488,46 @@ describe('liveupdate', function() | ||||
|     local b, tick = open(false, lines) | ||||
| 
 | ||||
|     -- turn on live updates for sessions 1, 2 and 3 | ||||
|     ok(request(1, 'nvim_buf_live_updates_start', b, true)) | ||||
|     ok(request(2, 'nvim_buf_live_updates_start', b, true)) | ||||
|     ok(request(3, 'nvim_buf_live_updates_start', b, true)) | ||||
|     wantn(1, 'LiveUpdateStart', {b, tick, lines, false}) | ||||
|     wantn(2, 'LiveUpdateStart', {b, tick, lines, false}) | ||||
|     wantn(3, 'LiveUpdateStart', {b, tick, lines, false}) | ||||
|     ok(request(1, 'nvim_buf_attach', b, true)) | ||||
|     ok(request(2, 'nvim_buf_attach', b, true)) | ||||
|     ok(request(3, 'nvim_buf_attach', b, true)) | ||||
|     wantn(1, 'nvim_buf_updates_start', {b, tick, lines, false}) | ||||
|     wantn(2, 'nvim_buf_updates_start', {b, tick, lines, false}) | ||||
|     wantn(3, 'nvim_buf_updates_start', {b, tick, lines, false}) | ||||
| 
 | ||||
|     -- make a change to the buffer | ||||
|     command('normal! x') | ||||
|     tick = tick + 1 | ||||
|     wantn(1, 'LiveUpdate', {b, tick, 0, 1, {'AA'}}) | ||||
|     wantn(2, 'LiveUpdate', {b, tick, 0, 1, {'AA'}}) | ||||
|     wantn(3, 'LiveUpdate', {b, tick, 0, 1, {'AA'}}) | ||||
|     wantn(1, 'nvim_buf_update', {b, tick, 0, 1, {'AA'}}) | ||||
|     wantn(2, 'nvim_buf_update', {b, tick, 0, 1, {'AA'}}) | ||||
|     wantn(3, 'nvim_buf_update', {b, tick, 0, 1, {'AA'}}) | ||||
| 
 | ||||
|     -- stop watching on channel 1 | ||||
|     ok(request(1, 'nvim_buf_live_updates_stop', b)) | ||||
|     wantn(1, 'LiveUpdateEnd', {b}) | ||||
|     ok(request(1, 'nvim_buf_detach', b)) | ||||
|     wantn(1, 'nvim_buf_updates_end', {b}) | ||||
| 
 | ||||
|     -- undo the change to buffer 1 | ||||
|     command('undo') | ||||
|     tick = tick + 1 | ||||
|     wantn(2, 'LiveUpdate', {b, tick, 0, 1, {'AAA'}}) | ||||
|     wantn(3, 'LiveUpdate', {b, tick, 0, 1, {'AAA'}}) | ||||
|     wantn(2, 'nvim_buf_update', {b, tick, 0, 1, {'AAA'}}) | ||||
|     wantn(3, 'nvim_buf_update', {b, tick, 0, 1, {'AAA'}}) | ||||
|     tick = tick + 1 | ||||
|     wantn(2, 'LiveUpdateTick', {b, tick}) | ||||
|     wantn(3, 'LiveUpdateTick', {b, tick}) | ||||
|     wantn(2, 'nvim_buf_update_tick', {b, tick}) | ||||
|     wantn(3, 'nvim_buf_update_tick', {b, tick}) | ||||
| 
 | ||||
|     -- make sure there are no other pending LiveUpdate messages going to | ||||
|     -- make sure there are no other pending nvim_buf_update messages going to | ||||
|     -- channel 1 | ||||
|     local channel1 = request(1, 'nvim_get_api_info')[1] | ||||
|     eval('rpcnotify('..channel1..', "Hello")') | ||||
|     wantn(1, 'Hello', {}) | ||||
| 
 | ||||
|     -- close the buffer and channels 2 and 3 should get a LiveUpdateEnd | ||||
|     -- close the buffer and channels 2 and 3 should get a nvim_buf_updates_end | ||||
|     -- notification | ||||
|     command('edit') | ||||
|     wantn(2, 'LiveUpdateEnd', {b}) | ||||
|     wantn(3, 'LiveUpdateEnd', {b}) | ||||
|     wantn(2, 'nvim_buf_updates_end', {b}) | ||||
|     wantn(3, 'nvim_buf_updates_end', {b}) | ||||
| 
 | ||||
|     -- make sure there are no other pending LiveUpdate messages going to | ||||
|     -- make sure there are no other pending nvim_buf_update messages going to | ||||
|     -- channel 1 | ||||
|     channel1 = request(1, 'nvim_get_api_info')[1] | ||||
|     eval('rpcnotify('..channel1..', "Hello Again")') | ||||
| @@ -550,13 +550,13 @@ describe('liveupdate', function() | ||||
|     command('normal! gg') | ||||
|     command('diffput') | ||||
|     tick2 = tick2 + 1 | ||||
|     expectn('LiveUpdate', {b2, tick2, 0, 0, {"AAA"}}) | ||||
|     expectn('nvim_buf_update', {b2, tick2, 0, 0, {"AAA"}}) | ||||
| 
 | ||||
|     -- use :diffget to grab the other change from buffer 2 | ||||
|     command('normal! G') | ||||
|     command('diffget') | ||||
|     tick1 = tick1 + 1 | ||||
|     expectn('LiveUpdate', {b1, tick1, 2, 2, {"CCC"}}) | ||||
|     expectn('nvim_buf_update', {b1, tick1, 2, 2, {"CCC"}}) | ||||
| 
 | ||||
|     eval('rpcnotify('..channel..', "Goodbye")') | ||||
|     expectn('Goodbye', {}) | ||||
| @@ -567,14 +567,14 @@ describe('liveupdate', function() | ||||
|     local b, tick = editoriginal(true, {"B", "D", "C", "A", "E"}) | ||||
|     command('%sort') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 0, 5, {"A", "B", "C", "D", "E"}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 0, 5, {"A", "B", "C", "D", "E"}}) | ||||
|   end) | ||||
| 
 | ||||
|   it('works with :left', function() | ||||
|     local b, tick = editoriginal(true, {" A", "  B", "B", "\tB", "\t\tC"}) | ||||
|     command('2,4left') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 1, 4, {"B", "B", "B"}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 1, 4, {"B", "B", "B"}}) | ||||
|   end) | ||||
| 
 | ||||
|   it('works with :right', function() | ||||
| @@ -586,7 +586,7 @@ describe('liveupdate', function() | ||||
|     command('set ts=2 et') | ||||
|     command('2,4retab') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 1, 4, {"    B", "      BB", "  B"}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 1, 4, {"    B", "      BB", "  B"}}) | ||||
|   end) | ||||
| 
 | ||||
|   it('works with :move', function() | ||||
| @@ -594,19 +594,19 @@ describe('liveupdate', function() | ||||
|     -- move text down towards the end of the file | ||||
|     command('2,3move 4') | ||||
|     tick = tick + 2 | ||||
|     expectn('LiveUpdate', {b, tick, 4, 4, {"original line 2", | ||||
|     expectn('nvim_buf_update', {b, tick, 4, 4, {"original line 2", | ||||
|                                            "original line 3"}}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 1, 3, {}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 1, 3, {}}) | ||||
| 
 | ||||
|     -- move text up towards the start of the file | ||||
|     tick = reopen(b, origlines) | ||||
|     command('4,5move 2') | ||||
|     tick = tick + 2 | ||||
|     expectn('LiveUpdate', {b, tick, 2, 2, {"original line 4", | ||||
|     expectn('nvim_buf_update', {b, tick, 2, 2, {"original line 4", | ||||
|                                            "original line 5"}}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 5, 7, {}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 5, 7, {}}) | ||||
|   end) | ||||
| 
 | ||||
|   it('sends sensible events when you manually add/remove folds', function() | ||||
| @@ -616,13 +616,13 @@ describe('liveupdate', function() | ||||
|     -- delete the inner fold | ||||
|     command('normal! zR3Gzd') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 1, 4, {'original line 2', | ||||
|     expectn('nvim_buf_update', {b, tick, 1, 4, {'original line 2', | ||||
|                                            'original line 3', | ||||
|                                            'original line 4'}}) | ||||
|     -- delete the outer fold | ||||
|     command('normal! zd') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 0, 6, origlines}) | ||||
|     expectn('nvim_buf_update', {b, tick, 0, 6, origlines}) | ||||
| 
 | ||||
|     -- discard changes and put the folds back | ||||
|     tick = reopenwithfolds(b) | ||||
| @@ -630,7 +630,7 @@ describe('liveupdate', function() | ||||
|     -- remove both folds at once | ||||
|     command('normal! ggzczD') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 0, 6, origlines}) | ||||
|     expectn('nvim_buf_update', {b, tick, 0, 6, origlines}) | ||||
| 
 | ||||
|     -- discard changes and put the folds back | ||||
|     tick = reopenwithfolds(b) | ||||
| @@ -638,17 +638,17 @@ describe('liveupdate', function() | ||||
|     -- now delete all folds at once | ||||
|     command('normal! zE') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 0, 6, origlines}) | ||||
|     expectn('nvim_buf_update', {b, tick, 0, 6, origlines}) | ||||
| 
 | ||||
|     -- create a fold from line 4 to the end of the file | ||||
|     command('normal! 4GA/*{{{*/') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 3, 4, {'original line 4/*{{{*/'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 3, 4, {'original line 4/*{{{*/'}}) | ||||
| 
 | ||||
|     -- delete the fold which only has one marker | ||||
|     command('normal! Gzd') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 3, 6, {'original line 4', | ||||
|     expectn('nvim_buf_update', {b, tick, 3, 6, {'original line 4', | ||||
|                                            'original line 5', | ||||
|                                            'original line 6'}}) | ||||
|   end) | ||||
| @@ -660,16 +660,16 @@ describe('liveupdate', function() | ||||
|     -- test live updates are working | ||||
|     command('normal! x') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 0, 1, {'AA'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 0, 1, {'AA'}}) | ||||
|     command('undo') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 0, 1, {'AAA'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 0, 1, {'AAA'}}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdateTick', {b, tick}) | ||||
|     expectn('nvim_buf_update_tick', {b, tick}) | ||||
| 
 | ||||
|     -- close our buffer by creating a new one | ||||
|     command('enew') | ||||
|     expectn('LiveUpdateEnd', {b}) | ||||
|     expectn('nvim_buf_updates_end', {b}) | ||||
| 
 | ||||
|     -- reopen the original buffer, make sure there are no Live Updates sent | ||||
|     command('b1') | ||||
| @@ -687,18 +687,18 @@ describe('liveupdate', function() | ||||
|     -- test live updates are working | ||||
|     command('normal! x') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 0, 1, {'AA'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 0, 1, {'AA'}}) | ||||
|     command('undo') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 0, 1, {'AAA'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 0, 1, {'AAA'}}) | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdateTick', {b, tick}) | ||||
|     expectn('nvim_buf_update_tick', {b, tick}) | ||||
| 
 | ||||
|     -- close our buffer by creating a new one | ||||
|     command('set hidden') | ||||
|     command('enew') | ||||
| 
 | ||||
|     -- note that no LiveUpdateEnd is sent | ||||
|     -- note that no nvim_buf_updates_end is sent | ||||
|     eval('rpcnotify('..channel..', "Hello There")') | ||||
|     expectn('Hello There', {}) | ||||
| 
 | ||||
| @@ -706,7 +706,7 @@ describe('liveupdate', function() | ||||
|     command('b1') | ||||
|     command('normal! x') | ||||
|     tick = tick + 1 | ||||
|     expectn('LiveUpdate', {b, tick, 0, 1, {'AA'}}) | ||||
|     expectn('nvim_buf_update', {b, tick, 0, 1, {'AA'}}) | ||||
|   end) | ||||
| 
 | ||||
|   it('turns off live updates when a buffer is unloaded, deleted, or wiped', | ||||
| @@ -721,17 +721,17 @@ describe('liveupdate', function() | ||||
|       local b = open(true, {'AAA'}) | ||||
| 
 | ||||
|       -- call :bunload or whatever the command is, and then check that we | ||||
|       -- receive a LiveUpdateEnd | ||||
|       -- receive a nvim_buf_updates_end | ||||
|       command(cmd) | ||||
|       expectn('LiveUpdateEnd', {b}) | ||||
|       expectn('nvim_buf_updates_end', {b}) | ||||
|     end | ||||
|   end) | ||||
| 
 | ||||
|   it('doesn\'t send the buffer\'s content when not requested', function() | ||||
|     helpers.clear() | ||||
|     local b, tick = editoriginal(false) | ||||
|     ok(buffer('live_updates_start', b, false)) | ||||
|     expectn('LiveUpdateStart', {b, tick, {}, false}) | ||||
|     ok(buffer('attach', b, false)) | ||||
|     expectn('nvim_buf_updates_start', {b, tick, {}, false}) | ||||
|   end) | ||||
| 
 | ||||
| end) | ||||
		Reference in New Issue
	
	Block a user
	 KillTheMule
					KillTheMule