This file is indexed.

/usr/include/libwildmagic/Wm5FileIO.h is in libwildmagic-dev 5.13-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
 98
 99
100
101
102
103
104
105
// Geometric Tools, LLC
// Copyright (c) 1998-2014
// Distributed under the Boost Software License, Version 1.0.
// http://www.boost.org/LICENSE_1_0.txt
// http://www.geometrictools.com/License/Boost/LICENSE_1_0.txt
//
// File Version: 5.0.1 (2010/10/01)

#ifndef WM5FILEIO_H
#define WM5FILEIO_H

#include "Wm5CoreLIB.h"

// Support for reading or writing a binary file.  If you open the file for
// reading, calling the writing routines is an error.  If you open the file
// for writing, calling the reading routines is an error.  This class does
// not support read-write access.  The class wraps FILE operations of fopen,
// fclose, fread, and fwrite.  A hint is passed to fopen to optimize caching
// for sequential access from disk.
//
// The nested enumeration Mode supports endianness mismatches between the
// platform that created the file and the platform that is using it.  The
// flags are defined as follows:
//
// FM_READ
//   Read the data from disk as is (no byte swapping).
//
// FM_WRITE
//   Write the data to disk as is (no byte swapping).
//
// FM_READ_AND_SWAP
//   Read from disk and swap 2-, 4-, and 8-byte inputs.
//
// FM_WRITE_AND_SWAP
//   Swap 2-, 4-, and 8-byte inputs and write to disk.

namespace Wm5
{

class WM5_CORE_ITEM FileIO
{
public:
    enum
    {
        FM_NONE,
        FM_READ,
        FM_WRITE,
        FM_READ_AND_SWAP,
        FM_WRITE_AND_SWAP,

        // All data files are in little endian format, because most platforms
        // these days are little endian.
#ifdef WM5_LITTLE_ENDIAN
        FM_DEFAULT_READ = FM_READ,
        FM_DEFAULT_WRITE = FM_WRITE
#else
        FM_DEFAULT_READ = FM_READ_AND_SWAP,
        FM_DEFAULT_WRITE = FM_WRITE_AND_SWAP
#endif
    };

    // Construction and destruction.
    FileIO ();
    FileIO (const std::string& filename, int mode);
    ~FileIO ();

    bool Open (const std::string& filename, int mode);
    bool Close ();

    // Implicit conversion to allow testing for successful file open.
    operator bool () const;

    // Member access.
    inline int GetMode () const;

    // The return value is 'true' if and only if the operation was
    // successful, in which case the number of bytes read or written is
    // the item size times number of items.
    bool Read (size_t itemSize, void* datum);
    bool Read (size_t itemSize, int numItems, void* data);
    bool Write (size_t itemSize, const void* datum);
    bool Write (size_t itemSize, int numItems, const void* data);

    // Load the entire file into a buffer.
    static bool Load (const std::string& filename, bool binaryFile,
        int& bufferSize, char*& buffer);

    // Save a buffer into a file.
    static bool Save (const std::string& filename, bool binaryFile,
        int bufferSize, const char* buffer);

    // Append the buffer to a file.
    static bool Append (const std::string& filename, bool binaryFile,
        int bufferSize, const char* buffer);

private:
    FILE* mFile;
    int mMode;
};

#include "Wm5FileIO.inl"

}

#endif