/usr/include/osgEarthDrivers/kml/KML is in libosgearth-dev 2.4.0+dfsg-6.
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 | /* -*-c++-*- */
/* osgEarth - Dynamic map generation toolkit for OpenSceneGraph
* Copyright 2008-2013 Pelican Mapping
* http://osgearth.org
*
* osgEarth is free software; you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* 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 Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>
*/
#ifndef OSGEARTH_DRIVER_KML
#define OSGEARTH_DRIVER_KML 1
#include <osgEarth/MapNode>
#include <osgEarth/URI>
#include <osgEarth/Registry>
#include <osgDB/ReaderWriter>
#include <osgDB/FileNameUtils>
#include "KMLOptions"
namespace osgEarth { namespace Drivers
{
using namespace osgEarth;
class KML // header-only (no export)
{
public:
/**
* Loads KML or KMZ from a URI.
*
* @param[in ] uri URI from which to load the KML or KMZ
* @param[in ] mapNode MapNode to which to attach KML elements
* @param[in ] options Optional KML options
*/
static osg::Node* load(const URI& uri,
MapNode* mapNode,
const osgDB::Options* dbOptions,
const KMLOptions& kmlOptions)
{
if ( !mapNode ) {
OE_WARN << "[KML] " << "MapNode instance required" << std::endl;
return 0L;
}
osg::ref_ptr<osgDB::Options> options = Registry::instance()->cloneOrCreateOptions( dbOptions );
options->setPluginData( "osgEarth::MapNode", mapNode );
options->setPluginData( "osgEarth::KMLOptions", (void*)&kmlOptions );
// for a KMZ archive over HTTP, we need to go through OSG's archive management system
if ( osgDB::containsServerAddress(uri.full()) && osgDB::getLowerCaseFileExtension(uri.full()) == "kmz" )
{
return osgDB::readNodeFile( uri.full() + "/.kml", options.get() );
}
return uri.getNode( options.get() );
}
static osg::Node* load(const URI& uri,
MapNode* mapNode,
const KMLOptions& kmlOptions =KMLOptions() )
{
return load(uri, mapNode, 0L, kmlOptions);
}
};
} } // namespace osgEarth::Drivers
#endif // OSGEARTH_DRIVER_KML
|