This file is indexed.

/usr/include/kml/engine/entity_mapper.h is in libkml-dev 1.3.0-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
 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
// Copyright 2008, Google 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:
//
//  1. Redistributions of source code must retain the above copyright notice,
//     this list of conditions and the following disclaimer.
//  2. 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.
//  3. Neither the name of Google 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 AUTHOR ``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 AUTHOR 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.

// This file contains the declatation of the EntityMapper class and the
// CreateExpandedEntities function.

#ifndef KML_ENGINE_ENTITY_MAPPER_H__
#define KML_ENGINE_ENTITY_MAPPER_H__

#include "kml/dom.h"
#include "kml/base/string_util.h"
#include "kml/engine/engine_types.h"
#include "kml/engine/kml_file.h"

namespace kmlengine {

// The EntityMapper walks through a given FeaturePtr in a given KmlFile
// and stores to the supplied StringMap any replacable entities and their
// replacement text. If a StringPairVector is supplied, it stores a mapping
// of any <ExtendedData> items and their values. (The utility of this latter
// is seen in Google Earth's behavior if asked to show the description balloon
// for a feature with <ExtendedData> but no <description>. It creates an
// HTML table of name-value pairs from the <ExtendedData> structure.)
//
// For an overview of how this is used within KML, see:
// http://code.google.com/apis/kml/documentation/kmlreference.html#text
// http://code.google.com/apis/kml/documentation/extendeddata.html
//
// Usage:
// kmlbase::StringMap your_entity_map;
// kmlbase::StringPairVector your_alt_text;
// EntityMapper entity_mapper(kml_file, &your_entity_map);
// entity_mapper.GetEntityFields(your_feature_ptr);
class EntityMapper {
 public:
  // Instantiate the class with a reference to a KmlFile object.
  // It is the caller's responsibility to ensure that the pointer to the
  // StringMap instance is not NULL.
  EntityMapper(const KmlFilePtr& kml_file, kmlbase::StringMap* string_map);

  // In addition to the string_map, this constructor also takes a pointer to
  // a StringPairVector which, if non-NULL, will be filled with a mapping
  // of name-value pairs of the ExtendedData items if present. This is
  // really a convenience to simulate the historical behavior of Google Earth
  // which, if given a Feature which has no <description> but does have
  // <ExtendedData>, will display a table of Data or SchemaData names together
  // with their values.
  EntityMapper(const KmlFilePtr& kml_file, kmlbase::StringMap* string_map,
               kmlbase::StringPairVector* alt_markup_map);

  ~EntityMapper();

  // Fills the StringMap supplied in the constructor with a mapping of all
  // replaceable entities in the given feature to their replacment text. The
  // StringMap is not modified in any way before being written into. If a
  // StringPairVector was supplied in the constructor, information from
  // any <ExtendedData> in the feature is stored there as described above. The
  // StringPairVector is not modified before writing. Note that this means
  // that this function is not idempotent if a StringPairVector has been
  // supplied; the StringMap will be overwritten, but the StringPairVector
  // will be created twice if this function is called twice.
  // It is the caller's responsibilty to ensure that the FeaturePtr exists
  // within the KmlFile from which the class was instantiated.
  void GetEntityFields(const kmldom::FeaturePtr& feature);

 private:
  void GatherObjectFields(const kmldom::FeaturePtr& feature);
  void GatherFeatureFields(const kmldom::FeaturePtr& feature);
  void GatherExtendedDataFields(const kmldom::FeaturePtr& feature);
  void GatherDataFields(const kmldom::DataPtr& feature);
  void GatherSchemaDataFields(const kmldom::SchemaDataPtr& feature);
  void GatherSimpleFieldFields(const kmldom::SimpleFieldPtr& simplefield,
                               const kmldom::SchemaPtr& schema);
  void GatherSimpleDataFields(const kmldom::SimpleDataPtr& simpledata);
  void PopulateSimpleFieldNameMap(const kmldom::SchemaPtr& schema);
  const KmlFilePtr kml_file_;
  kmlbase::StringMap* entity_map_;
  kmlbase::StringPairVector* alt_markup_map_;
  kmlbase::StringMap simplefield_name_map_;
  string schemadata_prefix_;
};

// Walks through the given string, replacing all keys in StringMap
// with the corresponding key value. The key strings are wrapped with the
// $[xxx] entity format before searching the string. Returns a new string with
// the replaced entities. The entity_map is typically built with the
// EntityMapper class declared in this file.
string CreateExpandedEntities(const string& in,
                              const kmlbase::StringMap& entity_map);

}  // end namespace kmlengine

#endif  // KML_ENGINE_ENTITY_MAPPER_H__