This file is indexed.

/usr/lib/python2.7/dist-packages/liblas/vlr.py is in python-liblas 1.8.1-6build1.

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
"""
/******************************************************************************
 * $Id$
 *
 * Project:  libLAS - http://liblas.org - A BSD library for LAS format data.
 * Purpose:  Python VLR implementation
  * Author:   Howard Butler, hobu.inc@gmail.com
 *
 ******************************************************************************
 * Copyright (c) 2009, Howard Butler
 *
 * 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 the Martin Isenburg or Iowa Department
 *       of Natural Resources 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.
 ****************************************************************************/
 """

from . import core
import ctypes


class VLR(object):
    def __init__(self, owned=True, handle=None):
        """
        :keyword owned: flag to denote whether or not the VLR owns itself.  \
                        If it is owned, the underlying C object will be \
                        destroyed once it goes out of scope.
        :keyword handle: raw ctypes object

        From the specification_:

            The Public Header Block is followed by one or more Variable Length
            Records (There is one mandatory Variable Length Record,
            GeoKeyDirectoryTag). The number of Variable Length Records is
            specified in the "Number of Variable Length Records"
            (:obj:`liblas.header.Header.records_count`) field in the Public
            Header Block. The Variable Length Records must be accessed
            sequentially since the size of each variable length record is
            contained in the Variable Length Record Header. Each Variable
            Length Record Header is 60 bytes in length.

        >>> from liblas import vlr
        >>> v = vlr.VLR()
        >>> v.reserved
        0
        >>> v.recordid
        0
        >>> v.recordid = 2
        >>> v.recordid
        2
        >>> v.userid
        ''
        >>> v.userid = 'liblas.org'
        >>> v.userid
        'liblas.org'

        >>> v.description
        ''
        >>> v.description = 'libLAS'
        >>> v.description
        'libLAS'

        """
        if handle:
            self.handle = handle
        else:
            self.handle = core.las.LASVLR_Create()
        self.owned = owned

    def __del__(self):
        if self.owned:
            if self.handle and core:
                core.las.LASVLR_Destroy(self.handle)

    def get_userid(self):
        return core.las.LASVLR_GetUserId(self.handle)

    def set_userid(self, value):
        return core.las.LASVLR_SetUserId(self.handle, value)
    doc = """User ID key for this VLR (clipped to 16 bytes long)
    
    The User ID for libLAS is ``liblas``, and it will be used 
    for all extra VLRs that libLAS itself can interpret.  
    
    .. seealso::
        :ref:`liblas_vlr_key` has more detail on the key and name.
        
    From the specification_:
        The User ID field is ASCII character data that identifies the user
        which created the variable length record. It is possible to have many
        Variable Length Records from different sources with different User
        IDs. If the character data is less than 16 characters, the remaining
        data must be null. The User ID must be registered with the LAS
        specification managing body. The management of these User IDs ensures
        that no two individuals accidentally use the same User ID. The
        specification will initially use two IDs: one for globally specified
        records (LASF_Spec), and another for projection types
        (LASF_Projection). Keys may be requested at
        http://www.asprs.org/lasform/keyform.html
        
    """
    userid = property(get_userid, set_userid, None, doc)
    user = userid

    def get_description(self):
        return core.las.LASVLR_GetDescription(self.handle)

    def set_description(self, value):
        return core.las.LASVLR_SetDescription(self.handle, value)
    doc = """Description of this VLR instance (clipped to 32 bytes long)

    From the specification_:
        Optional, null terminated text description of the data. Any remaining
        characters not used must be null.
    """
    description = property(get_description, set_description, None, doc)

    def get_recordlength(self):
        return core.las.LASVLR_GetRecordLength(self.handle)

    def set_recordlength(self, value):
        return core.las.LASVLR_SetRecordLength(self.handle, value)
    doc = """The number of bytes long the VLR is"""
    recordlength = property(get_recordlength, set_recordlength, None, doc)
    
    def __len__(self):
        return self.recordlength
        
    def get_recordid(self):
        return core.las.LASVLR_GetRecordId(self.handle)

    def set_recordid(self, value):
        return core.las.LASVLR_SetRecordId(self.handle, value)
    doc = """Record ID for the VLR

    From the specification_:
        The Record ID is dependent upon the User ID. There can be 0 to 65535
        Record IDs for every User ID. The LAS specification manages its own
        Record IDs (User IDs owned by the specification), otherwise Record IDs
        will be managed by the owner of the given User ID. Thus each User ID
        is allowed to assign 0 to 65535 Record IDs in any manner they desire.
        Publicizing the meaning of a given Record ID is left to the owner of
        the given User ID. Unknown User ID/Record ID combinations should be
        ignore
    """
    recordid = property(get_recordid, set_recordid, None, doc)

    def get_reserved(self):
        return core.las.LASVLR_GetReserved(self.handle)

    def set_reserved(self, value):
        return core.las.LASVLR_SetReserved(self.handle, value)
    doc = """Reserved value for the VLR.  Currently unused."""
    reserved = property(get_reserved, set_reserved, None, doc)

    def get_data(self):
        length = self.recordlength
        data = (ctypes.c_ubyte * length)()
        core.las.LASVLR_GetData(self.handle, data)
        return data

    def set_data(self, data):
        self.recordlength = len(data)
        pdata = ctypes.cast(data, ctypes.POINTER(ctypes.c_ubyte))
        core.las.LASVLR_SetData(self.handle, pdata, self.recordlength)
    doc = """Raw data (in the form of an array of :class:`ctypes.c_ubyte`)"""
    data = property(get_data, set_data, None, doc)