aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJustin M. Keyes <justinkz@gmail.com>2015-11-27 18:06:52 -0500
committerJustin M. Keyes <justinkz@gmail.com>2015-11-27 18:06:52 -0500
commitb9139e009f3eb833ab57e73d1ecdbe68752112fe (patch)
tree97c5556dfeb9cc745db844509946d7cfc12a57c5 /src
parent951714ede63beb324c3ffb4d326ba1c5a47a36ea (diff)
parentec8e60a055d75d7c78242957c87f574e360273a2 (diff)
downloadrneovim-b9139e009f3eb833ab57e73d1ecdbe68752112fe.tar.gz
rneovim-b9139e009f3eb833ab57e73d1ecdbe68752112fe.tar.bz2
rneovim-b9139e009f3eb833ab57e73d1ecdbe68752112fe.zip
Merge pull request #3724 from ZyX-I/fix-3635
shada: Do not save unlisted and quickfix buffers
Diffstat (limited to 'src')
-rw-r--r--src/nvim/shada.c9
1 files changed, 7 insertions, 2 deletions
diff --git a/src/nvim/shada.c b/src/nvim/shada.c
index 231dad07e5..e21c6f17fe 100644
--- a/src/nvim/shada.c
+++ b/src/nvim/shada.c
@@ -43,6 +43,7 @@
#include "nvim/path.h"
#include "nvim/fileio.h"
#include "nvim/strings.h"
+#include "nvim/quickfix.h"
#include "nvim/lib/khash.h"
#include "nvim/lib/kvec.h"
@@ -2484,8 +2485,11 @@ static ShaDaWriteResult shada_write(ShaDaWriteDef *const sd_writer,
// Write buffer list
if (find_shada_parameter('%') != NULL) {
size_t buf_count = 0;
+#define IGNORE_BUF(buf)\
+ (buf->b_ffname == NULL || !buf->b_p_bl || bt_quickfix(buf) \
+ || in_bufset(&removable_bufs, buf))
FOR_ALL_BUFFERS(buf) {
- if (buf->b_ffname != NULL && !in_bufset(&removable_bufs, buf)) {
+ if (!IGNORE_BUF(buf)) {
buf_count++;
}
}
@@ -2503,7 +2507,7 @@ static ShaDaWriteResult shada_write(ShaDaWriteDef *const sd_writer,
};
size_t i = 0;
FOR_ALL_BUFFERS(buf) {
- if (buf->b_ffname == NULL || in_bufset(&removable_bufs, buf)) {
+ if (IGNORE_BUF(buf)) {
continue;
}
buflist_entry.data.buffer_list.buffers[i] = (struct buffer_list_buffer) {
@@ -2519,6 +2523,7 @@ static ShaDaWriteResult shada_write(ShaDaWriteDef *const sd_writer,
goto shada_write_exit;
}
xfree(buflist_entry.data.buffer_list.buffers);
+#undef IGNORE_BUF
}
// Write some of the variables