This file is indexed.

/usr/include/openbabel-2.0/openbabel/alias.h is in libopenbabel-dev 2.3.2+dfsg-2.2build1.

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
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
/**********************************************************************
alias.h - OBGenericData class to hold alias information on atoms
Copyright (C) Copyright (C) 2007 by Chris Morley

This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation version 2 of the License.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.
***********************************************************************/

#ifndef OB_ALIAS_H
#define OB_ALIAS_H

#include <vector>
#include <openbabel/shared_ptr.h>
#include <openbabel/mol.h>

namespace OpenBabel
{
// This macro is used in DLL builds. If it has not
// been set in babelconfig.h, define it as nothing.
#ifndef OBCOMMON
  #define OBCOMMON
#endif

const unsigned int AliasDataType = 0x7883;

/** \class AliasData alias.h <openbabel/alias.h>
  \brief Indicate atoms as aliases for larger functional groups
  \since version 2.2

An object of this class can be attached to an OBAtom if it is considered
to be a placeholder for an alias, such as Ph, COOH, etc.

If the alias has not been interpreted chemically (expanded), the element type of the
placeholder atom should be set to Xx so that the molecule is not interpreted
incorrectly by formats which do not consider this class.

If the alias has been interpreted chemically (which formats, etc. should
normally do immediately), the alias may remain as extra
information or as a hint for an alternative representation, for example to
a chemical drawing program. The _expandedatoms vector would then contains
the ids of the atoms to which the alias is an alternative.
*/
class OBCOMMON AliasData : public OBGenericData
{
protected:
  std::string _alias;
  std::string _right_form;
  std::vector<unsigned long> _expandedatoms; //atom ids (not idxs)
  std::string _color;
public:

  AliasData(): OBGenericData("Alias", AliasDataType){ }

  virtual OBGenericData* Clone(OBBase* /*parent*/) const{return new AliasData(*this);}

  ///Add an alias
  void SetAlias(const std::string& alias) {_alias = alias;}
  void SetAlias(const char* alias) {_alias = alias;}

  /// /return value of alias or its version intended to be connected at its right hand end.
  std::string GetAlias(bool rightAligned = false) const;

  /// Return the color which has been assigned to this alias
  std::string GetColor() const { return _color; }

  /// Assign a color to this alias
  void SetColor(std::string color){ _color = color; }

  bool IsExpanded()const { return !_expandedatoms.empty(); }

  ///Converts all the expanded aliases in a molecule to the alias form.
  ///Note that this deletes atoms and bonds. Use only as a preparation for display.
  static void RevertToAliasForm(OBMol& mol);

  ///Interprets the alias text and adds atoms as appropriate to mol.
  bool Expand(OBMol& mol, const unsigned int atomindex);

 #ifdef HAVE_SHARED_POINTER
 ///Matches univalent fragments in the molecule and adds AliasData to provide an alternative representation.
  ///The molecule remains a respectable OBMol. Data in superatoms.txt decides what aliases are added.
  static bool AddAliases(OBMol* pmol);
 #endif

private:
  /// Interpret the alias as a formula
  bool FormulaParse(OBMol& mol, const unsigned atomindex);

  /// Add one of the atoms that can replace the alias
  void AddExpandedAtom(int id);

  /// Delete the atoms that replace the alias
  void DeleteExpandedAtoms(OBMol& mol);

  struct AliasItem
  {
    std::string right_form;
    std::string smiles;
    std::string color;
  };
  typedef std::map<std::string, AliasItem> SuperAtomTable; //key=alias left-form

  static bool LoadFile(SuperAtomTable& table);
  static SuperAtomTable& table()
  {
    static SuperAtomTable t;
    if(t.empty())
      LoadFile(t);
    return t;
  }
  bool        FromNameLookup(OBMol& mol, const unsigned int atomindex);
#ifdef HAVE_SHARED_POINTER
  typedef std::vector< std::pair<std::string, shared_ptr<OBSmartsPattern> > > SmartsTable;
  static bool LoadFile(SmartsTable& smtable);
#endif
};
} //namespace

#endif // OB_ALIAS_H

//! \file alias.h
//! \brief OBGenericData class to for atom alias data (e.g., in 2D drawing programs for "COOH")