Vala中如何指定在回调参数之前提供用户数据?
How do I specify that user data is provided before the callback parameter in Vala?
我有一个 C API 看起来像这样:
typedef void (*cprcen_channel_callback) (CPRC_abuf *abuf, void *user_data);
int CPRCEN_engine_set_callback(CPRCEN_engine *eng, CPRCEN_channel_handle chan,
void *userdata, cprcen_channel_callback callback);
如您所见,CPRCEN_engine_set_callback
函数在回调之前获取用户数据,而默认情况下,Vala 希望它在回调之后获取。我知道 CCode
属性的 delegate_target_pos
参数,但无论我指定什么位置,userdata
值都会作为生成的函数调用中的第一个参数而不是第三个参数提供。我似乎无法理解 Vala 的参数定位逻辑。
以下是我希望绑定的最终外观:
[CCode(cname = "cprcen_channel_callback", has_target = true)]
public delegate void ChannelCallback(AudioBuffer abuf);
[Compact]
[CCode(cname = "CPRCEN_engine")]
public class Engine {
[CCode(cname = "CPRCEN_engine_set_callback")]
public int set_channel_callback(ChannelHandle chan, ChannelCallback callback);
}
如何进行这项工作?
1.5
应该有效:
[CCode(cname = "CPRCEN_engine_set_callback")]
public int set_channel_callback(ChannelHandle chan, [CCode (delegate_target_pos = 1.5)] ChannelCallback callback);
逻辑很简单。 1.5 在第一个参数 (chan) 和第二个参数 (callback) 之间。如果你想在第二个和第三个之间使用它,你可以使用 2.5,依此类推。
当您希望它位于实例之前时,事情才真正开始变得稍微复杂一些——在这种情况下,您将使用介于 0 和 1 之间的值(例如 0.5)并使用 instance_pos CCode 属性来设置小于 1 但大于 0.5(例如 0.9)的实例。
我有一个 C API 看起来像这样:
typedef void (*cprcen_channel_callback) (CPRC_abuf *abuf, void *user_data);
int CPRCEN_engine_set_callback(CPRCEN_engine *eng, CPRCEN_channel_handle chan,
void *userdata, cprcen_channel_callback callback);
如您所见,CPRCEN_engine_set_callback
函数在回调之前获取用户数据,而默认情况下,Vala 希望它在回调之后获取。我知道 CCode
属性的 delegate_target_pos
参数,但无论我指定什么位置,userdata
值都会作为生成的函数调用中的第一个参数而不是第三个参数提供。我似乎无法理解 Vala 的参数定位逻辑。
以下是我希望绑定的最终外观:
[CCode(cname = "cprcen_channel_callback", has_target = true)]
public delegate void ChannelCallback(AudioBuffer abuf);
[Compact]
[CCode(cname = "CPRCEN_engine")]
public class Engine {
[CCode(cname = "CPRCEN_engine_set_callback")]
public int set_channel_callback(ChannelHandle chan, ChannelCallback callback);
}
如何进行这项工作?
1.5
应该有效:
[CCode(cname = "CPRCEN_engine_set_callback")]
public int set_channel_callback(ChannelHandle chan, [CCode (delegate_target_pos = 1.5)] ChannelCallback callback);
逻辑很简单。 1.5 在第一个参数 (chan) 和第二个参数 (callback) 之间。如果你想在第二个和第三个之间使用它,你可以使用 2.5,依此类推。
当您希望它位于实例之前时,事情才真正开始变得稍微复杂一些——在这种情况下,您将使用介于 0 和 1 之间的值(例如 0.5)并使用 instance_pos CCode 属性来设置小于 1 但大于 0.5(例如 0.9)的实例。