aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/buffer.h
diff options
context:
space:
mode:
authorZyX <kp-pav@yandex.ru>2017-02-15 02:00:45 +0300
committerZyX <kp-pav@yandex.ru>2017-02-23 19:46:44 +0300
commit4f10d42f829da51cd79ff756ac4db96a6532dbac (patch)
tree9623e92dd5395a0516916534b447e3680fe33c88 /src/nvim/buffer.h
parent0eab7ac4b98d9a29e9713251a0402b5fbc37355e (diff)
downloadrneovim-4f10d42f829da51cd79ff756ac4db96a6532dbac.tar.gz
rneovim-4f10d42f829da51cd79ff756ac4db96a6532dbac.tar.bz2
rneovim-4f10d42f829da51cd79ff756ac4db96a6532dbac.zip
buffer: Bind b:changedtick to b:['changedtick'], remove special cases
Diffstat (limited to 'src/nvim/buffer.h')
-rw-r--r--src/nvim/buffer.h23
1 files changed, 23 insertions, 0 deletions
diff --git a/src/nvim/buffer.h b/src/nvim/buffer.h
index 193c9f73d8..2633c1f9d8 100644
--- a/src/nvim/buffer.h
+++ b/src/nvim/buffer.h
@@ -5,6 +5,8 @@
#include "nvim/pos.h" // for linenr_T
#include "nvim/ex_cmds_defs.h" // for exarg_T
#include "nvim/screen.h" // for StlClickRecord
+#include "nvim/func_attr.h"
+#include "nvim/eval.h"
// Values for buflist_getfile()
enum getf_values {
@@ -79,6 +81,27 @@ static inline void restore_win_for_buf(win_T *save_curwin,
}
}
+static inline void buf_set_changedtick(buf_T *const buf, const int changedtick)
+ REAL_FATTR_NONNULL_ALL REAL_FATTR_ALWAYS_INLINE;
+
+/// Set b_changedtick and corresponding variable
+///
+/// @param[out] buf Buffer to set changedtick in.
+/// @param[in] changedtick New value.
+static inline void buf_set_changedtick(buf_T *const buf, const int changedtick)
+{
+#ifndef NDEBUG
+ dictitem_T *const changedtick_di = dict_find(
+ buf->b_vars, (char_u *)"changedtick", sizeof("changedtick") - 1);
+ assert(changedtick_di != NULL);
+ assert(changedtick_di->di_tv.v_type == VAR_NUMBER);
+ assert(changedtick_di->di_tv.v_lock == VAR_FIXED);
+ assert(&changedtick_di->di_tv.vval.v_number == buf->changedtick_val);
+ assert(*buf->changedtick_val == (varnumber_T)buf->b_changedtick);
+#endif
+ *buf->changedtick_val = buf->b_changedtick = changedtick;
+}
+
#define WITH_BUFFER(b, code) \
do { \
win_T *save_curwin = NULL; \