i3-msg: concatenate all arguments. now you can use i3-msg mark foo

This commit is contained in:
Michael Stapelberg 2011-07-13 18:01:24 +02:00
parent ba7e82fc94
commit 5c276be3d5

View File

@ -152,7 +152,7 @@ int main(int argc, char *argv[]) {
socket_path = getenv("I3SOCK"); socket_path = getenv("I3SOCK");
int o, option_index = 0; int o, option_index = 0;
int message_type = I3_IPC_MESSAGE_TYPE_COMMAND; int message_type = I3_IPC_MESSAGE_TYPE_COMMAND;
char *payload = ""; char *payload = NULL;
bool quiet = false; bool quiet = false;
static struct option long_options[] = { static struct option long_options[] = {
@ -204,8 +204,25 @@ int main(int argc, char *argv[]) {
if (socket_path == NULL) if (socket_path == NULL)
socket_path = strdup("/tmp/i3-ipc.sock"); socket_path = strdup("/tmp/i3-ipc.sock");
if (optind < argc) /* Use all arguments, separated by whitespace, as payload.
payload = argv[optind]; * This way, you dont have to do i3-msg 'mark foo', you can use
* i3-msg mark foo */
while (optind < argc) {
if (!payload) {
if (!(payload = strdup(argv[optind])))
err(EXIT_FAILURE, "strdup(argv[optind])");
} else {
char *both;
if (asprintf(&both, "%s %s", payload, argv[optind]) == -1)
err(EXIT_FAILURE, "asprintf");
free(payload);
payload = both;
}
optind++;
}
if (!payload)
payload = "";
int sockfd = socket(AF_LOCAL, SOCK_STREAM, 0); int sockfd = socket(AF_LOCAL, SOCK_STREAM, 0);
if (sockfd == -1) if (sockfd == -1)