Mercurial > hg > orthanc-python
view Sources/Autogenerated/sdk_OrthancPluginInstanceOrigin.impl.h @ 14:13589c36243d OrthancPython-1.0
OrthancPython-1.0
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Wed, 01 Apr 2020 09:45:03 +0200 |
parents | fef9a239df5c |
children | 9e466631660a |
line wrap: on
line source
/** * Python plugin for Orthanc * Copyright (C) 2017-2020 Osimis S.A., Belgium * * This program is free software: you can redistribute it and/or * modify it under the terms of the GNU Affero General Public License * as published by the Free Software Foundation, either version 3 of * the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. **/ typedef struct { PyObject_HEAD } sdk_OrthancPluginInstanceOrigin_Object; /** * Static global structure => the fields that are beyond the last * initialized field are set to zero. * https://stackoverflow.com/a/11152199/881731 **/ static PyTypeObject sdk_OrthancPluginInstanceOrigin_Type = { PyVarObject_HEAD_INIT(NULL, 0) "orthanc.InstanceOrigin", /* tp_name */ sizeof(sdk_OrthancPluginInstanceOrigin_Object), /* tp_basicsize */ }; void RegisterOrthancPluginInstanceOriginEnumeration(PyObject* module) { sdk_OrthancPluginInstanceOrigin_Type.tp_new = PyType_GenericNew; sdk_OrthancPluginInstanceOrigin_Type.tp_flags = Py_TPFLAGS_DEFAULT; sdk_OrthancPluginInstanceOrigin_Type.tp_doc = "Generated from C enumeration OrthancPluginOrthancPluginInstanceOrigin"; sdk_OrthancPluginInstanceOrigin_Type.tp_dict = PyDict_New(); if (PyType_Ready(&sdk_OrthancPluginInstanceOrigin_Type) < 0) { OrthancPlugins::LogError("Cannot register Python enumeration: OrthancPluginInstanceOrigin"); ORTHANC_PLUGINS_THROW_EXCEPTION(InternalError); } /** * Declare constants here (static members = class attributes) * https://stackoverflow.com/a/8017906/881731 * * "Static and class methods can be defined in tp_methods by adding * METH_STATIC or METH_CLASS to the ml_flags field of the * PyMethodDef structure. This is equivalent to @staticmethod and * @classmethod decorators." * * "Class attributes can be added by setting the tp_dict to a * dictionary with these attributes before calling PyType_Ready() * (in your module initialization function)." **/ PyDict_SetItemString(sdk_OrthancPluginInstanceOrigin_Type.tp_dict, "UNKNOWN", PyLong_FromLong(1)); PyDict_SetItemString(sdk_OrthancPluginInstanceOrigin_Type.tp_dict, "DICOM_PROTOCOL", PyLong_FromLong(2)); PyDict_SetItemString(sdk_OrthancPluginInstanceOrigin_Type.tp_dict, "REST_API", PyLong_FromLong(3)); PyDict_SetItemString(sdk_OrthancPluginInstanceOrigin_Type.tp_dict, "PLUGIN", PyLong_FromLong(4)); PyDict_SetItemString(sdk_OrthancPluginInstanceOrigin_Type.tp_dict, "LUA", PyLong_FromLong(5)); Py_INCREF(&sdk_OrthancPluginInstanceOrigin_Type); if (PyModule_AddObject(module, "InstanceOrigin", (PyObject *)&sdk_OrthancPluginInstanceOrigin_Type) < 0) { OrthancPlugins::LogError("Cannot register Python enumeration: OrthancPluginInstanceOrigin"); Py_DECREF(&sdk_OrthancPluginInstanceOrigin_Type); ORTHANC_PLUGINS_THROW_EXCEPTION(InternalError); } }