* Fix compilation errors on Windows hopefully. Implemented the suggestion done
by Aphex - thanks. * Added the doc strings to the Object module. * Added more functionality to the Object module.
This commit is contained in:
		@@ -159,6 +159,8 @@ PyObject *M_Armature_Init (void)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  printf ("In M_Armature_Init()\n");
 | 
					  printf ("In M_Armature_Init()\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  Armature_Type.ob_type = &PyType_Type;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  submodule = Py_InitModule3("Blender.Armature",
 | 
					  submodule = Py_InitModule3("Blender.Armature",
 | 
				
			||||||
                             M_Armature_methods, M_Armature_doc);
 | 
					                             M_Armature_methods, M_Armature_doc);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -139,7 +139,7 @@ static int ArmaturePrint (C_Armature *armature, FILE *fp, int flags);
 | 
				
			|||||||
/*****************************************************************************/
 | 
					/*****************************************************************************/
 | 
				
			||||||
static PyTypeObject Armature_Type =
 | 
					static PyTypeObject Armature_Type =
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
  PyObject_HEAD_INIT(&PyType_Type)
 | 
					  PyObject_HEAD_INIT(NULL)
 | 
				
			||||||
  0,                                      /* ob_size */
 | 
					  0,                                      /* ob_size */
 | 
				
			||||||
  "Armature",                               /* tp_name */
 | 
					  "Armature",                               /* tp_name */
 | 
				
			||||||
  sizeof (C_Armature),                     /* tp_basicsize */
 | 
					  sizeof (C_Armature),                     /* tp_basicsize */
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1000,6 +1000,8 @@ static struct PyMethodDef BGL_methods[] = {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
PyObject *M_BGL_Init(void) 
 | 
					PyObject *M_BGL_Init(void) 
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
 | 
					  buffer_Type.ob_type = &PyType_Type;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  PyObject *mod= Py_InitModule("Blender.BGL", BGL_methods);
 | 
					  PyObject *mod= Py_InitModule("Blender.BGL", BGL_methods);
 | 
				
			||||||
  PyObject *dict= PyModule_GetDict(mod);
 | 
					  PyObject *dict= PyModule_GetDict(mod);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -136,7 +136,7 @@ static PyObject *Buffer_getattr(PyObject *self, char *name);
 | 
				
			|||||||
static PyObject *Buffer_repr(PyObject *self);
 | 
					static PyObject *Buffer_repr(PyObject *self);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
PyTypeObject buffer_Type = {
 | 
					PyTypeObject buffer_Type = {
 | 
				
			||||||
  PyObject_HEAD_INIT(&PyType_Type)
 | 
					  PyObject_HEAD_INIT(NULL)
 | 
				
			||||||
  0,                            /*ob_size*/
 | 
					  0,                            /*ob_size*/
 | 
				
			||||||
  "Buffer",                     /*tp_name*/
 | 
					  "Buffer",                     /*tp_name*/
 | 
				
			||||||
  sizeof(Buffer),               /*tp_basicsize*/
 | 
					  sizeof(Buffer),               /*tp_basicsize*/
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -148,7 +148,7 @@ static int BonePrint (C_Bone *bone, FILE *fp, int flags);
 | 
				
			|||||||
/*****************************************************************************/
 | 
					/*****************************************************************************/
 | 
				
			||||||
static PyTypeObject Bone_Type =
 | 
					static PyTypeObject Bone_Type =
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
  PyObject_HEAD_INIT(&PyType_Type)
 | 
					  PyObject_HEAD_INIT(NULL)
 | 
				
			||||||
  0,                                      /* ob_size */
 | 
					  0,                                      /* ob_size */
 | 
				
			||||||
  "Bone",                               /* tp_name */
 | 
					  "Bone",                               /* tp_name */
 | 
				
			||||||
  sizeof (C_Bone),                     /* tp_basicsize */
 | 
					  sizeof (C_Bone),                     /* tp_basicsize */
 | 
				
			||||||
@@ -224,6 +224,8 @@ PyObject *M_Bone_Init (void)
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
  PyObject  *submodule;
 | 
					  PyObject  *submodule;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  Bone_Type.ob_type = &PyType_Type;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  printf ("In M_Bone_Init()\n");
 | 
					  printf ("In M_Bone_Init()\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  submodule = Py_InitModule3("Blender.Armature.Bone",
 | 
					  submodule = Py_InitModule3("Blender.Armature.Bone",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -161,6 +161,9 @@ PyObject *M_Camera_Init (void)
 | 
				
			|||||||
  PyObject  *submodule;
 | 
					  PyObject  *submodule;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  printf ("In M_Camera_Init()\n");
 | 
					  printf ("In M_Camera_Init()\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  Camera_Type.ob_type = &PyType_Type;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  submodule = Py_InitModule3("Blender.Camera",
 | 
					  submodule = Py_InitModule3("Blender.Camera",
 | 
				
			||||||
                  M_Camera_methods, M_Camera_doc);
 | 
					                  M_Camera_methods, M_Camera_doc);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -203,7 +203,7 @@ int CameraCheckPyObject (PyObject *pyobj);
 | 
				
			|||||||
/*****************************************************************************/
 | 
					/*****************************************************************************/
 | 
				
			||||||
PyTypeObject Camera_Type =
 | 
					PyTypeObject Camera_Type =
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
  PyObject_HEAD_INIT(&PyType_Type)
 | 
					  PyObject_HEAD_INIT(NULL)
 | 
				
			||||||
  0,                                      /* ob_size */
 | 
					  0,                                      /* ob_size */
 | 
				
			||||||
  "Camera",                               /* tp_name */
 | 
					  "Camera",                               /* tp_name */
 | 
				
			||||||
  sizeof (C_Camera),                      /* tp_basicsize */
 | 
					  sizeof (C_Camera),                      /* tp_basicsize */
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -145,6 +145,9 @@ PyObject *M_Curve_Init (void)
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
  PyObject  *submodule;
 | 
					  PyObject  *submodule;
 | 
				
			||||||
  printf ("In M_Curve_Init()\n");
 | 
					  printf ("In M_Curve_Init()\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  Curve_Type.ob_type = &PyType_Type;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  submodule = Py_InitModule3("Blender.Curve",M_Curve_methods, M_Curve_doc);
 | 
					  submodule = Py_InitModule3("Blender.Curve",M_Curve_methods, M_Curve_doc);
 | 
				
			||||||
  return (submodule);
 | 
					  return (submodule);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -200,7 +200,7 @@ struct Curve* CurveFromPyObject (PyObject *py_obj);
 | 
				
			|||||||
/*****************************************************************************/
 | 
					/*****************************************************************************/
 | 
				
			||||||
static PyTypeObject Curve_Type =
 | 
					static PyTypeObject Curve_Type =
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
  PyObject_HEAD_INIT(&PyType_Type)
 | 
					  PyObject_HEAD_INIT(NULL)
 | 
				
			||||||
  0,                                      /* ob_size */
 | 
					  0,                                      /* ob_size */
 | 
				
			||||||
  "Curve",                               /* tp_name */
 | 
					  "Curve",                               /* tp_name */
 | 
				
			||||||
  sizeof (C_Curve),                      /* tp_basicsize */
 | 
					  sizeof (C_Curve),                      /* tp_basicsize */
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -637,6 +637,8 @@ PyObject *M_Draw_Init (void)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	printf("In M_Draw_Init()\n");
 | 
						printf("In M_Draw_Init()\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    Button_Type.ob_type = &PyType_Type;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	submodule = Py_InitModule3("Blender.Draw", Draw_methods, Draw_doc);
 | 
						submodule = Py_InitModule3("Blender.Draw", Draw_methods, Draw_doc);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	dict= PyModule_GetDict(submodule);
 | 
						dict= PyModule_GetDict(submodule);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -102,7 +102,7 @@ static PyObject *Button_repr(PyObject *self);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
PyTypeObject Button_Type =
 | 
					PyTypeObject Button_Type =
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	PyObject_HEAD_INIT(&PyType_Type)
 | 
						PyObject_HEAD_INIT(NULL)
 | 
				
			||||||
	0,								              /*ob_size*/
 | 
						0,								              /*ob_size*/
 | 
				
			||||||
	"Button",						            /*tp_name*/
 | 
						"Button",						            /*tp_name*/
 | 
				
			||||||
	sizeof(Button),					        /*tp_basicsize*/
 | 
						sizeof(Button),					        /*tp_basicsize*/
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -210,6 +210,8 @@ PyObject *M_Image_Init (void)
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
  PyObject  *submodule;
 | 
					  PyObject  *submodule;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  Image_Type.ob_type = &PyType_Type;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  submodule = Py_InitModule3("Blender.Image", M_Image_methods, M_Image_doc);
 | 
					  submodule = Py_InitModule3("Blender.Image", M_Image_methods, M_Image_doc);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  return (submodule);
 | 
					  return (submodule);
 | 
				
			||||||
@@ -261,7 +263,7 @@ static PyObject *Image_Repr (C_Image *self);
 | 
				
			|||||||
/*****************************************************************************/
 | 
					/*****************************************************************************/
 | 
				
			||||||
PyTypeObject Image_Type =
 | 
					PyTypeObject Image_Type =
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
  PyObject_HEAD_INIT(&PyType_Type)
 | 
					  PyObject_HEAD_INIT(NULL)
 | 
				
			||||||
  0,                                     /* ob_size */
 | 
					  0,                                     /* ob_size */
 | 
				
			||||||
  "Image",                               /* tp_name */
 | 
					  "Image",                               /* tp_name */
 | 
				
			||||||
  sizeof (C_Image),                      /* tp_basicsize */
 | 
					  sizeof (C_Image),                      /* tp_basicsize */
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -200,6 +200,8 @@ PyObject *M_Lamp_Init (void)
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
  PyObject  *submodule, *Types, *Modes;
 | 
					  PyObject  *submodule, *Types, *Modes;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  Lamp_Type.ob_type = &PyType_Type;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	Types = M_Lamp_TypesDict ();
 | 
						Types = M_Lamp_TypesDict ();
 | 
				
			||||||
	Modes = M_Lamp_ModesDict ();
 | 
						Modes = M_Lamp_ModesDict ();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -303,7 +303,7 @@ int LampCheckPyObject (PyObject *pyobj);
 | 
				
			|||||||
/*****************************************************************************/
 | 
					/*****************************************************************************/
 | 
				
			||||||
PyTypeObject Lamp_Type =
 | 
					PyTypeObject Lamp_Type =
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
  PyObject_HEAD_INIT(&PyType_Type)
 | 
					  PyObject_HEAD_INIT(NULL)
 | 
				
			||||||
  0,                                    /* ob_size */
 | 
					  0,                                    /* ob_size */
 | 
				
			||||||
  "Lamp",                               /* tp_name */
 | 
					  "Lamp",                               /* tp_name */
 | 
				
			||||||
  sizeof (C_Lamp),                      /* tp_basicsize */
 | 
					  sizeof (C_Lamp),                      /* tp_basicsize */
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -250,6 +250,8 @@ PyObject *M_Material_Init (void)
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
  PyObject  *submodule;
 | 
					  PyObject  *submodule;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  Material_Type.ob_type = &PyType_Type;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  submodule = Py_InitModule3("Blender.Material",
 | 
					  submodule = Py_InitModule3("Blender.Material",
 | 
				
			||||||
                  M_Material_methods, M_Material_doc);
 | 
					                  M_Material_methods, M_Material_doc);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -436,7 +438,7 @@ static PyObject *Material_Repr (C_Material *self);
 | 
				
			|||||||
/*****************************************************************************/
 | 
					/*****************************************************************************/
 | 
				
			||||||
PyTypeObject Material_Type =
 | 
					PyTypeObject Material_Type =
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
  PyObject_HEAD_INIT(&PyType_Type)
 | 
					  PyObject_HEAD_INIT(NULL)
 | 
				
			||||||
  0,                                      /* ob_size */
 | 
					  0,                                      /* ob_size */
 | 
				
			||||||
  "Material",                             /* tp_name */
 | 
					  "Material",                             /* tp_name */
 | 
				
			||||||
  sizeof (C_Material),                    /* tp_basicsize */
 | 
					  sizeof (C_Material),                    /* tp_basicsize */
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -110,7 +110,7 @@ PyObject *NMCol_repr(C_NMCol *self)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
PyTypeObject NMCol_Type =
 | 
					PyTypeObject NMCol_Type =
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
  PyObject_HEAD_INIT(&PyType_Type)
 | 
					  PyObject_HEAD_INIT(NULL)
 | 
				
			||||||
  0,                            /* ob_size */
 | 
					  0,                            /* ob_size */
 | 
				
			||||||
  "NMCol",                      /* tp_name */
 | 
					  "NMCol",                      /* tp_name */
 | 
				
			||||||
  sizeof(C_NMCol),              /* tp_basicsize */
 | 
					  sizeof(C_NMCol),              /* tp_basicsize */
 | 
				
			||||||
@@ -350,7 +350,7 @@ static PySequenceMethods NMFace_SeqMethods =
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
PyTypeObject NMFace_Type =
 | 
					PyTypeObject NMFace_Type =
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
  PyObject_HEAD_INIT(&PyType_Type)
 | 
					  PyObject_HEAD_INIT(NULL)
 | 
				
			||||||
  0,                            /*ob_size*/
 | 
					  0,                            /*ob_size*/
 | 
				
			||||||
  "NMFace",                     /*tp_name*/
 | 
					  "NMFace",                     /*tp_name*/
 | 
				
			||||||
  sizeof(C_NMFace),             /*tp_basicsize*/
 | 
					  sizeof(C_NMFace),             /*tp_basicsize*/
 | 
				
			||||||
@@ -521,7 +521,7 @@ static PySequenceMethods NMVert_SeqMethods =
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
PyTypeObject NMVert_Type =
 | 
					PyTypeObject NMVert_Type =
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
  PyObject_HEAD_INIT(&PyType_Type)
 | 
					  PyObject_HEAD_INIT(NULL)
 | 
				
			||||||
  0,                             /*ob_size*/
 | 
					  0,                             /*ob_size*/
 | 
				
			||||||
  "NMVert",                      /*tp_name*/
 | 
					  "NMVert",                      /*tp_name*/
 | 
				
			||||||
  sizeof(C_NMVert),              /*tp_basicsize*/
 | 
					  sizeof(C_NMVert),              /*tp_basicsize*/
 | 
				
			||||||
@@ -851,7 +851,7 @@ static int NMesh_setattr(PyObject *self, char *name, PyObject *v)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
PyTypeObject NMesh_Type =
 | 
					PyTypeObject NMesh_Type =
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
  PyObject_HEAD_INIT(&PyType_Type)
 | 
					  PyObject_HEAD_INIT(NULL)
 | 
				
			||||||
  0,                             /*ob_size*/
 | 
					  0,                             /*ob_size*/
 | 
				
			||||||
  "NMesh",                       /*tp_name*/
 | 
					  "NMesh",                       /*tp_name*/
 | 
				
			||||||
  sizeof(C_NMesh),               /*tp_basicsize*/
 | 
					  sizeof(C_NMesh),               /*tp_basicsize*/
 | 
				
			||||||
@@ -1667,6 +1667,11 @@ PyObject *M_NMesh_Init (void)
 | 
				
			|||||||
  PyObject *FaceModes = M_NMesh_FaceModesDict ();
 | 
					  PyObject *FaceModes = M_NMesh_FaceModesDict ();
 | 
				
			||||||
  PyObject *FaceTranspModes = M_NMesh_FaceTranspModesDict ();
 | 
					  PyObject *FaceTranspModes = M_NMesh_FaceTranspModesDict ();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  NMCol_Type.ob_type = &PyType_Type;
 | 
				
			||||||
 | 
					  NMFace_Type.ob_type = &PyType_Type;
 | 
				
			||||||
 | 
					  NMVert_Type.ob_type = &PyType_Type;
 | 
				
			||||||
 | 
					  NMesh_Type.ob_type = &PyType_Type;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	submodule = Py_InitModule3("Blender.NMesh", M_NMesh_methods, M_NMesh_doc);
 | 
						submodule = Py_InitModule3("Blender.NMesh", M_NMesh_methods, M_NMesh_doc);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (FaceFlags) PyModule_AddObject (submodule, "FaceFlags" , FaceFlags);
 | 
						if (FaceFlags) PyModule_AddObject (submodule, "FaceFlags" , FaceFlags);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -40,34 +40,42 @@ PyObject *M_Object_New(PyObject *self, PyObject *args)
 | 
				
			|||||||
    struct Object   * object;
 | 
					    struct Object   * object;
 | 
				
			||||||
    C_Object        * blen_object;
 | 
					    C_Object        * blen_object;
 | 
				
			||||||
    int               type;
 | 
					    int               type;
 | 
				
			||||||
    char              name[32];
 | 
					    char            * str_type;
 | 
				
			||||||
 | 
					    char            * name = NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    printf ("In Object_New()\n");
 | 
					    printf ("In Object_New()\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (!PyArg_ParseTuple(args, "i", &type))
 | 
					    if (!PyArg_ParseTuple(args, "s|s", &str_type, &name))
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        PythonReturnErrorObject (PyExc_TypeError,
 | 
					        PythonReturnErrorObject (PyExc_TypeError,
 | 
				
			||||||
                    "type expected");
 | 
					                    "string expected as argument");
 | 
				
			||||||
        return (NULL);
 | 
					        return (NULL);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /* Create a new object. */
 | 
					    if (strcmp (str_type, "Armature") == 0)     type = OB_ARMATURE;
 | 
				
			||||||
    switch (type)
 | 
					    else if (strcmp (str_type, "Camera") == 0)  type = OB_CAMERA;
 | 
				
			||||||
 | 
					    else if (strcmp (str_type, "Curve") == 0)   type = OB_CURVE;
 | 
				
			||||||
 | 
					/*    else if (strcmp (str_type, "Text") == 0)    type = OB_FONT; */
 | 
				
			||||||
 | 
					/*    else if (strcmp (str_type, "Ika") == 0)     type = OB_IKA; */
 | 
				
			||||||
 | 
					    else if (strcmp (str_type, "Lamp") == 0)    type = OB_LAMP;
 | 
				
			||||||
 | 
					/*    else if (strcmp (str_type, "Lattice") == 0) type = OB_LATTICE; */
 | 
				
			||||||
 | 
					/*    else if (strcmp (str_type, "Mball") == 0)   type = OB_MBALL; */
 | 
				
			||||||
 | 
					    else if (strcmp (str_type, "Mesh") == 0)    type = OB_MESH;
 | 
				
			||||||
 | 
					/*    else if (strcmp (str_type, "Surf") == 0)    type = OB_SURF; */
 | 
				
			||||||
 | 
					/*    else if (strcmp (str_type, "Wave") == 0)    type = OB_WAVE; */
 | 
				
			||||||
 | 
					    else if (strcmp (str_type, "Empty") == 0)   type = OB_EMPTY;
 | 
				
			||||||
 | 
					    else
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        case OB_MESH:       strcpy (name, "Mesh");      break;
 | 
					        return (PythonReturnErrorObject (PyExc_AttributeError,
 | 
				
			||||||
        case OB_CURVE:      strcpy (name, "Curve");     break;
 | 
					            "Unknown type specified"));
 | 
				
			||||||
        case OB_SURF:       strcpy (name, "Surf");      break;
 | 
					 | 
				
			||||||
        case OB_FONT:       strcpy (name, "Text");      break;
 | 
					 | 
				
			||||||
        case OB_MBALL:      strcpy (name, "Mball");     break;
 | 
					 | 
				
			||||||
        case OB_CAMERA:     strcpy (name, "Camera");    break;
 | 
					 | 
				
			||||||
        case OB_LAMP:       strcpy (name, "Lamp");      break;
 | 
					 | 
				
			||||||
        case OB_IKA:        strcpy (name, "Ika");       break;
 | 
					 | 
				
			||||||
        case OB_LATTICE:    strcpy (name, "Lattice");   break;
 | 
					 | 
				
			||||||
        case OB_WAVE:       strcpy (name, "Wave");      break;
 | 
					 | 
				
			||||||
        case OB_ARMATURE:   strcpy (name, "Armature");  break;
 | 
					 | 
				
			||||||
        default:            strcpy (name, "Empty");
 | 
					 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* Create a new object. */
 | 
				
			||||||
 | 
					    if (name == NULL)
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        /* No name is specified, set the name to the type of the object. */
 | 
				
			||||||
 | 
					        name = str_type;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
    object = alloc_libblock (&(G.main->object), ID_OB, name);
 | 
					    object = alloc_libblock (&(G.main->object), ID_OB, name);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    object->flag = 0;
 | 
					    object->flag = 0;
 | 
				
			||||||
@@ -123,23 +131,28 @@ PyObject *M_Object_New(PyObject *self, PyObject *args)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    switch(type)
 | 
					    switch(type)
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        case OB_MESH:
 | 
					        case OB_ARMATURE:
 | 
				
			||||||
            object->data = add_mesh();
 | 
					        /* TODO: Do we need to add something to G? (see the OB_LAMP case) */
 | 
				
			||||||
            G.totmesh++;
 | 
					            object->data = add_armature();
 | 
				
			||||||
            break;
 | 
					            break;
 | 
				
			||||||
        case OB_CAMERA:
 | 
					        case OB_CAMERA:
 | 
				
			||||||
 | 
					        /* TODO: Do we need to add something to G? (see the OB_LAMP case) */
 | 
				
			||||||
            object->data = add_camera();
 | 
					            object->data = add_camera();
 | 
				
			||||||
            break;
 | 
					            break;
 | 
				
			||||||
 | 
					        case OB_CURVE:
 | 
				
			||||||
 | 
					            object->data = add_curve(OB_CURVE);
 | 
				
			||||||
 | 
					            G.totcurve++;
 | 
				
			||||||
 | 
					            break;
 | 
				
			||||||
        case OB_LAMP:
 | 
					        case OB_LAMP:
 | 
				
			||||||
            object->data = add_lamp();
 | 
					            object->data = add_lamp();
 | 
				
			||||||
            G.totlamp++;
 | 
					            G.totlamp++;
 | 
				
			||||||
            break;
 | 
					            break;
 | 
				
			||||||
 | 
					        case OB_MESH:
 | 
				
			||||||
 | 
					            object->data = add_mesh();
 | 
				
			||||||
 | 
					            G.totmesh++;
 | 
				
			||||||
 | 
					            break;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /* TODO the following types will be supported later
 | 
					    /* TODO the following types will be supported later
 | 
				
			||||||
        case OB_CURVE:
 | 
					 | 
				
			||||||
            object->data = add_curve(OB_CURVE);
 | 
					 | 
				
			||||||
            G.totcurve++;
 | 
					 | 
				
			||||||
            break;
 | 
					 | 
				
			||||||
        case OB_SURF:
 | 
					        case OB_SURF:
 | 
				
			||||||
            object->data = add_curve(OB_SURF);
 | 
					            object->data = add_curve(OB_SURF);
 | 
				
			||||||
            G.totcurve++;
 | 
					            G.totcurve++;
 | 
				
			||||||
@@ -161,9 +174,6 @@ PyObject *M_Object_New(PyObject *self, PyObject *args)
 | 
				
			|||||||
        case OB_WAVE:
 | 
					        case OB_WAVE:
 | 
				
			||||||
            object->data = add_wave();
 | 
					            object->data = add_wave();
 | 
				
			||||||
            break;
 | 
					            break;
 | 
				
			||||||
        case OB_ARMATURE:
 | 
					 | 
				
			||||||
            object->data = add_armature();
 | 
					 | 
				
			||||||
            break;
 | 
					 | 
				
			||||||
    */
 | 
					    */
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -306,6 +316,8 @@ PyObject *M_Object_Init (void)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    printf ("In initObject()\n");
 | 
					    printf ("In initObject()\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    Object_Type.ob_type = &PyType_Type;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    module = Py_InitModule3("Object", M_Object_methods, M_Object_doc);
 | 
					    module = Py_InitModule3("Object", M_Object_methods, M_Object_doc);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    return (module);
 | 
					    return (module);
 | 
				
			||||||
@@ -370,6 +382,9 @@ static PyObject *Object_getData (C_Object *self)
 | 
				
			|||||||
    obj_id = MAKE_ID2 (id->name[0], id->name[1]);
 | 
					    obj_id = MAKE_ID2 (id->name[0], id->name[1]);
 | 
				
			||||||
    switch (obj_id)
 | 
					    switch (obj_id)
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
 | 
					        case ID_AR:
 | 
				
			||||||
 | 
					            data_object = M_ArmatureCreatePyObject (self->object->data);
 | 
				
			||||||
 | 
					            break;
 | 
				
			||||||
        case ID_CA:
 | 
					        case ID_CA:
 | 
				
			||||||
            data_object = Camera_createPyObject (self->object->data);
 | 
					            data_object = Camera_createPyObject (self->object->data);
 | 
				
			||||||
            break;
 | 
					            break;
 | 
				
			||||||
@@ -377,6 +392,7 @@ static PyObject *Object_getData (C_Object *self)
 | 
				
			|||||||
            data_object = CurveCreatePyObject (self->object->data);
 | 
					            data_object = CurveCreatePyObject (self->object->data);
 | 
				
			||||||
            break;
 | 
					            break;
 | 
				
			||||||
        case ID_IM:
 | 
					        case ID_IM:
 | 
				
			||||||
 | 
					            data_object = Image_CreatePyObject (self->object->data);
 | 
				
			||||||
            break;
 | 
					            break;
 | 
				
			||||||
        case ID_IP:
 | 
					        case ID_IP:
 | 
				
			||||||
            break;
 | 
					            break;
 | 
				
			||||||
@@ -432,21 +448,22 @@ static PyObject *Object_getDeltaLocation (C_Object *self)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
static PyObject *Object_getDrawMode (C_Object *self)
 | 
					static PyObject *Object_getDrawMode (C_Object *self)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    return (Py_None);
 | 
					    PyObject *attr = Py_BuildValue ("b", self->object->dtx);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (attr) return (attr);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return (PythonReturnErrorObject (PyExc_RuntimeError,
 | 
				
			||||||
 | 
					            "couldn't get Object.drawMode attribute"));
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static PyObject *Object_getDrawType (C_Object *self)
 | 
					static PyObject *Object_getDrawType (C_Object *self)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    /* TODO: this needs to be verified, if the api is correct! */
 | 
					 | 
				
			||||||
/*
 | 
					 | 
				
			||||||
    PyObject *attr = Py_BuildValue ("b", self->object->dt);
 | 
					    PyObject *attr = Py_BuildValue ("b", self->object->dt);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (attr) return (attr);
 | 
					    if (attr) return (attr);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    return (PythonReturnErrorObject (PyExc_RuntimeError,
 | 
					    return (PythonReturnErrorObject (PyExc_RuntimeError,
 | 
				
			||||||
            "couldn't get Object.drawType attribute"));
 | 
					            "couldn't get Object.drawType attribute"));
 | 
				
			||||||
*/
 | 
					 | 
				
			||||||
    return (Py_None);
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static PyObject *Object_getEuler (C_Object *self)
 | 
					static PyObject *Object_getEuler (C_Object *self)
 | 
				
			||||||
@@ -539,7 +556,22 @@ static PyObject *Object_getTracked (C_Object *self)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
static PyObject *Object_getType (C_Object *self)
 | 
					static PyObject *Object_getType (C_Object *self)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    return (Py_None);
 | 
					    switch (self->object->type)
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        case OB_ARMATURE:   return (Py_BuildValue ("s", "Armature"));
 | 
				
			||||||
 | 
					        case OB_CAMERA:     return (Py_BuildValue ("s", "Camera"));
 | 
				
			||||||
 | 
					        case OB_CURVE:      return (Py_BuildValue ("s", "Curve"));
 | 
				
			||||||
 | 
					        case OB_EMPTY:      return (Py_BuildValue ("s", "Empty"));
 | 
				
			||||||
 | 
					        case OB_FONT:       return (Py_BuildValue ("s", "Text"));
 | 
				
			||||||
 | 
					        case OB_IKA:        return (Py_BuildValue ("s", "Ika"));
 | 
				
			||||||
 | 
					        case OB_LAMP:       return (Py_BuildValue ("s", "Lamp"));
 | 
				
			||||||
 | 
					        case OB_LATTICE:    return (Py_BuildValue ("s", "Lattice"));
 | 
				
			||||||
 | 
					        case OB_MBALL:      return (Py_BuildValue ("s", "MBall"));
 | 
				
			||||||
 | 
					        case OB_MESH:       return (Py_BuildValue ("s", "Mesh"));
 | 
				
			||||||
 | 
					        case OB_SURF:       return (Py_BuildValue ("s", "Surf"));
 | 
				
			||||||
 | 
					        case OB_WAVE:       return (Py_BuildValue ("s", "Wave"));
 | 
				
			||||||
 | 
					        default:            return (Py_BuildValue ("s", "unknown"));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static PyObject *Object_link (C_Object *self, PyObject *args)
 | 
					static PyObject *Object_link (C_Object *self, PyObject *args)
 | 
				
			||||||
@@ -567,13 +599,6 @@ static PyObject *Object_link (C_Object *self, PyObject *args)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    switch (obj_id)
 | 
					    switch (obj_id)
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        case ID_ME:
 | 
					 | 
				
			||||||
            if (self->object->type != OB_MESH)
 | 
					 | 
				
			||||||
            {
 | 
					 | 
				
			||||||
                return (PythonReturnErrorObject (PyExc_AttributeError,
 | 
					 | 
				
			||||||
                    "The 'link' object is incompatible with the base object"));
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
            break;
 | 
					 | 
				
			||||||
        case ID_CA:
 | 
					        case ID_CA:
 | 
				
			||||||
            if (self->object->type != OB_CAMERA)
 | 
					            if (self->object->type != OB_CAMERA)
 | 
				
			||||||
            {
 | 
					            {
 | 
				
			||||||
@@ -588,6 +613,13 @@ static PyObject *Object_link (C_Object *self, PyObject *args)
 | 
				
			|||||||
                    "The 'link' object is incompatible with the base object"));
 | 
					                    "The 'link' object is incompatible with the base object"));
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
            break;
 | 
					            break;
 | 
				
			||||||
 | 
					        case ID_ME:
 | 
				
			||||||
 | 
					            if (self->object->type != OB_MESH)
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                return (PythonReturnErrorObject (PyExc_AttributeError,
 | 
				
			||||||
 | 
					                    "The 'link' object is incompatible with the base object"));
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            break;
 | 
				
			||||||
        default:
 | 
					        default:
 | 
				
			||||||
            return (PythonReturnErrorObject (PyExc_AttributeError,
 | 
					            return (PythonReturnErrorObject (PyExc_AttributeError,
 | 
				
			||||||
                "Linking this object type is not supported"));
 | 
					                "Linking this object type is not supported"));
 | 
				
			||||||
@@ -597,9 +629,9 @@ static PyObject *Object_link (C_Object *self, PyObject *args)
 | 
				
			|||||||
    id_us_plus (id);
 | 
					    id_us_plus (id);
 | 
				
			||||||
    if (oldid)
 | 
					    if (oldid)
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        if (id->us > 0)
 | 
					        if (oldid->us > 0)
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
            id->us--;
 | 
					            oldid->us--;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        else
 | 
					        else
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
@@ -694,7 +726,7 @@ static PyObject *Object_setDeltaLocation (C_Object *self, PyObject *args)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    if (!PyArg_Parse (args, "fff", &dloc1, &dloc2, &dloc3))
 | 
					    if (!PyArg_Parse (args, "fff", &dloc1, &dloc2, &dloc3))
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        return (PythonReturnErrorObject (PyExc_TypeError,
 | 
					        return (PythonReturnErrorObject (PyExc_AttributeError,
 | 
				
			||||||
                "expected three float arguments"));
 | 
					                "expected three float arguments"));
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -708,11 +740,31 @@ static PyObject *Object_setDeltaLocation (C_Object *self, PyObject *args)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
static PyObject *Object_setDrawMode (C_Object *self, PyObject *args)
 | 
					static PyObject *Object_setDrawMode (C_Object *self, PyObject *args)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
 | 
					    char    dt;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (!PyArg_Parse (args, "b", &dt))
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        return (PythonReturnErrorObject (PyExc_AttributeError,
 | 
				
			||||||
 | 
					                "expected an integer as argument"));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    self->object->dt = dt;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    Py_INCREF (Py_None);
 | 
				
			||||||
    return (Py_None);
 | 
					    return (Py_None);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static PyObject *Object_setDrawType (C_Object *self, PyObject *args)
 | 
					static PyObject *Object_setDrawType (C_Object *self, PyObject *args)
 | 
				
			||||||
{ 
 | 
					{ 
 | 
				
			||||||
 | 
					    char    dtx;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (!PyArg_Parse (args, "b", &dtx))
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        return (PythonReturnErrorObject (PyExc_AttributeError,
 | 
				
			||||||
 | 
					                "expected an integer as argument"));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    self->object->dtx = dtx;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    Py_INCREF (Py_None);
 | 
				
			||||||
    return (Py_None);
 | 
					    return (Py_None);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -724,7 +776,7 @@ static PyObject *Object_setEuler (C_Object *self, PyObject *args)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    if (!PyArg_Parse (args, "fff", &drot1, &drot2, &drot3))
 | 
					    if (!PyArg_Parse (args, "fff", &drot1, &drot2, &drot3))
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        return (PythonReturnErrorObject (PyExc_TypeError,
 | 
					        return (PythonReturnErrorObject (PyExc_AttributeError,
 | 
				
			||||||
                "expected three float arguments"));
 | 
					                "expected three float arguments"));
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -744,7 +796,7 @@ static PyObject *Object_setLocation (C_Object *self, PyObject *args)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    if (!PyArg_Parse (args, "fff", &loc1, &loc2, &loc3))
 | 
					    if (!PyArg_Parse (args, "fff", &loc1, &loc2, &loc3))
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        return (PythonReturnErrorObject (PyExc_TypeError,
 | 
					        return (PythonReturnErrorObject (PyExc_AttributeError,
 | 
				
			||||||
                "expected three float arguments"));
 | 
					                "expected three float arguments"));
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -758,11 +810,123 @@ static PyObject *Object_setLocation (C_Object *self, PyObject *args)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
static PyObject *Object_setMaterials (C_Object *self, PyObject *args)
 | 
					static PyObject *Object_setMaterials (C_Object *self, PyObject *args)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
 | 
					#if 0
 | 
				
			||||||
 | 
					    PyObject     * list;
 | 
				
			||||||
 | 
					    int            len;
 | 
				
			||||||
 | 
					    int            i;
 | 
				
			||||||
 | 
					    Material    ** matlist;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (!PyArg_Parse (args, "O", &list))
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        return (PythonReturnErrorObject (PyExc_AttributeError,
 | 
				
			||||||
 | 
					                "expected a list of materials as argument"));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    len = PySequence_Length (list);
 | 
				
			||||||
 | 
					    if (len > 0)
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        matlist = EXPP_newMaterialList_fromPyList (list);
 | 
				
			||||||
 | 
					        if (!matlist)
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					            return (PythonReturnErrorObject (PyExc_AttributeError,
 | 
				
			||||||
 | 
					                "material list must be a list of valid materials!"));
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if ((len < 0) || (len > MAXMAT))
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					            return (PythonReturnErrorObject (PyExc_RuntimeError,
 | 
				
			||||||
 | 
					                "illegal material index!"));
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (self->object->mat)
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					            /* TODO: create replacement function */
 | 
				
			||||||
 | 
					            releaseMaterialList (self->object->mat, len);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        /* Increase the user count on all materials */
 | 
				
			||||||
 | 
					        for (i=0 ; i<len ; i++)
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					            id_us_plus ((ID *) matlist[i]);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        self->object->mat = matlist;
 | 
				
			||||||
 | 
					        self->object->totcol = len;
 | 
				
			||||||
 | 
					        self->object->actcol = -1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        switch (self->object->type)
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					            case OB_CURVE:  /* fall through */
 | 
				
			||||||
 | 
					            case OB_FONT:   /* fall through */
 | 
				
			||||||
 | 
					            case OB_MESH:   /* fall through */
 | 
				
			||||||
 | 
					            case OB_MBALL:  /* fall through */
 | 
				
			||||||
 | 
					            case OB_SURF
 | 
				
			||||||
 | 
					                /* TODO: create replacement function */:
 | 
				
			||||||
 | 
					                synchronizeMaterialLists (self->object, self->object->data);
 | 
				
			||||||
 | 
					                break;
 | 
				
			||||||
 | 
					            default:
 | 
				
			||||||
 | 
					                break;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    Py_INCREF (Py_None);
 | 
				
			||||||
    return (Py_None);
 | 
					    return (Py_None);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static PyObject *Object_shareFrom (C_Object *self, PyObject *args)
 | 
					static PyObject *Object_shareFrom (C_Object *self, PyObject *args)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
 | 
					    C_Object        * object;
 | 
				
			||||||
 | 
					    ID              * id;
 | 
				
			||||||
 | 
					    ID              * oldid;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (!PyArg_Parse (args, "O", &object))
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        PythonReturnErrorObject (PyExc_AttributeError,
 | 
				
			||||||
 | 
					                "expected an object argument");
 | 
				
			||||||
 | 
					        return (NULL);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    if (!M_ObjectCheckPyObject ((PyObject*)object))
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        PythonReturnErrorObject (PyExc_TypeError,
 | 
				
			||||||
 | 
					                "argument 1 is not of type 'Object'");
 | 
				
			||||||
 | 
					        return (NULL);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (self->object->type != object->object->type)
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        PythonReturnErrorObject (PyExc_TypeError,
 | 
				
			||||||
 | 
					                "objects are not of same data type");
 | 
				
			||||||
 | 
					        return (NULL);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    switch (self->object->type)
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        case OB_MESH:
 | 
				
			||||||
 | 
					            oldid = (ID*) self->object->data;
 | 
				
			||||||
 | 
					            id = (ID*) object->data;
 | 
				
			||||||
 | 
					            self->object->data = object->data;
 | 
				
			||||||
 | 
					            if (self->data != NULL)
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                Py_DECREF (self->data);
 | 
				
			||||||
 | 
					                self->data = NULL;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            id_us_plus (id);
 | 
				
			||||||
 | 
					            if (oldid)
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                if (oldid->us > 0)
 | 
				
			||||||
 | 
					                {
 | 
				
			||||||
 | 
					                    oldid->us--;
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					                else
 | 
				
			||||||
 | 
					                {
 | 
				
			||||||
 | 
					                    return (PythonReturnErrorObject (PyExc_RuntimeError,
 | 
				
			||||||
 | 
					                            "old object reference count below 0"));
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            Py_INCREF (Py_None);
 | 
				
			||||||
 | 
					            return (Py_None);
 | 
				
			||||||
 | 
					        default:
 | 
				
			||||||
 | 
					            PythonReturnErrorObject (PyExc_TypeError,
 | 
				
			||||||
 | 
					                    "type not supported");
 | 
				
			||||||
 | 
					            return (NULL);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
    return (Py_None);
 | 
					    return (Py_None);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1081,9 +1245,19 @@ static int ObjectSetAttr (C_Object *obj, char *name, PyObject *value)
 | 
				
			|||||||
    if (StringEqual (name, "colbits"))
 | 
					    if (StringEqual (name, "colbits"))
 | 
				
			||||||
        return (!PyArg_Parse (value, "h", &(object->colbits)));
 | 
					        return (!PyArg_Parse (value, "h", &(object->colbits)));
 | 
				
			||||||
    if (StringEqual (name, "drawType"))
 | 
					    if (StringEqual (name, "drawType"))
 | 
				
			||||||
        return (!PyArg_Parse (value, "b", &(object->dt)));
 | 
					    {
 | 
				
			||||||
 | 
					        if (Object_setDrawType (obj, value) != Py_None)
 | 
				
			||||||
 | 
					            return (-1);
 | 
				
			||||||
 | 
					        else
 | 
				
			||||||
 | 
					            return (0);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
    if (StringEqual (name, "drawMode"))
 | 
					    if (StringEqual (name, "drawMode"))
 | 
				
			||||||
        return (!PyArg_Parse (value, "b", &(object->dtx)));
 | 
					    {
 | 
				
			||||||
 | 
					        if (Object_setDrawMode (obj, value) != Py_None)
 | 
				
			||||||
 | 
					            return (-1);
 | 
				
			||||||
 | 
					        else
 | 
				
			||||||
 | 
					            return (0);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    printf ("Unknown variable.\n");
 | 
					    printf ("Unknown variable.\n");
 | 
				
			||||||
    return (0);
 | 
					    return (0);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -36,6 +36,8 @@
 | 
				
			|||||||
#include <stdio.h>
 | 
					#include <stdio.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include <BDR_editobject.h>
 | 
					#include <BDR_editobject.h>
 | 
				
			||||||
 | 
					#include <BKE_armature.h>
 | 
				
			||||||
 | 
					#include <BKE_curve.h>
 | 
				
			||||||
#include <BKE_global.h>
 | 
					#include <BKE_global.h>
 | 
				
			||||||
#include <BKE_library.h>
 | 
					#include <BKE_library.h>
 | 
				
			||||||
#include <BKE_main.h>
 | 
					#include <BKE_main.h>
 | 
				
			||||||
@@ -44,6 +46,7 @@
 | 
				
			|||||||
#include <BKE_scene.h>
 | 
					#include <BKE_scene.h>
 | 
				
			||||||
#include <BLI_arithb.h>
 | 
					#include <BLI_arithb.h>
 | 
				
			||||||
#include <BLI_blenlib.h>
 | 
					#include <BLI_blenlib.h>
 | 
				
			||||||
 | 
					#include <DNA_armature_types.h>
 | 
				
			||||||
#include <DNA_ID.h>
 | 
					#include <DNA_ID.h>
 | 
				
			||||||
#include <DNA_ika_types.h>
 | 
					#include <DNA_ika_types.h>
 | 
				
			||||||
#include <DNA_listBase.h>
 | 
					#include <DNA_listBase.h>
 | 
				
			||||||
@@ -155,53 +158,73 @@ static PyObject *Object_shareFrom (C_Object *self, PyObject *args);
 | 
				
			|||||||
static PyMethodDef C_Object_methods[] = {
 | 
					static PyMethodDef C_Object_methods[] = {
 | 
				
			||||||
    /* name, method, flags, doc */
 | 
					    /* name, method, flags, doc */
 | 
				
			||||||
    {"clrParent",        (PyCFunction)Object_clrParent,        METH_VARARGS,
 | 
					    {"clrParent",        (PyCFunction)Object_clrParent,        METH_VARARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Clears parent object. Optionally specify:\n\
 | 
				
			||||||
 | 
					mode\n\t2: Keep object transform\nfast\n\t>0: Don't update scene \
 | 
				
			||||||
 | 
					hierarchy (faster)"},
 | 
				
			||||||
    {"getData",          (PyCFunction)Object_getData,          METH_NOARGS,
 | 
					    {"getData",          (PyCFunction)Object_getData,          METH_NOARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Returns the datablock object containing the object's data, \
 | 
				
			||||||
 | 
					e.g. Mesh"},
 | 
				
			||||||
    {"getDeformData",    (PyCFunction)Object_getDeformData,    METH_NOARGS,
 | 
					    {"getDeformData",    (PyCFunction)Object_getDeformData,    METH_NOARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Returns the datablock object containing the object's deformed \
 | 
				
			||||||
 | 
					data.\nCurrently, this is only supported for a Mesh"},
 | 
				
			||||||
    {"getDeltaLocation", (PyCFunction)Object_getDeltaLocation, METH_NOARGS,
 | 
					    {"getDeltaLocation", (PyCFunction)Object_getDeltaLocation, METH_NOARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Returns the object's delta location (x, y, z)"},
 | 
				
			||||||
    {"getDrawMode",      (PyCFunction)Object_getDrawMode,      METH_NOARGS,
 | 
					    {"getDrawMode",      (PyCFunction)Object_getDrawMode,      METH_NOARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Returns the object draw modes"},
 | 
				
			||||||
    {"getDrawType",      (PyCFunction)Object_getDrawType,      METH_NOARGS,
 | 
					    {"getDrawType",      (PyCFunction)Object_getDrawType,      METH_NOARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Returns the object draw type"},
 | 
				
			||||||
    {"getEuler",         (PyCFunction)Object_getEuler,         METH_NOARGS,
 | 
					    {"getEuler",         (PyCFunction)Object_getEuler,         METH_NOARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Returns the object's rotation as Euler rotation vector\n\
 | 
				
			||||||
 | 
					(rotX, rotY, rotZ)"},
 | 
				
			||||||
    {"getInverseMatrix", (PyCFunction)Object_getInverseMatrix, METH_NOARGS,
 | 
					    {"getInverseMatrix", (PyCFunction)Object_getInverseMatrix, METH_NOARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Returns the object's inverse matrix"},
 | 
				
			||||||
    {"getLocation",      (PyCFunction)Object_getLocation,      METH_VARARGS,
 | 
					    {"getLocation",      (PyCFunction)Object_getLocation,      METH_VARARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Returns the object's location (x, y, z)"},
 | 
				
			||||||
    {"getMaterials",     (PyCFunction)Object_getMaterials,     METH_NOARGS,
 | 
					    {"getMaterials",     (PyCFunction)Object_getMaterials,     METH_NOARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Returns list of materials assigned to the object"},
 | 
				
			||||||
    {"getMatrix",        (PyCFunction)Object_getMatrix,        METH_NOARGS,
 | 
					    {"getMatrix",        (PyCFunction)Object_getMatrix,        METH_NOARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Returns the object matrix"},
 | 
				
			||||||
    {"getParent",        (PyCFunction)Object_getParent,        METH_NOARGS,
 | 
					    {"getParent",        (PyCFunction)Object_getParent,        METH_NOARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Returns the object's parent object"},
 | 
				
			||||||
    {"getTracked",       (PyCFunction)Object_getTracked,       METH_NOARGS,
 | 
					    {"getTracked",       (PyCFunction)Object_getTracked,       METH_NOARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Returns the object's tracked object"},
 | 
				
			||||||
    {"getType",          (PyCFunction)Object_getType,          METH_NOARGS,
 | 
					    {"getType",          (PyCFunction)Object_getType,          METH_NOARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Returns type of string of Object"},
 | 
				
			||||||
    {"link",             (PyCFunction)Object_link,             METH_VARARGS,
 | 
					    {"link",             (PyCFunction)Object_link,             METH_VARARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Links Object with data provided in the argument. The data must \n\
 | 
				
			||||||
 | 
					match the Object's type, so you cannot link a Lamp to a Mesh type object."},
 | 
				
			||||||
    {"makeParent",       (PyCFunction)Object_makeParent,       METH_VARARGS,
 | 
					    {"makeParent",       (PyCFunction)Object_makeParent,       METH_VARARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Makes the object the parent of the objects provided in the \n\
 | 
				
			||||||
 | 
					argument which must be a list of valid Objects. Optional extra arguments:\n\
 | 
				
			||||||
 | 
					mode:\n\t0: make parent with inverse\n\t1: without inverse\n\
 | 
				
			||||||
 | 
					fase:\n\t0: update scene hierarchy automatically\n\t\
 | 
				
			||||||
 | 
					don't update scene hierarchy (faster). In this case, you must\n\t\
 | 
				
			||||||
 | 
					explicitely update the Scene hierarchy."},
 | 
				
			||||||
    {"materialUsage",    (PyCFunction)Object_materialUsage,    METH_VARARGS,
 | 
					    {"materialUsage",    (PyCFunction)Object_materialUsage,    METH_VARARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Determines the way the material is used and returs status.\n\
 | 
				
			||||||
 | 
					Possible arguments (provide as strings):\n\
 | 
				
			||||||
 | 
					\tData:   Materials assigned to the object's data are shown. (default)\n\
 | 
				
			||||||
 | 
					\tObject: Materials assigned to the object are shown."},
 | 
				
			||||||
    {"setDeltaLocation", (PyCFunction)Object_setDeltaLocation, METH_VARARGS,
 | 
					    {"setDeltaLocation", (PyCFunction)Object_setDeltaLocation, METH_VARARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Sets the object's delta location which must be a vector triple."},
 | 
				
			||||||
    {"setDrawMode",      (PyCFunction)Object_setDrawMode,      METH_VARARGS,
 | 
					    {"setDrawMode",      (PyCFunction)Object_setDrawMode,      METH_VARARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Sets the object's drawing mode. The argument can be a sum of:\n\
 | 
				
			||||||
 | 
					2:  axis\n4:  texspace\n8:  drawname\n16: drawimage\n32: drawwire"},
 | 
				
			||||||
    {"setDrawType",      (PyCFunction)Object_setDrawType,      METH_VARARGS,
 | 
					    {"setDrawType",      (PyCFunction)Object_setDrawType,      METH_VARARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Sets the object's drawing type. The argument must be one of:\n\
 | 
				
			||||||
 | 
					1: Bounding box\n2: Wire\n3: Solid\n4: Shaded\n5: Textured"},
 | 
				
			||||||
    {"setEuler",         (PyCFunction)Object_setEuler,         METH_VARARGS,
 | 
					    {"setEuler",         (PyCFunction)Object_setEuler,         METH_VARARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Set the object's rotation according to the specified Euler\n\
 | 
				
			||||||
 | 
					angles. The argument must be a vector triple"},
 | 
				
			||||||
    {"setLocation",      (PyCFunction)Object_setLocation,      METH_VARARGS,
 | 
					    {"setLocation",      (PyCFunction)Object_setLocation,      METH_VARARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Set the object's location. The first argument must be a vector\n\
 | 
				
			||||||
 | 
					triple."},
 | 
				
			||||||
    {"setMaterials",     (PyCFunction)Object_setMaterials,     METH_VARARGS,
 | 
					    {"setMaterials",     (PyCFunction)Object_setMaterials,     METH_VARARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Sets materials. The argument must be a list of valid material\n\
 | 
				
			||||||
 | 
					objects."},
 | 
				
			||||||
    {"shareFrom",        (PyCFunction)Object_shareFrom,        METH_VARARGS,
 | 
					    {"shareFrom",        (PyCFunction)Object_shareFrom,        METH_VARARGS,
 | 
				
			||||||
        "(x) - "},
 | 
					        "Link data of self with object specified in the argument. This\n\
 | 
				
			||||||
 | 
					works only if self and the object specified are of the same type."},
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*****************************************************************************/
 | 
					/*****************************************************************************/
 | 
				
			||||||
@@ -218,7 +241,7 @@ static PyObject* ObjectRepr    (C_Object *obj);
 | 
				
			|||||||
/*****************************************************************************/
 | 
					/*****************************************************************************/
 | 
				
			||||||
PyTypeObject Object_Type =
 | 
					PyTypeObject Object_Type =
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    PyObject_HEAD_INIT(&PyType_Type)
 | 
					    PyObject_HEAD_INIT(NULL)
 | 
				
			||||||
    0,                                /* ob_size */
 | 
					    0,                                /* ob_size */
 | 
				
			||||||
    "Object",                         /* tp_name */
 | 
					    "Object",                         /* tp_name */
 | 
				
			||||||
    sizeof (C_Object),                /* tp_basicsize */
 | 
					    sizeof (C_Object),                /* tp_basicsize */
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -207,6 +207,8 @@ PyObject *M_Text_Init (void)
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
  PyObject  *submodule;
 | 
					  PyObject  *submodule;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  Text_Type.ob_type = &PyType_Type;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  submodule = Py_InitModule3("Blender.Text", M_Text_methods, M_Text_doc);
 | 
					  submodule = Py_InitModule3("Blender.Text", M_Text_methods, M_Text_doc);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  return (submodule);
 | 
					  return (submodule);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -154,7 +154,7 @@ static PyObject *TextRepr (C_Text *self);
 | 
				
			|||||||
/*****************************************************************************/
 | 
					/*****************************************************************************/
 | 
				
			||||||
PyTypeObject Text_Type =
 | 
					PyTypeObject Text_Type =
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
  PyObject_HEAD_INIT(&PyType_Type)
 | 
					  PyObject_HEAD_INIT(NULL)
 | 
				
			||||||
  0,                                    /* ob_size */
 | 
					  0,                                    /* ob_size */
 | 
				
			||||||
  "Text",                               /* tp_name */
 | 
					  "Text",                               /* tp_name */
 | 
				
			||||||
  sizeof (C_Text),                      /* tp_basicsize */
 | 
					  sizeof (C_Text),                      /* tp_basicsize */
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -60,7 +60,7 @@ static PyMappingMethods constantAsMapping =
 | 
				
			|||||||
/*****************************************************************************/
 | 
					/*****************************************************************************/
 | 
				
			||||||
PyTypeObject constant_Type =
 | 
					PyTypeObject constant_Type =
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
  PyObject_HEAD_INIT(&PyType_Type)
 | 
					  PyObject_HEAD_INIT(NULL)
 | 
				
			||||||
  0,                                      /* ob_size */
 | 
					  0,                                      /* ob_size */
 | 
				
			||||||
  "constant",                             /* tp_name */
 | 
					  "constant",                             /* tp_name */
 | 
				
			||||||
  sizeof (C_constant),                    /* tp_basicsize */
 | 
					  sizeof (C_constant),                    /* tp_basicsize */
 | 
				
			||||||
@@ -97,6 +97,8 @@ static PyObject *new_const(void)
 | 
				
			|||||||
{ /* this is the static one */
 | 
					{ /* this is the static one */
 | 
				
			||||||
  C_constant *constant;
 | 
					  C_constant *constant;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  constant_Type.ob_type = &PyType_Type;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  printf ("In constant_New()\n");
 | 
					  printf ("In constant_New()\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  constant = (C_constant *)PyObject_NEW(C_constant, &constant_Type);
 | 
					  constant = (C_constant *)PyObject_NEW(C_constant, &constant_Type);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -89,9 +89,9 @@ int             CurveCheckPyObject  (PyObject *py_obj);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
/* Armature Data */
 | 
					/* Armature Data */
 | 
				
			||||||
PyObject *         M_Armature_Init (void);
 | 
					PyObject *         M_Armature_Init (void);
 | 
				
			||||||
PyObject *         ArtmatureCreatePyObject (bArmature *armature);
 | 
					PyObject *         M_ArmatureCreatePyObject (bArmature *armature);
 | 
				
			||||||
bArmature*         ArmatureFromPyObject   (PyObject *py_obj);
 | 
					bArmature*         M_ArmatureFromPyObject   (PyObject *py_obj);
 | 
				
			||||||
int                ArmatureCheckPyObject  (PyObject *py_obj);
 | 
					int                M_ArmatureCheckPyObject  (PyObject *py_obj);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Particle Effects Data */
 | 
					/* Particle Effects Data */
 | 
				
			||||||
/*PyObject *      M_Effect_Init (void);
 | 
					/*PyObject *      M_Effect_Init (void);
 | 
				
			||||||
@@ -102,8 +102,8 @@ int             EffectCheckPyObject (PyObject *py_obj);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
/* Image */
 | 
					/* Image */
 | 
				
			||||||
PyObject * M_Image_Init (void);
 | 
					PyObject * M_Image_Init (void);
 | 
				
			||||||
PyObject * ImageCreatePyObject (Image *image);
 | 
					PyObject * Image_CreatePyObject (Image *image);
 | 
				
			||||||
int        Image_checkPyObject (PyObject *pyobj);
 | 
					int        Image_CheckPyObject (PyObject *pyobj);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Init functions for other modules */
 | 
					/* Init functions for other modules */
 | 
				
			||||||
PyObject * M_Window_Init (void);
 | 
					PyObject * M_Window_Init (void);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -83,7 +83,7 @@ static PySequenceMethods rgbTupleAsSequence =
 | 
				
			|||||||
/*****************************************************************************/
 | 
					/*****************************************************************************/
 | 
				
			||||||
PyTypeObject rgbTuple_Type =
 | 
					PyTypeObject rgbTuple_Type =
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
  PyObject_HEAD_INIT(&PyType_Type)
 | 
					  PyObject_HEAD_INIT(NULL)
 | 
				
			||||||
  0,                                      /* ob_size */
 | 
					  0,                                      /* ob_size */
 | 
				
			||||||
  "rgbTuple",                             /* tp_name */
 | 
					  "rgbTuple",                             /* tp_name */
 | 
				
			||||||
  sizeof (C_rgbTuple),                    /* tp_basicsize */
 | 
					  sizeof (C_rgbTuple),                    /* tp_basicsize */
 | 
				
			||||||
@@ -115,6 +115,8 @@ PyObject *rgbTuple_New(float *rgb[3])
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  printf ("In rgbTuple_New()\n");
 | 
					  printf ("In rgbTuple_New()\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  rgbTuple_Type.ob_type = &PyType_Type;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  rgbTuple = (C_rgbTuple *)PyObject_NEW(C_rgbTuple, &rgbTuple_Type);
 | 
					  rgbTuple = (C_rgbTuple *)PyObject_NEW(C_rgbTuple, &rgbTuple_Type);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  if (rgbTuple == NULL)
 | 
					  if (rgbTuple == NULL)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -193,7 +193,7 @@ static PySequenceMethods Vector_SeqMethods =
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
PyTypeObject vector_Type =
 | 
					PyTypeObject vector_Type =
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	PyObject_HEAD_INIT(&PyType_Type)
 | 
						PyObject_HEAD_INIT(NULL)
 | 
				
			||||||
	0,								           /*ob_size*/
 | 
						0,								           /*ob_size*/
 | 
				
			||||||
	"Vector",						         /*tp_name*/
 | 
						"Vector",						         /*tp_name*/
 | 
				
			||||||
	sizeof(VectorObject),			   /*tp_basicsize*/
 | 
						sizeof(VectorObject),			   /*tp_basicsize*/
 | 
				
			||||||
@@ -213,6 +213,8 @@ PyObject *newVectorObject(float *vec, int size)
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
	VectorObject *self;
 | 
						VectorObject *self;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    vector_Type.ob_type = &PyType_Type;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	self= PyObject_NEW(VectorObject, &vector_Type);
 | 
						self= PyObject_NEW(VectorObject, &vector_Type);
 | 
				
			||||||
	
 | 
						
 | 
				
			||||||
	self->vec= vec;
 | 
						self->vec= vec;
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user