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
|
//
// Copyright (C) 2004-2006 Rational Discovery LLC
//
// @@ 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 <RDGeneral/export.h>
#ifndef __FEATUREPARSER_H_02122004_1810__
#define __FEATUREPARSER_H_02122004_1810__
#include <iostream>
#include <string>
#include <map>
#include <utility>
#include "MolChemicalFeatureDef.h"
namespace RDKit {
//! \brief class used to indicate errors in parsing feature definition
//! files.
class RDKIT_MOLCHEMICALFEATURES_EXPORT FeatureFileParseException
: public std::exception {
public:
FeatureFileParseException(unsigned int lineNo, std::string line,
std::string msg)
: d_lineNo(lineNo), d_line(std::move(line)), d_msg(std::move(msg)) {}
unsigned int lineNo() const { return d_lineNo; }
std::string line() const { return d_line; }
const char *what() const noexcept override { return d_msg.c_str(); }
~FeatureFileParseException() noexcept override = default;
private:
unsigned int d_lineNo;
std::string d_line, d_msg;
};
RDKIT_MOLCHEMICALFEATURES_EXPORT int parseFeatureData(
const std::string &defnText,
MolChemicalFeatureDef::CollectionType &featDefs);
RDKIT_MOLCHEMICALFEATURES_EXPORT int parseFeatureData(
std::istream &istream, MolChemicalFeatureDef::CollectionType &featDefs);
RDKIT_MOLCHEMICALFEATURES_EXPORT int parseFeatureFile(
const std::string &fileName,
MolChemicalFeatureDef::CollectionType &featDefs);
namespace Local {
// these functions are exposed only so they can be tested
RDKIT_MOLCHEMICALFEATURES_EXPORT void parseAtomType(
const std::string &inLine, std::map<std::string, std::string> &atomTypeDefs,
const unsigned int &lineNo);
RDKIT_MOLCHEMICALFEATURES_EXPORT MolChemicalFeatureDef *parseFeatureDef(
std::istream &inStream, const std::string &inLine, unsigned int &lineNo,
const std::map<std::string, std::string> &atomTypeDefs);
} // namespace Local
} // end of namespace RDKit
#endif
|