Merge pull request #1254 from nyorain/master

Fix #926
This commit is contained in:
Drew DeVault 2017-07-01 13:07:25 -04:00 committed by GitHub
commit fe763991d4
3 changed files with 40 additions and 0 deletions

View file

@ -103,6 +103,7 @@ sway_cmd cmd_client_unfocused;
sway_cmd cmd_client_urgent;
sway_cmd cmd_client_placeholder;
sway_cmd cmd_client_background;
sway_cmd cmd_clipboard;
sway_cmd cmd_commands;
sway_cmd cmd_debuglog;
sway_cmd cmd_default_border;

View file

@ -165,6 +165,7 @@ static struct cmd_handler handlers[] = {
{ "client.placeholder", cmd_client_placeholder },
{ "client.unfocused", cmd_client_unfocused },
{ "client.urgent", cmd_client_urgent },
{ "clipboard", cmd_clipboard },
{ "commands", cmd_commands },
{ "debuglog", cmd_debuglog },
{ "default_border", cmd_default_border },

38
sway/commands/clipboard.c Normal file
View file

@ -0,0 +1,38 @@
#include <wlc/wlc.h>
#include <unistd.h>
#include <string.h>
#include "sway/commands.h"
#include "stringop.h"
static void send_clipboard(void *data, const char *type, int fd) {
if (strcmp(type, "text/plain") != 0
&& strcmp(type, "text/plain;charset=utf-8") != 0) {
close(fd);
return;
}
const char *str = data;
write(fd, str, strlen(str));
close(fd);
}
struct cmd_results *cmd_clipboard(int argc, char **argv) {
static char *current_data = NULL;
struct cmd_results *error = NULL;
if ((error = checkarg(argc, "clipboard", EXPECTED_AT_LEAST, 1))) {
return error;
}
static const char *types[2] = {
"text/plain",
"text/plain;charset=utf-8"
};
char *str = join_args(argv, argc);
wlc_set_selection(str, types, 2, &send_clipboard);
free(current_data);
current_data = str;
return cmd_results_new(CMD_SUCCESS, NULL, NULL);
}