X-Git-Url: http://git.tuebingen.mpg.de/?p=paraslash.git;a=blobdiff_plain;f=recv_common.c;h=a5689390987ac9c9b063dad200653e990268824e;hp=5f2412b5a0b02c0a40b479ed4ed635c43adb617e;hb=ef81b9f4f0fa6a26043c68d429c0deeb7c949351;hpb=40de1dd2fdbb054444d585aa70e2d50166a66e07;ds=sidebyside diff --git a/recv_common.c b/recv_common.c index 5f2412b5..a5689390 100644 --- a/recv_common.c +++ b/recv_common.c @@ -1,13 +1,14 @@ /* - * Copyright (C) 2006-2008 Andre Noll + * Copyright (C) 2006-2009 Andre Noll * * Licensed under the GPL v2. For licencing details see COPYING. */ /** \file recv_common.c common functions of para_recv and para_audiod */ -#include "para.h" +#include +#include "para.h" #include "list.h" #include "sched.h" #include "ggo.h" @@ -15,6 +16,18 @@ #include "string.h" DEFINE_RECEIVER_ARRAY; + +/** + * Call the init function of each paraslash receiver. + */ +void recv_init(void) +{ + int i; + + FOR_EACH_RECEIVER(i) + receivers[i].init(&receivers[i]); +} + static void *parse_receiver_args(int receiver_num, char *options) { struct receiver *r = &receivers[receiver_num]; @@ -23,16 +36,17 @@ static void *parse_receiver_args(int receiver_num, char *options) void *conf; -// PARA_DEBUG_LOG("%s, options: %s\n", r->name, -// options? options : "(none)"); + PARA_DEBUG_LOG("%s, options: %s\n", r->name, + options? options : "(none)"); if (options) { PARA_DEBUG_LOG("options: %s\n", options); - argc = split_args(options, &argv, " \t"); + argc = create_argv(options, " \t", &argv); + if (argc < 0) + return NULL; for (i = argc - 1; i >= 0; i--) argv[i + 1] = argv[i]; - argv[0] = para_strdup(r->name); - argc += 1; - PARA_DEBUG_LOG("argc = %d, argv[0]: %s\n", argc, argv[0]); + argv[0] = NULL; + argc++; } else { argc = 1; argv = para_malloc(2 * sizeof(char*)); @@ -40,7 +54,8 @@ static void *parse_receiver_args(int receiver_num, char *options) argv[1] = NULL; } conf = r->parse_config(argc, argv); - free(argv[0]); + for (i = 1; i < argc; i++) + free(argv[i]); free(argv); return conf; } @@ -85,6 +100,11 @@ void *check_receiver_arg(char *ra, int *receiver_num) return NULL; } +/** + * Print out the help texts to all receivers. + * + * \param detailed Whether the detailed help should be printed. + */ void print_receiver_helps(int detailed) { int i; @@ -95,7 +115,6 @@ void print_receiver_helps(int detailed) printf_or_die("\n\n"); FOR_EACH_RECEIVER(i) { struct receiver *r = receivers + i; - if (!r->help.short_help) continue; printf_or_die("Options for %s:\n", r->name);