[pulseaudio-discuss] Is this a pulseaudio bug or a vala bug?

Sean McNamara smcnam at gmail.com
Thu Mar 24 22:29:53 PDT 2011


Replying to myself:

On Fri, Mar 25, 2011 at 1:08 AM, Sean McNamara <smcnam at gmail.com> wrote:
> Hi,
>
> On Thu, Mar 24, 2011 at 10:37 PM, Alexander Kurtz
> <kurtz.alex at googlemail.com> wrote:
>> Hi,
>>
>> I have a problem with Pulseaudio (0.9.21) + Vala (0.10.4). I've written
>> this small demonstration program:
>>
>>        $ cat test.vala
>>        class MyClass : Object {
>>                static void main(){
>>                        PulseAudio.SampleSpec spec = PulseAudio.SampleSpec() {
>>                                format = PulseAudio.SampleFormat.S32NE,
>>                                channels = 2,
>>                                rate = 44100
>>                        };
>>                        PulseAudio.MainLoop loop =
>>                                new PulseAudio.MainLoop();
>>                        PulseAudio.Context context =
>>                                new PulseAudio.Context(loop.get_api(), null);
>>                        PulseAudio.Stream stream =
>>                                new PulseAudio.Stream(context, "", spec);
>>                        int32[] data = new int32[10];
>>                        stream.write(data, sizeof(int32) * data.length);
>>                }
>>        }
>>        $
>>
>> I know that this program won't work (i.e. "run") but it should compile
>> just fine. However, I get this:
>>
>>        $ valac --vapidir=. --pkg=libpulse --pkg=posix test.vala
>>        /home/alexander/test/test.vala.c: In function ‘myclass_main’:
>>        /home/alexander/test/test.vala.c:61: warning: passing argument 5 of ‘pa_stream_write’ makes integer from pointer without a cast
>>        /usr/include/pulse/stream.h:503: note: expected ‘int64_t’ but argument is of type ‘void *’
>>        /home/alexander/test/test.vala.c:61: error: too many arguments to function ‘pa_stream_write’
>>        error: cc exited with status 256
>>        Compilation failed: 1 error(s), 0 warning(s)
>>        $
>>
>> Looking at the generated C-Code reveals this:
>>
>>        $ valac --vapidir=. --pkg=libpulse --pkg=posix --ccode test.vala
>>        $ cat test.c
>>        [...]
>>                pa_stream_write (stream, data, (gsize) (sizeof (gint32) * data_length1), NULL, NULL, 0, PA_SEEK_RELATIVE);
>>        [...]
>>        $
>>
>> This is obviously wrong, since pa_stream_write takes 6 arguments not 7, see[1].
>>
>> Is this a bug in PA's Vala bindings or in Vala itself?
>
> Look at the PulseAudio bindings in
> /usr/share/vala*/vapi/pulseaudio.vapi, or in git:
> http://git.0pointer.de/?p=pulseaudio.git;a=blob_plain;f=vala/libpulse.vapi;hb=refs/heads/master-tx
>
> [Vala]:
> public int write(void *data, size_t bytes, FreeCb? free_cb = null,
> int64 offset = 0, SeekMode mode = SeekMode.RELATIVE);
>
> Compared to [C]:
> int     pa_stream_write (pa_stream *p, const void *data, size_t nbytes,
> pa_free_cb_t free_cb, int64_t offset, pa_seek_mode_t seek)
>
> It seems that the parameters match up in the vapi, but it compiles
> down to two NULLs instead of just one for the FreeCb. But if you look
> at the signature of FreeCb, it tries to accept a void* as a parameter:
>
> [Vala]
> public delegate void FreeCb(void *p);
>
> Maybe the extra parameter that Vala compiles in is supposed to be the
> void* that the callback would then get passed? I think this is the
> default behavior of a delegate. Maybe there is an annotation to tell
> the Vala compiler not to supply a parameter to the call for the formal
> parameters of the delegate?
>
> Try the following
>
> [CCode (has_target = false)]
> public delegate void FreeCb(void *p);

Yep, this works!

$ valac --pkg=libpulse --pkg=posix test.vala
$ file test
test: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically
linked (uses shared libs), for GNU/Linux 2.6.15, not stripped

Attached is a patch

HTH,

Sean

>
> Just a guess though -- it may not work as intended! There's virtually
> no documentation on this attribute; I'm just guessing from the Vala
> sources.
>
> HTH,
>
> Sean
>
>>
>> Best regards
>>
>> Alexander Kurtz
>>
>> [1] http://0pointer.de/lennart/projects/pulseaudio/doxygen/stream_8h.html#a4fc69dec0cc202fcc174125dc88dada7
>>
>> _______________________________________________
>> pulseaudio-discuss mailing list
>> pulseaudio-discuss at mail.0pointer.de
>> https://tango.0pointer.de/mailman/listinfo/pulseaudio-discuss
>>
>>
>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: 0001-Vala-delegate-FreeCb-does-not-have-a-target.patch
Type: text/x-patch
Size: 788 bytes
Desc: not available
URL: <http://lists.freedesktop.org/archives/pulseaudio-discuss/attachments/20110325/eebc7613/attachment.bin>


More information about the pulseaudio-discuss mailing list