diff options
author | Hugo Parente Lima <hugo.pl@gmail.com> | 2010-07-01 16:15:47 -0300 |
---|---|---|
committer | Hugo Parente Lima <hugo.pl@gmail.com> | 2010-07-01 16:50:01 -0300 |
commit | 7a726a6338e80bdfe9a4a926af29176012859f88 (patch) | |
tree | 07a83876a7ef67cb3955fbd9e8ab7a6314ef1402 /cppgenerator.cpp | |
parent | e4d8e78f5390b54338a1229f7e8d9c73a1930f1e (diff) |
Do not write setters for const fields.
Reviewer: Luciano Wolf <luciano.wolf@openbossa.org>
Marcelo Lira <marcelo.lira@openbossa.org>
Diffstat (limited to 'cppgenerator.cpp')
-rw-r--r-- | cppgenerator.cpp | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/cppgenerator.cpp b/cppgenerator.cpp index 350795958..a9c9a8f65 100644 --- a/cppgenerator.cpp +++ b/cppgenerator.cpp @@ -330,16 +330,18 @@ void CppGenerator::generateClass(QTextStream &s, const AbstractMetaClass *metaCl if (shouldGenerateGetSetList(metaClass)) { foreach (const AbstractMetaField* metaField, metaClass->fields()) { writeGetterFunction(s, metaField); - writeSetterFunction(s, metaField); + if (!metaField->type()->isConstant()) + writeSetterFunction(s, metaField); s << endl; } s << "// Getters and Setters for " << metaClass->name() << endl; s << "static PyGetSetDef " << cpythonGettersSettersDefinitionName(metaClass) << "[] = {" << endl; foreach (const AbstractMetaField* metaField, metaClass->fields()) { + bool hasSetter = !metaField->type()->isConstant(); s << INDENT << "{const_cast<char*>(\"" << metaField->name() << "\"), "; - s << "(getter)" << cpythonGetterFunctionName(metaField); - s << ", (setter)" << cpythonSetterFunctionName(metaField); + s << cpythonGetterFunctionName(metaField); + s << ", " << (hasSetter ? cpythonSetterFunctionName(metaField) : "0"); s << "}," << endl; } s << INDENT << "{0} // Sentinel" << endl; @@ -2486,7 +2488,7 @@ void CppGenerator::writeTypeAsNumberDefinition(QTextStream& s, const AbstractMet void CppGenerator::writeGetterFunction(QTextStream& s, const AbstractMetaField* metaField) { - s << "static PyObject* " << cpythonGetterFunctionName(metaField) << "(SbkBaseWrapper* self)" << endl; + s << "static PyObject* " << cpythonGetterFunctionName(metaField) << "(PyObject* self, void*)" << endl; s << '{' << endl; s << INDENT << "return "; @@ -2504,7 +2506,7 @@ void CppGenerator::writeGetterFunction(QTextStream& s, const AbstractMetaField* void CppGenerator::writeSetterFunction(QTextStream& s, const AbstractMetaField* metaField) { - s << "static int " << cpythonSetterFunctionName(metaField) << "(SbkBaseWrapper* self, PyObject* value)" << endl; + s << "static int " << cpythonSetterFunctionName(metaField) << "(PyObject* self, PyObject* value, void*)" << endl; s << '{' << endl; s << INDENT << "if (value == 0) {" << endl; |