This file is indexed.

/usr/include/pdal/io/LasVLR.hpp is in libpdal-dev 1.6.0-1build2.

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
/******************************************************************************
* Copyright (c) 2011, Michael P. Gerlek (mpg@flaxen.com)
*
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following
* conditions are met:
*
*     * Redistributions of source code must retain the above copyright
*       notice, this list of conditions and the following disclaimer.
*     * 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.
*     * Neither the name of Hobu, Inc. or Flaxen Geo Consulting 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 COPYRIGHT HOLDERS AND CONTRIBUTORS
* "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
* COPYRIGHT OWNER OR CONTRIBUTORS 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.
****************************************************************************/

#pragma once

#include <limits>
#include <string>
#include <vector>

#include <pdal/SpatialReference.hpp>
#include <pdal/util/IStream.hpp>
#include <pdal/util/OStream.hpp>

namespace pdal
{

static const int WKT_RECORD_ID = 2112;
static const uint16_t GEOTIFF_DIRECTORY_RECORD_ID = 34735;
static const uint16_t GEOTIFF_DOUBLES_RECORD_ID = 34736;
static const uint16_t GEOTIFF_ASCII_RECORD_ID = 34737;
static const uint16_t LASZIP_RECORD_ID = 22204;
static const uint16_t EXTRA_BYTES_RECORD_ID = 4;
static const uint16_t PDAL_METADATA_RECORD_ID = 12;
static const uint16_t PDAL_PIPELINE_RECORD_ID = 13;

static const char TRANSFORM_USER_ID[] = "LASF_Projection";
static const char SPEC_USER_ID[] = "LASF_Spec";
static const char LIBLAS_USER_ID[] = "liblas";
static const char LASZIP_USER_ID[] = "laszip encoded";
static const char PDAL_USER_ID[] = "PDAL";

class LasVLR;
typedef std::vector<LasVLR> VlrList;

class PDAL_DLL LasVLR
{
public:
    static const uint16_t MAX_DATA_SIZE;

    LasVLR(const std::string& userId, uint16_t recordId,
            const std::string& description, std::vector<uint8_t>& data) :
        m_userId(userId), m_recordId(recordId), m_description(description),
        m_data(std::move(data)), m_recordSig(0)
    {}
    LasVLR() : m_recordId(0), m_recordSig(0)
    {}

    std::string userId() const
        { return m_userId;}
    uint16_t recordId() const
        { return m_recordId; }
    std::string description() const
        { return m_description; }

    bool matches(const std::string& userId) const
        { return userId == m_userId; }
    bool matches(const std::string& userId, uint16_t recordId) const
        { return matches(userId) && (recordId == m_recordId); }

    const char* data() const
        { return (const char *)m_data.data(); }
    char* data()
        { return (char *)m_data.data(); }
    bool isEmpty() const
        { return m_data.size() == 0; }
    uint64_t dataLen() const
        { return m_data.size(); }
    void setDataLen(uint64_t size)
        { m_data.resize((size_t)size); }
    void write(OLeStream& out, uint16_t recordSig);

    friend ILeStream& operator>>(ILeStream& in, LasVLR& v);
    friend OLeStream& operator<<(OLeStream& out, const LasVLR& v);

protected:
    std::string m_userId;
    uint16_t m_recordId;
    std::string m_description;
    std::vector<uint8_t> m_data;
    uint16_t m_recordSig;
};

class ExtLasVLR : public LasVLR
{
public:
    ExtLasVLR(const std::string& userId, uint16_t recordId,
            const std::string& description, std::vector<uint8_t>& data) :
        LasVLR(userId, recordId, description, data)
    {}
    ExtLasVLR()
    {}

    friend ILeStream& operator>>(ILeStream& in, ExtLasVLR& v);
    friend OLeStream& operator<<(OLeStream& out,
        const ExtLasVLR& v);
};

} // namespace pdal