1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125
|
/*
A* -------------------------------------------------------------------
B* This file contains source code for the PyMOL computer program
C* copyright 1998-2006 by Warren Lyford Delano of DeLano Scientific.
D* -------------------------------------------------------------------
E* It is unlawful to modify or remove this copyright notice.
F* -------------------------------------------------------------------
G* Please see the accompanying LICENSE file for further information.
H* -------------------------------------------------------------------
I* Additional authors of this source file include:
-*
-*
-*
Z* -------------------------------------------------------------------
*/
#include"os_python.h"
#include"os_predef.h"
#include"os_std.h"
#include"os_gl.h"
#include"OOMac.h"
#include"ObjectGroup.h"
#include"Base.h"
#include"MemoryDebug.h"
#include"PConv.h"
int ObjectGroupNewFromPyList(PyMOLGlobals * G, PyObject * list, ObjectGroup ** result,
int version)
{
int ok = true, ll = 0;
ObjectGroup *I = NULL;
(*result) = NULL;
if(ok)
ok = (list != Py_None);
if(ok)
ok = PyList_Check(list);
if(ok)
ll = PyList_Size(list);
I = ObjectGroupNew(G);
if(ok)
ok = (I != NULL);
if(ok)
ok = ObjectFromPyList(G, PyList_GetItem(list, 0), &I->Obj);
if(ok)
ok = PConvPyIntToInt(PyList_GetItem(list, 1), &I->OpenOrClosed);
if(ok && (ll > 2))
ok = ObjectStateFromPyList(G, PyList_GetItem(list, 2), &I->State);
if(ok) {
*result = I;
} else {
/* to do: cleanup */
}
return (ok);
}
PyObject *ObjectGroupAsPyList(ObjectGroup * I)
{
PyObject *result = NULL;
result = PyList_New(3);
PyList_SetItem(result, 0, ObjectAsPyList(&I->Obj));
PyList_SetItem(result, 1, PyInt_FromLong(I->OpenOrClosed));
PyList_SetItem(result, 2, ObjectStateAsPyList(&I->State));
return (PConvAutoNone(result));
}
/*========================================================================*/
static void ObjectGroupFree(ObjectGroup * I)
{
ObjectStatePurge(&I->State);
ObjectPurge(&I->Obj);
OOFreeP(I);
}
/*========================================================================*/
static CObjectState *ObjectGroupGetObjectState(ObjectGroup * I, int state)
{
return &I->State;
}
/*========================================================================*/
ObjectGroup *ObjectGroupNew(PyMOLGlobals * G)
{
OOAlloc(G, ObjectGroup);
ObjectInit(G, (CObject *) I);
I->Obj.type = cObjectGroup;
I->Obj.fFree = (void (*)(CObject *)) ObjectGroupFree;
I->Obj.fRender = NULL;
I->OpenOrClosed = false;
I->Obj.fGetObjectState = (CObjectState * (*)(CObject *, int state))
ObjectGroupGetObjectState;
ObjectStateInit(G, &I->State);
return (I);
}
void ObjectGroupResetMatrix(ObjectGroup * I, int state)
{
ObjectStateResetMatrix(&I->State);
}
int ObjectGroupGetMatrix(ObjectGroup * I, int state, double **matrix)
{
*matrix = ObjectStateGetMatrix(&I->State);
return true;
}
int ObjectGroupSetMatrix(ObjectGroup * I, int state, double *matrix)
{
ObjectStateSetMatrix(&I->State, matrix);
return true;
}
void ObjectGroupTransformMatrix(ObjectGroup * I, int state, double *matrix)
{
ObjectStateTransformMatrix(&I->State, matrix);
}
|