# HG changeset patch # User Kim Alvefur # Date 1521670530 -3600 # Node ID 3b28c7728e3f0613d184c710a81d53670a5c8a53 # Parent 11b6aa30b3e01d9264f810e693632ebfbe2bff0a mod_roster: Iterate over roster group items in more modern manner diff -r 11b6aa30b3e0 -r 3b28c7728e3f plugins/mod_roster.lua --- a/plugins/mod_roster.lua Wed Mar 21 22:13:11 2018 +0000 +++ b/plugins/mod_roster.lua Wed Mar 21 23:15:30 2018 +0100 @@ -11,9 +11,8 @@ local jid_split = require "util.jid".split; local jid_prep = require "util.jid".prep; -local t_concat = table.concat; local tonumber = tonumber; -local pairs, ipairs = pairs, ipairs; +local pairs = pairs; local rm_load_roster = require "core.rostermanager".load_roster; local rm_remove_from_roster = require "core.rostermanager".remove_from_roster; @@ -96,12 +95,10 @@ else r_item.subscription = "none"; end - for _, child in ipairs(item) do - if child.name == "group" then - local text = t_concat(child); - if text and text ~= "" then - r_item.groups[text] = true; - end + for group in item:childtags("group") do + local text = group:get_text(); + if text then + r_item.groups[text] = true; end end local success, err_type, err_cond, err_msg = rm_add_to_roster(session, jid, r_item);