Files
rdkit/Code/GraphMol/Wrap/ChiralityOps.cpp
Greg Landrum c060e5de98 New version of AssignStereochemistry (#5442)
* bring over some new functionality

* adjust your expectations

* more tests

* additional cleanup and testing

* implement fix from #5407

* more testing

* a bit of optimization

* add the new func to the python wrappers

* cleanup

* findPossible working in the new code
NOTE: the combination of findPossible and cleanIt does not work and needs to be disallowed

* do some cleanup

* better handling of UNKNOWN (not unspecified) atoms and bonds

* update

* backup... we're close

* catch_chirality tests all pass

* all tests pass

* cleanup

* docs and a bit of optimization

* "optimization" which makes things slower... maybe revert this

* we don't need cleanExistingStereo() anymore... get rid of it

* cleanup

* changes in response to review
2022-09-06 12:53:02 +02:00

39 lines
1.2 KiB
C++

//
// Copyright (C) 2020-2022 Greg Landrum and T5 Informatics GmbH
//
// @@ All Rights Reserved @@
// This file is part of the RDKit.
// The contents are covered by the terms of the BSD license
// which is included in the file license.txt, found at the root
// of the RDKit source tree.
//
#include <RDBoost/python.h>
#include <string>
#include <GraphMol/RDKitBase.h>
#include <GraphMol/Chirality.h>
#include <RDBoost/Wrap.h>
namespace python = boost::python;
namespace RDKit {
struct chiralityops_wrapper {
static void wrap() {
RegisterVectorConverter<Chirality::StereoInfo>();
python::def(
"FindPotentialStereo",
(std::vector<Chirality::StereoInfo>(*)(ROMol &, bool, bool)) &
Chirality::findPotentialStereo,
(python::arg("mol"), python::arg("cleanIt") = false,
python::arg("flagPossible") = true),
"find potential stereo elements in a molecule and returns them as StereoInfo objects\n\
Note that this function is still somewhat experimental and the API\n\
and results may change in a future release.",
python::with_custodian_and_ward_postcall<0, 1>());
};
};
} // namespace RDKit
void wrap_chiralityops() { RDKit::chiralityops_wrapper::wrap(); }