Алхимия AS3_Shim сломана? - PullRequest
       8

Алхимия AS3_Shim сломана?

2 голосов
/ 13 сентября 2010

Я пытаюсь использовать AS3_Shim в моем коде алхимии, но, похоже, он не работает.Он всегда возвращает нулевой указатель на функцию.Кажется, нет никаких примеров использования AS3_Shim, поэтому я не уверен, что я делаю неправильно.Вот пример кода:

static AS3_Val thunk_logtest(void *self, AS3_Val args) {

    // warning: this leaks
    AS3_Val ns= AS3_String("mx.logging");
    AS3_Val clazz= AS3_NSGetS(ns, "Log");
    AS3_Val logger= AS3_CallTS("getLogger", clazz, "StrType", "alchemy");

    // works
    AS3_Val logret= AS3_CallTS("debug", logger, "StrType", "this is a test");

    // doesn't work: AS3_Shim returns NULL!
    typedef void (*log_func_t)(const char[], ...);   
    log_func_t log_func= (log_func_t)AS3_Shim(AS3_String("debug"), logger, "VoidType", "StrType", true);
    printf("log_func= %d \n", log_func); fflush(stdout);

    // because log_func is NULL, this throws TypeError: Error #1006: value is not a function
    log_func("this is a test");

    return AS3_Undefined();
}

1 Ответ

1 голос
/ 14 сентября 2010

AS3_Shim ожидает функцию для своего первого параметра, а не имя функции.Заменить AS3_String("debug") на AS3_GetS(logger, "debug")

log_func_t log_func = (log_func_t)AS3_Shim(
    AS3_GetS(logger, "debug"), logger, "VoidType", "StrType", true );
...