This file is indexed.

/usr/include/arc/message/MessageAttributes.h is in nordugrid-arc-dev 4.2.0-2.

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
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
// MessageAttributes.h

#ifndef __ARC_MESSAGE_ATTRIBUTES__
#define __ARC_MESSAGE_ATTRIBUTES__

#include <map>
#include <string>

namespace Arc {

  //! A typefed of a multimap for storage of message attributes.
  /*! This typedef is used as a shorthand for a multimap that uses
    strings for keys as well as values. It is used within the
    MesssageAttributes class for internal storage of message
    attributes, but is not visible externally.
  */
  typedef std::multimap<std::string,std::string> AttrMap;


  //! A typedef of a const_iterator for AttrMap.
  /*! This typedef is used as a shorthand for a const_iterator for
    AttrMap. It is used extensively within the MessageAttributes class
    as well as the AttributesIterator class, but is not visible
    externally.
   */
  typedef AttrMap::const_iterator AttrConstIter;


  //! A typedef of an (non-const) iterator for AttrMap.
  /*! This typedef is used as a shorthand for a (non-const) iterator
    for AttrMap. It is used in one method within the MessageAttributes
    class, but is not visible externally.
   */
  typedef AttrMap::iterator AttrIter;


  //! A const iterator class for accessing multiple values of an attribute.
  /*! This is an iterator class that is used when accessing multiple
    values of an attribute. The getAll() method of the
    MessageAttributes class returns an AttributeIterator object that
    can be used to access the values of the attribute.

    Typical usage is:
    \code
    MessageAttributes attributes;
    ...
    for (AttributeIterator iterator=attributes.getAll("Foo:Bar");
         iterator.hasMore(); ++iterator)
      std::cout << *iterator << std::endl;
    \endcode
   */
  class AttributeIterator {
  public:

    //! Default constructor.
    /*! The default constructor. Does nothing since all attributes are
      instances of well-behaving STL classes.
     */
    AttributeIterator();

    //! The dereference operator.
    /*! This operator is used to access the current value referred to
      by the iterator.
      \return A (constant reference to a) string representation of the
      current value.
     */
    const std::string& operator*() const;

    //! The arrow operator.
    /*! Used to call methods for value objects (strings) conveniently.
     */
    const std::string* operator->() const;

    //! The key of attribute.
    /*! This method returns reference to key of attribute to which
      iterator refers.
     */
    const std::string& key(void) const;

    //! The prefix advance operator.
    /*! Advances the iterator to the next value. Works intuitively.
      \return A const reference to this iterator.
     */
    const AttributeIterator& operator++();

    //! The postfix advance operator.
    /*! Advances the iterator to the next value. Works intuitively.
      \return An iterator referring to the value referred to by this
      iterator before the advance.
     */
    AttributeIterator operator++(int);

    //! Predicate method for iteration termination.
    /*! This method determines whether there are more values for the
      iterator to refer to.
      \return Returns true if there are more values, otherwise false.
     */
    bool hasMore() const;

  protected:

    //! Protected constructor used by the MessageAttributes class.
    /*! This constructor is used to create an iterator for iteration
      over all values of an attribute. It is not supposed to be
      visible externally, but is only used from within the getAll()
      method of MessageAttributes class.
      \param begin A const_iterator pointing to the first matching
      key-value pair in the internal multimap of the MessageAttributes
      class.
      \param end A const_iterator pointing to the first key-value pair
      in the internal multimap of the MessageAttributes class where
      the key is larger than the key searched for.
     */
    AttributeIterator(AttrConstIter begin, AttrConstIter end);

    //! A const_iterator pointing to the current key-value pair.
    /*! This iterator is the internal representation of the current
      value. It points to the corresponding key-value pair in the
      internal multimap of the MessageAttributes class.
    */
    AttrConstIter current_;

    //! A const_iterator pointing beyond the last key-value pair.
    /*! A const_iterator pointing to the first key-value pair in the
      internal multimap of the MessageAttributes class where the key
      is larger than the key searched for.
    */
    AttrConstIter end_;

    //! The MessageAttributes class is a friend.
    /*! The constructor that creates an AttributeIterator that is
      connected to the internal multimap of the MessageAttributes
      class should not be exposed to the outside, but it still needs
      to be accessible from the getAll() method of the
      MessageAttributes class. Therefore, that class is a friend.
     */
    friend class MessageAttributes;

  };


  //! A class for storage of attribute values.
  /*! This class is used to store attributes of messages. All
    attribute keys and their corresponding values are stored as
    strings. Any key or value that is not a string must thus be
    represented as a string during storage. Furthermore, an attribute
    is usually a key-value pair with a unique key, but there may also
    be multiple such pairs with equal keys.

    The key of an attribute is composed by the name of the Message
    Chain Component (MCC) which produce it and the name of the
    attribute itself with a colon (:) in between,
    i.e. MCC_Name:Attribute_Name. For example, the key of the
    "Content-Length" attribute of the HTTP MCC is thus
    "HTTP:Content-Length".

    There are also "global attributes", which may be produced by
    different MCCs depending on the configuration. The keys of such
    attributes are NOT prefixed by the name of the producing
    MCC. Before any new global attribute is introduced, it must be
    agreed upon by the core development team and added below. The
    global attributes decided so far are:
    \li \c Request-URI Identifies the service to which the message
    shall be sent. This attribute is produced by e.g. the HTTP MCC
    and used by the plexer for routing the message to the
    appropriate service.
    */
  class MessageAttributes {
  public:

    //! The default constructor.
    /*! This is the default constructor of the MessageAttributes
      class. It constructs an empty object that initially contains no
      attributes.
     */
    MessageAttributes();

    //! Sets a unique value of an attribute.
    /*! This method removes any previous value of an attribute and
      sets the new value as the only value.
      \param key The key of the attribute.
      \param value The (new) value of the attribute.
     */
    void set(const std::string& key, const std::string& value);

    //! Adds a value to an attribute.
    /*! This method adds a new value to an attribute. Any previous
      value will be preserved, i.e. the attribute may become multiple
      valued.
      \param key The key of the attribute.
      \param value The (new) value of the attribute.
     */
    void add(const std::string& key, const std::string& value);

    //! Removes all attributes with a certain key.
    /*! This method removes all attributes that match a certain key.
      \param key The key of the attributes to remove.
     */
    void removeAll(const std::string& key);

    //! Removes one value of an attribute.
    /*! This method removes a certain value from the attribute that
      matches a certain key.
      \param key The key of the attribute from which the value shall
      be removed.
      \param value The value to remove.
     */
    void remove(const std::string& key, const std::string& value);

    //! Returns the number of values of an attribute.
    /*! Returns the number of values of an attribute that matches a
      certain key.
      \param key The key of the attribute for which to count values.
      \return The number of values that corresponds to the key.
    */
    int count(const std::string& key) const;

    //! Returns the value of a single-valued attribute.
    /*! This method returns the value of a single-valued attribute. If
      the attribute is not single valued (i.e. there is no such
      attribute or it is a multiple-valued attribute) an empty string
      is returned.
      \param key The key of the attribute for which to return the
      value.
      \return The value of the attribute.
     */
    const std::string& get(const std::string& key) const;

    //! Access the value(s) of an attribute.
    /*! This method returns an AttributeIterator that can be used to
      access the values of an attribute.
      \param key The key of the attribute for which to return the
      values.
      \return An AttributeIterator for access of the values of the
      attribute.
     */    
    AttributeIterator getAll(const std::string& key) const;

    //! Access all value and attributes.
    AttributeIterator getAll(void) const;

  protected:

    //! Internal storage of attributes.
    /*! An AttrMap (multimap) in which all attributes (key-value
      pairs) are stored.
     */
    AttrMap attributes_;

  };

}

#endif