%module python_nondynamic /* Use the %pythonnondynamic directuve to make the wrapped class a nondynamic one, ie, a python class that doesn't dynamically add new attributes. Hence, for the class %pythonnondynamic A; struct A { int a; int b; }; you will get: aa = A() aa.a = 1 # Ok aa.b = 1 # Ok aa.c = 3 # error Since "nondynamic" is a feature, if you use %pythonnondynamic; it will make all the wrapped class nondynamic ones. The implementation is based on the recipe: http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/252158 and works for modern (-modern) and plain python. */ %pythonnondynamic A; %pythondynamic C; %inline %{ struct A { int a; int b; }; struct C { int a; int b; }; %}