This file is indexed.

/usr/include/wvstreams/xplc/IMoniker.h is in libwvstreams-dev 4.6.1-12~deb9u1.

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
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
 *
 * XPLC - Cross-Platform Lightweight Components
 * Copyright (C) 2002, Pierre Phaneuf
 * Copyright (C) 2002, Net Integration Technologies, Inc.
 *
 * This library 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.1 of
 * the License, or (at your option) any later version.
 *
 * This library 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 library; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
 * USA
 */

#ifndef __XPLC_IMONIKER_H__
#define __XPLC_IMONIKER_H__

#if defined(__GNUC__) && __GNUC__ > 3
# pragma GCC system_header
#endif

#include <xplc/IObject.h>

/** \interface IMoniker IMoniker.h xplc/IMoniker.h
 *
 * An interface for obtaining an IObject given a moniker string.
 *
 * A moniker can be used to obtain a particular object using a
 * human-readable string to describe it, rather than having to know
 * the object's UUID.  Human-readable strings are, unfortunately, not
 * guaranteed to be universally unique, so you might (theoretically)
 * not get the object you want.
 * 
 * You can retrieve the standard %XPLC moniker service from the service
 * manager using the XPLC_monikers UUID, which can then be used to
 * resolve monikers and register your own using the IMonikerService
 * interface it provides.
 *
 * Note that XPLC::get() and XPLC::create() are a convenient interface
 * to the %XPLC moniker system.
 */
class IMoniker: public IObject {
  UNSTABLE_INTERFACE
public:
  /**
   * Given a moniker string, return the IObject it refers to, or NULL if
   * no objects match.  The returned object is already addRef()'d.
   */
  virtual IObject* resolve(const char* moniker) = 0;
};

DEFINE_IID(IMoniker, {0x6c0bb432, 0x7c32, 0x4614,
  {0xa5, 0xab, 0xb2, 0x5d, 0x92, 0x23, 0xda, 0xa2}});

#endif /* __XPLC_IMONIKER_H__ */