mirror of
https://github.com/neovim/neovim.git
synced 2025-01-01 17:23:36 -07:00
refactor(object): get rid of redundant FIXED_TEMP_ARRAY
use the MAXSIZE_TEMP_ARRAY + ADD_C pattern instead, as exemplified by the changes in this commit.
This commit is contained in:
parent
1ef84547a8
commit
c65e73f2d6
@ -538,9 +538,9 @@ void nvim_buf_set_text(uint64_t channel_id, Buffer buffer, Integer start_row, In
|
|||||||
Integer end_row, Integer end_col, ArrayOf(String) replacement, Error *err)
|
Integer end_row, Integer end_col, ArrayOf(String) replacement, Error *err)
|
||||||
FUNC_API_SINCE(7)
|
FUNC_API_SINCE(7)
|
||||||
{
|
{
|
||||||
FIXED_TEMP_ARRAY(scratch, 1);
|
MAXSIZE_TEMP_ARRAY(scratch, 1);
|
||||||
if (replacement.size == 0) {
|
if (replacement.size == 0) {
|
||||||
scratch.items[0] = STRING_OBJ(STATIC_CSTR_AS_STRING(""));
|
ADD_C(scratch, STRING_OBJ(STATIC_CSTR_AS_STRING("")));
|
||||||
replacement = scratch;
|
replacement = scratch;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -74,12 +74,6 @@
|
|||||||
#define ADD_C(array, item) \
|
#define ADD_C(array, item) \
|
||||||
kv_push_c(array, item)
|
kv_push_c(array, item)
|
||||||
|
|
||||||
#define FIXED_TEMP_ARRAY(name, fixsize) \
|
|
||||||
Array name = ARRAY_DICT_INIT; \
|
|
||||||
Object name##__items[fixsize]; \
|
|
||||||
name.size = fixsize; \
|
|
||||||
name.items = name##__items; \
|
|
||||||
|
|
||||||
#define MAXSIZE_TEMP_ARRAY(name, maxsize) \
|
#define MAXSIZE_TEMP_ARRAY(name, maxsize) \
|
||||||
Array name = ARRAY_DICT_INIT; \
|
Array name = ARRAY_DICT_INIT; \
|
||||||
Object name##__items[maxsize]; \
|
Object name##__items[maxsize]; \
|
||||||
|
@ -473,10 +473,10 @@ Object nvim_exec_lua(String code, Array args, Error *err)
|
|||||||
Object nvim_notify(String msg, Integer log_level, Dictionary opts, Error *err)
|
Object nvim_notify(String msg, Integer log_level, Dictionary opts, Error *err)
|
||||||
FUNC_API_SINCE(7)
|
FUNC_API_SINCE(7)
|
||||||
{
|
{
|
||||||
FIXED_TEMP_ARRAY(args, 3);
|
MAXSIZE_TEMP_ARRAY(args, 3);
|
||||||
args.items[0] = STRING_OBJ(msg);
|
ADD_C(args, STRING_OBJ(msg));
|
||||||
args.items[1] = INTEGER_OBJ(log_level);
|
ADD_C(args, INTEGER_OBJ(log_level));
|
||||||
args.items[2] = DICTIONARY_OBJ(opts);
|
ADD_C(args, DICTIONARY_OBJ(opts));
|
||||||
|
|
||||||
return nlua_exec(STATIC_CSTR_AS_STRING("return vim.notify(...)"), args, err);
|
return nlua_exec(STATIC_CSTR_AS_STRING("return vim.notify(...)"), args, err);
|
||||||
}
|
}
|
||||||
@ -1010,10 +1010,10 @@ static void term_write(char *buf, size_t size, void *data)
|
|||||||
if (cb == LUA_NOREF) {
|
if (cb == LUA_NOREF) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
FIXED_TEMP_ARRAY(args, 3);
|
MAXSIZE_TEMP_ARRAY(args, 3);
|
||||||
args.items[0] = INTEGER_OBJ((Integer)chan->id);
|
ADD_C(args, INTEGER_OBJ((Integer)chan->id));
|
||||||
args.items[1] = BUFFER_OBJ(terminal_buf(chan->term));
|
ADD_C(args, BUFFER_OBJ(terminal_buf(chan->term)));
|
||||||
args.items[2] = STRING_OBJ(((String){ .data = buf, .size = size }));
|
ADD_C(args, STRING_OBJ(((String){ .data = buf, .size = size })));
|
||||||
textlock++;
|
textlock++;
|
||||||
nlua_call_ref(cb, "input", args, false, NULL);
|
nlua_call_ref(cb, "input", args, false, NULL);
|
||||||
textlock--;
|
textlock--;
|
||||||
|
@ -2052,8 +2052,8 @@ static bool call_autocmd_callback(const AutoCmd *ac, const AutoPatCmd *apc)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
FIXED_TEMP_ARRAY(args, 1);
|
MAXSIZE_TEMP_ARRAY(args, 1);
|
||||||
args.items[0] = DICTIONARY_OBJ(data);
|
ADD_C(args, DICTIONARY_OBJ(data));
|
||||||
|
|
||||||
Object result = nlua_call_ref(callback.data.luaref, NULL, args, true, NULL);
|
Object result = nlua_call_ref(callback.data.luaref, NULL, args, true, NULL);
|
||||||
if (result.type == kObjectTypeBoolean) {
|
if (result.type == kObjectTypeBoolean) {
|
||||||
|
@ -316,23 +316,23 @@ void buf_updates_send_splice(buf_T *buf, int start_row, colnr_T start_col, bcoun
|
|||||||
BufUpdateCallbacks cb = kv_A(buf->update_callbacks, i);
|
BufUpdateCallbacks cb = kv_A(buf->update_callbacks, i);
|
||||||
bool keep = true;
|
bool keep = true;
|
||||||
if (cb.on_bytes != LUA_NOREF && (cb.preview || !cmdpreview)) {
|
if (cb.on_bytes != LUA_NOREF && (cb.preview || !cmdpreview)) {
|
||||||
FIXED_TEMP_ARRAY(args, 11);
|
MAXSIZE_TEMP_ARRAY(args, 11);
|
||||||
|
|
||||||
// the first argument is always the buffer handle
|
// the first argument is always the buffer handle
|
||||||
args.items[0] = BUFFER_OBJ(buf->handle);
|
ADD_C(args, BUFFER_OBJ(buf->handle));
|
||||||
|
|
||||||
// next argument is b:changedtick
|
// next argument is b:changedtick
|
||||||
args.items[1] = INTEGER_OBJ(buf_get_changedtick(buf));
|
ADD_C(args, INTEGER_OBJ(buf_get_changedtick(buf)));
|
||||||
|
|
||||||
args.items[2] = INTEGER_OBJ(start_row);
|
ADD_C(args, INTEGER_OBJ(start_row));
|
||||||
args.items[3] = INTEGER_OBJ(start_col);
|
ADD_C(args, INTEGER_OBJ(start_col));
|
||||||
args.items[4] = INTEGER_OBJ(start_byte);
|
ADD_C(args, INTEGER_OBJ(start_byte));
|
||||||
args.items[5] = INTEGER_OBJ(old_row);
|
ADD_C(args, INTEGER_OBJ(old_row));
|
||||||
args.items[6] = INTEGER_OBJ(old_col);
|
ADD_C(args, INTEGER_OBJ(old_col));
|
||||||
args.items[7] = INTEGER_OBJ(old_byte);
|
ADD_C(args, INTEGER_OBJ(old_byte));
|
||||||
args.items[8] = INTEGER_OBJ(new_row);
|
ADD_C(args, INTEGER_OBJ(new_row));
|
||||||
args.items[9] = INTEGER_OBJ(new_col);
|
ADD_C(args, INTEGER_OBJ(new_col));
|
||||||
args.items[10] = INTEGER_OBJ(new_byte);
|
ADD_C(args, INTEGER_OBJ(new_byte));
|
||||||
|
|
||||||
textlock++;
|
textlock++;
|
||||||
Object res = nlua_call_ref(cb.on_bytes, "bytes", args, true, NULL);
|
Object res = nlua_call_ref(cb.on_bytes, "bytes", args, true, NULL);
|
||||||
@ -361,13 +361,13 @@ void buf_updates_changedtick(buf_T *buf)
|
|||||||
BufUpdateCallbacks cb = kv_A(buf->update_callbacks, i);
|
BufUpdateCallbacks cb = kv_A(buf->update_callbacks, i);
|
||||||
bool keep = true;
|
bool keep = true;
|
||||||
if (cb.on_changedtick != LUA_NOREF) {
|
if (cb.on_changedtick != LUA_NOREF) {
|
||||||
FIXED_TEMP_ARRAY(args, 2);
|
MAXSIZE_TEMP_ARRAY(args, 2);
|
||||||
|
|
||||||
// the first argument is always the buffer handle
|
// the first argument is always the buffer handle
|
||||||
args.items[0] = BUFFER_OBJ(buf->handle);
|
ADD_C(args, BUFFER_OBJ(buf->handle));
|
||||||
|
|
||||||
// next argument is b:changedtick
|
// next argument is b:changedtick
|
||||||
args.items[1] = INTEGER_OBJ(buf_get_changedtick(buf));
|
ADD_C(args, INTEGER_OBJ(buf_get_changedtick(buf)));
|
||||||
|
|
||||||
textlock++;
|
textlock++;
|
||||||
Object res = nlua_call_ref(cb.on_changedtick, "changedtick",
|
Object res = nlua_call_ref(cb.on_changedtick, "changedtick",
|
||||||
|
@ -63,9 +63,9 @@ void decor_providers_start(DecorProviders *providers, int type, char **err)
|
|||||||
|
|
||||||
bool active;
|
bool active;
|
||||||
if (p->redraw_start != LUA_NOREF) {
|
if (p->redraw_start != LUA_NOREF) {
|
||||||
FIXED_TEMP_ARRAY(args, 2);
|
MAXSIZE_TEMP_ARRAY(args, 2);
|
||||||
args.items[0] = INTEGER_OBJ((int)display_tick);
|
ADD_C(args, INTEGER_OBJ((int)display_tick));
|
||||||
args.items[1] = INTEGER_OBJ(type);
|
ADD_C(args, INTEGER_OBJ(type));
|
||||||
active = decor_provider_invoke(p->ns_id, "start", p->redraw_start, args, true, err);
|
active = decor_provider_invoke(p->ns_id, "start", p->redraw_start, args, true, err);
|
||||||
} else {
|
} else {
|
||||||
active = true;
|
active = true;
|
||||||
@ -96,12 +96,12 @@ void decor_providers_invoke_win(win_T *wp, DecorProviders *providers,
|
|||||||
for (size_t k = 0; k < kv_size(*providers); k++) {
|
for (size_t k = 0; k < kv_size(*providers); k++) {
|
||||||
DecorProvider *p = kv_A(*providers, k);
|
DecorProvider *p = kv_A(*providers, k);
|
||||||
if (p && p->redraw_win != LUA_NOREF) {
|
if (p && p->redraw_win != LUA_NOREF) {
|
||||||
FIXED_TEMP_ARRAY(args, 4);
|
MAXSIZE_TEMP_ARRAY(args, 4);
|
||||||
args.items[0] = WINDOW_OBJ(wp->handle);
|
ADD_C(args, WINDOW_OBJ(wp->handle));
|
||||||
args.items[1] = BUFFER_OBJ(wp->w_buffer->handle);
|
ADD_C(args, BUFFER_OBJ(wp->w_buffer->handle));
|
||||||
// TODO(bfredl): we are not using this, but should be first drawn line?
|
// TODO(bfredl): we are not using this, but should be first drawn line?
|
||||||
args.items[2] = INTEGER_OBJ(wp->w_topline - 1);
|
ADD_C(args, INTEGER_OBJ(wp->w_topline - 1));
|
||||||
args.items[3] = INTEGER_OBJ(knownmax);
|
ADD_C(args, INTEGER_OBJ(knownmax));
|
||||||
if (decor_provider_invoke(p->ns_id, "win", p->redraw_win, args, true, err)) {
|
if (decor_provider_invoke(p->ns_id, "win", p->redraw_win, args, true, err)) {
|
||||||
kvi_push(*line_providers, p);
|
kvi_push(*line_providers, p);
|
||||||
}
|
}
|
||||||
@ -124,10 +124,10 @@ void providers_invoke_line(win_T *wp, DecorProviders *providers, int row, bool *
|
|||||||
for (size_t k = 0; k < kv_size(*providers); k++) {
|
for (size_t k = 0; k < kv_size(*providers); k++) {
|
||||||
DecorProvider *p = kv_A(*providers, k);
|
DecorProvider *p = kv_A(*providers, k);
|
||||||
if (p && p->redraw_line != LUA_NOREF) {
|
if (p && p->redraw_line != LUA_NOREF) {
|
||||||
FIXED_TEMP_ARRAY(args, 3);
|
MAXSIZE_TEMP_ARRAY(args, 3);
|
||||||
args.items[0] = WINDOW_OBJ(wp->handle);
|
ADD_C(args, WINDOW_OBJ(wp->handle));
|
||||||
args.items[1] = BUFFER_OBJ(wp->w_buffer->handle);
|
ADD_C(args, BUFFER_OBJ(wp->w_buffer->handle));
|
||||||
args.items[2] = INTEGER_OBJ(row);
|
ADD_C(args, INTEGER_OBJ(row));
|
||||||
if (decor_provider_invoke(p->ns_id, "line", p->redraw_line, args, true, err)) {
|
if (decor_provider_invoke(p->ns_id, "line", p->redraw_line, args, true, err)) {
|
||||||
*has_decor = true;
|
*has_decor = true;
|
||||||
} else {
|
} else {
|
||||||
@ -150,8 +150,8 @@ void decor_providers_invoke_buf(buf_T *buf, DecorProviders *providers, char **er
|
|||||||
for (size_t i = 0; i < kv_size(*providers); i++) {
|
for (size_t i = 0; i < kv_size(*providers); i++) {
|
||||||
DecorProvider *p = kv_A(*providers, i);
|
DecorProvider *p = kv_A(*providers, i);
|
||||||
if (p && p->redraw_buf != LUA_NOREF) {
|
if (p && p->redraw_buf != LUA_NOREF) {
|
||||||
FIXED_TEMP_ARRAY(args, 1);
|
MAXSIZE_TEMP_ARRAY(args, 1);
|
||||||
args.items[0] = BUFFER_OBJ(buf->handle);
|
ADD_C(args, BUFFER_OBJ(buf->handle));
|
||||||
decor_provider_invoke(p->ns_id, "buf", p->redraw_buf, args, true, err);
|
decor_provider_invoke(p->ns_id, "buf", p->redraw_buf, args, true, err);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -167,8 +167,8 @@ void decor_providers_invoke_end(DecorProviders *providers, char **err)
|
|||||||
for (size_t i = 0; i < kv_size(*providers); i++) {
|
for (size_t i = 0; i < kv_size(*providers); i++) {
|
||||||
DecorProvider *p = kv_A(*providers, i);
|
DecorProvider *p = kv_A(*providers, i);
|
||||||
if (p && p->active && p->redraw_end != LUA_NOREF) {
|
if (p && p->active && p->redraw_end != LUA_NOREF) {
|
||||||
FIXED_TEMP_ARRAY(args, 1);
|
MAXSIZE_TEMP_ARRAY(args, 1);
|
||||||
args.items[0] = INTEGER_OBJ((int)display_tick);
|
ADD_C(args, INTEGER_OBJ((int)display_tick));
|
||||||
decor_provider_invoke(p->ns_id, "end", p->redraw_end, args, true, err);
|
decor_provider_invoke(p->ns_id, "end", p->redraw_end, args, true, err);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -183,10 +183,10 @@ int ns_get_hl(NS ns_id, int hl_id, bool link, bool nodefault)
|
|||||||
bool valid_cache = it.version >= p->hl_valid;
|
bool valid_cache = it.version >= p->hl_valid;
|
||||||
|
|
||||||
if (!valid_cache && p->hl_def != LUA_NOREF && !recursive) {
|
if (!valid_cache && p->hl_def != LUA_NOREF && !recursive) {
|
||||||
FIXED_TEMP_ARRAY(args, 3);
|
MAXSIZE_TEMP_ARRAY(args, 3);
|
||||||
args.items[0] = INTEGER_OBJ((Integer)ns_id);
|
ADD_C(args, INTEGER_OBJ((Integer)ns_id));
|
||||||
args.items[1] = STRING_OBJ(cstr_to_string((char *)syn_id2name(hl_id)));
|
ADD_C(args, STRING_OBJ(cstr_to_string((char *)syn_id2name(hl_id))));
|
||||||
args.items[2] = BOOLEAN_OBJ(link);
|
ADD_C(args, BOOLEAN_OBJ(link));
|
||||||
// TODO(bfredl): preload the "global" attr dict?
|
// TODO(bfredl): preload the "global" attr dict?
|
||||||
|
|
||||||
Error err = ERROR_INIT;
|
Error err = ERROR_INIT;
|
||||||
|
Loading…
Reference in New Issue
Block a user