On Fri, 06 May 2011 05:56:17 -0400, Mike Parker <aldac...@gmail.com> wrote:

Testing out a new binding I knocked up for a C library. One of the functions takes a struct by value. It looks somewhat like this:

struct S {}
struct Color
{
     float r,g,b,a;
}

extern C void function(S* s, Color color, int x, int y, in char*) draw_text;

Now, there is another function that adjusts color values when making a color. In C, it is sometimes used like so:

draw_text(s, map_color(255, 0, 0, 0), 0, 0, "Blarg");

When I'm calling draw_text like this on the D side, my text output is corrupt. I keep getting weird things like ^^P^, but in the appropriate color. It's consistent, no matter what string I pass, but is different for each color value. If I call draw_text like this:

auto color = map_color(...);
draw_text(s, color, 0, 0, "Blarg");

It works as expected. Has anyone else seen this, or know of a workaround? I'm going to dig through bugzilla later on and see if it's been reported already, but I'm curious if anyone knows of the cause off hand.


There are two possible causes I can think of, depending on how draw_text is defined in C.

1. is it truly a function pointer? That is, does the definition look like void (*draw_text)(S* s, ...), or is it just void draw_text(S* s, ...)?

2. It's possible that the extern C (BTW, I thought it had to be extern(C)?) is only applying to the symbol name draw_text and not the function type.

If you answer no to #1, then your problem is your draw_text definition in D. It should look like this:

extern(C) void draw_text(S * s, Color color, int x, int y, in char *);

If you answer yes to #1, then to check what type the compiler is giving to draw text, do:

pragma(msg, (typeof(draw_text)).stringof);

This hopefully tells you that it's extern(C), but if not, that is likely the problem.

If that's not it, I have no idea ;)

-Steve

Reply via email to