HEX
Server: nginx/1.28.1
System: Linux 10-41-63-61 6.8.0-31-generic #31-Ubuntu SMP PREEMPT_DYNAMIC Sat Apr 20 00:40:06 UTC 2024 x86_64
User: www (1001)
PHP: 7.4.33
Disabled: passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv
Upload Files
File: //proc/37320/cwd/usr/share/swig4.0/python/pybuffer.i
/* Implementing buffer protocol typemaps */

/* %pybuffer_mutable_binary(TYPEMAP, SIZE)
 *
 * Macro for functions accept mutable buffer pointer with a size.
 * This can be used for both input and output. For example:
 * 
 *      %pybuffer_mutable_binary(char *buff, int size);
 *      void foo(char *buff, int size) {
 *        for(int i=0; i<size; ++i)
 *          buff[i]++;  
 *      }
 */

/* Note that in Py_LIMITED_API case we have no choice, but to use deprecated
 * functions, as they provides the only way to access buffer data with limited
 * API, which doesn't include Py_buffer definition. We also disable the
 * warnings about doing this because they're not useful in our case.
 */

%define %pybuffer_mutable_binary(TYPEMAP, SIZE)
%typemap(in) (TYPEMAP, SIZE) {
  int res; Py_ssize_t size = 0; void *buf = 0;
%#ifndef Py_LIMITED_API
  Py_buffer view;
  res = PyObject_GetBuffer($input, &view, PyBUF_WRITABLE);
%#else
  %#if defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6))
    %#pragma GCC diagnostic push
    %#pragma GCC diagnostic ignored "-Wdeprecated"
    %#pragma GCC diagnostic ignored "-Wdeprecated-declarations"
  %#elif defined(_MSC_VER)
    %#pragma warning(push)
    %#pragma warning(disable: 4996)
  %#endif
  res = PyObject_AsWriteBuffer($input, &buf, &size);
  %#if defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6))
    %#pragma GCC diagnostic pop
  %#elif defined(_MSC_VER)
    %#pragma warning(pop)
  %#endif
%#endif
  if (res < 0) {
    PyErr_Clear();
    %argument_fail(res, "(TYPEMAP, SIZE)", $symname, $argnum);
  }
%#ifndef Py_LIMITED_API
  size = view.len;
  buf = view.buf;
  PyBuffer_Release(&view);
%#endif
  $1 = ($1_ltype) buf;
  $2 = ($2_ltype) (size/sizeof($*1_type));
}
%enddef

/* %pybuffer_mutable_string(TYPEMAP)
 *
 * Macro for functions accept mutable zero terminated string pointer.
 * This can be used for both input and output. For example:
 * 
 *      %pybuffer_mutable_string(char *str);
 *      void foo(char *str) {
 *        while(*str) {
 *          *str = toupper(*str);
 *          str++;
 *      }
 */

%define %pybuffer_mutable_string(TYPEMAP)
%typemap(in) (TYPEMAP) {
  int res; void *buf = 0;
%#ifndef Py_LIMITED_API
  Py_buffer view;
  res = PyObject_GetBuffer($input, &view, PyBUF_WRITABLE);
%#else
  %#if defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6))
    %#pragma GCC diagnostic push
    %#pragma GCC diagnostic ignored "-Wdeprecated"
    %#pragma GCC diagnostic ignored "-Wdeprecated-declarations"
  %#elif defined(_MSC_VER)
    %#pragma warning(push)
    %#pragma warning(disable: 4996)
  %#endif
  Py_ssize_t size;
  res = PyObject_AsWriteBuffer($input, &buf, &size);
  %#if defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6))
    %#pragma GCC diagnostic pop
  %#elif defined(_MSC_VER)
    %#pragma warning(pop)
  %#endif
%#endif
  if (res < 0) {
    PyErr_Clear();
    %argument_fail(res, "(TYPEMAP)", $symname, $argnum);
  }
%#ifndef Py_LIMITED_API
  buf = view.buf;
  PyBuffer_Release(&view);
%#endif
  $1 = ($1_ltype) buf;
}
%enddef

/* pybuffer_binary(TYPEMAP, SIZE)
 *
 * Macro for functions accept read only buffer pointer with a size.
 * This must be used for input. For example:
 * 
 *      %pybuffer_binary(char *buff, int size);
 *      int foo(char *buff, int size) {
 *        int count = 0;
 *        for(int i=0; i<size; ++i)
 *          if (0==buff[i]) count++;
 *        return count;
 *      }
 */

%define %pybuffer_binary(TYPEMAP, SIZE)
%typemap(in) (TYPEMAP, SIZE) {
  int res; Py_ssize_t size = 0; const void *buf = 0;
%#ifndef Py_LIMITED_API
  Py_buffer view;
  res = PyObject_GetBuffer($input, &view, PyBUF_CONTIG_RO);
%#else
  %#if defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6))
    %#pragma GCC diagnostic push
    %#pragma GCC diagnostic ignored "-Wdeprecated"
    %#pragma GCC diagnostic ignored "-Wdeprecated-declarations"
  %#elif defined(_MSC_VER)
    %#pragma warning(push)
    %#pragma warning(disable: 4996)
  %#endif
  res = PyObject_AsReadBuffer($input, &buf, &size);
  %#if defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6))
    %#pragma GCC diagnostic pop
  %#elif defined(_MSC_VER)
    %#pragma warning(pop)
  %#endif
%#endif
  if (res < 0) {
    PyErr_Clear();
    %argument_fail(res, "(TYPEMAP, SIZE)", $symname, $argnum);
  }
%#ifndef Py_LIMITED_API
  size = view.len;
  buf = view.buf;
  PyBuffer_Release(&view);
%#endif
  $1 = ($1_ltype) buf;
  $2 = ($2_ltype) (size / sizeof($*1_type));
}
%enddef

/* %pybuffer_string(TYPEMAP)
 *
 * Macro for functions accept read only zero terminated string pointer.
 * This can be used for input. For example:
 * 
 *      %pybuffer_string(char *str);
 *      int foo(char *str) {
 *        int count = 0;
 *        while(*str) {
 *          if (isalnum(*str))
 *            count++;
 *          str++;
 *      }
 */

%define %pybuffer_string(TYPEMAP)
%typemap(in) (TYPEMAP) {
  int res; const void *buf = 0;
%#ifndef Py_LIMITED_API
  Py_buffer view;
  res = PyObject_GetBuffer($input, &view, PyBUF_CONTIG_RO);
%#else
  %#if defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6))
    %#pragma GCC diagnostic push
    %#pragma GCC diagnostic ignored "-Wdeprecated"
    %#pragma GCC diagnostic ignored "-Wdeprecated-declarations"
  %#elif defined(_MSC_VER)
    %#pragma warning(push)
    %#pragma warning(disable: 4996)
  %#endif
  Py_ssize_t size;
  res = PyObject_AsReadBuffer($input, &buf, &size);
  %#if defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6))
    %#pragma GCC diagnostic pop
  %#elif defined(_MSC_VER)
    %#pragma warning(pop)
  %#endif
%#endif
  if (res < 0) {
    PyErr_Clear();
    %argument_fail(res, "(TYPEMAP)", $symname, $argnum);
  }
%#ifndef Py_LIMITED_API
  buf = view.buf;
  PyBuffer_Release(&view);
%#endif
  $1 = ($1_ltype) buf;
}
%enddef