This file is indexed.

/usr/include/lvtk-1/lvtk/ext/urimap.hpp is in lvtk-dev 1.2.0~dfsg0-1build1.

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
/**
    urimap.hpp - Support file for writing LV2 plugins in C++

    Copyright (C) 2012 Michael Fisher <mfisher31@gmail.com>

    This program is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation; either version 3 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 General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with this program; if not, write to the Free Software
    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 01222-1307  USA
 */
/**
    @file urimap.hpp
    C++ convenience header for the LV2 URIMap extension.
    LV2 C Version: 1.6 (2012-04-17) DEPRECATED

    This extension is deprecated. New implementations should use LV2 URID instead.

    This extension defines a simple mechanism for plugins to map URIs to integers,
    usually for performance reasons (e.g. processing events typed by URIs in
    real time). The expected use case is for plugins to map URIs to integers
    for things they 'understand' at instantiation time, and store those values
    for use in the audio thread without doing any string comparison. This allows
    the extensibility of RDF with the performance of integers (or centrally defined
    enumerations).
 */

#ifndef LVTK_URIMAP_HPP
#define LVTK_URIMAP_HPP

#include <lv2/lv2plug.in/ns/ext/uri-map/uri-map.h>
#include <lvtk/private/types.hpp>

#warning "this header uses the deprecated lv2 extension uri-map. \
	please use URID instead."

namespace lvtk
{

    /** The URI map mixin. This can be used by both plugins and GUIs.
        @see The internal struct I for API details
        @headerfile lvtk/ext/urimap.hpp
        @ingroup pluginmixins
        @ingroup guimixins
        @deprecated
     */
    template<bool Required = true>
    struct URIMap
    {
        template<class Derived>
        struct I : Extension<Required>
        {

            I() :  m_callback_data(0), m_func(0)
            {
            }

            /** @skip */
            static void
            map_feature_handlers(FeatureHandlerMap& hmap)
            {
                hmap[LV2_URI_MAP_URI] = &I<Derived>::handle_feature;
            }

            /** @skip */
            static void
            handle_feature(void* instance, void* data)
            {
                Derived* d = reinterpret_cast<Derived*>(instance);
                I<Derived>* fe = static_cast<I<Derived>*>(d);
                LV2_URI_Map_Feature* umf =
                        reinterpret_cast<LV2_URI_Map_Feature*>(data);
                fe->m_callback_data = umf->callback_data;
                fe->m_func = umf->uri_to_id;
                fe->m_ok = (fe->m_func != 0);
            }

            /** Sanity check the mixin */
            bool
            check_ok()
            {
                if (LVTK_DEBUG)
                {
                    std::clog << "    [LV2::URIMap] Validation "
                            << (this->m_ok ? "succeeded" : "failed")
                            << "." << std::endl;
                }

                return this->m_ok;
            }

        protected:

            /** This returns a numeric identifier for a given URI and map.
                This is used for e.g. getting numeric IDs for event types
                specified by URIs. A return value of 0 should be considered to
                mean that the URI you passed is not supported by the host.
                @param map An URI to be used as namespace.
                @param uri The URI that you want to map to a numeric ID.
             */
            uint32_t
            uri_to_id(const char* map, const char* uri) const
            {
                if (LVTK_DEBUG)
                {
                    uint32_t result = m_func(m_callback_data, map, uri);
                    std::clog << "[LV2::URIMap] uri_to_id(\"" << uri
                            << "\") -> " << result << std::endl;
                    return result;
                }
                return m_func(m_callback_data, map, uri);
            }

            LV2_URI_Map_Callback_Data m_callback_data;
            uint32_t (*m_func)(LV2_URI_Map_Callback_Data, const char*, const char*);

        };
    };
} /* namespace lvtk */

#endif /* LVTK_URIMAP_HPP */