Mercurial > hg > orthanc-python
view CodeAnalysis/Enumeration.mustache @ 129:5643e97d9367 fix-leak
reproducible code generation
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Wed, 30 Aug 2023 11:40:22 +0200 |
parents | 5b59ebc267e1 |
children | c55b0583084b |
line wrap: on
line source
/** * Python plugin for Orthanc * Copyright (C) 2020-2022 Osimis S.A., Belgium * Copyright (C) 2021-2022 Sebastien Jodogne, ICTEAM UCLouvain, 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_{{name}}_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_{{name}}_Type = { PyVarObject_HEAD_INIT(NULL, 0) "orthanc.{{short_name}}", /* tp_name */ sizeof(sdk_{{name}}_Object), /* tp_basicsize */ }; void Register{{name}}Enumeration(PyObject* module) { sdk_{{name}}_Type.tp_new = PyType_GenericNew; sdk_{{name}}_Type.tp_flags = Py_TPFLAGS_DEFAULT; sdk_{{name}}_Type.tp_doc = "Generated from C enumeration OrthancPlugin{{name}}"; sdk_{{name}}_Type.tp_dict = PyDict_New(); if (PyType_Ready(&sdk_{{name}}_Type) < 0) { OrthancPlugins::LogError("Cannot register Python enumeration: {{name}}"); 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)." **/ {{#values}} { PyObject* tmp = PyLong_FromLong({{value}}); PyDict_SetItemString(sdk_{{name}}_Type.tp_dict, "{{key}}", tmp); Py_DECREF(tmp); } {{/values}} Py_INCREF(&sdk_{{name}}_Type); if (PyModule_AddObject(module, "{{short_name}}", (PyObject *)&sdk_{{name}}_Type) < 0) { OrthancPlugins::LogError("Cannot register Python enumeration: {{name}}"); Py_DECREF(&sdk_{{name}}_Type); ORTHANC_PLUGINS_THROW_EXCEPTION(InternalError); } }