From 659d9490527afe0a376b17cac864ed499a91505a Mon Sep 17 00:00:00 2001 From: Uli Schlachter Date: Tue, 18 Jan 2011 14:21:37 +0100 Subject: [PATCH] Tag clients more intelligently (FS#700) Before this commit, c:tags(tags) and t:clients(clients) first removed all tags/clients and then added the new one. This is now changed into only removing the tags/clients that have to be removed and leaving the others in place. Hopefully, this avoids all kinds of weird issues which we had. Signed-off-by: Uli Schlachter --- objects/client.c | 21 ++++++++++++++++++++- objects/tag.c | 21 ++++++++++++++++++++- 2 files changed, 40 insertions(+), 2 deletions(-) diff --git a/objects/client.c b/objects/client.c index 1a634de30..e4ba2dd27 100644 --- a/objects/client.c +++ b/objects/client.c @@ -1169,7 +1169,26 @@ luaA_client_tags(lua_State *L) { luaA_checktable(L, 2); for(int i = 0; i < tags->len; i++) - untag_client(c, tags->tab[i]); + { + /* Only untag if we aren't going to add this tag again */ + bool found = false; + lua_pushnil(L); + while(lua_next(L, 2)) + { + tag_t *t = lua_touserdata(L, -1); + /* Pop the value from lua_next */ + lua_pop(L, 1); + if (t != tags->tab[i]) + continue; + + /* Pop the key from lua_next */ + lua_pop(L, 1); + found = true; + break; + } + if(!found) + untag_client(c, tags->tab[i]); + } lua_pushnil(L); while(lua_next(L, 2)) tag_client(c); diff --git a/objects/tag.c b/objects/tag.c index 2901a01fe..7f08ae150 100644 --- a/objects/tag.c +++ b/objects/tag.c @@ -292,7 +292,26 @@ luaA_tag_clients(lua_State *L) { luaA_checktable(L, 2); foreach(c, tag->clients) - untag_client(*c, tag); + { + /* Only untag if we aren't going to add this tag again */ + bool found = false; + lua_pushnil(L); + while(lua_next(L, 2)) + { + client_t *tc = luaA_checkudata(L, -1, &client_class); + /* Pop the value from lua_next */ + lua_pop(L, 1); + if (tc != *c) + continue; + + /* Pop the key from lua_next */ + lua_pop(L, 1); + found = true; + break; + } + if(!found) + untag_client(*c, tag); + } lua_pushnil(L); while(lua_next(L, 2)) {