[Python-checkins] python/dist/src/Mac/Modules/cm _Cmmodule.c,1.10,1.11 cmsupport.py,1.6,1.7
jackjansen@users.sourceforge.net
jackjansen@users.sourceforge.net
Fri, 29 Nov 2002 15:41:14 -0800
Update of /cvsroot/python/python/dist/src/Mac/Modules/cm
In directory sc8-pr-cvs1:/tmp/cvs-serv8673/cm
Modified Files:
_Cmmodule.c cmsupport.py
Log Message:
Converted the Carbon modules to use PEP252-style objects, with
descriptors in stead of manual getattr hooks to get at attributes
of the objects.
For Qd I have in stead gotten rid of most of the attribute access
in favor of the carbon-style accessor methods (with the exception
of visRgn, to be done later), and of the Carbon.Qd.qd global object,
for which accessor functions are also available.
For List I have fixed the fact that various methods were incorrectly
generated as functions.
CF is untouched: PEP252 doesn't allow "poor-mans-inheritance" with
basechain, so it will have to wait for PEP253 support.
Index: _Cmmodule.c
===================================================================
RCS file: /cvsroot/python/python/dist/src/Mac/Modules/cm/_Cmmodule.c,v
retrieving revision 1.10
retrieving revision 1.11
diff -C2 -d -r1.10 -r1.11
*** _Cmmodule.c 16 Aug 2002 09:09:19 -0000 1.10
--- _Cmmodule.c 29 Nov 2002 23:40:42 -0000 1.11
***************
*** 306,317 ****
};
! PyMethodChain CmpInstObj_chain = { CmpInstObj_methods, NULL };
!
! static PyObject *CmpInstObj_getattr(ComponentInstanceObject *self, char *name)
! {
! return Py_FindMethodInChain(&CmpInstObj_chain, (PyObject *)self, name);
! }
!
! #define CmpInstObj_setattr NULL
#define CmpInstObj_compare NULL
--- 306,310 ----
};
! #define CmpInstObj_getsetlist NULL
#define CmpInstObj_compare NULL
***************
*** 330,335 ****
(destructor) CmpInstObj_dealloc, /*tp_dealloc*/
0, /*tp_print*/
! (getattrfunc) CmpInstObj_getattr, /*tp_getattr*/
! (setattrfunc) CmpInstObj_setattr, /*tp_setattr*/
(cmpfunc) CmpInstObj_compare, /*tp_compare*/
(reprfunc) CmpInstObj_repr, /*tp_repr*/
--- 323,328 ----
(destructor) CmpInstObj_dealloc, /*tp_dealloc*/
0, /*tp_print*/
! (getattrfunc)0, /*tp_getattr*/
! (setattrfunc)0, /*tp_setattr*/
(cmpfunc) CmpInstObj_compare, /*tp_compare*/
(reprfunc) CmpInstObj_repr, /*tp_repr*/
***************
*** 338,341 ****
--- 331,351 ----
(PyMappingMethods *)0, /* tp_as_mapping */
(hashfunc) CmpInstObj_hash, /*tp_hash*/
+ 0, /*tp_call*/
+ 0, /*tp_str*/
+ PyObject_GenericGetAttr, /*tp_getattro*/
+ PyObject_GenericSetAttr, /*tp_setattro */
+ 0, /*outputHook_tp_as_buffer*/
+ 0, /*outputHook_tp_flags*/
+ 0, /*outputHook_tp_doc*/
+ 0, /*outputHook_tp_traverse*/
+ 0, /*outputHook_tp_clear*/
+ 0, /*outputHook_tp_richcompare*/
+ 0, /*outputHook_tp_weaklistoffset*/
+ 0, /*outputHook_tp_iter*/
+ 0, /*outputHook_tp_iternext*/
+ CmpInstObj_methods, /* tp_methods */
+ 0, /*outputHook_tp_members*/
+ CmpInstObj_getsetlist, /*tp_getset*/
+ 0, /*outputHook_tp_base*/
};
***************
*** 702,713 ****
};
! PyMethodChain CmpObj_chain = { CmpObj_methods, NULL };
!
! static PyObject *CmpObj_getattr(ComponentObject *self, char *name)
! {
! return Py_FindMethodInChain(&CmpObj_chain, (PyObject *)self, name);
! }
!
! #define CmpObj_setattr NULL
#define CmpObj_compare NULL
--- 712,716 ----
};
! #define CmpObj_getsetlist NULL
#define CmpObj_compare NULL
***************
*** 726,731 ****
(destructor) CmpObj_dealloc, /*tp_dealloc*/
0, /*tp_print*/
! (getattrfunc) CmpObj_getattr, /*tp_getattr*/
! (setattrfunc) CmpObj_setattr, /*tp_setattr*/
(cmpfunc) CmpObj_compare, /*tp_compare*/
(reprfunc) CmpObj_repr, /*tp_repr*/
--- 729,734 ----
(destructor) CmpObj_dealloc, /*tp_dealloc*/
0, /*tp_print*/
! (getattrfunc)0, /*tp_getattr*/
! (setattrfunc)0, /*tp_setattr*/
(cmpfunc) CmpObj_compare, /*tp_compare*/
(reprfunc) CmpObj_repr, /*tp_repr*/
***************
*** 734,737 ****
--- 737,757 ----
(PyMappingMethods *)0, /* tp_as_mapping */
(hashfunc) CmpObj_hash, /*tp_hash*/
+ 0, /*tp_call*/
+ 0, /*tp_str*/
+ PyObject_GenericGetAttr, /*tp_getattro*/
+ PyObject_GenericSetAttr, /*tp_setattro */
+ 0, /*outputHook_tp_as_buffer*/
+ 0, /*outputHook_tp_flags*/
+ 0, /*outputHook_tp_doc*/
+ 0, /*outputHook_tp_traverse*/
+ 0, /*outputHook_tp_clear*/
+ 0, /*outputHook_tp_richcompare*/
+ 0, /*outputHook_tp_weaklistoffset*/
+ 0, /*outputHook_tp_iter*/
+ 0, /*outputHook_tp_iternext*/
+ CmpObj_methods, /* tp_methods */
+ 0, /*outputHook_tp_members*/
+ CmpObj_getsetlist, /*tp_getset*/
+ 0, /*outputHook_tp_base*/
};
Index: cmsupport.py
===================================================================
RCS file: /cvsroot/python/python/dist/src/Mac/Modules/cm/cmsupport.py,v
retrieving revision 1.6
retrieving revision 1.7
diff -C2 -d -r1.6 -r1.7
*** cmsupport.py 25 Mar 2002 00:32:13 -0000 1.6
--- cmsupport.py 29 Nov 2002 23:40:42 -0000 1.7
***************
*** 80,84 ****
ComponentResourceHandle = OpaqueByValueType("ComponentResourceHandle", "ResObj")
! class MyCIObjectDefinition(GlobalObjectDefinition):
def outputCheckNewArg(self):
Output("""if (itself == NULL) {
--- 80,84 ----
ComponentResourceHandle = OpaqueByValueType("ComponentResourceHandle", "ResObj")
! class MyCIObjectDefinition(PEP252Mixin, GlobalObjectDefinition):
def outputCheckNewArg(self):
Output("""if (itself == NULL) {
***************
*** 87,91 ****
}""")
! class MyCObjectDefinition(GlobalObjectDefinition):
def outputCheckNewArg(self):
Output("""if (itself == NULL) {
--- 87,91 ----
}""")
! class MyCObjectDefinition(PEP252Mixin, GlobalObjectDefinition):
def outputCheckNewArg(self):
Output("""if (itself == NULL) {