This file is indexed.

/usr/include/osgEarthUtil/MGRSGraticule is in libosgearth-dev 2.9.0+dfsg-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
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
/* -*-c++-*- */
/* osgEarth - Dynamic map generation toolkit for OpenSceneGraph
 * Copyright 2016 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 OSGEARTHUTIL_MGRS_GRATICLE
#define OSGEARTHUTIL_MGRS_GRATICLE

#include <osgEarthUtil/Common>
#include <osgEarth/VisibleLayer>
#include <osgEarthSymbology/StyleSheet>
#include <osgEarthFeatures/Feature>
#include <osg/ClipPlane>


namespace osgEarth { namespace Util
{
    using namespace osgEarth;
    using namespace osgEarth::Features;
    using namespace osgEarth::Symbology;

    /**
     * Configuration options for the geodetic graticule.
     */
    class OSGEARTHUTIL_EXPORT MGRSGraticuleOptions : public VisibleLayerOptions
    {
    public:
        //! Construct an MGRS options structure
        MGRSGraticuleOptions(const ConfigOptions& conf =ConfigOptions());

        //! Location of the SQID feature data
        //! This is a prebuilt binary file that you should distribute 
        //! with the application - typically names "mgrs_sqid.bin"
        optional<URI>& sqidData() { return _sqidURI; }
        const optional<URI>& sqidData() const { return _sqidURI; }

        //! Styles for each display level. Each level should be names in the
        //! following manner:
        //! The top-level grid zone designator is called "gzd".
        //! Each consecutive level is a power of 10, starting with "100000"
        //! (for the SQID 100km grid) and going down from there (10000, 1000, etc.
        //! down to level 1).
        //! You can set only certain levels if you wish in order to override
        //! the defaults.
        osg::ref_ptr<StyleSheet>& styleSheet() { return _styleSheet; }
        const osg::ref_ptr<StyleSheet>& styleSheet() const { return _styleSheet; }

        //! Whether to apply default styles when you do not expressly
        //! set them for all levels. Defaults to true.
        optional<bool>& useDefaultStyles() { return _useDefaultStyles; }
        const optional<bool>& useDefaultStyles() const { return _useDefaultStyles; }

    public:
        virtual Config getConfig() const;

        virtual void fromConfig(const Config& conf);

    protected:
        void mergeConfig(const Config& conf) {
            VisibleLayerOptions::mergeConfig(conf);
            fromConfig(conf);
        }

        optional<URI> _sqidURI;
        osg::ref_ptr<StyleSheet> _styleSheet;
        optional<bool> _useDefaultStyles;
    };


    /**
     * Implements a MGRS (Military Grid Reference System) map graticule. 
     * 
     * NOTE: So far, this only works for geocentric maps.
     * TODO: Add projected support; add text label support
     */
    class OSGEARTHUTIL_EXPORT MGRSGraticule : public VisibleLayer
    {
    public:
        META_Layer(osgEarthUtil, MGRSGraticule, MGRSGraticuleOptions);

        //! Constructs a default graticule
        MGRSGraticule();

        /**
         * Constructs a new graticule for use with the specified map.
         *
         * @param options
         *      Optional "options" that configure the graticule. Defaults will be used
         *      if you don't specify this.
         */
        MGRSGraticule(const MGRSGraticuleOptions& options);

        /**
         * If you change any of the options, call this to refresh the display
         * to refelct the new settings.
         */
        void dirty();

    public: // Layer

        virtual void addedToMap(const Map* map);

        virtual void removedFromMap(const Map* map);
        
        virtual osg::Node* getOrCreateNode();

        virtual void init();

    protected:

        /** dtor */
        virtual ~MGRSGraticule() { }


    private:
        
        void setUpDefaultStyles();

        void rebuild();

        osg::ref_ptr<const Profile> _profile;

        osg::ref_ptr<FeatureProfile> _featureProfile;

        osg::ref_ptr<osg::ClipPlane> _clipPlane;

        osg::ref_ptr<osg::Group> _root;

        osg::observer_ptr<const Map> _map;

        void loadGZDFeatures(const SpatialReference* srs, FeatureList& output) const;

    };

} } // namespace osgEarth::Util

#endif // OSGEARTHUTIL_UTM_GRATICLE