diff options
author | Chris Robinson <[email protected]> | 2018-11-12 19:02:38 -0800 |
---|---|---|
committer | Chris Robinson <[email protected]> | 2018-11-12 19:02:38 -0800 |
commit | d4d0b1fdd48e1c056fad9cbe3e063fc9de1a0b75 (patch) | |
tree | 444431c3168625100071641aa738adac5fb369a5 /Alc/panning.cpp | |
parent | c0f2858f3d47323205bb90b3b1cc7db2553e6917 (diff) |
Use a regular char* for the HRTF string name
Diffstat (limited to 'Alc/panning.cpp')
-rw-r--r-- | Alc/panning.cpp | 25 |
1 files changed, 18 insertions, 7 deletions
diff --git a/Alc/panning.cpp b/Alc/panning.cpp index db476884..e39abab9 100644 --- a/Alc/panning.cpp +++ b/Alc/panning.cpp @@ -38,7 +38,9 @@ #include "bs2b.h" -static const ALsizei FuMa2ACN[MAX_AMBI_COEFFS] = { +namespace { + +constexpr ALsizei FuMa2ACN[MAX_AMBI_COEFFS] = { 0, /* W */ 3, /* X */ 1, /* Y */ @@ -56,11 +58,20 @@ static const ALsizei FuMa2ACN[MAX_AMBI_COEFFS] = { 15, /* P */ 9, /* Q */ }; -static const ALsizei ACN2ACN[MAX_AMBI_COEFFS] = { +constexpr ALsizei ACN2ACN[MAX_AMBI_COEFFS] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 }; +char *alstrdup(const_al_string str) +{ + const size_t len{alstr_length(str)}; + char *ret{static_cast<char*>(al_calloc(DEF_ALIGN, len+1))}; + memcpy(ret, alstr_get_cstr(str), len); + return ret; +} + +} // namespace void CalcAmbiCoeffs(const ALfloat y, const ALfloat z, const ALfloat x, const ALfloat spread, ALfloat coeffs[MAX_AMBI_COEFFS]) @@ -931,7 +942,8 @@ void aluInitRenderer(ALCdevice *device, ALint hrtf_id, enum HrtfRequestMode hrtf al_free(device->Hrtf); device->Hrtf = NULL; device->HrtfHandle = NULL; - alstr_clear(&device->HrtfName); + al_free(device->HrtfName); + device->HrtfName = NULL; device->Render_Mode = NormalRender; memset(&device->Dry.Ambi, 0, sizeof(device->Dry.Ambi)); @@ -1114,7 +1126,7 @@ void aluInitRenderer(ALCdevice *device, ALint hrtf_id, enum HrtfRequestMode hrtf if(hrtf && hrtf->sampleRate == device->Frequency) { device->HrtfHandle = hrtf; - alstr_copy(&device->HrtfName, entry->name); + device->HrtfName = alstrdup(entry->name); } else if(hrtf) Hrtf_DecRef(hrtf); @@ -1127,7 +1139,7 @@ void aluInitRenderer(ALCdevice *device, ALint hrtf_id, enum HrtfRequestMode hrtf if(hrtf && hrtf->sampleRate == device->Frequency) { device->HrtfHandle = hrtf; - alstr_copy(&device->HrtfName, entry->name); + device->HrtfName = alstrdup(entry->name); } else if(hrtf) Hrtf_DecRef(hrtf); @@ -1164,8 +1176,7 @@ void aluInitRenderer(ALCdevice *device, ALint hrtf_id, enum HrtfRequestMode hrtf } TRACE("%s HRTF rendering enabled, using \"%s\"\n", - ((device->Render_Mode == HrtfRender) ? "Full" : "Basic"), - alstr_get_cstr(device->HrtfName) + ((device->Render_Mode == HrtfRender) ? "Full" : "Basic"), device->HrtfName ); InitHrtfPanning(device); return; |