This file is indexed.

/usr/include/libfm-1.0/fm-module.h is in libfm-dev 1.2.0-1ubuntu2.

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
/*
 *      fm-module.h
 *
 *      This file is a part of the Libfm project.
 *
 *      Copyright 2013-2014 Andriy Grytsenko (LStranger) <andrej@rep.kiev.ua>
 *
 *      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 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 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., 51 Franklin Street, Fifth Floor, Boston,
 *      MA 02110-1301, USA.
 */

#ifndef __FM_MODULE_H__
#define __FM_MODULE_H__ 1

#include <gio/gio.h>

#define __FM_MODULE_VERSION__(xx) FM_MODULE_##xx##_VERSION
#define __FM_DEFINE_VERSION__(xx) __FM_MODULE_VERSION__(xx)

/**
 * FM_DEFINE_MODULE
 * @_type_: type of module (e.g. `vfs')
 * @_name_: module type specific key (e.g. `menu')
 *
 * Macro used in module definition. Module should have module specific
 * structure: if @type is vfs then it should be fm_module_init_vfs. See
 * specific header file for some `extern' definition.
 */
#define FM_DEFINE_MODULE(_type_, _name_) \
int module_##_type_##_version = __FM_DEFINE_VERSION__(_type_); \
char module_name[] = #_name_;

/**
 * FmModuleInitCallback
 * @key: the module name as key value for the type
 * @init_data: module type specific initialization data
 * @version: version of loaded module
 *
 * This API is used to make callback from the modules loader to the
 * implementation which uses module so the implementation may do required
 * checks and add module to own list of supported data.
 * This callback will be done in default main context.
 *
 * Returns: %TRUE if module was accepted by implementation.
 *
 * Since: 1.2.0
 */
typedef gboolean (*FmModuleInitCallback)(const char *key, gpointer init_data, int version);

/**
 * FM_MODULE_DEFINE_TYPE
 * @_type_: type of module (e.g. `vfs')
 * @_struct_: type of struct with module callbacks
 * @_minver_: minimum version supported
 *
 * Macro used in module caller. Callback is ran when matched module is
 * found, it should return %TRUE on success.
 */
#define FM_MODULE_DEFINE_TYPE(_type_, _struct_, _minver_) \
static gboolean fm_module_callback_##_type_(const char *, gpointer, int ver); \
\
static inline void fm_module_register_##_type_ (void) { \
    fm_module_register_type(#_type_, \
                            _minver_, __FM_DEFINE_VERSION__(_type_), \
                            fm_module_callback_##_type_); \
}

/* use this whenever extension is about to be used */
#define CHECK_MODULES(...) if(G_UNLIKELY(!fm_modules_loaded)) fm_modules_load()

G_BEGIN_DECLS

/* adds schedule */
void fm_module_register_type(const char *type, int minver, int maxver, FmModuleInitCallback cb);
/* removes schedule */
void fm_module_unregister_type(const char *type);
/* forces schedules */
void fm_modules_load(void);
/* checks if in use */
gboolean fm_module_is_in_use(const char *type, const char *name);
/* add application-dependent path for modules */
gboolean fm_modules_add_directory(const char *path);
/* the flag */
extern volatile gint fm_modules_loaded;

G_END_DECLS

#endif /* __FM_MODULE_H__ */