This makes para_write with no options work again.
cwt->task.error = 0;
register_task(&cwt->task);
- wns = para_malloc(conf.writer_given * sizeof(*wns));
+ PARA_CRIT_LOG("writers:\n");
- for (i = 0; i < conf.writer_given; i++) {
- struct writer_node *wn = para_calloc(sizeof(*wn));
- struct writer *w;
- const char *name;
-
- ret = -E_WRITE_SYNTAX;
- wn->conf = check_writer_arg(conf.writer_arg[i],
- &wn->writer_num);
- if (!wn->conf)
+ ret = -E_WRITE_SYNTAX;
+ if (!conf.writer_given) {
+ i = 0;
+ wns = para_malloc(sizeof(*wns));
+ wns[0] = setup_writer_node(NULL, cwt->btrn);
+ if (!wns[0])
goto out;
- w = writers + wn->writer_num;
- name = writer_names[wn->writer_num];
- wn->btrn = btr_new_node(name, cwt->btrn, w->execute, wn);
- sprintf(wn->task.status, "%s", name);
- w->open(wn);
- wn->task.post_select = w->post_select_btr;
- wn->task.pre_select = w->pre_select_btr;
- register_task(&wn->task);
- wns[i] = wn;
+ } else {
+ wns = para_malloc(conf.writer_given * sizeof(*wns));
+ for (i = 0; i < conf.writer_given; i++) {
+ PARA_CRIT_LOG("i: %d\n", i);
+ wns[i] = setup_writer_node(conf.writer_arg[i],
+ cwt->btrn);
+ if (!wns[i])
+ goto out;
+ }
}
- i--;
s->default_timeout.tv_sec = 10;
s->default_timeout.tv_usec = 50000;
ret = schedule(s);
out:
- for (; i >= 0; i--) {
+ for (i--; i >= 0; i--) {
struct writer_node *wn = wns[i];
- free(wn->conf);
+ struct writer *w = writers + wn->writer_num;
+ w->close(wn);
+ free(wn->conf); /* FIXME should call gengetopt cleanup funtion */
free(wn);
}
free(wns);
wng->writer_nodes[0].conf = writers[DEFAULT_WRITER].parse_config("");
return wng;
}
+
+/**
+ * Setup a writer node with the default writer.
+ *
+ * If arg is \p NULL, the OS-dependent default writer is used with an empty
+ * configuration string. It defaults to alsa for Linux, osx for OS X, oss for
+ * *BSD and the file writer if neither of these is supported.
+ *
+ * Once the writer configuration has been retrieved, a writer node is created,
+ * its buffer tree node is added to the buffer tree as a child of the given
+ * parent.
+ *
+ * Finally, the new writer node's taks structure is initialized and registered
+ * to the paraslash scheduler.
+ *
+ * \return A pointer to the allocated writer node group.
+ */
+struct writer_node *setup_writer_node(const char *arg, struct btr_node *parent)
+{
+ struct writer_node *wn = para_calloc(sizeof(*wn));
+ struct writer *w;
+ const char *name;
+
+ if (arg)
+ wn->conf = check_writer_arg(arg, &wn->writer_num);
+ else {
+ wn->writer_num = DEFAULT_WRITER;
+ wn->conf = writers[DEFAULT_WRITER].parse_config("");
+ }
+ if (!wn->conf) {
+ free(wn);
+ return NULL;
+ }
+ w = writers + wn->writer_num;
+ name = writer_names[wn->writer_num];
+ wn->btrn = btr_new_node(name, parent, w->execute, wn);
+ sprintf(wn->task.status, "%s", name);
+ w->open(wn);
+ wn->task.post_select = w->post_select_btr;
+ wn->task.pre_select = w->pre_select_btr;
+ register_task(&wn->task);
+ return wn;
+}
+
+
/**
* Print the help text of all writers to stdout.
*
void *check_writer_arg(const char *wa, int *writer_num);
struct writer_node_group *setup_default_wng(void);
void print_writer_helps(int detailed);
+struct writer_node *setup_writer_node(const char *arg, struct btr_node *parent);