mirror of
https://github.com/openbabel/openbabel.git
synced 2025-02-25 18:55:23 -06:00
206 lines
6.2 KiB
OpenEdge ABL
206 lines
6.2 KiB
OpenEdge ABL
%module openbabel
|
|
|
|
%{
|
|
// used to set import/export for Cygwin DLLs
|
|
#ifdef WIN32
|
|
#define USING_OBDLL
|
|
#endif
|
|
|
|
|
|
#include <openbabel/obutil.h>
|
|
#include <openbabel/rand.h>
|
|
#include <openbabel/math/vector3.h>
|
|
#include <openbabel/math/matrix3x3.h>
|
|
#include <openbabel/generic.h>
|
|
|
|
#include <openbabel/base.h>
|
|
#include <openbabel/mol.h>
|
|
#include <openbabel/atom.h>
|
|
#include <openbabel/bond.h>
|
|
#include <openbabel/residue.h>
|
|
#include <openbabel/internalcoord.h>
|
|
|
|
#include <openbabel/ring.h>
|
|
#include <openbabel/obconversion.h>
|
|
#include <openbabel/oberror.h>
|
|
#include <openbabel/pluginiter.h>
|
|
#include <openbabel/fingerprint.h>
|
|
|
|
#include <openbabel/data.h>
|
|
#include <openbabel/parsmart.h>
|
|
%}
|
|
|
|
%include "std_list.i"
|
|
%include "std_map.i"
|
|
%include "std_vector.i"
|
|
%include "std_string.i"
|
|
|
|
namespace std {
|
|
%template (vectorInt) vector<int>;
|
|
%template (vectorUnsignedInt) vector<unsigned int>;
|
|
%template (vvInt) vector< vector<int> >;
|
|
%template (vectorDouble) vector<double>;
|
|
%template (vVector3) vector<OpenBabel::vector3>;
|
|
|
|
%template (vectorMol) vector<OpenBabel::OBMol>;
|
|
%template (vectorBond) vector<OpenBabel::OBBond>;
|
|
%template (vectorResidue) vector<OpenBabel::OBResidue>;
|
|
%template (vectorRing) vector<OpenBabel::OBRing>;
|
|
%template (vectorData) vector<OpenBabel::OBGenericData*>;
|
|
}
|
|
|
|
|
|
|
|
// These methods are renamed to valid Python method names, as otherwise
|
|
// they cannot be used from Python
|
|
%rename(inc) *::operator++;
|
|
%rename(good) *::operator bool;
|
|
%rename(deref) *::operator->;
|
|
%import <openbabel/babelconfig.h>
|
|
|
|
%include <openbabel/data.h>
|
|
%include <openbabel/rand.h>
|
|
%include <openbabel/obutil.h>
|
|
%include <openbabel/math/vector3.h>
|
|
%import <openbabel/math/matrix3x3.h>
|
|
%include <openbabel/generic.h>
|
|
|
|
%include <openbabel/base.h>
|
|
|
|
%import <openbabel/chains.h>
|
|
%import <openbabel/bitvec.h>
|
|
%import <openbabel/typer.h>
|
|
|
|
%include <openbabel/pluginiter.h>
|
|
%template (pluginiterFingerprint) OpenBabel::PluginIter<OpenBabel::OBFingerprint>;
|
|
|
|
%include <openbabel/oberror.h>
|
|
%include <openbabel/obconversion.h>
|
|
%include <openbabel/residue.h>
|
|
%include <openbabel/internalcoord.h>
|
|
%include <openbabel/atom.h>
|
|
%include <openbabel/bond.h>
|
|
%include <openbabel/mol.h>
|
|
%include <openbabel/ring.h>
|
|
%include <openbabel/parsmart.h>
|
|
|
|
%include <openbabel/fingerprint.h>
|
|
|
|
# The following %ignores avoid warning messages due to shadowed classes.
|
|
# This does not imply a loss of functionality as (in this case)
|
|
# the shadowed class is identical (from the point of view of SWIG) to
|
|
# the shadowing class.
|
|
# This is because C++ references (&) are transformed by SWIG back into
|
|
# pointers, so that OBAtomIter(OBMol &) would be treated the same as
|
|
# OBAtomIter(OBMol *).
|
|
|
|
%ignore OBAtomAtomIter(OBAtom &);
|
|
%ignore OBAtomBondIter(OBAtom &);
|
|
%ignore OBMolAngleIter(OBMol &);
|
|
%ignore OBMolAtomIter(OBMol &);
|
|
%ignore OBMolAtomBFSIter(OBMol &);
|
|
%ignore OBMolAtomDFSIter(OBMol &);
|
|
%ignore OBMolBondIter(OBMol &);
|
|
%ignore OBMolPairIter(OBMol &);
|
|
%ignore OBMolRingIter(OBMol &);
|
|
%ignore OBMolTorsionIter(OBMol &);
|
|
%ignore OBResidueIter(OBMol &);
|
|
%ignore OBResidueAtomIter(OBResidue &);
|
|
|
|
# These classes are renamed so that they can be replaced by Python
|
|
# classes of the same name which provide Pythonic iterators
|
|
# (see %pythoncode section below)
|
|
|
|
%rename(_OBAtomAtomIter) OpenBabel::OBAtomAtomIter;
|
|
%rename(_OBAtomBondIter) OpenBabel::OBAtomBondIter;
|
|
%rename(_OBMolAngleIter) OpenBabel::OBMolAngleIter;
|
|
%rename(_OBMolAtomIter) OpenBabel::OBMolAtomIter;
|
|
%rename(_OBMolAtomBFSIter) OpenBabel::OBMolAtomBFSIter;
|
|
%rename(_OBMolAtomDFSIter) OpenBabel::OBMolAtomDFSIter;
|
|
%rename(_OBMolBondIter) OpenBabel::OBMolBondIter;
|
|
%rename(_OBMolPairIter) OpenBabel::OBMolPairIter;
|
|
%rename(_OBMolRingIter) OpenBabel::OBMolRingIter;
|
|
%rename(_OBMolTorsionIter) OpenBabel::OBMolTorsionIter;
|
|
%rename(_OBResidueIter) OpenBabel::OBResidueIter;
|
|
%rename(_OBResidueAtomIter) OpenBabel::OBResidueAtomIter;
|
|
%rename(_OBFingerprintIter) OpenBabel::PluginIter<OBFingerprint>;
|
|
|
|
%ignore *::operator=;
|
|
|
|
%include <openbabel/obiter.h>
|
|
|
|
# The following class, OBiter, is subclassed to provide Python iterators
|
|
# equivalent to the C++ iterators in obiter.h and the plugin iterators
|
|
|
|
%pythoncode %{
|
|
class OBIter(object):
|
|
OBiterator = None # This is defined by the subclasses
|
|
|
|
def __init__(self, *params):
|
|
self.iter = self.OBiterator(*params)
|
|
self.finished = False
|
|
|
|
def __iter__(self):
|
|
return self
|
|
|
|
def next(self):
|
|
if not self.finished:
|
|
b = self.iter.deref()
|
|
self.iter.inc()
|
|
if not self.iter.good():
|
|
# There is nothing left to iterate over
|
|
self.finished = True
|
|
return b
|
|
else:
|
|
raise StopIteration
|
|
|
|
class OBAtomAtomIter(OBIter):
|
|
"""Iterator over the atoms attached to an atom."""
|
|
OBiterator = _OBAtomAtomIter
|
|
class OBAtomBondIter(OBIter):
|
|
"""Iterator over the bonds attached to an atom."""
|
|
OBiterator = _OBAtomBondIter
|
|
class OBMolAngleIter(OBIter):
|
|
"""Iterator over the angles in a molecule."""
|
|
OBiterator = _OBMolAngleIter
|
|
class OBMolAtomIter(OBIter):
|
|
"""Iterator over the atoms in a molecule."""
|
|
OBiterator = _OBMolAtomIter
|
|
class OBMolAtomBFSIter(OBIter):
|
|
"""Iterator over the atoms in a molecule in a breadth-first manner."""
|
|
OBiterator = _OBMolAtomBFSIter
|
|
class OBMolAtomDFSIter(OBIter):
|
|
"""Iterator over the atoms in a molecule in a depth-first manner."""
|
|
OBiterator = _OBMolAtomDFSIter
|
|
class OBMolBondIter(OBIter):
|
|
"""Iterator over the bonds in a molecule."""
|
|
OBiterator = _OBMolBondIter
|
|
class OBMolPairIter(OBIter):
|
|
"""Iterator over pairs of atoms in a molecule."""
|
|
OBiterator = _OBMolPairIter
|
|
class OBMolRingIter(OBIter):
|
|
"""Iterator over the rings in a molecule."""
|
|
OBiterator = _OBMolRingIter
|
|
class OBMolTorsionIter(OBIter):
|
|
"""Iterator over the torsion angles in a molecule."""
|
|
OBiterator = _OBMolTorsionIter
|
|
class OBResidueIter(OBIter):
|
|
"""Iterator over the residues in a molecule."""
|
|
OBiterator = _OBResidueIter
|
|
class OBResidueAtomIter(OBIter):
|
|
"""Iterator over the atoms in a residue."""
|
|
OBiterator = _OBResidueAtomIter
|
|
%}
|
|
|
|
%include "carrays.i"
|
|
%array_class(double, doubleArray)
|
|
%pythoncode %{
|
|
def double_array(mylist):
|
|
"""Create a C array of doubles from a list."""
|
|
c = doubleArray(len(mylist))
|
|
for i,v in enumerate(mylist):
|
|
c[i] = v
|
|
return c
|
|
%}
|
|
|