File: BondTypeHistory.cpp

package info (click to toggle)
pymol 2.4.0%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 43,312 kB
  • sloc: cpp: 480,106; python: 79,860; ansic: 28,343; javascript: 6,792; sh: 47; makefile: 30; csh: 8
file content (73 lines) | stat: -rw-r--r-- 2,133 bytes parent folder | download
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

/*
 * (c) Schrodinger, Inc.
 */

#include"BondTypeHistory.h"
#include"MemoryDebug.h"

#define COPY_ATTR(attr_name) dest->attr_name = src->attr_name
#define COPY_ATTR_ARR_2(attr_name) dest->attr_name[0] = src->attr_name[0]; dest->attr_name[1] = src->attr_name[1]
#define COPY_ATTR_N(attr_name, N) memcpy( dest->attr_name, src->attr_name, N)

template <typename fromVersion, typename toVersion>
void Copy_BondType(const fromVersion *src,  toVersion *dest){
  COPY_ATTR(index[0]);
  COPY_ATTR(index[1]);
  COPY_ATTR(order);
  COPY_ATTR(id);
  COPY_ATTR(unique_id);
  COPY_ATTR(stereo);
  COPY_ATTR(has_setting);
}

template <typename fromVersion, typename toVersion>
void CopyN_BondType(const fromVersion *src,  toVersion *dest, int NBond){
  for (int a = 0; a < NBond; ++a){
    Copy_BondType(src++, dest++);
  }
}

template <typename toVersion>
toVersion *CreateAndCopyN_BondType(const BondType *src, int NBond){
  toVersion *dest = VLACalloc(toVersion, NBond);
  toVersion *origdest = dest;
  for (int a = 0; a < NBond; ++a){
    Copy_BondType(src++, dest++);
  }
  return origdest;
}

void Copy_Into_BondType_From_Version(const void *src, int bondInfo_version, BondType *Bond, int NBond){
  switch(bondInfo_version){
  case 176:
    CopyN_BondType((BondType_1_7_6*)src, Bond, NBond);
    break;
  case 177:
    CopyN_BondType((BondType_1_7_7*)src, Bond, NBond);
    break;
  case 181:
    CopyN_BondType((BondType_1_8_1*)src, Bond, NBond);
    break;
  default:
      printf("ERROR: unknown bondInfo_version=%d from BondInfoVERSION=%d\n", bondInfo_version, BondInfoVERSION);
  }
}

void *Copy_To_BondType_Version(int bondInfo_version, BondType *Bond, int NBond){
  switch (bondInfo_version){
  case 176:
    return CreateAndCopyN_BondType<BondType_1_7_6>(Bond, NBond);
    break;
  case 177:
    return CreateAndCopyN_BondType<BondType_1_7_7>(Bond, NBond);
    break;
  case 181:
    return CreateAndCopyN_BondType<BondType_1_8_1>(Bond, NBond);
    break;
  default:
      printf("ERROR: Copy_To_BondType_Version: unknown bondInfo_version=%d from BondInfoVERSION=%d\n", bondInfo_version, BondInfoVERSION);
  }
  return nullptr;

}