aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/ops.c
diff options
context:
space:
mode:
authorJustin M. Keyes <justinkz@gmail.com>2015-06-25 19:31:17 -0400
committerJustin M. Keyes <justinkz@gmail.com>2015-06-25 19:31:17 -0400
commit568d9985491181b3fdfde58aec1f3ddd13e93345 (patch)
tree9d850a5af2391359c5a426424d816ed84ab28160 /src/nvim/ops.c
parent01a200996ab7180bb99fad78dc9e2e88ed304582 (diff)
parent3fcfd524226f0d41fa5b4eec870a8a2f9767044d (diff)
downloadrneovim-568d9985491181b3fdfde58aec1f3ddd13e93345.tar.gz
rneovim-568d9985491181b3fdfde58aec1f3ddd13e93345.tar.bz2
rneovim-568d9985491181b3fdfde58aec1f3ddd13e93345.zip
Merge #2703 'Clipboard: do not use &shell to invoke provider + cache owned clipboard'.
Diffstat (limited to 'src/nvim/ops.c')
-rw-r--r--src/nvim/ops.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/src/nvim/ops.c b/src/nvim/ops.c
index 0b95dd4642..d8df6ae72d 100644
--- a/src/nvim/ops.c
+++ b/src/nvim/ops.c
@@ -5291,6 +5291,9 @@ static yankreg_T *adjust_clipboard_name(int *name, bool quiet)
static bool get_clipboard(int name, yankreg_T **target, bool quiet)
{
+ // show message on error
+ bool errmsg = true;
+
yankreg_T *reg = adjust_clipboard_name(&name, quiet);
if (reg == NULL) {
return false;
@@ -5304,6 +5307,10 @@ static bool get_clipboard(int name, yankreg_T **target, bool quiet)
typval_T result = eval_call_provider("clipboard", "get", args);
if (result.v_type != VAR_LIST) {
+ if (result.v_type == VAR_NUMBER && result.vval.v_number == 0) {
+ // failure has already been indicated by provider
+ errmsg = false;
+ }
goto err;
}
@@ -5389,7 +5396,9 @@ err:
}
reg->y_array = NULL;
reg->y_size = 0;
- EMSG("clipboard: provider returned invalid data");
+ if (errmsg) {
+ EMSG("clipboard: provider returned invalid data");
+ }
*target = reg;
return false;
}