This file is indexed.

/usr/include/GDF/Channel.h is in libgdf-dev 0.1.2-2.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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
//
// This file is part of libGDF.
//
// libGDF 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 3 of
// the License, or (at your option) any later version.
//
// libGDF 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 libGDF.  If not, see <http://www.gnu.org/licenses/>.
//
// Copyright 2010 Martin Billinger

#ifndef __CHANNEL_H_INCLUDED__
#define __CHANNEL_H_INCLUDED__

#include "GDF/SignalHeader.h"
#include "ChannelDataBase.h"
#include "GDF/Types.h"
#include <boost/numeric/conversion/cast.hpp>
#include <boost/lexical_cast.hpp>

namespace gdf
{
    class SignalHeader;

    /// Representation of a channel (signal in GDF)
    /**
    */
    class Channel
    {
    public:
        /// Constructor
        Channel( const SignalHeader *sig_hdr, const size_t length );

        /// Constructor
        /** Channel length is initialized to channel's samples_per_record. */
        Channel( const SignalHeader *sig_hdr );

        /// Copy Constructor
        Channel( const Channel &other );

        /// Destructor
        virtual ~Channel( );

        /// Reset read and write positions
        void clear( );

        /// Add a physical sample to the channel.
        /** value is scaled from [phys_min..phys_max] to [dig_min..dig_max] and converted to the channel's data type */
        void addSamplePhys( const double value );

        /// Add a raw sample to the channel.
        /** value is converted to the channel's data type. but otherwise remains unmodified */
        template<typename T> void addSampleRaw( const T rawval );

        /// Blit a number of physical samples into channel.
        /** values are scaled from [phys_min..phys_max] to [dig_min..dig_max] and converted to the channel's data type */
        void blitSamplesPhys( const double *values, size_t num );

        /// Blit a number of raw samples into channel.
        /** values are converted to the channel's data type but otherwise remains unmodified */
        template<typename T> void blitSamplesRaw( const T *values, size_t num );

        /// Fill a number of samples with the same physical value.
        /** value is scaled from [phys_min..phys_max] to [dig_min..dig_max] and converted to the channel's data type */
        void fillPhys( const double value, size_t num );

        /// Fill a number of samples with the same raw value.
        /** value is converted to the channel's data type but otherwise remains unmodified */
        template<typename T> void fillRaw( const T value, size_t num );

        /// set sample value
        void setSamplePhys( size_t pos, double value );

        /// get sample value
        double getSamplePhys( size_t pos );

        /// Blit a number of physical samples from channel to buffer.
        /** values are scaled from [dig_min..dig_max] to [phys_min..phys_max] and converted to double */
        void deblitSamplesPhys( double *values, size_t start, size_t num );

        /// Blit a number of raw samples from channel to buffer.
        template<typename T> void deblitSamplesRaw( T *values, size_t start, size_t num );

        /// Get number of free samples
        size_t getFree( );

        /// Get number of written samples
        size_t getWritten( );

        /// Get type of channel
        uint32 getTypeID( );

        friend std::ostream &operator<<( std::ostream &out, const Channel &c );
        friend std::istream &operator>>( std::istream &in, Channel &c );

    private:
        const SignalHeader *m_signalheader;
        ChannelDataBase *m_data;
    };

    /// Channel Serializer
    std::ostream &operator<<( std::ostream &out, const Channel &c );

    /// Channel Deserializer
    std::istream &operator>>( std::istream &in, Channel &c );



    //===================================================================================================
    //===================================================================================================

    template<typename T> void Channel::addSampleRaw( const T rawval )
    {
        using boost::numeric_cast;

        switch( m_signalheader->get_datatype( ) )
        {
        case INT8: m_data->addSample( numeric_cast<int8>(rawval) ); break;
        case UINT8: m_data->addSample( numeric_cast<uint8>(rawval) ); break;
        case INT16: m_data->addSample( numeric_cast<int16>(rawval) ); break;
        case UINT16: m_data->addSample( numeric_cast<uint16>(rawval) ); break;
        case INT32: m_data->addSample( numeric_cast<int32>(rawval) ); break;
        case UINT32: m_data->addSample( numeric_cast<uint32>(rawval) ); break;
        case INT64: m_data->addSample( numeric_cast<int64>(rawval) ); break;
        case UINT64: m_data->addSample( numeric_cast<uint64>(rawval) ); break;
        case FLOAT32: m_data->addSample( numeric_cast<float32>(rawval) ); break;
        case FLOAT64: m_data->addSample( numeric_cast<float64>(rawval) ); break;
        default: throw exception::invalid_type_id( boost::lexical_cast<std::string>(m_signalheader->get_datatype( )) ); break;
        };
    }

    //===================================================================================================
    //===================================================================================================

    template<typename T> void Channel::blitSamplesRaw( const T *values, size_t num )
    {
        for( size_t i=0; i<num; i++ )
            addSampleRaw( values[i] );
    }

}

#endif