struct ast_dnsmgr_entry *entry;
int total_size = sizeof(*entry) + strlen(name) + (service ? strlen(service) + 1 : 0);
- if (!result || ast_strlen_zero(name) || !(entry = ast_calloc(1, total_size)))
+ if (!result || ast_strlen_zero(name) || !(entry = ast_calloc(1, total_size))) {
return NULL;
+ }
entry->result = result;
ast_mutex_init(&entry->lock);
int ast_dnsmgr_lookup(const char *name, struct ast_sockaddr *result, struct ast_dnsmgr_entry **dnsmgr, const char *service)
{
- if (ast_strlen_zero(name) || !result || !dnsmgr)
+ if (ast_strlen_zero(name) || !result || !dnsmgr) {
return -1;
+ }
- if (*dnsmgr && !strcasecmp((*dnsmgr)->name, name))
+ if (*dnsmgr && !strcasecmp((*dnsmgr)->name, name)) {
return 0;
+ }
ast_verb(4, "doing dnsmgr_lookup for '%s'\n", name);
ast_get_ip_or_srv(result, name, service);
/* if dnsmgr is not enable don't bother adding an entry */
- if (!enabled)
+ if (!enabled) {
return 0;
+ }
ast_verb(3, "adding dns manager for '%s'\n", name);
*dnsmgr = ast_dnsmgr_get(name, result, service);
{
const char *host;
unsigned short port;
+
while (!(ast_srv_lookup(context, NULL, &host, &port)));
}
struct srv_entry *current;
int ret;
- if (chan && ast_autoservice_start(chan) < 0)
+ if (chan && ast_autoservice_start(chan) < 0) {
return -1;
+ }
ret = ast_search_dns(&context, service, C_IN, T_SRV, srv_callback);
- if (context.have_weights)
+ if (context.have_weights) {
process_weights(&context);
+ }
- if (chan)
+ if (chan) {
ret |= ast_autoservice_stop(chan);
+ }
/* TODO: there could be a "." entry in the returned list of
answers... if so, this requires special handling */
*port = -1;
}
- while ((current = AST_LIST_REMOVE_HEAD(&context.entries, list)))
+ while ((current = AST_LIST_REMOVE_HEAD(&context.entries, list))) {
ast_free(current);
+ }
return ret;
}