This file is indexed.

/usr/include/CLAM/AudioDevice.hxx is in libclam-dev 1.4.0-5build1.

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
/*
 * Copyright (c) 2001-2004 MUSIC TECHNOLOGY GROUP (MTG)
 *                         UNIVERSITAT POMPEU FABRA
 *
 *
 * 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., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 *
 */
#ifndef __AudioDevice__
#define __AudioDevice__

#include "AudioManager.hxx"
#include "Audio.hxx"

namespace CLAM{



/** This is the abstract base class for an audio device. With an audio device
 * we refer to any kind of (multichannel) audio input/output/fullduplex.
 * AudioDevices are usually created by the AudioManager. The interface 
 * for the user however, are the AudioIn and AudioOut classes.
 * <p>
 * Each AudioIn and AudioOut created is registered with the AudioManager. When the AudioManager is started, it will create the appropiate AudioDevice or AudioDevices, based on the number of inputs, outputs, operating system and AudioIOConfig of the AudioIn and AudioOut objects.
 * @see AudioIn, AudioOut, AudioDeviceList, AudioManager
 */
class AudioDevice
{
	friend class AudioIn;
	friend class AudioOut;
	friend class AudioManager;
public:
	/** This class is used to respond to device information
	 *	request using the GetInfo method.
	 */
	struct TInfo
	{
		std::string mName;
		std::string mArch;
		/** Number of used Read channels*/
		int mNReadChannels;
		/** Number of used Write channels*/
		int mNWriteChannels;
		/** Number of channels configured in the PCM device.
		 *  max( mNReadChannels , mNWriteChannels)
		 */
		int mNChannels;
		int mSampleRate;
		unsigned int mNotifySize;

		/** Base constructor, calls to Reset method to clear all the values*/
		TInfo() { Reset();}

		/** Clear all the values of object, setting strings mName and mArch to "" and integer values mNChannels, mSampleRate and mNotifySize to 0
		 */
		void Reset()
		{
			mName=mArch="";
			mNChannels=mNReadChannels=mNWriteChannels=mSampleRate=mNotifySize=0;
		}
	};
	
	std::vector<AudioIn*> mInputs;
	std::vector<AudioOut*> mOutputs;
	
	std::string mName;
	bool mForceNChannels;
	int mNChannels;
	int mNReadChannels;
	int mNWriteChannels;
	
	/** Constructor of the class that sets the name of object to the string passed by parameter
	 *  @arg name String with the name of object
	 */
	AudioDevice(const std::string& name)
	{
		mName = name;
		mNChannels = mNReadChannels = mNWriteChannels = 0;
		mForceNChannels=false;
		mAudioManager=0;
	}
	
	/** Destructor of class*/
	virtual ~AudioDevice() { };
	
	/** This method must be called to begin the use of this Device. Must be implemented by any Device derived from this class*/
	virtual void Start(void) throw(Err) = 0;
	/** This method must be called to end the use of this Device. Must be implemented by any Device derived from this class*/
	virtual void Stop(void) throw(Err) = 0;
	/** Reads the information given by this Device and passes data to an Audio chunk. Must be implemented by any Device derived from this class.
	 *  @param audio Audio object where data will be stored.
	 *  @param channelID Channel to read.
	 */
	virtual void Read(Audio& audio,const int channelID) = 0;

	/** Writes the information given by an Audio chunk in the Devices. Must be implemented by any Device derived from this class.
	 *  @param audio Audio object with values that must to be passed to Devices
	 *  @param channelID Channel to write
	 */
	virtual void Write(const Audio& audio,const int channelID) = 0;
	
	/** Getter for the Info of Device Object attached to this AudioDevices instantiation
	 *  @param info TInfo object that method will modify with the values of Tinfo internal object
	 */
	virtual void GetInfo(TInfo&);

	/** Setter for the number of channels to allocate in the hardware.
	 *  This is necessary for certain hardware which needs a fixed number
	 *  of channels (ADAT or SPDIF).
	 *  @param Number of channels
	 */
	virtual void SetNChannels(int channels);
	
protected:
	
	bool Register(AudioManager* am,AudioIn& in);
	bool Register(AudioManager* am,AudioOut& out);
	void Unregister(AudioIn& in);
	void Unregister(AudioOut& out);
	
	int SampleRate(void);
	int Latency(void);
	void SetLatency(int latency);

private:
	AudioManager* mAudioManager;
	AudioManager& _AudioManager(void);
	void _SetAudioManager(AudioManager* am);
};

};//CLAM

#endif