This file is indexed.

/usr/include/grooveloudness/loudness.h is in libgrooveloudness-dev 4.2.1-1.

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
/*
 * Copyright (c) 2013 Andrew Kelley
 *
 * This file is part of libgroove, which is MIT licensed.
 * See http://opensource.org/licenses/MIT
 */

#ifndef GROOVE_LOUDNESS_H_INCLUDED
#define GROOVE_LOUDNESS_H_INCLUDED

#include <groove/groove.h>

#ifdef __cplusplus
extern "C"
{
#endif /* __cplusplus */

struct GrooveLoudnessDetectorInfo {
    /* loudness is in LUFS. 1 LUFS == 1 dB
     * EBU R128 specifies that playback should target -23 LUFS. replaygain on
     * the other hand is a suggestion of how many dB to adjust the gain so
     * that it equals -18 dB.
     * so, for playback you might adjust the gain so that it is equal to -18 dB
     * (this would be the replaygain standard) or so that it is equal to -23 dB
     * (this would be the EBU R128 standard).
     */
    double loudness;
    /* peak amplitude in float format */
    double peak;
    /* how many seconds long this song is */
    double duration;

    /* if item is NULL, this info applies to all songs analyzed until
     * this point. otherwise it is the playlist item that this info
     * applies to.
     * when disable_album is set, this sentinel is still sent, but loudness
     * will be set to 0
     */
    struct GroovePlaylistItem *item;
};

struct GrooveLoudnessDetector {
    /* maximum number of GrooveLoudnessDetectorInfo items to store in this
     * loudness detector's queue. this defaults to MAX_INT, meaning that
     * the loudness detector will cause the decoder to decode the entire
     * playlist. if you want to instead, for example, obtain loudness info
     * at the same time as playback, you might set this value to 1.
     */
    int info_queue_size;

    /* how big the sink buffer should be, in sample frames.
     * groove_loudness_detector_create defaults this to 8192
     */
    int sink_buffer_size;

    /* set to 1 to only compute track loudness. This is faster and requires
     * less memory than computing both.
     */
    int disable_album;

    /* read-only. set when attached and cleared when detached */
    struct GroovePlaylist *playlist;
};

struct GrooveLoudnessDetector *groove_loudness_detector_create(void);
void groove_loudness_detector_destroy(struct GrooveLoudnessDetector *detector);

/* once you attach, you must detach before destroying the playlist */
int groove_loudness_detector_attach(struct GrooveLoudnessDetector *detector,
        struct GroovePlaylist *playlist);
int groove_loudness_detector_detach(struct GrooveLoudnessDetector *detector);

/* returns < 0 on error, 0 on aborted (block=1) or no info ready (block=0),
 * 1 on info returned
 */
int groove_loudness_detector_info_get(struct GrooveLoudnessDetector *detector,
        struct GrooveLoudnessDetectorInfo *info, int block);

/* returns < 0 on error, 0 on no info ready, 1 on info ready
 * if block is 1, block until info is ready
 */
int groove_loudness_detector_info_peek(struct GrooveLoudnessDetector *detector,
        int block);

/* get the position of the detect head
 * both the current playlist item and the position in seconds in the playlist
 * item are given. item will be set to NULL if the playlist is empty
 * you may pass NULL for item or seconds
 */
void groove_loudness_detector_position(struct GrooveLoudnessDetector *detector,
        struct GroovePlaylistItem **item, double *seconds);

#ifdef __cplusplus
}
#endif /* __cplusplus */

#endif /* GROOVE_LOUDNESS_H_INCLUDED */