aboutsummaryrefslogtreecommitdiff
path: root/sway/commands/unmark.c
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2017-04-03 14:52:20 -0400
committerGitHub <noreply@github.com>2017-04-03 14:52:20 -0400
commit7d43a76b4e765eb8072c09cdec3847e877cf65d7 (patch)
tree030844d9fb13be7814dd760a6ffedbec8f5264cd /sway/commands/unmark.c
parentab7570d311d65ff03fd14627ec3157fa37995ced (diff)
parent2445d279604d7be38c00db60ffde4279a3c75459 (diff)
Merge pull request #1145 from 4e554c4c/marks
Impliment i3-style marks
Diffstat (limited to 'sway/commands/unmark.c')
-rw-r--r--sway/commands/unmark.c31
1 files changed, 31 insertions, 0 deletions
diff --git a/sway/commands/unmark.c b/sway/commands/unmark.c
new file mode 100644
index 00000000..34a2ae44
--- /dev/null
+++ b/sway/commands/unmark.c
@@ -0,0 +1,31 @@
+#include <string.h>
+#include <strings.h>
+#include "sway/commands.h"
+#include "list.h"
+#include "stringop.h"
+
+struct cmd_results *cmd_unmark(int argc, char **argv) {
+ swayc_t *view = get_focused_container(&root_container);
+
+ if (view->marks) {
+ if (argc) {
+ char *mark = join_args(argv, argc);
+ int index;
+ if ((index = list_seq_find(view->marks, (int (*)(const void *, const void *))strcmp, mark)) != -1) {
+ free(view->marks->items[index]);
+ list_del(view->marks, index);
+
+ if (view->marks->length == 0) {
+ list_free(view->marks);
+ view->marks = NULL;
+ }
+ }
+ free(mark);
+ } else {
+ list_foreach(view->marks, free);
+ list_free(view->marks);
+ view->marks = NULL;
+ }
+ }
+ return cmd_results_new(CMD_SUCCESS, NULL, NULL);
+}