Как создать правильный обратный вызов для cairo_pdf_surface_create_for_stream ()? - PullRequest
0 голосов
/ 16 марта 2011

Мне нужно вывести PDF в дескриптор файла, и я подумывал об использовании Cairo, и cairo_pdf_surface_create_for_stream():

У меня есть функция записи, которая имеет эту подпись:

static cairo_status_t cairowrite(void *fp, unsigned char const *data, unsigned int length);

Возвращает CAIRO_STATUS_SUCCESS.

Теперь, как мне передать эту функцию в качестве обратного вызова?

Я попробовал это:

cairo_write_func_t (*wfunc)(void *, unsigned char const *, unsigned int);
wfunc = (cairo_write_func_t)&cairowrite;
surface = cairo_pdf_surface_create_for_stream((cairo_write_func_t)wfunc, fp, (double)realwidth, (double)realwidth);

Но я получаюпредупреждения компилятора: warning: assignment from incompatible pointer type Что находится на линии, где я делаю wfunc = &cairowrite;.

Что я делаю не так?

Функция обратного вызова выдает эту ошибку gcc: cairo_status_t, но должнабыть типа cairo_write_func_t.

С clang я получаю эту ошибку:

qrencode.c:250:11: warning: incompatible pointer types assigning to 'cairo_write_func_t (*)(void *, unsigned char const *, unsigned int)' from
      'cairo_write_func_t' (aka 'cairo_status_t (*)(void *, unsigned char const *, unsigned int)')
    wfunc = (cairo_write_func_t)&cairowrite;
          ^ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1 warning generated.

Что мне делать?

Ответы [ 2 ]

0 голосов
/ 16 марта 2011

Проблема решена!

У меня есть определение функции:

static cairo_status_t cairowrite(void *fh, unsigned char const *data, unsigned int length);

И вот как я передаю обратный вызов:

surface = cairo_pdf_surface_create_for_stream((cairo_write_func_t)cairowrite, fp, (double)realwidth, (double)realwidth);

Я больше не использую указатель промежуточной функции.clang и gcc не выдают ошибок.

0 голосов
/ 16 марта 2011

Вы можете попытаться определить указатель функции с помощью

cairo_status_t (*wfunc)(FILE *, unsigned char *, unsigned int) = &cairowrite;

Пример:

#include <iostream>

int funp(int a, int b) {
  return a + b;
}

int call(int a, int b, int (*ptr)(int, int)) {
  int result = ptr(a, b);
  return result;
}

int main() {
  int (*ptr)(int, int) = &funp;
  int r = call(3, 5, ptr);
  std::cout << "Result " << r << std::endl;
  return 0;
}

Вывод:

Result 8
...