aboutsummaryrefslogtreecommitdiffstats
path: root/cppgenerator.cpp
diff options
context:
space:
mode:
authorHugo Parente Lima <hugo.pl@gmail.com>2010-07-01 16:15:47 -0300
committerHugo Parente Lima <hugo.pl@gmail.com>2010-07-01 16:50:01 -0300
commit7a726a6338e80bdfe9a4a926af29176012859f88 (patch)
tree07a83876a7ef67cb3955fbd9e8ab7a6314ef1402 /cppgenerator.cpp
parente4d8e78f5390b54338a1229f7e8d9c73a1930f1e (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.cpp12
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;