This file is indexed.

/usr/include/givaro/modular-defines.h is in libgivaro-dev 4.0.2-5.

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
// ==========================================================================
// Copyright(c)'1994-2015 by The Givaro group
// This file is part of Givaro.
// Givaro is governed by the CeCILL-B license under French law
// and abiding by the rules of distribution of free software.
// see the COPYRIGHT file for more details.
// Authors: A. Breust <Alexis.Breust@imag.fr>
//         Brice Boyer (briceboyer) <boyer.brice@gmail.com>
// ==========================================================================

#ifndef __GIVARO_modular_defines_H
#define __GIVARO_modular_defines_H

// r <- a^-1
#define __GIVARO_MODULAR_RECINT_NEG(r,p,a) { if (a == 0) RecInt::reset(r); else RecInt::sub(r, p, a); }
#define __GIVARO_MODULAR_INTEGER_NEG(r,p,a) ( \
    r = a == 0 ? static_cast<Element>(0) : \
    static_cast<Element>(static_cast<Compute_t>(p)-static_cast<Compute_t>(a)) )
#define __GIVARO_MODULAR_FLOATING_NEG(r,p,a) ( r = (a == 0 ? 0 : p-a) )

// r <- r^-1
#define __GIVARO_MODULAR_RECINT_NEGIN(r,p) { if (r == 0) RecInt::reset(r); else RecInt::sub(r, p, r); }
#define __GIVARO_MODULAR_INTEGER_NEGIN(r,p) ( \
    r = r == 0 ? static_cast<Element>(0) : \
    static_cast<Element>(static_cast<Compute_t>(p)-static_cast<Compute_t>(r)) )
#define __GIVARO_MODULAR_FLOATING_NEGIN(r,p) ( r = (r == 0 ? 0 : p-r) )

// r <- a * b
#define __GIVARO_MODULAR_RECINT_MUL(r,p,a,b) { RecInt::mod_n(RecInt::mul(r, a, b), p); }
#define __GIVARO_MODULAR_INTEGER_MUL(r,p,a,b) ( \
    r = static_cast<Element>(static_cast<Compute_t>(a)*static_cast<Compute_t>(b) % static_cast<Compute_t>(p)) )
#define __GIVARO_MODULAR_FLOATING_MUL(r,p,a,b) ( r = std::fmod(a*b, p) )

// r <- r * a
#define __GIVARO_MODULAR_RECINT_MULIN(r,p,a) { RecInt::mod_n(RecInt::mul(r, a), p); }
#define __GIVARO_MODULAR_INTEGER_MULIN(r,p,a) ( r = static_cast<Element>(static_cast<Compute_t>(r)*static_cast<Compute_t>(a) % static_cast<Compute_t>(p)) )
#define __GIVARO_MODULAR_FLOATING_MULIN(r,p,a) ( r = std::fmod((r*a), p) )

// r <- a - b
#define __GIVARO_MODULAR_RECINT_SUB(r,p,a,b) { \
    if (a < b) { RecInt::sub(r, p, b); RecInt::add(r, a); } \
    else { RecInt::sub(r, a, b); } }
#define __GIVARO_MODULAR_INTEGER_SUB(r,p,a,b) ( \
    r = static_cast<Element>((static_cast<Compute_t>(a) >= static_cast<Compute_t>(b)) ? \
    static_cast<Compute_t>(a)-static_cast<Compute_t>(b) : \
    static_cast<Compute_t>(p)-static_cast<Compute_t>(b)+static_cast<Compute_t>(a)) )
#define __GIVARO_MODULAR_FLOATING_SUB(r,p,a,b) ( r = (a>=b) ? a-b: (p-b)+a )

// r <- r - a
#define __GIVARO_MODULAR_RECINT_SUBIN(r,p,a) { \
    if (r < a) { RecInt::add(r, p - a); } \
    else { RecInt::sub(r, a); } }
#define __GIVARO_MODULAR_INTEGER_SUBIN(r,p,a) { \
	if (static_cast<Compute_t>(r) < static_cast<Compute_t>(a)) \
	r = static_cast<Element>(static_cast<Compute_t>(r) + static_cast<Compute_t>(p) - static_cast<Compute_t>(a)); \
	else r = static_cast<Element>(static_cast<Compute_t>(r) - static_cast<Compute_t>(a)); }
#define __GIVARO_MODULAR_FLOATING_SUBIN(r,p,a) { if (r<a) r+=(p-a); else r-=a; }

// r <- a + b
#define __GIVARO_MODULAR_RECINT_ADD(r,p,a,b) { \
    RecInt::add(r, a, b); \
    if (r >= p) RecInt::sub(r, p); }
#define __GIVARO_MODULAR_INTEGER_ADD(r,p,a,b) { \
    r = static_cast<Element>(static_cast<Compute_t>(a) + static_cast<Compute_t>(b)); \
    r = static_cast<Element>((static_cast<Compute_t>(r) < static_cast<Compute_t>(p)) ? r : \
    static_cast<Compute_t>(r) - static_cast<Compute_t>(p)); }
#define __GIVARO_MODULAR_FLOATING_ADD(r,p,a,b) { r = (a+b); r= (r < p ? r : r-p); }

// r <- r + a
#define __GIVARO_MODULAR_RECINT_ADDIN(r,p,a) { \
    RecInt::add(r, a); \
    if (r >= p) RecInt::sub(r, p); }
#define __GIVARO_MODULAR_INTEGER_ADDIN(r,p,a) { \
    r = static_cast<Element>(r + a); \
    r = static_cast<Element>((static_cast<Compute_t>(r) < static_cast<Compute_t>(p)) ? r : \
    static_cast<Compute_t>(r) - static_cast<Compute_t>(p)); }
#define __GIVARO_MODULAR_FLOATING_ADDIN(r,p,a) { r += a;  r= (r < p ? r : r-p); }

// r <- c + a*b
#define __GIVARO_MODULAR_RECINT_MULADD(r,p,a,b,c) {	\
    RecInt::copy(r, c);					\
    RecInt::addmul(r, a, b);				\
    RecInt::mod_n(r, p); }
#define __GIVARO_MODULAR_INTEGER_MULADD(r,p,a,b,c) ( \
    r = static_cast<Element>((static_cast<Compute_t>(a)*static_cast<Compute_t>(b) \
    + static_cast<Compute_t>(c)) % static_cast<Compute_t>(p)))
#define __GIVARO_MODULAR_FLOATING_MULADD(r,p,a,b,c) ( r = std::fmod((a*b+c), p) )

// r <- r + a*b
#define __GIVARO_MODULAR_RECINT_MULADDIN(r,p,a,b) { \
    RecInt::addmul(r, a, b); \
    RecInt::mod_n(r, p); }
#define __GIVARO_MODULAR_INTEGER_MULADDIN(r,p,a,b) ( \
    r = static_cast<Element>((static_cast<Compute_t>(a)*static_cast<Compute_t>(b) \
    + static_cast<Compute_t>(r)) % static_cast<Compute_t>(p)))
#define __GIVARO_MODULAR_FLOATING_MULADDIN(r,p,a,b) ( r = std::fmod((a*b+r), p) )

// r <- a*b - c
#define __GIVARO_MODULAR_RECINT_MULSUB(r,p,a,b,c) { \
    __GIVARO_MODULAR_RECINT_MUL(r,p,a,b); \
    __GIVARO_MODULAR_RECINT_SUBIN(r,p,c); }
#define __GIVARO_MODULAR_INTEGER_MULSUB(r,p,a,b,c) ( \
    r = static_cast<Element>((static_cast<Compute_t>(a)*static_cast<Compute_t>(b) \
    + static_cast<Compute_t>(p)-static_cast<Compute_t>(c)) % static_cast<Compute_t>(p)))
#define __GIVARO_MODULAR_FLOATING_MULSUB(r,p,a,b,c) ( r = std::fmod((a*b+p-c), p) )

// r <- a*b - r
#define __GIVARO_MODULAR_RECINT_SUBMULIN(r,p,a,b) { \
    __GIVARO_MODULAR_RECINT_NEGIN(r,p); \
    RecInt::addmul(r, a, b); \
    RecInt::mod_n(r, p); }
#define __GIVARO_MODULAR_INTEGER_SUBMULIN(r,p,a,b) { \
    r = static_cast<Element>((static_cast<Compute_t>(a)*static_cast<Compute_t>(b) \
    +static_cast<Compute_t>(p)-static_cast<Compute_t>(r)) % static_cast<Compute_t>(p)); \
    __GIVARO_MODULAR_INTEGER_NEGIN(r,p); }
#define __GIVARO_MODULAR_FLOATING_SUBMULIN(r,p,a,b) { \
    r = (a*b+p-r); \
    r= (r<p ? r : std::fmod(r, p)); \
    __GIVARO_MODULAR_FLOATING_NEGIN(r,p); }

#endif // __GIVARO_modular_defines_H