2013-05-23 18:50:07 -07:00
|
|
|
|
2019-07-29 19:59:48 -07:00
|
|
|
#include "config.h"
|
2013-05-23 18:50:07 -07:00
|
|
|
|
|
|
|
#include "AL/al.h"
|
|
|
|
#include "AL/alc.h"
|
2018-11-17 23:02:27 -08:00
|
|
|
|
2019-07-29 17:54:07 -07:00
|
|
|
#include "al/auxeffectslot.h"
|
2019-07-28 18:33:29 -07:00
|
|
|
#include "alcmain.h"
|
2019-07-30 21:32:05 -07:00
|
|
|
#include "alcontext.h"
|
2019-07-29 19:59:48 -07:00
|
|
|
#include "almalloc.h"
|
|
|
|
#include "alspan.h"
|
|
|
|
#include "effects/base.h"
|
2013-05-23 18:50:07 -07:00
|
|
|
|
|
|
|
|
2019-03-22 12:58:24 -07:00
|
|
|
namespace {
|
|
|
|
|
2019-03-22 13:33:58 -07:00
|
|
|
struct NullState final : public EffectState {
|
|
|
|
NullState();
|
|
|
|
~NullState() override;
|
2016-08-25 03:42:43 -07:00
|
|
|
|
2020-04-16 17:29:32 -07:00
|
|
|
void deviceUpdate(const ALCdevice *device) override;
|
2019-03-22 22:48:12 -07:00
|
|
|
void update(const ALCcontext *context, const ALeffectslot *slot, const EffectProps *props, const EffectTarget target) override;
|
2019-08-26 09:16:20 -07:00
|
|
|
void process(const size_t samplesToDo, const al::span<const FloatBufferLine> samplesIn, const al::span<FloatBufferLine> samplesOut) override;
|
2016-08-25 03:42:43 -07:00
|
|
|
|
2019-03-22 13:33:58 -07:00
|
|
|
DEF_NEWDEL(NullState)
|
2018-11-19 22:34:26 -08:00
|
|
|
};
|
2016-08-25 03:42:43 -07:00
|
|
|
|
|
|
|
/* This constructs the effect state. It's called when the object is first
|
2018-11-19 22:34:26 -08:00
|
|
|
* created.
|
2016-08-25 03:42:43 -07:00
|
|
|
*/
|
2019-03-22 13:33:58 -07:00
|
|
|
NullState::NullState() = default;
|
2013-05-25 17:42:34 -07:00
|
|
|
|
2019-03-22 16:04:13 -07:00
|
|
|
/* This destructs the effect state. It's called only when the effect instance
|
|
|
|
* is no longer used.
|
2013-05-25 17:42:34 -07:00
|
|
|
*/
|
2019-03-22 13:33:58 -07:00
|
|
|
NullState::~NullState() = default;
|
2013-05-25 17:42:34 -07:00
|
|
|
|
2019-07-28 17:15:34 -07:00
|
|
|
/* This updates the device-dependant effect state. This is called on state
|
2019-03-22 16:04:13 -07:00
|
|
|
* initialization and any time the device parameters (e.g. playback frequency,
|
|
|
|
* format) have been changed. Will always be followed by a call to the update
|
|
|
|
* method, if successful.
|
2013-05-25 17:42:34 -07:00
|
|
|
*/
|
2020-04-16 17:29:32 -07:00
|
|
|
void NullState::deviceUpdate(const ALCdevice* /*device*/)
|
2013-05-23 18:50:07 -07:00
|
|
|
{
|
|
|
|
}
|
2013-05-25 17:42:34 -07:00
|
|
|
|
2019-07-28 17:15:34 -07:00
|
|
|
/* This updates the effect state with new properties. This is called any time
|
|
|
|
* the effect is (re)loaded into a slot.
|
2013-05-25 17:42:34 -07:00
|
|
|
*/
|
2019-07-28 17:15:34 -07:00
|
|
|
void NullState::update(const ALCcontext* /*context*/, const ALeffectslot* /*slot*/,
|
|
|
|
const EffectProps* /*props*/, const EffectTarget /*target*/)
|
2013-05-23 18:50:07 -07:00
|
|
|
{
|
|
|
|
}
|
2013-05-25 17:42:34 -07:00
|
|
|
|
|
|
|
/* This processes the effect state, for the given number of samples from the
|
|
|
|
* input to the output buffer. The result should be added to the output buffer,
|
|
|
|
* not replace it.
|
|
|
|
*/
|
2019-08-20 14:30:04 -07:00
|
|
|
void NullState::process(const size_t/*samplesToDo*/,
|
2019-08-26 09:16:20 -07:00
|
|
|
const al::span<const FloatBufferLine> /*samplesIn*/,
|
2019-07-28 17:15:34 -07:00
|
|
|
const al::span<FloatBufferLine> /*samplesOut*/)
|
2013-05-23 18:50:07 -07:00
|
|
|
{
|
|
|
|
}
|
2013-05-25 17:42:34 -07:00
|
|
|
|
2013-05-23 18:50:07 -07:00
|
|
|
|
2020-04-10 20:23:20 -07:00
|
|
|
void NullEffect_setParami(EffectProps* /*props*/, ALenum param, int /*val*/)
|
2013-05-25 17:42:34 -07:00
|
|
|
{
|
|
|
|
switch(param)
|
|
|
|
{
|
2018-01-25 15:59:59 -08:00
|
|
|
default:
|
2020-04-10 20:23:20 -07:00
|
|
|
throw effect_exception{AL_INVALID_ENUM, "Invalid null effect integer property 0x%04x",
|
|
|
|
param};
|
2013-05-25 17:42:34 -07:00
|
|
|
}
|
|
|
|
}
|
2020-04-10 20:23:20 -07:00
|
|
|
void NullEffect_setParamiv(EffectProps *props, ALenum param, const int *vals)
|
2013-05-25 17:42:34 -07:00
|
|
|
{
|
|
|
|
switch(param)
|
|
|
|
{
|
2018-01-25 15:59:59 -08:00
|
|
|
default:
|
2020-04-10 20:23:20 -07:00
|
|
|
NullEffect_setParami(props, param, vals[0]);
|
2013-05-25 17:42:34 -07:00
|
|
|
}
|
|
|
|
}
|
2020-04-10 20:23:20 -07:00
|
|
|
void NullEffect_setParamf(EffectProps* /*props*/, ALenum param, float /*val*/)
|
2013-05-25 17:42:34 -07:00
|
|
|
{
|
|
|
|
switch(param)
|
|
|
|
{
|
2018-01-25 15:59:59 -08:00
|
|
|
default:
|
2020-04-10 20:23:20 -07:00
|
|
|
throw effect_exception{AL_INVALID_ENUM, "Invalid null effect float property 0x%04x",
|
|
|
|
param};
|
2013-05-25 17:42:34 -07:00
|
|
|
}
|
|
|
|
}
|
2020-04-10 20:23:20 -07:00
|
|
|
void NullEffect_setParamfv(EffectProps *props, ALenum param, const float *vals)
|
2013-05-25 17:42:34 -07:00
|
|
|
{
|
|
|
|
switch(param)
|
|
|
|
{
|
2018-01-25 15:59:59 -08:00
|
|
|
default:
|
2020-04-10 20:23:20 -07:00
|
|
|
NullEffect_setParamf(props, param, vals[0]);
|
2013-05-25 17:42:34 -07:00
|
|
|
}
|
|
|
|
}
|
2013-05-23 18:50:07 -07:00
|
|
|
|
2020-04-10 20:23:20 -07:00
|
|
|
void NullEffect_getParami(const EffectProps* /*props*/, ALenum param, int* /*val*/)
|
2013-05-25 17:42:34 -07:00
|
|
|
{
|
|
|
|
switch(param)
|
|
|
|
{
|
2018-01-25 15:59:59 -08:00
|
|
|
default:
|
2020-04-10 20:23:20 -07:00
|
|
|
throw effect_exception{AL_INVALID_ENUM, "Invalid null effect integer property 0x%04x",
|
|
|
|
param};
|
2013-05-25 17:42:34 -07:00
|
|
|
}
|
|
|
|
}
|
2020-04-10 20:23:20 -07:00
|
|
|
void NullEffect_getParamiv(const EffectProps *props, ALenum param, int *vals)
|
2013-05-25 17:42:34 -07:00
|
|
|
{
|
|
|
|
switch(param)
|
|
|
|
{
|
2018-01-25 15:59:59 -08:00
|
|
|
default:
|
2020-04-10 20:23:20 -07:00
|
|
|
NullEffect_getParami(props, param, vals);
|
2013-05-25 17:42:34 -07:00
|
|
|
}
|
|
|
|
}
|
2020-04-10 20:23:20 -07:00
|
|
|
void NullEffect_getParamf(const EffectProps* /*props*/, ALenum param, float* /*val*/)
|
2013-05-25 17:42:34 -07:00
|
|
|
{
|
|
|
|
switch(param)
|
|
|
|
{
|
2018-01-25 15:59:59 -08:00
|
|
|
default:
|
2020-04-10 20:23:20 -07:00
|
|
|
throw effect_exception{AL_INVALID_ENUM, "Invalid null effect float property 0x%04x",
|
|
|
|
param};
|
2013-05-25 17:42:34 -07:00
|
|
|
}
|
|
|
|
}
|
2020-04-10 20:23:20 -07:00
|
|
|
void NullEffect_getParamfv(const EffectProps *props, ALenum param, float *vals)
|
2013-05-25 17:42:34 -07:00
|
|
|
{
|
|
|
|
switch(param)
|
|
|
|
{
|
2018-01-25 15:59:59 -08:00
|
|
|
default:
|
2020-04-10 20:23:20 -07:00
|
|
|
NullEffect_getParamf(props, param, vals);
|
2013-05-25 17:42:34 -07:00
|
|
|
}
|
|
|
|
}
|
2013-05-24 23:26:59 -07:00
|
|
|
|
2019-03-22 16:04:13 -07:00
|
|
|
DEFINE_ALEFFECT_VTABLE(NullEffect);
|
2019-03-22 13:33:58 -07:00
|
|
|
|
|
|
|
|
|
|
|
struct NullStateFactory final : public EffectStateFactory {
|
|
|
|
EffectState *create() override;
|
2019-03-22 22:48:12 -07:00
|
|
|
EffectProps getDefaultProps() const noexcept override;
|
2019-03-22 16:04:13 -07:00
|
|
|
const EffectVtable *getEffectVtable() const noexcept override;
|
2019-03-22 13:33:58 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
/* Creates EffectState objects of the appropriate type. */
|
|
|
|
EffectState *NullStateFactory::create()
|
|
|
|
{ return new NullState{}; }
|
|
|
|
|
2019-03-22 16:04:13 -07:00
|
|
|
/* Returns an ALeffectProps initialized with this effect type's default
|
|
|
|
* property values.
|
|
|
|
*/
|
2019-03-22 22:48:12 -07:00
|
|
|
EffectProps NullStateFactory::getDefaultProps() const noexcept
|
2019-03-22 13:33:58 -07:00
|
|
|
{
|
2019-03-22 22:48:12 -07:00
|
|
|
EffectProps props{};
|
2019-03-22 13:33:58 -07:00
|
|
|
return props;
|
|
|
|
}
|
|
|
|
|
2019-03-22 16:04:13 -07:00
|
|
|
/* Returns a pointer to this effect type's global set/get vtable. */
|
|
|
|
const EffectVtable *NullStateFactory::getEffectVtable() const noexcept
|
|
|
|
{ return &NullEffect_vtable; }
|
|
|
|
|
2019-03-22 13:33:58 -07:00
|
|
|
} // namespace
|
|
|
|
|
|
|
|
EffectStateFactory *NullStateFactory_getFactory()
|
|
|
|
{
|
|
|
|
static NullStateFactory NullFactory{};
|
|
|
|
return &NullFactory;
|
|
|
|
}
|