Browse Source

Remove some of DShow-dependent in AudioCaps.

This code was used to loop over all the audio devices and print their
names to a log file. No other initialization or parameter setting was
done. I'm quite sure the world will continue to operate without device
names printed out to an encrypted log file. ;)
Darryl Pogue 14 years ago
parent
commit
b50b505a67
  1. 58
      Sources/Plasma/PubUtilLib/plAudio/plAudioCaps.cpp
  2. 1
      Sources/Plasma/PubUtilLib/plAudio/plAudioCaps.h

58
Sources/Plasma/PubUtilLib/plAudio/plAudioCaps.cpp

@ -40,7 +40,6 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#include <eaxlegacy.h> #include <eaxlegacy.h>
#endif #endif
#include <iostream> #include <iostream>
#include <DShow.h>
#include "plStatusLog/plStatusLog.h" #include "plStatusLog/plStatusLog.h"
@ -97,8 +96,6 @@ plAudioCaps &plAudioCapsDetector::Detect( hsBool logIt, hsBool init )
} }
} }
EnumerateAudioDevices();
if( logIt ) if( logIt )
fLog = plStatusLogMgr::GetInstance().CreateStatusLog( 30, "audioCaps.log" ); fLog = plStatusLogMgr::GetInstance().CreateStatusLog( 30, "audioCaps.log" );
else else
@ -138,59 +135,6 @@ plAudioCaps &plAudioCapsDetector::Detect( hsBool logIt, hsBool init )
return fCaps; return fCaps;
} }
void plAudioCapsDetector::EnumerateAudioDevices()
{
ICreateDevEnum *pDevEnum;
IEnumMoniker *pEnumMon;
IMoniker *pMoniker;
ULONG cFetched;
HRESULT hr;
char audioCardName[MAX_AUDIOCARD_NAME];
short *pShort;
// Enumerate audio devices
hr = CoCreateInstance(CLSID_SystemDeviceEnum, NULL, CLSCTX_INPROC_SERVER, IID_ICreateDevEnum, (void **)&pDevEnum);
if(SUCCEEDED(hr))
{
hr = pDevEnum->CreateClassEnumerator(CLSID_AudioRendererCategory, &pEnumMon, 0);
if(SUCCEEDED(hr))
{
while(pEnumMon->Next(1, &pMoniker, &cFetched) == S_OK)
{
if(pMoniker)
{
IPropertyBag *pPropBag;
hr = pMoniker->BindToStorage(0, 0, IID_IPropertyBag, (void **)&pPropBag);
if(SUCCEEDED(hr))
{
VARIANT varName;
VariantInit(&varName);
hr = pPropBag->Read(L"FriendlyName", &varName, 0);
memset(audioCardName, 0, MAX_AUDIOCARD_NAME);
pShort = varName.piVal;
// copy from wide character array to char array
for(int i = 0; *pShort != 0 && i < MAX_AUDIOCARD_NAME; pShort++, i++)
{
audioCardName[i] = (char)*pShort;
}
if(SUCCEEDED(hr))
{
plStatusLog::AddLineS("audiocaps.log", audioCardName );
}
VariantClear(&varName);
pPropBag->Release();
}
pMoniker->Release();
}
}
pEnumMon->Release();
}
pDevEnum->Release();
}
}
//// IDetectEAX ////////////////////////////////////////////////////////////// //// IDetectEAX //////////////////////////////////////////////////////////////
// Attempt to actually init the EAX listener.Note that we can potentially do // Attempt to actually init the EAX listener.Note that we can potentially do
// this even if we didn't load the EAX Unified driver (we could just be // this even if we didn't load the EAX Unified driver (we could just be
@ -225,4 +169,4 @@ hsBool plAudioCapsDetector::IDetectEAX( )
kLogMe 0xff00ff00, "EAX disabled in this build"); kLogMe 0xff00ff00, "EAX disabled in this build");
return false; return false;
#endif #endif
} }

1
Sources/Plasma/PubUtilLib/plAudio/plAudioCaps.h

@ -78,7 +78,6 @@ protected:
static hsBool fGotCaps; static hsBool fGotCaps;
static hsBool IDetectEAX( ); static hsBool IDetectEAX( );
static void EnumerateAudioDevices();
}; };
#endif //_plAudioCaps_h #endif //_plAudioCaps_h

Loading…
Cancel
Save