This file is indexed.

/usr/include/rdkit/GraphMol/ChemReactions/ReactionParser.h is in librdkit-dev 201309-1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 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
85
86
//
//  Copyright (c) 2007, Novartis Institutes for BioMedical Research Inc.
//  All rights reserved.
// 
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
// met: 
//
//     * Redistributions of source code must retain the above copyright 
//       notice, this list of conditions and the following disclaimer.
//     * Redistributions in binary form must reproduce the above
//       copyright notice, this list of conditions and the following 
//       disclaimer in the documentation and/or other materials provided 
//       with the distribution.
//     * Neither the name of Novartis Institutes for BioMedical Research Inc. 
//       nor the names of its contributors may be used to endorse or promote 
//       products derived from this software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
//

#ifndef __RD_REACTIONPARSER_H_21Aug2006__
#define __RD_REACTIONPARSER_H_21Aug2006__

#include <string>
#include <iostream>

namespace RDKit{
  class ChemicalReaction;
  
  //! used to indicate an error in parsing reaction data
  class ChemicalReactionParserException : public std::exception {
  public:
    //! construct with an error message
    explicit ChemicalReactionParserException(const char *msg) : _msg(msg) {};
    //! construct with an error message
    explicit ChemicalReactionParserException(const std::string msg) : _msg(msg) {};
    //! get the error message
    const char *message () const { return _msg.c_str(); };
    ~ChemicalReactionParserException () throw () {};
  private:
    std::string _msg;
  };
  
  
  
  //! Parse a text block in MDL rxn format into a ChemicalReaction 
  ChemicalReaction * RxnBlockToChemicalReaction(const std::string &rxnBlock);
  //! Parse a file in MDL rxn format into a ChemicalReaction 
  ChemicalReaction * RxnFileToChemicalReaction(const std::string &fileName);
  //! Parse a text stream in MDL rxn format into a ChemicalReaction 
  ChemicalReaction * RxnDataStreamToChemicalReaction(std::istream &rxnStream,
                                                     unsigned int &line);
  
  //! Parse a string containing "Reaction SMARTS" into a ChemicalReaction
  /*!
     Our definition of Reaction SMARTS is something that looks a lot like
     reaction SMILES, except that SMARTS queries are allowed on the reactant
     side and that atom-map numbers are required (at least for now)

     \param text          the SMARTS to convert
     \param replacements  a string->string map of replacement strings.
                          \see SmilesToMol for more information about replacements
   */ 
  ChemicalReaction * RxnSmartsToChemicalReaction(const std::string &text,
                                                 std::map<std::string,std::string> *replacements=0);

  //! returns the reaction SMARTS for a reaction
  std::string ChemicalReactionToRxnSmarts(ChemicalReaction &rxn);

  //! returns an RXN block for a reaction
  std::string ChemicalReactionToRxnBlock(const ChemicalReaction &rxn);
  
}; // end of RDKit namespace

#endif