[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