+ avahi_interface_update_rrs(i, remove_rrs);
+
+ if (m->list_complete &&
+ !remove_rrs &&
+ m->server->config.publish_workstation &&
+ (m->server->state == AVAHI_SERVER_RUNNING)) {
+
+ if (!hw->entry_group)
+ hw->entry_group = avahi_s_entry_group_new(m->server, avahi_host_rr_entry_group_callback, NULL);
+
+ if (!hw->entry_group)
+ return; /* OOM */
+
+ if (avahi_s_entry_group_is_empty(hw->entry_group)) {
+ char name[AVAHI_LABEL_MAX], unescaped[AVAHI_LABEL_MAX], mac[256];
+ const char *p = m->server->host_name;
+
+ avahi_unescape_label(&p, unescaped, sizeof(unescaped));
+ avahi_format_mac_address(mac, sizeof(mac), hw->mac_address, hw->mac_address_size);
+ snprintf(name, sizeof(name), "%s [%s]", unescaped, mac);
+
+ if (avahi_server_add_service(m->server, hw->entry_group, hw->index, AVAHI_PROTO_UNSPEC, 0, name, "_workstation._tcp", NULL, NULL, 9, NULL) < 0) {
+ avahi_log_warn(__FILE__": avahi_server_add_service() failed: %s", avahi_strerror(m->server->error));
+ avahi_s_entry_group_free(hw->entry_group);
+ hw->entry_group = NULL;
+ } else
+ avahi_s_entry_group_commit(hw->entry_group);
+ }
+
+ } else {
+
+ if (hw->entry_group && !avahi_s_entry_group_is_empty(hw->entry_group)) {
+
+ avahi_log_info("Withdrawing workstation service for %s.", hw->name);
+
+ if (avahi_s_entry_group_get_state(hw->entry_group) == AVAHI_ENTRY_GROUP_REGISTERING &&
+ m->server->state == AVAHI_SERVER_REGISTERING)
+ avahi_server_decrease_host_rr_pending(m->server);
+
+ avahi_s_entry_group_reset(hw->entry_group);
+ }
+ }
+}
+
+void avahi_interface_monitor_update_rrs(AvahiInterfaceMonitor *m, int remove_rrs) {
+ AvahiHwInterface *hw;
+
+ assert(m);
+
+ for (hw = m->hw_interfaces; hw; hw = hw->hardware_next)
+ avahi_hw_interface_update_rrs(hw, remove_rrs);