X-Git-Url: http://git.tuebingen.mpg.de/?p=paraslash.git;a=blobdiff_plain;f=mix.h;h=cad435e811e09a9d3d924f946608fd57cce81ed1;hp=427a84f559c8f67369c24e9f4910f9cccdb83e8a;hb=9d232e636d79a2321e280fe3eee6839c8f45c36f;hpb=58864df1c0784c58e421949b67a091fd0a60e140 diff --git a/mix.h b/mix.h index 427a84f5..cad435e8 100644 --- a/mix.h +++ b/mix.h @@ -1,10 +1,6 @@ -/* - * Copyright (C) 2012-2013 Andre Noll - * - * Licensed under the GPL v2. For licencing details see COPYING. - */ +/* Copyright (C) 2012 Andre Noll , see file COPYING. */ -/** \file mix.h Mixer API (used by para_fade). */ +/** \file mix.h Mixer API for para_mixer. */ /** * Opaque structure which corresponds to an instance of a mixer. @@ -16,10 +12,14 @@ struct mixer_handle; /** * Operations provided by each mixer plugin. + * + * Each mixer plugin must define a non-static instance of this structure, with + * all pointers initialized to non-NULL values. No other symbols need to be + * exported. */ struct mixer { - /** Called on startup, must fill in all other members. */ - void (*init)(struct mixer *self); + /** Used to identify the mixer. */ + const char * const name; /** Return a handle that can be passed to other methods. */ int (*open)(const char *dev, struct mixer_handle **handle); /** Returns a string of all valid mixer channels. */ @@ -31,6 +31,9 @@ struct mixer { int (*get)(struct mixer_handle *handle); /** Change the value of the selected channel. */ int (*set)(struct mixer_handle *handle, int val); - /** Free all ressources associated with the given handle. */ + /** Free all resources associated with the given handle. */ void (*close)(struct mixer_handle **handle); }; + +/** Declared even if unsupported because it does not hurt and avoids ifdefs. */ +extern const struct mixer alsa_mixer, oss_mixer;