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
|
//
// Copyright (C) 2024 Novartis Biomedical Research and other RDKit contributors
//
// @@ 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.
//
#define USE_BETTER_ENUMS
#include <RDGeneral/BoostStartInclude.h>
#include <boost/property_tree/ptree.hpp>
#include <boost/property_tree/json_parser.hpp>
#include <RDGeneral/BoostEndInclude.h>
#include "SmilesJSONParsers.h"
namespace RDKit {
void updateSmilesWriteParamsFromJSON(SmilesWriteParams ¶ms,
const char *details_json) {
if (details_json && strlen(details_json)) {
boost::property_tree::ptree pt;
std::istringstream ss;
ss.str(details_json);
boost::property_tree::read_json(ss, pt);
params.doIsomericSmiles =
pt.get("doIsomericSmiles", params.doIsomericSmiles);
params.doKekule = pt.get("doKekule", params.doKekule);
params.rootedAtAtom = pt.get("rootedAtAtom", params.rootedAtAtom);
params.canonical = pt.get("canonical", params.canonical);
params.allBondsExplicit =
pt.get("allBondsExplicit", params.allBondsExplicit);
params.allHsExplicit = pt.get("allHsExplicit", params.allHsExplicit);
params.doRandom = pt.get("doRandom", params.doRandom);
}
}
void updateSmilesWriteParamsFromJSON(SmilesWriteParams ¶ms,
const std::string &details_json) {
updateSmilesWriteParamsFromJSON(params, details_json.c_str());
}
void updateCXSmilesFieldsFromJSON(std::uint32_t &cxSmilesFields,
unsigned int &restoreBondDirs,
const char *details_json) {
if (details_json && strlen(details_json)) {
boost::property_tree::ptree pt;
std::istringstream ss;
ss.str(details_json);
boost::property_tree::read_json(ss, pt);
auto cxSmilesFieldsFromJson =
(+SmilesWrite::CXSmilesFields::CX_NONE)._to_integral();
bool haveCXSmilesFields = false;
for (const auto *key : SmilesWrite::CXSmilesFields::_names()) {
const auto it = pt.find(key);
if (it != pt.not_found()) {
haveCXSmilesFields = true;
if (it->second.get_value<bool>()) {
cxSmilesFieldsFromJson |=
SmilesWrite::CXSmilesFields::_from_string(key)._to_integral();
}
}
}
if (haveCXSmilesFields) {
cxSmilesFields = cxSmilesFieldsFromJson;
}
std::string restoreBondDirOption;
restoreBondDirOption = pt.get("restoreBondDirOption", restoreBondDirOption);
if (RestoreBondDirOption::_is_valid(restoreBondDirOption.c_str())) {
restoreBondDirs =
RestoreBondDirOption::_from_string(restoreBondDirOption.c_str());
}
}
}
void updateCXSmilesFieldsFromJSON(std::uint32_t &cxSmilesFields,
unsigned int &restoreBondDirs,
const std::string &details_json) {
updateCXSmilesFieldsFromJSON(cxSmilesFields, restoreBondDirs,
details_json.c_str());
}
} // end namespace RDKit
|