1import sys
2import os
3
4import CDPL.Pharm as Pharm
5import CDPL.Chem as Chem
6
7
8# outputs all (available) properties of the features stored in the given feature container
9def outputFeatureProps(ph4: Pharm.FeatureContainer) -> None:
10 ftr_type_str = { Pharm.FeatureType.UNKNOWN : 'UNKNOWN',
11 Pharm.FeatureType.HYDROPHOBIC : 'HYDROPHOBIC',
12 Pharm.FeatureType.AROMATIC : 'AROMATIC',
13 Pharm.FeatureType.NEGATIVE_IONIZABLE : 'NEGATIVE_IONIZABLE',
14 Pharm.FeatureType.POSITIVE_IONIZABLE : 'POSITIVE_IONIZABLE',
15 Pharm.FeatureType.H_BOND_DONOR : 'H_BOND_DONOR',
16 Pharm.FeatureType.H_BOND_ACCEPTOR : 'H_BOND_ACCEPTOR',
17 Pharm.FeatureType.HALOGEN_BOND_DONOR : 'HALOGEN_BOND_DONOR',
18 Pharm.FeatureType.HALOGEN_BOND_ACCEPTOR : 'HALOGEN_BOND_ACCEPTOR',
19 Pharm.FeatureType.EXCLUSION_VOLUME : 'EXCLUSION_VOLUME' }
20
21 geom_str = { Pharm.FeatureGeometry.UNDEF : 'UNDEF',
22 Pharm.FeatureGeometry.SPHERE : 'SPHERE',
23 Pharm.FeatureGeometry.VECTOR : 'VECTOR',
24 Pharm.FeatureGeometry.PLANE : 'PLANE' }
25
26 print('Composition of pharmacophore \'%s\':' % Pharm.getName(ph4))
27
28 for i in range(0, len(ph4)):
29 ftr = ph4[i]
30
31 print(' - Feature #%s:' % str(i))
32 print(' - Type: %s' % ftr_type_str[Pharm.getType(ftr)])
33 print(' - Geometry: %s' % geom_str[Pharm.getGeometry(ftr)])
34 print(' - Tolerance: %s' % Pharm.getTolerance(ftr))
35 print(' - Weight: %s' % Pharm.getWeight(ftr))
36 print(' - Optional: %s' % Pharm.getOptionalFlag(ftr))
37 print(' - Disabled: %s' % Pharm.getDisabledFlag(ftr))
38 print(' - Length: %s' % Pharm.getLength(ftr))
39 print(' - Hydrophobicity: %s' % Pharm.getHydrophobicity(ftr))
40
41 if Chem.has3DCoordinates(ftr): # Pharm.Feature derives from Chem.Entity3D - therefore a function from the Chem package is used here!
42 print(' - Position: %s' % Chem.get3DCoordinates(ftr))
43
44 if Pharm.hasOrientation(ftr):
45 print(' - Orientation: %s' % Pharm.getOrientation(ftr))
46
47def main() -> None:
48 if len(sys.argv) < 2:
49 sys.exit('Usage: %s <input pharm. file>' % sys.argv[0])
50
51 # create reader for input pharmacophores (format specified by file extension)
52 reader = Pharm.PharmacophoreReader(sys.argv[1])
53
54 # create an instance of the default implementation of the Pharm.Pharmacophore interface
55 ph4 = Pharm.BasicPharmacophore()
56
57 # read and process pharmacophores one after the other until the end of input has been reached
58 try:
59 while reader.read(ph4):
60 try:
61 outputFeatureProps(ph4)
62 except Exception as e:
63 sys.exit('Error: processing of pharmacophore failed: ' + str(e))
64
65 except Exception as e: # handle exception raised in case of severe read errors
66 sys.exit('Error: reading pharmacophore failed: ' + str(e))
67
68 sys.exit(0)
69
70if __name__ == '__main__':
71 main()