From 60043da29fed70a9d4aa503ae6c73fd6f4e14a40 Mon Sep 17 00:00:00 2001 From: Thiago de Arruda Date: Sun, 11 May 2014 00:06:39 -0300 Subject: API: Implement `buffer_get_mark` --- src/api/buffer.c | 36 ++++++++++++++++++++++++++++++++++-- 1 file changed, 34 insertions(+), 2 deletions(-) (limited to 'src/api/buffer.c') diff --git a/src/api/buffer.c b/src/api/buffer.c index 6dde6d6ae0..aeb507ac6e 100644 --- a/src/api/buffer.c +++ b/src/api/buffer.c @@ -321,9 +321,41 @@ void buffer_insert(Buffer buffer, int64_t index, StringArray lines, Error *err) buffer_set_slice(buffer, index, index, false, true, lines, err); } -Position buffer_mark(Buffer buffer, String name, Error *err) +Position buffer_get_mark(Buffer buffer, String name, Error *err) { - abort(); + Position rv; + buf_T *buf = find_buffer(buffer, err); + + if (!buf) { + return rv; + } + + if (name.size != 0) { + set_api_error("mark name must be a single character", err); + return rv; + } + + pos_T *posp; + buf_T *savebuf; + char mark = *name.data; + + try_start(); + switch_buffer(&savebuf, buf); + posp = getmark(mark, false); + restore_buffer(savebuf); + + if (try_end(err)) { + return rv; + } + + if (posp == NULL) { + set_api_error("invalid mark name", err); + return rv; + } + + rv.row = posp->lnum; + rv.col = posp->col; + return rv; } static void switch_to_win_for_buf(buf_T *buf, -- cgit