| /*********************************************************** |
| Copyright 1991-1995 by Stichting Mathematisch Centrum, Amsterdam, |
| The Netherlands. |
| |
| All Rights Reserved |
| |
| Permission to use, copy, modify, and distribute this software and its |
| documentation for any purpose and without fee is hereby granted, |
| provided that the above copyright notice appear in all copies and that |
| both that copyright notice and this permission notice appear in |
| supporting documentation, and that the names of Stichting Mathematisch |
| Centrum or CWI or Corporation for National Research Initiatives or |
| CNRI not be used in advertising or publicity pertaining to |
| distribution of the software without specific, written prior |
| permission. |
| |
| While CWI is the initial source for this software, a modified version |
| is made available by the Corporation for National Research Initiatives |
| (CNRI) at the Internet address ftp://ftp.python.org. |
| |
| STICHTING MATHEMATISCH CENTRUM AND CNRI DISCLAIM ALL WARRANTIES WITH |
| REGARD TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF |
| MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL STICHTING MATHEMATISCH |
| CENTRUM OR CNRI BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL |
| DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR |
| PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER |
| TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR |
| PERFORMANCE OF THIS SOFTWARE. |
| |
| ******************************************************************/ |
| |
| |
| /* Cl objects */ |
| |
| #define CLDEBUG |
| |
| #include <stdarg.h> |
| #include <cl.h> |
| #include "Python.h" |
| |
| typedef struct { |
| PyObject_HEAD |
| int ob_isCompressor; /* Compressor or Decompressor */ |
| CL_Handle ob_compressorHdl; |
| int *ob_paramtypes; |
| int ob_nparams; |
| } clobject; |
| |
| static PyObject *ClError; /* exception cl.error */ |
| |
| static int error_handler_called = 0; |
| |
| /* |
| * We want to use the function prototypes that are available in the C |
| * compiler on the SGI. Because of that, we need to declare the first |
| * argument of the compressor and decompressor methods as "object *", |
| * even though they are really "clobject *". Therefore we cast the |
| * argument to the proper type using this macro. |
| */ |
| #define SELF ((clobject *) self) |
| |
| /******************************************************************** |
| Utility routines. |
| ********************************************************************/ |
| static void |
| cl_ErrorHandler(CL_Handle handle, int code, const char *fmt, ...) |
| { |
| va_list ap; |
| char errbuf[BUFSIZ]; /* hopefully big enough */ |
| char *p; |
| |
| if (PyErr_Occurred()) /* don't change existing error */ |
| return; |
| error_handler_called = 1; |
| va_start(ap, fmt); |
| vsprintf(errbuf, fmt, ap); |
| va_end(ap); |
| p = &errbuf[strlen(errbuf) - 1]; /* swat the line feed */ |
| if (*p == '\n') |
| *p = 0; |
| PyErr_SetString(ClError, errbuf); |
| } |
| |
| /* |
| * This assumes that params are always in the range 0 to some maximum. |
| */ |
| static int |
| param_type_is_float(clobject *self, int param) |
| { |
| int bufferlength; |
| |
| if (self->ob_paramtypes == NULL) { |
| error_handler_called = 0; |
| bufferlength = clQueryParams(self->ob_compressorHdl, 0, 0); |
| if (error_handler_called) |
| return -1; |
| |
| self->ob_paramtypes = PyMem_NEW(int, bufferlength); |
| if (self->ob_paramtypes == NULL) |
| return -1; |
| self->ob_nparams = bufferlength / 2; |
| |
| (void) clQueryParams(self->ob_compressorHdl, |
| self->ob_paramtypes, bufferlength); |
| if (error_handler_called) { |
| PyMem_DEL(self->ob_paramtypes); |
| self->ob_paramtypes = NULL; |
| return -1; |
| } |
| } |
| |
| if (param < 0 || param >= self->ob_nparams) |
| return -1; |
| |
| if (self->ob_paramtypes[param*2 + 1] == CL_FLOATING_ENUM_VALUE || |
| self->ob_paramtypes[param*2 + 1] == CL_FLOATING_RANGE_VALUE) |
| return 1; |
| else |
| return 0; |
| } |
| |
| /******************************************************************** |
| Single image compression/decompression. |
| ********************************************************************/ |
| static PyObject * |
| cl_CompressImage(PyObject *self, PyObject *args) |
| { |
| int compressionScheme, width, height, originalFormat; |
| float compressionRatio; |
| int frameBufferSize, compressedBufferSize; |
| char *frameBuffer; |
| PyObject *compressedBuffer; |
| |
| if (!PyArg_Parse(args, "(iiiifs#)", &compressionScheme, |
| &width, &height, |
| &originalFormat, &compressionRatio, &frameBuffer, |
| &frameBufferSize)) |
| return NULL; |
| |
| retry: |
| compressedBuffer = PyString_FromStringAndSize(NULL, frameBufferSize); |
| if (compressedBuffer == NULL) |
| return NULL; |
| |
| compressedBufferSize = frameBufferSize; |
| error_handler_called = 0; |
| if (clCompressImage(compressionScheme, width, height, originalFormat, |
| compressionRatio, (void *) frameBuffer, |
| &compressedBufferSize, |
| (void *) PyString_AsString(compressedBuffer)) |
| == FAILURE) { |
| Py_DECREF(compressedBuffer); |
| if (!error_handler_called) |
| PyErr_SetString(ClError, "clCompressImage failed"); |
| return NULL; |
| } |
| |
| if (compressedBufferSize > frameBufferSize) { |
| frameBufferSize = compressedBufferSize; |
| Py_DECREF(compressedBuffer); |
| goto retry; |
| } |
| |
| if (compressedBufferSize < frameBufferSize) |
| if (_PyString_Resize(&compressedBuffer, compressedBufferSize)) |
| return NULL; |
| |
| return compressedBuffer; |
| } |
| |
| static PyObject * |
| cl_DecompressImage(PyObject *self, PyObject *args) |
| { |
| int compressionScheme, width, height, originalFormat; |
| char *compressedBuffer; |
| int compressedBufferSize, frameBufferSize; |
| PyObject *frameBuffer; |
| |
| if (!PyArg_Parse(args, "(iiiis#)", &compressionScheme, &width, &height, |
| &originalFormat, &compressedBuffer, |
| &compressedBufferSize)) |
| return NULL; |
| |
| frameBufferSize = width * height * CL_BytesPerPixel(originalFormat); |
| |
| frameBuffer = PyString_FromStringAndSize(NULL, frameBufferSize); |
| if (frameBuffer == NULL) |
| return NULL; |
| |
| error_handler_called = 0; |
| if (clDecompressImage(compressionScheme, width, height, originalFormat, |
| compressedBufferSize, compressedBuffer, |
| (void *) PyString_AsString(frameBuffer)) |
| == FAILURE) { |
| Py_DECREF(frameBuffer); |
| if (!error_handler_called) |
| PyErr_SetString(ClError, "clDecompressImage failed"); |
| return NULL; |
| } |
| |
| return frameBuffer; |
| } |
| |
| /******************************************************************** |
| Sequential compression/decompression. |
| ********************************************************************/ |
| #define CheckCompressor(self) if ((self)->ob_compressorHdl == NULL) { \ |
| PyErr_SetString(PyExc_RuntimeError, "(de)compressor not active"); \ |
| return NULL; \ |
| } |
| |
| static PyObject * |
| doClose(clobject *self, PyObject *args, int (*close_func)(CL_Handle)) |
| { |
| CheckCompressor(self); |
| |
| if (!PyArg_NoArgs(args)) |
| return NULL; |
| |
| error_handler_called = 0; |
| if ((*close_func)(self->ob_compressorHdl) == FAILURE) { |
| if (!error_handler_called) |
| PyErr_SetString(ClError, "close failed"); |
| return NULL; |
| } |
| |
| self->ob_compressorHdl = NULL; |
| |
| if (self->ob_paramtypes) |
| PyMem_DEL(self->ob_paramtypes); |
| self->ob_paramtypes = NULL; |
| |
| Py_INCREF(Py_None); |
| return Py_None; |
| } |
| |
| static PyObject * |
| clm_CloseCompressor(PyObject *self, PyObject *args) |
| { |
| return doClose(SELF, args, clCloseCompressor); |
| } |
| |
| static PyObject * |
| clm_CloseDecompressor(PyObject *self, PyObject *args) |
| { |
| return doClose(SELF, args, clCloseDecompressor); |
| } |
| |
| static PyObject * |
| clm_Compress(PyObject *self, PyObject *args) |
| { |
| int numberOfFrames; |
| int frameBufferSize, compressedBufferSize, size; |
| char *frameBuffer; |
| PyObject *data; |
| |
| CheckCompressor(SELF); |
| |
| if (!PyArg_Parse(args, "(is#)", &numberOfFrames, |
| &frameBuffer, &frameBufferSize)) |
| return NULL; |
| |
| error_handler_called = 0; |
| size = clGetParam(SELF->ob_compressorHdl, CL_COMPRESSED_BUFFER_SIZE); |
| compressedBufferSize = size; |
| if (error_handler_called) |
| return NULL; |
| |
| data = PyString_FromStringAndSize(NULL, size); |
| if (data == NULL) |
| return NULL; |
| |
| error_handler_called = 0; |
| if (clCompress(SELF->ob_compressorHdl, numberOfFrames, |
| (void *) frameBuffer, &compressedBufferSize, |
| (void *) PyString_AsString(data)) == FAILURE) { |
| Py_DECREF(data); |
| if (!error_handler_called) |
| PyErr_SetString(ClError, "compress failed"); |
| return NULL; |
| } |
| |
| if (compressedBufferSize < size) |
| if (_PyString_Resize(&data, compressedBufferSize)) |
| return NULL; |
| |
| if (compressedBufferSize > size) { |
| /* we didn't get all "compressed" data */ |
| Py_DECREF(data); |
| PyErr_SetString(ClError, |
| "compressed data is more than fitted"); |
| return NULL; |
| } |
| |
| return data; |
| } |
| |
| static PyObject * |
| clm_Decompress(PyObject *self, PyObject *args) |
| { |
| PyObject *data; |
| int numberOfFrames; |
| char *compressedData; |
| int compressedDataSize, dataSize; |
| |
| CheckCompressor(SELF); |
| |
| if (!PyArg_Parse(args, "(is#)", &numberOfFrames, &compressedData, |
| &compressedDataSize)) |
| return NULL; |
| |
| error_handler_called = 0; |
| dataSize = clGetParam(SELF->ob_compressorHdl, CL_FRAME_BUFFER_SIZE); |
| if (error_handler_called) |
| return NULL; |
| |
| data = PyString_FromStringAndSize(NULL, dataSize); |
| if (data == NULL) |
| return NULL; |
| |
| error_handler_called = 0; |
| if (clDecompress(SELF->ob_compressorHdl, numberOfFrames, |
| compressedDataSize, (void *) compressedData, |
| (void *) PyString_AsString(data)) == FAILURE) { |
| Py_DECREF(data); |
| if (!error_handler_called) |
| PyErr_SetString(ClError, "decompress failed"); |
| return NULL; |
| } |
| |
| return data; |
| } |
| |
| static PyObject * |
| doParams(clobject *self, PyObject *args, int (*func)(CL_Handle, int *, int), |
| int modified) |
| { |
| PyObject *list, *v; |
| int *PVbuffer; |
| int length; |
| int i; |
| float number; |
| |
| CheckCompressor(self); |
| |
| if (!PyArg_Parse(args, "O", &list)) |
| return NULL; |
| if (!PyList_Check(list)) { |
| PyErr_BadArgument(); |
| return NULL; |
| } |
| length = PyList_Size(list); |
| PVbuffer = PyMem_NEW(int, length); |
| if (PVbuffer == NULL) |
| return PyErr_NoMemory(); |
| for (i = 0; i < length; i++) { |
| v = PyList_GetItem(list, i); |
| if (PyFloat_Check(v)) { |
| number = PyFloat_AsDouble(v); |
| PVbuffer[i] = CL_TypeIsInt(number); |
| } else if (PyInt_Check(v)) { |
| PVbuffer[i] = PyInt_AsLong(v); |
| if ((i & 1) && |
| param_type_is_float(self, PVbuffer[i-1]) > 0) { |
| number = PVbuffer[i]; |
| PVbuffer[i] = CL_TypeIsInt(number); |
| } |
| } else { |
| PyMem_DEL(PVbuffer); |
| PyErr_BadArgument(); |
| return NULL; |
| } |
| } |
| |
| error_handler_called = 0; |
| (*func)(self->ob_compressorHdl, PVbuffer, length); |
| if (error_handler_called) { |
| PyMem_DEL(PVbuffer); |
| return NULL; |
| } |
| |
| if (modified) { |
| for (i = 0; i < length; i++) { |
| if ((i & 1) && |
| param_type_is_float(self, PVbuffer[i-1]) > 0) { |
| number = CL_TypeIsFloat(PVbuffer[i]); |
| v = PyFloat_FromDouble(number); |
| } else |
| v = PyInt_FromLong(PVbuffer[i]); |
| PyList_SetItem(list, i, v); |
| } |
| } |
| |
| PyMem_DEL(PVbuffer); |
| |
| Py_INCREF(Py_None); |
| return Py_None; |
| } |
| |
| static PyObject * |
| clm_GetParams(PyObject *self, PyObject *args) |
| { |
| return doParams(SELF, args, clGetParams, 1); |
| } |
| |
| static PyObject * |
| clm_SetParams(PyObject *self, PyObject *args) |
| { |
| return doParams(SELF, args, clSetParams, 0); |
| } |
| |
| static PyObject * |
| do_get(clobject *self, PyObject *args, int (*func)(CL_Handle, int)) |
| { |
| int paramID, value; |
| float fvalue; |
| |
| CheckCompressor(self); |
| |
| if (!PyArg_Parse(args, "i", ¶mID)) |
| return NULL; |
| |
| error_handler_called = 0; |
| value = (*func)(self->ob_compressorHdl, paramID); |
| if (error_handler_called) |
| return NULL; |
| |
| if (param_type_is_float(self, paramID) > 0) { |
| fvalue = CL_TypeIsFloat(value); |
| return PyFloat_FromDouble(fvalue); |
| } |
| |
| return PyInt_FromLong(value); |
| } |
| |
| static PyObject * |
| clm_GetParam(PyObject *self, PyObject *args) |
| { |
| return do_get(SELF, args, clGetParam); |
| } |
| |
| static PyObject * |
| clm_GetDefault(PyObject *self, PyObject *args) |
| { |
| return do_get(SELF, args, clGetDefault); |
| } |
| |
| static PyObject * |
| clm_SetParam(PyObject *self, PyObject *args) |
| { |
| int paramID, value; |
| float fvalue; |
| |
| CheckCompressor(SELF); |
| |
| if (!PyArg_Parse(args, "(ii)", ¶mID, &value)) { |
| PyErr_Clear(); |
| if (!PyArg_Parse(args, "(if)", ¶mID, &fvalue)) { |
| PyErr_Clear(); |
| PyErr_SetString(PyExc_TypeError, |
| "bad argument list (format '(ii)' or '(if)')"); |
| return NULL; |
| } |
| value = CL_TypeIsInt(fvalue); |
| } else { |
| if (param_type_is_float(SELF, paramID) > 0) { |
| fvalue = value; |
| value = CL_TypeIsInt(fvalue); |
| } |
| } |
| |
| error_handler_called = 0; |
| value = clSetParam(SELF->ob_compressorHdl, paramID, value); |
| if (error_handler_called) |
| return NULL; |
| |
| if (param_type_is_float(SELF, paramID) > 0) |
| return PyFloat_FromDouble(CL_TypeIsFloat(value)); |
| else |
| return PyInt_FromLong(value); |
| } |
| |
| static PyObject * |
| clm_GetParamID(PyObject *self, PyObject *args) |
| { |
| char *name; |
| int value; |
| |
| CheckCompressor(SELF); |
| |
| if (!PyArg_Parse(args, "s", &name)) |
| return NULL; |
| |
| error_handler_called = 0; |
| value = clGetParamID(SELF->ob_compressorHdl, name); |
| if (value == FAILURE) { |
| if (!error_handler_called) |
| PyErr_SetString(ClError, "getparamid failed"); |
| return NULL; |
| } |
| |
| return PyInt_FromLong(value); |
| } |
| |
| static PyObject * |
| clm_QueryParams(PyObject *self, PyObject *args) |
| { |
| int bufferlength; |
| int *PVbuffer; |
| PyObject *list; |
| int i; |
| |
| CheckCompressor(SELF); |
| |
| if (!PyArg_NoArgs(args)) |
| return NULL; |
| |
| error_handler_called = 0; |
| bufferlength = clQueryParams(SELF->ob_compressorHdl, 0, 0); |
| if (error_handler_called) |
| return NULL; |
| |
| PVbuffer = PyMem_NEW(int, bufferlength); |
| if (PVbuffer == NULL) |
| return PyErr_NoMemory(); |
| |
| bufferlength = clQueryParams(SELF->ob_compressorHdl, PVbuffer, |
| bufferlength); |
| if (error_handler_called) { |
| PyMem_DEL(PVbuffer); |
| return NULL; |
| } |
| |
| list = PyList_New(bufferlength); |
| if (list == NULL) { |
| PyMem_DEL(PVbuffer); |
| return NULL; |
| } |
| |
| for (i = 0; i < bufferlength; i++) { |
| if (i & 1) |
| PyList_SetItem(list, i, PyInt_FromLong(PVbuffer[i])); |
| else if (PVbuffer[i] == 0) { |
| Py_INCREF(Py_None); |
| PyList_SetItem(list, i, Py_None); |
| } else |
| PyList_SetItem(list, i, |
| PyString_FromString((char *) PVbuffer[i])); |
| } |
| |
| PyMem_DEL(PVbuffer); |
| |
| return list; |
| } |
| |
| static PyObject * |
| clm_GetMinMax(PyObject *self, PyObject *args) |
| { |
| int param, min, max; |
| float fmin, fmax; |
| |
| CheckCompressor(SELF); |
| |
| if (!PyArg_Parse(args, "i", ¶m)) |
| return NULL; |
| |
| clGetMinMax(SELF->ob_compressorHdl, param, &min, &max); |
| |
| if (param_type_is_float(SELF, param) > 0) { |
| fmin = CL_TypeIsFloat(min); |
| fmax = CL_TypeIsFloat(max); |
| return Py_BuildValue("(ff)", fmin, fmax); |
| } |
| |
| return Py_BuildValue("(ii)", min, max); |
| } |
| |
| static PyObject * |
| clm_GetName(PyObject *self, PyObject *args) |
| { |
| int param; |
| char *name; |
| |
| CheckCompressor(SELF); |
| |
| if (!PyArg_Parse(args, "i", ¶m)) |
| return NULL; |
| |
| error_handler_called = 0; |
| name = clGetName(SELF->ob_compressorHdl, param); |
| if (name == NULL || error_handler_called) { |
| if (!error_handler_called) |
| PyErr_SetString(ClError, "getname failed"); |
| return NULL; |
| } |
| |
| return PyString_FromString(name); |
| } |
| |
| static PyObject * |
| clm_QuerySchemeFromHandle(PyObject *self, PyObject *args) |
| { |
| CheckCompressor(SELF); |
| |
| if (!PyArg_NoArgs(args)) |
| return NULL; |
| |
| return PyInt_FromLong(clQuerySchemeFromHandle(SELF->ob_compressorHdl)); |
| } |
| |
| static PyObject * |
| clm_ReadHeader(PyObject *self, PyObject *args) |
| { |
| char *header; |
| int headerSize; |
| |
| CheckCompressor(SELF); |
| |
| if (!PyArg_Parse(args, "s#", &header, &headerSize)) |
| return NULL; |
| |
| return PyInt_FromLong(clReadHeader(SELF->ob_compressorHdl, |
| headerSize, header)); |
| } |
| |
| static PyMethodDef compressor_methods[] = { |
| {"close", clm_CloseCompressor}, /* alias */ |
| {"CloseCompressor", clm_CloseCompressor}, |
| {"Compress", clm_Compress}, |
| {"GetDefault", clm_GetDefault}, |
| {"GetMinMax", clm_GetMinMax}, |
| {"GetName", clm_GetName}, |
| {"GetParam", clm_GetParam}, |
| {"GetParamID", clm_GetParamID}, |
| {"GetParams", clm_GetParams}, |
| {"QueryParams", clm_QueryParams}, |
| {"QuerySchemeFromHandle",clm_QuerySchemeFromHandle}, |
| {"SetParam", clm_SetParam}, |
| {"SetParams", clm_SetParams}, |
| {NULL, NULL} /* sentinel */ |
| }; |
| |
| static PyMethodDef decompressor_methods[] = { |
| {"close", clm_CloseDecompressor}, /* alias */ |
| {"CloseDecompressor", clm_CloseDecompressor}, |
| {"Decompress", clm_Decompress}, |
| {"GetDefault", clm_GetDefault}, |
| {"GetMinMax", clm_GetMinMax}, |
| {"GetName", clm_GetName}, |
| {"GetParam", clm_GetParam}, |
| {"GetParamID", clm_GetParamID}, |
| {"GetParams", clm_GetParams}, |
| {"ReadHeader", clm_ReadHeader}, |
| {"QueryParams", clm_QueryParams}, |
| {"QuerySchemeFromHandle",clm_QuerySchemeFromHandle}, |
| {"SetParam", clm_SetParam}, |
| {"SetParams", clm_SetParams}, |
| {NULL, NULL} /* sentinel */ |
| }; |
| |
| static void |
| cl_dealloc(PyObject *self) |
| { |
| if (SELF->ob_compressorHdl) { |
| if (SELF->ob_isCompressor) |
| clCloseCompressor(SELF->ob_compressorHdl); |
| else |
| clCloseDecompressor(SELF->ob_compressorHdl); |
| } |
| PyMem_DEL(self); |
| } |
| |
| static PyObject * |
| cl_getattr(PyObject *self, char *name) |
| { |
| if (SELF->ob_isCompressor) |
| return Py_FindMethod(compressor_methods, self, name); |
| else |
| return Py_FindMethod(decompressor_methods, self, name); |
| } |
| |
| static PyTypeObject Cltype = { |
| PyObject_HEAD_INIT(&PyType_Type) |
| 0, /*ob_size*/ |
| "cl", /*tp_name*/ |
| sizeof(clobject), /*tp_size*/ |
| 0, /*tp_itemsize*/ |
| /* methods */ |
| (destructor)cl_dealloc, /*tp_dealloc*/ |
| 0, /*tp_print*/ |
| (getattrfunc)cl_getattr, /*tp_getattr*/ |
| 0, /*tp_setattr*/ |
| 0, /*tp_compare*/ |
| 0, /*tp_repr*/ |
| 0, /*tp_as_number*/ |
| 0, /*tp_as_sequence*/ |
| 0, /*tp_as_mapping*/ |
| }; |
| |
| static PyObject * |
| doOpen(PyObject *self, PyObject *args, int (*open_func)(int, CL_Handle *), |
| int iscompressor) |
| { |
| int scheme; |
| clobject *new; |
| |
| if (!PyArg_Parse(args, "i", &scheme)) |
| return NULL; |
| |
| new = PyObject_NEW(clobject, &Cltype); |
| if (new == NULL) |
| return NULL; |
| |
| new->ob_compressorHdl = NULL; |
| new->ob_isCompressor = iscompressor; |
| new->ob_paramtypes = NULL; |
| |
| error_handler_called = 0; |
| if ((*open_func)(scheme, &new->ob_compressorHdl) == FAILURE) { |
| Py_DECREF(new); |
| if (!error_handler_called) |
| PyErr_SetString(ClError, "Open(De)Compressor failed"); |
| return NULL; |
| } |
| return (PyObject *)new; |
| } |
| |
| static PyObject * |
| cl_OpenCompressor(PyObject *self, PyObject *args) |
| { |
| return doOpen(self, args, clOpenCompressor, 1); |
| } |
| |
| static PyObject * |
| cl_OpenDecompressor(PyObject *self, PyObject *args) |
| { |
| return doOpen(self, args, clOpenDecompressor, 0); |
| } |
| |
| static PyObject * |
| cl_QueryScheme(PyObject *self, PyObject *args) |
| { |
| char *header; |
| int headerlen; |
| int scheme; |
| |
| if (!PyArg_Parse(args, "s#", &header, &headerlen)) |
| return NULL; |
| |
| scheme = clQueryScheme(header); |
| if (scheme < 0) { |
| PyErr_SetString(ClError, "unknown compression scheme"); |
| return NULL; |
| } |
| |
| return PyInt_FromLong(scheme); |
| } |
| |
| static PyObject * |
| cl_QueryMaxHeaderSize(PyObject *self, PyObject *args) |
| { |
| int scheme; |
| |
| if (!PyArg_Parse(args, "i", &scheme)) |
| return NULL; |
| |
| return PyInt_FromLong(clQueryMaxHeaderSize(scheme)); |
| } |
| |
| static PyObject * |
| cl_QueryAlgorithms(PyObject *self, PyObject *args) |
| { |
| int algorithmMediaType; |
| int bufferlength; |
| int *PVbuffer; |
| PyObject *list; |
| int i; |
| |
| if (!PyArg_Parse(args, "i", &algorithmMediaType)) |
| return NULL; |
| |
| error_handler_called = 0; |
| bufferlength = clQueryAlgorithms(algorithmMediaType, 0, 0); |
| if (error_handler_called) |
| return NULL; |
| |
| PVbuffer = PyMem_NEW(int, bufferlength); |
| if (PVbuffer == NULL) |
| return PyErr_NoMemory(); |
| |
| bufferlength = clQueryAlgorithms(algorithmMediaType, PVbuffer, |
| bufferlength); |
| if (error_handler_called) { |
| PyMem_DEL(PVbuffer); |
| return NULL; |
| } |
| |
| list = PyList_New(bufferlength); |
| if (list == NULL) { |
| PyMem_DEL(PVbuffer); |
| return NULL; |
| } |
| |
| for (i = 0; i < bufferlength; i++) { |
| if (i & 1) |
| PyList_SetItem(list, i, PyInt_FromLong(PVbuffer[i])); |
| else if (PVbuffer[i] == 0) { |
| Py_INCREF(Py_None); |
| PyList_SetItem(list, i, Py_None); |
| } else |
| PyList_SetItem(list, i, |
| PyString_FromString((char *) PVbuffer[i])); |
| } |
| |
| PyMem_DEL(PVbuffer); |
| |
| return list; |
| } |
| |
| static PyObject * |
| cl_QuerySchemeFromName(PyObject *self, PyObject *args) |
| { |
| int algorithmMediaType; |
| char *name; |
| int scheme; |
| |
| if (!PyArg_Parse(args, "(is)", &algorithmMediaType, &name)) |
| return NULL; |
| |
| error_handler_called = 0; |
| scheme = clQuerySchemeFromName(algorithmMediaType, name); |
| if (error_handler_called) { |
| PyErr_SetString(ClError, "unknown compression scheme"); |
| return NULL; |
| } |
| |
| return PyInt_FromLong(scheme); |
| } |
| |
| static PyObject * |
| cl_GetAlgorithmName(PyObject *self, PyObject *args) |
| { |
| int scheme; |
| char *name; |
| |
| if (!PyArg_Parse(args, "i", &scheme)) |
| return NULL; |
| |
| name = clGetAlgorithmName(scheme); |
| if (name == 0) { |
| PyErr_SetString(ClError, "unknown compression scheme"); |
| return NULL; |
| } |
| |
| return PyString_FromString(name); |
| } |
| |
| static PyObject * |
| do_set(PyObject *self, PyObject *args, int (*func)(int, int, int)) |
| { |
| int scheme, paramID, value; |
| float fvalue; |
| int is_float = 0; |
| |
| if (!PyArg_Parse(args, "(iii)", &scheme, ¶mID, &value)) { |
| PyErr_Clear(); |
| if (!PyArg_Parse(args, "(iif)", &scheme, ¶mID, &fvalue)) { |
| PyErr_Clear(); |
| PyErr_SetString(PyExc_TypeError, |
| "bad argument list (format '(iii)' or '(iif)')"); |
| return NULL; |
| } |
| value = CL_TypeIsInt(fvalue); |
| is_float = 1; |
| } else { |
| /* check some parameters which we know to be floats */ |
| switch (scheme) { |
| case CL_COMPRESSION_RATIO: |
| case CL_SPEED: |
| fvalue = value; |
| value = CL_TypeIsInt(fvalue); |
| is_float = 1; |
| break; |
| } |
| } |
| |
| error_handler_called = 0; |
| value = (*func)(scheme, paramID, value); |
| if (error_handler_called) |
| return NULL; |
| |
| if (is_float) |
| return PyFloat_FromDouble(CL_TypeIsFloat(value)); |
| else |
| return PyInt_FromLong(value); |
| } |
| |
| static PyObject * |
| cl_SetDefault(PyObject *self, PyObject *args) |
| { |
| return do_set(self, args, clSetDefault); |
| } |
| |
| static PyObject * |
| cl_SetMin(PyObject *self, PyObject *args) |
| { |
| return do_set(self, args, clSetMin); |
| } |
| |
| static PyObject * |
| cl_SetMax(PyObject *self, PyObject *args) |
| { |
| return do_set(self, args, clSetMax); |
| } |
| |
| #define func(name, handler) \ |
| static PyObject *cl_##name(PyObject *self, PyObject *args) \ |
| { \ |
| int x; \ |
| if (!PyArg_Parse(args, "i", &x)) return NULL; \ |
| return Py##handler(CL_##name(x)); \ |
| } |
| |
| #define func2(name, handler) \ |
| static PyObject *cl_##name(PyObject *self, PyObject *args) \ |
| { \ |
| int a1, a2; \ |
| if (!PyArg_Parse(args, "(ii)", &a1, &a2)) return NULL; \ |
| return Py##handler(CL_##name(a1, a2)); \ |
| } |
| |
| func(BytesPerSample, Int_FromLong) |
| func(BytesPerPixel, Int_FromLong) |
| func(AudioFormatName, String_FromString) |
| func(VideoFormatName, String_FromString) |
| func(AlgorithmNumber, Int_FromLong) |
| func(AlgorithmType, Int_FromLong) |
| func2(Algorithm, Int_FromLong) |
| func(ParamNumber, Int_FromLong) |
| func(ParamType, Int_FromLong) |
| func2(ParamID, Int_FromLong) |
| |
| #ifdef CLDEBUG |
| static PyObject * |
| cvt_type(PyObject *self, PyObject *args) |
| { |
| int number; |
| float fnumber; |
| |
| if (PyArg_Parse(args, "i", &number)) |
| return PyFloat_FromDouble(CL_TypeIsFloat(number)); |
| else { |
| PyErr_Clear(); |
| if (PyArg_Parse(args, "f", &fnumber)) |
| return PyInt_FromLong(CL_TypeIsInt(fnumber)); |
| return NULL; |
| } |
| } |
| #endif |
| |
| static PyMethodDef cl_methods[] = { |
| {"CompressImage", cl_CompressImage}, |
| {"DecompressImage", cl_DecompressImage}, |
| {"GetAlgorithmName", cl_GetAlgorithmName}, |
| {"OpenCompressor", cl_OpenCompressor}, |
| {"OpenDecompressor", cl_OpenDecompressor}, |
| {"QueryAlgorithms", cl_QueryAlgorithms}, |
| {"QueryMaxHeaderSize", cl_QueryMaxHeaderSize}, |
| {"QueryScheme", cl_QueryScheme}, |
| {"QuerySchemeFromName", cl_QuerySchemeFromName}, |
| {"SetDefault", cl_SetDefault}, |
| {"SetMax", cl_SetMax}, |
| {"SetMin", cl_SetMin}, |
| {"BytesPerSample", cl_BytesPerSample}, |
| {"BytesPerPixel", cl_BytesPerPixel}, |
| {"AudioFormatName", cl_AudioFormatName}, |
| {"VideoFormatName", cl_VideoFormatName}, |
| {"AlgorithmNumber", cl_AlgorithmNumber}, |
| {"AlgorithmType", cl_AlgorithmType}, |
| {"Algorithm", cl_Algorithm}, |
| {"ParamNumber", cl_ParamNumber}, |
| {"ParamType", cl_ParamType}, |
| {"ParamID", cl_ParamID}, |
| #ifdef CLDEBUG |
| {"cvt_type", cvt_type}, |
| #endif |
| {NULL, NULL} /* Sentinel */ |
| }; |
| |
| #ifdef CL_JPEG_SOFTWARE |
| #define IRIX_5_3_LIBRARY |
| #endif |
| |
| void |
| initcl() |
| { |
| PyObject *m, *d; |
| |
| m = Py_InitModule("cl", cl_methods); |
| d = PyModule_GetDict(m); |
| |
| ClError = PyString_FromString("cl.error"); |
| (void) PyDict_SetItemString(d, "error", ClError); |
| |
| (void) PyDict_SetItemString(d, "MAX_NUMBER_OF_ORIGINAL_FORMATS", |
| PyInt_FromLong(CL_MAX_NUMBER_OF_ORIGINAL_FORMATS)); |
| (void) PyDict_SetItemString(d, "MONO", PyInt_FromLong(CL_MONO)); |
| (void) PyDict_SetItemString(d, "STEREO_INTERLEAVED", |
| PyInt_FromLong(CL_STEREO_INTERLEAVED)); |
| (void) PyDict_SetItemString(d, "RGB", PyInt_FromLong(CL_RGB)); |
| (void) PyDict_SetItemString(d, "RGBX", PyInt_FromLong(CL_RGBX)); |
| (void) PyDict_SetItemString(d, "RGBA", PyInt_FromLong(CL_RGBA)); |
| (void) PyDict_SetItemString(d, "RGB332", PyInt_FromLong(CL_RGB332)); |
| (void) PyDict_SetItemString(d, "GRAYSCALE", |
| PyInt_FromLong(CL_GRAYSCALE)); |
| (void) PyDict_SetItemString(d, "Y", PyInt_FromLong(CL_Y)); |
| (void) PyDict_SetItemString(d, "YUV", PyInt_FromLong(CL_YUV)); |
| (void) PyDict_SetItemString(d, "YCbCr", PyInt_FromLong(CL_YCbCr)); |
| (void) PyDict_SetItemString(d, "YUV422", PyInt_FromLong(CL_YUV422)); |
| (void) PyDict_SetItemString(d, "YCbCr422", |
| PyInt_FromLong(CL_YCbCr422)); |
| (void) PyDict_SetItemString(d, "YUV422HC", |
| PyInt_FromLong(CL_YUV422HC)); |
| (void) PyDict_SetItemString(d, "YCbCr422HC", |
| PyInt_FromLong(CL_YCbCr422HC)); |
| (void) PyDict_SetItemString(d, "YUV422DC", |
| PyInt_FromLong(CL_YUV422DC)); |
| (void) PyDict_SetItemString(d, "YCbCr422DC", |
| PyInt_FromLong(CL_YCbCr422DC)); |
| (void) PyDict_SetItemString(d, "RGB8", PyInt_FromLong(CL_RGB8)); |
| (void) PyDict_SetItemString(d, "BEST_FIT", |
| PyInt_FromLong(CL_BEST_FIT)); |
| (void) PyDict_SetItemString(d, "MAX_NUMBER_OF_AUDIO_ALGORITHMS", |
| PyInt_FromLong(CL_MAX_NUMBER_OF_AUDIO_ALGORITHMS)); |
| (void) PyDict_SetItemString(d, "MAX_NUMBER_OF_VIDEO_ALGORITHMS", |
| PyInt_FromLong(CL_MAX_NUMBER_OF_VIDEO_ALGORITHMS)); |
| (void) PyDict_SetItemString(d, "AUDIO", PyInt_FromLong(CL_AUDIO)); |
| (void) PyDict_SetItemString(d, "VIDEO", PyInt_FromLong(CL_VIDEO)); |
| (void) PyDict_SetItemString(d, "UNKNOWN_SCHEME", |
| PyInt_FromLong(CL_UNKNOWN_SCHEME)); |
| (void) PyDict_SetItemString(d, "UNCOMPRESSED_AUDIO", |
| PyInt_FromLong(CL_UNCOMPRESSED_AUDIO)); |
| (void) PyDict_SetItemString(d, "G711_ULAW", |
| PyInt_FromLong(CL_G711_ULAW)); |
| (void) PyDict_SetItemString(d, "ULAW", PyInt_FromLong(CL_ULAW)); |
| (void) PyDict_SetItemString(d, "G711_ALAW", |
| PyInt_FromLong(CL_G711_ALAW)); |
| (void) PyDict_SetItemString(d, "ALAW", PyInt_FromLong(CL_ALAW)); |
| (void) PyDict_SetItemString(d, "AWARE_MPEG_AUDIO", |
| PyInt_FromLong(CL_AWARE_MPEG_AUDIO)); |
| (void) PyDict_SetItemString(d, "AWARE_MULTIRATE", |
| PyInt_FromLong(CL_AWARE_MULTIRATE)); |
| (void) PyDict_SetItemString(d, "UNCOMPRESSED", |
| PyInt_FromLong(CL_UNCOMPRESSED)); |
| (void) PyDict_SetItemString(d, "UNCOMPRESSED_VIDEO", |
| PyInt_FromLong(CL_UNCOMPRESSED_VIDEO)); |
| (void) PyDict_SetItemString(d, "RLE", PyInt_FromLong(CL_RLE)); |
| (void) PyDict_SetItemString(d, "JPEG", PyInt_FromLong(CL_JPEG)); |
| #ifdef IRIX_5_3_LIBRARY |
| (void) PyDict_SetItemString(d, "JPEG_SOFTWARE", |
| PyInt_FromLong(CL_JPEG_SOFTWARE)); |
| #endif |
| (void) PyDict_SetItemString(d, "MPEG_VIDEO", |
| PyInt_FromLong(CL_MPEG_VIDEO)); |
| (void) PyDict_SetItemString(d, "MVC1", PyInt_FromLong(CL_MVC1)); |
| (void) PyDict_SetItemString(d, "RTR", PyInt_FromLong(CL_RTR)); |
| (void) PyDict_SetItemString(d, "RTR1", PyInt_FromLong(CL_RTR1)); |
| (void) PyDict_SetItemString(d, "HDCC", PyInt_FromLong(CL_HDCC)); |
| (void) PyDict_SetItemString(d, "MVC2", PyInt_FromLong(CL_MVC2)); |
| (void) PyDict_SetItemString(d, "RLE24", PyInt_FromLong(CL_RLE24)); |
| (void) PyDict_SetItemString(d, "MAX_NUMBER_OF_PARAMS", |
| PyInt_FromLong(CL_MAX_NUMBER_OF_PARAMS)); |
| (void) PyDict_SetItemString(d, "IMAGE_WIDTH", |
| PyInt_FromLong(CL_IMAGE_WIDTH)); |
| (void) PyDict_SetItemString(d, "IMAGE_HEIGHT", |
| PyInt_FromLong(CL_IMAGE_HEIGHT)); |
| (void) PyDict_SetItemString(d, "ORIGINAL_FORMAT", |
| PyInt_FromLong(CL_ORIGINAL_FORMAT)); |
| (void) PyDict_SetItemString(d, "INTERNAL_FORMAT", |
| PyInt_FromLong(CL_INTERNAL_FORMAT)); |
| (void) PyDict_SetItemString(d, "COMPONENTS", |
| PyInt_FromLong(CL_COMPONENTS)); |
| (void) PyDict_SetItemString(d, "BITS_PER_COMPONENT", |
| PyInt_FromLong(CL_BITS_PER_COMPONENT)); |
| (void) PyDict_SetItemString(d, "FRAME_RATE", |
| PyInt_FromLong(CL_FRAME_RATE)); |
| (void) PyDict_SetItemString(d, "COMPRESSION_RATIO", |
| PyInt_FromLong(CL_COMPRESSION_RATIO)); |
| (void) PyDict_SetItemString(d, "EXACT_COMPRESSION_RATIO", |
| PyInt_FromLong(CL_EXACT_COMPRESSION_RATIO)); |
| (void) PyDict_SetItemString(d, "FRAME_BUFFER_SIZE", |
| PyInt_FromLong(CL_FRAME_BUFFER_SIZE)); |
| (void) PyDict_SetItemString(d, "COMPRESSED_BUFFER_SIZE", |
| PyInt_FromLong(CL_COMPRESSED_BUFFER_SIZE)); |
| (void) PyDict_SetItemString(d, "BLOCK_SIZE", |
| PyInt_FromLong(CL_BLOCK_SIZE)); |
| (void) PyDict_SetItemString(d, "PREROLL", PyInt_FromLong(CL_PREROLL)); |
| (void) PyDict_SetItemString(d, "FRAME_TYPE", |
| PyInt_FromLong(CL_FRAME_TYPE)); |
| (void) PyDict_SetItemString(d, "ALGORITHM_ID", |
| PyInt_FromLong(CL_ALGORITHM_ID)); |
| (void) PyDict_SetItemString(d, "ALGORITHM_VERSION", |
| PyInt_FromLong(CL_ALGORITHM_VERSION)); |
| (void) PyDict_SetItemString(d, "ORIENTATION", |
| PyInt_FromLong(CL_ORIENTATION)); |
| (void) PyDict_SetItemString(d, "NUMBER_OF_FRAMES", |
| PyInt_FromLong(CL_NUMBER_OF_FRAMES)); |
| (void) PyDict_SetItemString(d, "SPEED", PyInt_FromLong(CL_SPEED)); |
| (void) PyDict_SetItemString(d, "LAST_FRAME_INDEX", |
| PyInt_FromLong(CL_LAST_FRAME_INDEX)); |
| #ifdef IRIX_5_3_LIBRARY |
| (void) PyDict_SetItemString(d, "ENABLE_IMAGEINFO", |
| PyInt_FromLong(CL_ENABLE_IMAGEINFO)); |
| (void) PyDict_SetItemString(d, "INTERNAL_IMAGE_WIDTH", |
| PyInt_FromLong(CL_INTERNAL_IMAGE_WIDTH)); |
| (void) PyDict_SetItemString(d, "INTERNAL_IMAGE_HEIGHT", |
| PyInt_FromLong(CL_INTERNAL_IMAGE_HEIGHT)); |
| #endif |
| (void) PyDict_SetItemString(d, "NUMBER_OF_PARAMS", |
| PyInt_FromLong(CL_NUMBER_OF_PARAMS)); |
| #ifdef IRIX_5_3_LIBRARY |
| (void) PyDict_SetItemString(d, "MVC2_LUMA_THRESHOLD", |
| PyInt_FromLong(CL_MVC2_LUMA_THRESHOLD)); |
| (void) PyDict_SetItemString(d, "MVC2_CHROMA_THRESHOLD", |
| PyInt_FromLong(CL_MVC2_CHROMA_THRESHOLD)); |
| (void) PyDict_SetItemString(d, "MVC2_EDGE_THRESHOLD", |
| PyInt_FromLong(CL_MVC2_EDGE_THRESHOLD)); |
| (void) PyDict_SetItemString(d, "MVC2_BLENDING", |
| PyInt_FromLong(CL_MVC2_BLENDING)); |
| (void) PyDict_SetItemString(d, "MVC2_BLENDING_OFF", |
| PyInt_FromLong(CL_MVC2_BLENDING_OFF)); |
| (void) PyDict_SetItemString(d, "MVC2_BLENDING_ON", |
| PyInt_FromLong(CL_MVC2_BLENDING_ON)); |
| (void) PyDict_SetItemString(d, "JPEG_QUALITY_FACTOR", |
| PyInt_FromLong(CL_JPEG_QUALITY_FACTOR)); |
| (void) PyDict_SetItemString(d, "JPEG_STREAM_HEADERS", |
| PyInt_FromLong(CL_JPEG_STREAM_HEADERS)); |
| (void) PyDict_SetItemString(d, "JPEG_QUANTIZATION_TABLES", |
| PyInt_FromLong(CL_JPEG_QUANTIZATION_TABLES)); |
| (void) PyDict_SetItemString(d, "JPEG_NUM_PARAMS", |
| PyInt_FromLong(CL_JPEG_NUM_PARAMS)); |
| (void) PyDict_SetItemString(d, "RTR_QUALITY_LEVEL", |
| PyInt_FromLong(CL_RTR_QUALITY_LEVEL)); |
| (void) PyDict_SetItemString(d, "HDCC_TILE_THRESHOLD", |
| PyInt_FromLong(CL_HDCC_TILE_THRESHOLD)); |
| (void) PyDict_SetItemString(d, "HDCC_SAMPLES_PER_TILE", |
| PyInt_FromLong(CL_HDCC_SAMPLES_PER_TILE)); |
| #endif |
| (void) PyDict_SetItemString(d, "END_OF_SEQUENCE", |
| PyInt_FromLong(CL_END_OF_SEQUENCE)); |
| (void) PyDict_SetItemString(d, "CHANNEL_POLICY", |
| PyInt_FromLong(CL_CHANNEL_POLICY)); |
| (void) PyDict_SetItemString(d, "NOISE_MARGIN", |
| PyInt_FromLong(CL_NOISE_MARGIN)); |
| (void) PyDict_SetItemString(d, "BITRATE_POLICY", |
| PyInt_FromLong(CL_BITRATE_POLICY)); |
| (void) PyDict_SetItemString(d, "BITRATE_TARGET", |
| PyInt_FromLong(CL_BITRATE_TARGET)); |
| (void) PyDict_SetItemString(d, "LAYER", PyInt_FromLong(CL_LAYER)); |
| (void) PyDict_SetItemString(d, "ENUM_VALUE", |
| PyInt_FromLong(CL_ENUM_VALUE)); |
| (void) PyDict_SetItemString(d, "RANGE_VALUE", |
| PyInt_FromLong(CL_RANGE_VALUE)); |
| (void) PyDict_SetItemString(d, "FLOATING_ENUM_VALUE", |
| PyInt_FromLong(CL_FLOATING_ENUM_VALUE)); |
| (void) PyDict_SetItemString(d, "FLOATING_RANGE_VALUE", |
| PyInt_FromLong(CL_FLOATING_RANGE_VALUE)); |
| (void) PyDict_SetItemString(d, "DECOMPRESSOR", |
| PyInt_FromLong(CL_DECOMPRESSOR)); |
| (void) PyDict_SetItemString(d, "COMPRESSOR", |
| PyInt_FromLong(CL_COMPRESSOR)); |
| (void) PyDict_SetItemString(d, "CODEC", PyInt_FromLong(CL_CODEC)); |
| (void) PyDict_SetItemString(d, "NONE", PyInt_FromLong(CL_NONE)); |
| #ifdef IRIX_5_3_LIBRARY |
| (void) PyDict_SetItemString(d, "BUF_FRAME", |
| PyInt_FromLong(CL_BUF_FRAME)); |
| (void) PyDict_SetItemString(d, "BUF_DATA", |
| PyInt_FromLong(CL_BUF_DATA)); |
| #endif |
| #ifdef CL_FRAME |
| (void) PyDict_SetItemString(d, "FRAME", PyInt_FromLong(CL_FRAME)); |
| (void) PyDict_SetItemString(d, "DATA", PyInt_FromLong(CL_DATA)); |
| #endif |
| (void) PyDict_SetItemString(d, "NONE", PyInt_FromLong(CL_NONE)); |
| (void) PyDict_SetItemString(d, "KEYFRAME", |
| PyInt_FromLong(CL_KEYFRAME)); |
| (void) PyDict_SetItemString(d, "INTRA", PyInt_FromLong(CL_INTRA)); |
| (void) PyDict_SetItemString(d, "PREDICTED", |
| PyInt_FromLong(CL_PREDICTED)); |
| (void) PyDict_SetItemString(d, "BIDIRECTIONAL", |
| PyInt_FromLong(CL_BIDIRECTIONAL)); |
| (void) PyDict_SetItemString(d, "TOP_DOWN", |
| PyInt_FromLong(CL_TOP_DOWN)); |
| (void) PyDict_SetItemString(d, "BOTTOM_UP", |
| PyInt_FromLong(CL_BOTTOM_UP)); |
| #ifdef IRIX_5_3_LIBRARY |
| (void) PyDict_SetItemString(d, "CONTINUOUS_BLOCK", |
| PyInt_FromLong(CL_CONTINUOUS_BLOCK)); |
| (void) PyDict_SetItemString(d, "CONTINUOUS_NONBLOCK", |
| PyInt_FromLong(CL_CONTINUOUS_NONBLOCK)); |
| (void) PyDict_SetItemString(d, "EXTERNAL_DEVICE", |
| PyInt_FromLong((long)CL_EXTERNAL_DEVICE)); |
| #endif |
| (void) PyDict_SetItemString(d, "AWCMP_STEREO", |
| PyInt_FromLong(AWCMP_STEREO)); |
| (void) PyDict_SetItemString(d, "AWCMP_JOINT_STEREO", |
| PyInt_FromLong(AWCMP_JOINT_STEREO)); |
| (void) PyDict_SetItemString(d, "AWCMP_INDEPENDENT", |
| PyInt_FromLong(AWCMP_INDEPENDENT)); |
| (void) PyDict_SetItemString(d, "AWCMP_FIXED_RATE", |
| PyInt_FromLong(AWCMP_FIXED_RATE)); |
| (void) PyDict_SetItemString(d, "AWCMP_CONST_QUAL", |
| PyInt_FromLong(AWCMP_CONST_QUAL)); |
| (void) PyDict_SetItemString(d, "AWCMP_LOSSLESS", |
| PyInt_FromLong(AWCMP_LOSSLESS)); |
| (void) PyDict_SetItemString(d, "AWCMP_MPEG_LAYER_I", |
| PyInt_FromLong(AWCMP_MPEG_LAYER_I)); |
| (void) PyDict_SetItemString(d, "AWCMP_MPEG_LAYER_II", |
| PyInt_FromLong(AWCMP_MPEG_LAYER_II)); |
| (void) PyDict_SetItemString(d, "HEADER_START_CODE", |
| PyInt_FromLong(CL_HEADER_START_CODE)); |
| (void) PyDict_SetItemString(d, "BAD_NO_BUFFERSPACE", |
| PyInt_FromLong(CL_BAD_NO_BUFFERSPACE)); |
| (void) PyDict_SetItemString(d, "BAD_PVBUFFER", |
| PyInt_FromLong(CL_BAD_PVBUFFER)); |
| (void) PyDict_SetItemString(d, "BAD_BUFFERLENGTH_NEG", |
| PyInt_FromLong(CL_BAD_BUFFERLENGTH_NEG)); |
| (void) PyDict_SetItemString(d, "BAD_BUFFERLENGTH_ODD", |
| PyInt_FromLong(CL_BAD_BUFFERLENGTH_ODD)); |
| (void) PyDict_SetItemString(d, "BAD_PARAM", |
| PyInt_FromLong(CL_BAD_PARAM)); |
| (void) PyDict_SetItemString(d, "BAD_COMPRESSION_SCHEME", |
| PyInt_FromLong(CL_BAD_COMPRESSION_SCHEME)); |
| (void) PyDict_SetItemString(d, "BAD_COMPRESSOR_HANDLE", |
| PyInt_FromLong(CL_BAD_COMPRESSOR_HANDLE)); |
| (void) PyDict_SetItemString(d, "BAD_COMPRESSOR_HANDLE_POINTER", |
| PyInt_FromLong(CL_BAD_COMPRESSOR_HANDLE_POINTER)); |
| (void) PyDict_SetItemString(d, "BAD_BUFFER_HANDLE", |
| PyInt_FromLong(CL_BAD_BUFFER_HANDLE)); |
| (void) PyDict_SetItemString(d, "BAD_BUFFER_QUERY_SIZE", |
| PyInt_FromLong(CL_BAD_BUFFER_QUERY_SIZE)); |
| (void) PyDict_SetItemString(d, "JPEG_ERROR", |
| PyInt_FromLong(CL_JPEG_ERROR)); |
| (void) PyDict_SetItemString(d, "BAD_FRAME_SIZE", |
| PyInt_FromLong(CL_BAD_FRAME_SIZE)); |
| (void) PyDict_SetItemString(d, "PARAM_OUT_OF_RANGE", |
| PyInt_FromLong(CL_PARAM_OUT_OF_RANGE)); |
| (void) PyDict_SetItemString(d, "ADDED_ALGORITHM_ERROR", |
| PyInt_FromLong(CL_ADDED_ALGORITHM_ERROR)); |
| (void) PyDict_SetItemString(d, "BAD_ALGORITHM_TYPE", |
| PyInt_FromLong(CL_BAD_ALGORITHM_TYPE)); |
| (void) PyDict_SetItemString(d, "BAD_ALGORITHM_NAME", |
| PyInt_FromLong(CL_BAD_ALGORITHM_NAME)); |
| (void) PyDict_SetItemString(d, "BAD_BUFFERING", |
| PyInt_FromLong(CL_BAD_BUFFERING)); |
| (void) PyDict_SetItemString(d, "BUFFER_NOT_CREATED", |
| PyInt_FromLong(CL_BUFFER_NOT_CREATED)); |
| (void) PyDict_SetItemString(d, "BAD_BUFFER_EXISTS", |
| PyInt_FromLong(CL_BAD_BUFFER_EXISTS)); |
| (void) PyDict_SetItemString(d, "BAD_INTERNAL_FORMAT", |
| PyInt_FromLong(CL_BAD_INTERNAL_FORMAT)); |
| (void) PyDict_SetItemString(d, "BAD_BUFFER_POINTER", |
| PyInt_FromLong(CL_BAD_BUFFER_POINTER)); |
| (void) PyDict_SetItemString(d, "FRAME_BUFFER_SIZE_ZERO", |
| PyInt_FromLong(CL_FRAME_BUFFER_SIZE_ZERO)); |
| (void) PyDict_SetItemString(d, "BAD_STREAM_HEADER", |
| PyInt_FromLong(CL_BAD_STREAM_HEADER)); |
| (void) PyDict_SetItemString(d, "BAD_LICENSE", |
| PyInt_FromLong(CL_BAD_LICENSE)); |
| (void) PyDict_SetItemString(d, "AWARE_ERROR", |
| PyInt_FromLong(CL_AWARE_ERROR)); |
| (void) PyDict_SetItemString(d, "BAD_BUFFER_SIZE_POINTER", |
| PyInt_FromLong(CL_BAD_BUFFER_SIZE_POINTER)); |
| (void) PyDict_SetItemString(d, "BAD_BUFFER_SIZE", |
| PyInt_FromLong(CL_BAD_BUFFER_SIZE)); |
| (void) PyDict_SetItemString(d, "BAD_BUFFER_TYPE", |
| PyInt_FromLong(CL_BAD_BUFFER_TYPE)); |
| (void) PyDict_SetItemString(d, "BAD_HEADER_SIZE", |
| PyInt_FromLong(CL_BAD_HEADER_SIZE)); |
| (void) PyDict_SetItemString(d, "BAD_FUNCTION_POINTER", |
| PyInt_FromLong(CL_BAD_FUNCTION_POINTER)); |
| (void) PyDict_SetItemString(d, "BAD_SCHEME_POINTER", |
| PyInt_FromLong(CL_BAD_SCHEME_POINTER)); |
| (void) PyDict_SetItemString(d, "BAD_STRING_POINTER", |
| PyInt_FromLong(CL_BAD_STRING_POINTER)); |
| (void) PyDict_SetItemString(d, "BAD_MIN_GT_MAX", |
| PyInt_FromLong(CL_BAD_MIN_GT_MAX)); |
| (void) PyDict_SetItemString(d, "BAD_INITIAL_VALUE", |
| PyInt_FromLong(CL_BAD_INITIAL_VALUE)); |
| (void) PyDict_SetItemString(d, "BAD_PARAM_ID_POINTER", |
| PyInt_FromLong(CL_BAD_PARAM_ID_POINTER)); |
| (void) PyDict_SetItemString(d, "BAD_PARAM_TYPE", |
| PyInt_FromLong(CL_BAD_PARAM_TYPE)); |
| (void) PyDict_SetItemString(d, "BAD_TEXT_STRING_PTR", |
| PyInt_FromLong(CL_BAD_TEXT_STRING_PTR)); |
| (void) PyDict_SetItemString(d, "BAD_FUNCTIONALITY", |
| PyInt_FromLong(CL_BAD_FUNCTIONALITY)); |
| (void) PyDict_SetItemString(d, "BAD_NUMBER_OF_BLOCKS", |
| PyInt_FromLong(CL_BAD_NUMBER_OF_BLOCKS)); |
| (void) PyDict_SetItemString(d, "BAD_BLOCK_SIZE", |
| PyInt_FromLong(CL_BAD_BLOCK_SIZE)); |
| (void) PyDict_SetItemString(d, "BAD_POINTER", |
| PyInt_FromLong(CL_BAD_POINTER)); |
| (void) PyDict_SetItemString(d, "BAD_BOARD", |
| PyInt_FromLong(CL_BAD_BOARD)); |
| (void) PyDict_SetItemString(d, "MVC2_ERROR", |
| PyInt_FromLong(CL_MVC2_ERROR)); |
| #ifdef IRIX_5_3_LIBRARY |
| (void) PyDict_SetItemString(d, "NEXT_NOT_AVAILABLE", |
| PyInt_FromLong(CL_NEXT_NOT_AVAILABLE)); |
| (void) PyDict_SetItemString(d, "SCHEME_BUSY", |
| PyInt_FromLong(CL_SCHEME_BUSY)); |
| (void) PyDict_SetItemString(d, "SCHEME_NOT_AVAILABLE", |
| PyInt_FromLong(CL_SCHEME_NOT_AVAILABLE)); |
| #endif |
| #ifdef CL_LUMA_THRESHOLD |
| /* backward compatibility */ |
| (void) PyDict_SetItemString(d, "LUMA_THRESHOLD", |
| PyInt_FromLong(CL_LUMA_THRESHOLD)); |
| (void) PyDict_SetItemString(d, "CHROMA_THRESHOLD", |
| PyInt_FromLong(CL_CHROMA_THRESHOLD)); |
| (void) PyDict_SetItemString(d, "EDGE_THRESHOLD", |
| PyInt_FromLong(CL_EDGE_THRESHOLD)); |
| (void) PyDict_SetItemString(d, "BLENDING", |
| PyInt_FromLong(CL_BLENDING)); |
| (void) PyDict_SetItemString(d, "QUALITY_FACTOR", |
| PyInt_FromLong(CL_QUALITY_FACTOR)); |
| (void) PyDict_SetItemString(d, "STREAM_HEADERS", |
| PyInt_FromLong(CL_STREAM_HEADERS)); |
| (void) PyDict_SetItemString(d, "QUALITY_LEVEL", |
| PyInt_FromLong(CL_QUALITY_LEVEL)); |
| (void) PyDict_SetItemString(d, "TILE_THRESHOLD", |
| PyInt_FromLong(CL_TILE_THRESHOLD)); |
| (void) PyDict_SetItemString(d, "SAMPLES_PER_TILE", |
| PyInt_FromLong(CL_SAMPLES_PER_TILE)); |
| #endif |
| |
| if (PyErr_Occurred()) |
| Py_FatalError("can't initialize module cl"); |
| |
| (void) clSetErrorHandler(cl_ErrorHandler); |
| } |