}
/**
- * the main function of para_recv
+ * The main function of para_recv.
*
* \param argc number of arguments
* \param argv vector of arguments
}
r = &receivers[receiver_num];
rn.receiver = r;
+ rn.btrn = btr_new_node(&(struct btr_node_description)
+ EMBRACE(.name = r->name));
ret = r->open(&rn);
if (ret < 0)
goto out;
r_opened = 1;
- if (conf.buffer_tree_given)
- sot.btrn = btr_new_node("stdout", rn.btrn);
-
+ sot.btrn = btr_new_node(&(struct btr_node_description)
+ EMBRACE(.parent = rn.btrn, .name = "stdout"));
stdout_set_defaults(&sot);
- sot.bufp = &rn.buf;
- sot.loaded = &rn.loaded;
- sot.input_error = &rn.task.error;
register_task(&sot.task);
rn.task.pre_select = r->pre_select;
rn.task.post_select = r->post_select;
- sprintf(rn.task.status, "receiver node");
+ sprintf(rn.task.status, "%s", r->name);
register_task(&rn.task);
ret = schedule(&s);
out:
if (r_opened)
r->close(&rn);
- if (r)
- r->shutdown();
+ btr_free_node(rn.btrn);
+ btr_free_node(sot.btrn);
+ if (rn.conf)
+ r->free_config(rn.conf);
if (ret < 0)
PARA_ERROR_LOG("%s\n", para_strerror(-ret));
return ret < 0? EXIT_FAILURE : EXIT_SUCCESS;