Cleanup sound manager class (#7158)

* Cleanup sound manager client

* Use some const refs
* Use auto on iterators
* Drop unused parameters
* Move sound_openal.* to client folder
* Move sound.cpp + OnDemandSoundFetcher to client/ folder + reorganize includes properly
This commit is contained in:
Loïc Blot 2018-03-24 15:45:25 +01:00 committed by GitHub
parent bcd22fc34c
commit 4fd9715876
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
19 changed files with 151 additions and 140 deletions

@ -227,8 +227,6 @@ LOCAL_SRC_FILES := \
jni/src/serverobject.cpp \ jni/src/serverobject.cpp \
jni/src/shader.cpp \ jni/src/shader.cpp \
jni/src/sky.cpp \ jni/src/sky.cpp \
jni/src/sound.cpp \
jni/src/sound_openal.cpp \
jni/src/staticobject.cpp \ jni/src/staticobject.cpp \
jni/src/subgame.cpp \ jni/src/subgame.cpp \
jni/src/tileanimation.cpp \ jni/src/tileanimation.cpp \
@ -280,6 +278,8 @@ LOCAL_SRC_FILES := \
jni/src/client/hud.cpp \ jni/src/client/hud.cpp \
jni/src/client/inputhandler.cpp \ jni/src/client/inputhandler.cpp \
jni/src/client/renderingengine.cpp \ jni/src/client/renderingengine.cpp \
jni/src/client/sound.cpp \
jni/src/client/sound_openal.cpp \
jni/src/client/tile.cpp \ jni/src/client/tile.cpp \
jni/src/client/joystick_controller.cpp \ jni/src/client/joystick_controller.cpp \
jni/src/client/render/factory.cpp \ jni/src/client/render/factory.cpp \

@ -101,19 +101,6 @@ if(BUILD_CLIENT AND ENABLE_SOUND)
endif() endif()
endif() endif()
if(USE_SOUND)
set(sound_SRCS sound_openal.cpp)
set(SOUND_INCLUDE_DIRS
${OPENAL_INCLUDE_DIR}
${VORBIS_INCLUDE_DIR}
${OGG_INCLUDE_DIR}
)
set(SOUND_LIBRARIES
${OPENAL_LIBRARY}
${VORBIS_LIBRARIES}
)
endif()
option(ENABLE_GLES "Enable OpenGL ES support" FALSE) option(ENABLE_GLES "Enable OpenGL ES support" FALSE)
mark_as_advanced(ENABLE_GLES) mark_as_advanced(ENABLE_GLES)
@ -440,7 +427,6 @@ set(common_SRCS
serverlist.cpp serverlist.cpp
serverobject.cpp serverobject.cpp
settings.cpp settings.cpp
sound.cpp
staticobject.cpp staticobject.cpp
subgame.cpp subgame.cpp
terminal_chat_console.cpp terminal_chat_console.cpp
@ -489,7 +475,6 @@ set(client_SRCS
${client_SRCS} ${client_SRCS}
${common_SRCS} ${common_SRCS}
${gui_SRCS} ${gui_SRCS}
${sound_SRCS}
${client_network_SRCS} ${client_network_SRCS}
${client_irrlicht_changes_SRCS} ${client_irrlicht_changes_SRCS}
camera.cpp camera.cpp

@ -30,6 +30,7 @@ with this program; if not, write to the Free Software Foundation, Inc.,
#include "client/clientevent.h" #include "client/clientevent.h"
#include "client/gameui.h" #include "client/gameui.h"
#include "client/renderingengine.h" #include "client/renderingengine.h"
#include "client/sound.h"
#include "client/tile.h" #include "client/tile.h"
#include "util/auth.h" #include "util/auth.h"
#include "util/directiontables.h" #include "util/directiontables.h"

@ -48,6 +48,7 @@ class MapBlockMesh;
class IWritableTextureSource; class IWritableTextureSource;
class IWritableShaderSource; class IWritableShaderSource;
class IWritableItemDefManager; class IWritableItemDefManager;
class ISoundManager;
class NodeDefManager; class NodeDefManager;
//class IWritableCraftDefManager; //class IWritableCraftDefManager;
class ClientMediaDownloader; class ClientMediaDownloader;

@ -1,4 +1,21 @@
set(sound_SRCS ${CMAKE_CURRENT_SOURCE_DIR}/sound.cpp)
if(USE_SOUND)
set(sound_SRCS ${sound_SRCS}
${CMAKE_CURRENT_SOURCE_DIR}/sound_openal.cpp)
set(SOUND_INCLUDE_DIRS
${OPENAL_INCLUDE_DIR}
${VORBIS_INCLUDE_DIR}
${OGG_INCLUDE_DIR}
PARENT_SCOPE)
set(SOUND_LIBRARIES
${OPENAL_LIBRARY}
${VORBIS_LIBRARIES}
PARENT_SCOPE)
endif()
set(client_SRCS set(client_SRCS
${sound_SRCS}
${CMAKE_CURRENT_SOURCE_DIR}/meshgen/collector.cpp ${CMAKE_CURRENT_SOURCE_DIR}/meshgen/collector.cpp
${CMAKE_CURRENT_SOURCE_DIR}/render/anaglyph.cpp ${CMAKE_CURRENT_SOURCE_DIR}/render/anaglyph.cpp
${CMAKE_CURRENT_SOURCE_DIR}/render/core.cpp ${CMAKE_CURRENT_SOURCE_DIR}/render/core.cpp

@ -21,5 +21,3 @@ with this program; if not, write to the Free Software Foundation, Inc.,
// Global DummySoundManager singleton // Global DummySoundManager singleton
DummySoundManager dummySoundManager; DummySoundManager dummySoundManager;

111
src/client/sound.h Normal file

@ -0,0 +1,111 @@
/*
Minetest
Copyright (C) 2013 celeron55, Perttu Ahola <celeron55@gmail.com>
This program 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 2.1 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 Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License along
with this program; if not, write to the Free Software Foundation, Inc.,
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#pragma once
#include <set>
#include <string>
#include "irr_v3d.h"
#include "../sound.h"
class OnDemandSoundFetcher
{
public:
virtual void fetchSounds(const std::string &name,
std::set<std::string> &dst_paths,
std::set<std::string> &dst_datas) = 0;
};
class ISoundManager
{
public:
virtual ~ISoundManager() = default;
// Multiple sounds can be loaded per name; when played, the sound
// should be chosen randomly from alternatives
// Return value determines success/failure
virtual bool loadSoundFile(
const std::string &name, const std::string &filepath) = 0;
virtual bool loadSoundData(
const std::string &name, const std::string &filedata) = 0;
virtual void updateListener(
const v3f &pos, const v3f &vel, const v3f &at, const v3f &up) = 0;
virtual void setListenerGain(float gain) = 0;
// playSound functions return -1 on failure, otherwise a handle to the
// sound. If name=="", call should be ignored without error.
virtual int playSound(const std::string &name, bool loop, float volume,
float fade = 0.0f, float pitch = 1.0f) = 0;
virtual int playSoundAt(const std::string &name, bool loop, float volume, v3f pos,
float pitch = 1.0f) = 0;
virtual void stopSound(int sound) = 0;
virtual bool soundExists(int sound) = 0;
virtual void updateSoundPosition(int sound, v3f pos) = 0;
virtual bool updateSoundGain(int id, float gain) = 0;
virtual float getSoundGain(int id) = 0;
virtual void step(float dtime) = 0;
virtual void fadeSound(int sound, float step, float gain) = 0;
int playSound(const SimpleSoundSpec &spec, bool loop)
{
return playSound(spec.name, loop, spec.gain, spec.fade, spec.pitch);
}
int playSoundAt(const SimpleSoundSpec &spec, bool loop, const v3f &pos)
{
return playSoundAt(spec.name, loop, spec.gain, pos, spec.pitch);
}
};
class DummySoundManager : public ISoundManager
{
public:
virtual bool loadSoundFile(const std::string &name, const std::string &filepath)
{
return true;
}
virtual bool loadSoundData(const std::string &name, const std::string &filedata)
{
return true;
}
void updateListener(const v3f &pos, const v3f &vel, const v3f &at, const v3f &up)
{
}
void setListenerGain(float gain) {}
int playSound(const std::string &name, bool loop, float volume, float fade,
float pitch)
{
return 0;
}
int playSoundAt(const std::string &name, bool loop, float volume, v3f pos,
float pitch)
{
return 0;
}
void stopSound(int sound) {}
bool soundExists(int sound) { return false; }
void updateSoundPosition(int sound, v3f pos) {}
bool updateSoundGain(int id, float gain) { return false; }
float getSoundGain(int id) { return 0; }
void step(float dtime) {}
void fadeSound(int sound, float step, float gain) {}
};
// Global DummySoundManager singleton
extern DummySoundManager dummySoundManager;

@ -68,26 +68,6 @@ static void delete_alccontext(ALCcontext *p)
} }
} }
static const char *alcErrorString(ALCenum err)
{
switch (err) {
case ALC_NO_ERROR:
return "no error";
case ALC_INVALID_DEVICE:
return "invalid device";
case ALC_INVALID_CONTEXT:
return "invalid context";
case ALC_INVALID_ENUM:
return "invalid enum";
case ALC_INVALID_VALUE:
return "invalid value";
case ALC_OUT_OF_MEMORY:
return "out of memory";
default:
return "<unknown OpenAL error>";
}
}
static const char *alErrorString(ALenum err) static const char *alErrorString(ALenum err)
{ {
switch (err) { switch (err) {
@ -331,7 +311,6 @@ private:
int m_next_id; int m_next_id;
std::unordered_map<std::string, std::vector<SoundBuffer*>> m_buffers; std::unordered_map<std::string, std::vector<SoundBuffer*>> m_buffers;
std::unordered_map<int, PlayingSound*> m_sounds_playing; std::unordered_map<int, PlayingSound*> m_sounds_playing;
v3f m_listener_pos;
struct FadeState { struct FadeState {
FadeState() = default; FadeState() = default;
@ -563,9 +542,8 @@ public:
return false; return false;
} }
void updateListener(v3f pos, v3f vel, v3f at, v3f up) void updateListener(const v3f &pos, const v3f &vel, const v3f &at, const v3f &up)
{ {
m_listener_pos = pos;
alListener3f(AL_POSITION, pos.X, pos.Y, pos.Z); alListener3f(AL_POSITION, pos.X, pos.Y, pos.Z);
alListener3f(AL_VELOCITY, vel.X, vel.Y, vel.Z); alListener3f(AL_VELOCITY, vel.X, vel.Y, vel.Z);
ALfloat f[6]; ALfloat f[6];
@ -634,7 +612,7 @@ public:
return; return;
float chkGain = 0; float chkGain = 0;
for (std::unordered_map<int, FadeState>::iterator i = m_sounds_fading.begin(); for (auto i = m_sounds_fading.begin();
i != m_sounds_fading.end();) { i != m_sounds_fading.end();) {
if (i->second.step < 0.f) if (i->second.step < 0.f)
chkGain = -(i->second.current_gain); chkGain = -(i->second.current_gain);
@ -665,7 +643,7 @@ public:
void updateSoundPosition(int id, v3f pos) void updateSoundPosition(int id, v3f pos)
{ {
std::unordered_map<int, PlayingSound*>::iterator i = m_sounds_playing.find(id); auto i = m_sounds_playing.find(id);
if (i == m_sounds_playing.end()) if (i == m_sounds_playing.end())
return; return;
PlayingSound *sound = i->second; PlayingSound *sound = i->second;
@ -678,7 +656,7 @@ public:
bool updateSoundGain(int id, float gain) bool updateSoundGain(int id, float gain)
{ {
std::unordered_map<int, PlayingSound*>::iterator i = m_sounds_playing.find(id); auto i = m_sounds_playing.find(id);
if (i == m_sounds_playing.end()) if (i == m_sounds_playing.end())
return false; return false;
@ -689,7 +667,7 @@ public:
float getSoundGain(int id) float getSoundGain(int id)
{ {
std::unordered_map<int, PlayingSound*>::iterator i = m_sounds_playing.find(id); auto i = m_sounds_playing.find(id);
if (i == m_sounds_playing.end()) if (i == m_sounds_playing.end())
return 0; return 0;

@ -27,4 +27,5 @@ class SoundManagerSingleton;
extern std::shared_ptr<SoundManagerSingleton> g_sound_manager_singleton; extern std::shared_ptr<SoundManagerSingleton> g_sound_manager_singleton;
std::shared_ptr<SoundManagerSingleton> createSoundManagerSingleton(); std::shared_ptr<SoundManagerSingleton> createSoundManagerSingleton();
ISoundManager *createOpenALSoundManager(SoundManagerSingleton *smg, OnDemandSoundFetcher *fetcher); ISoundManager *createOpenALSoundManager(
SoundManagerSingleton *smg, OnDemandSoundFetcher *fetcher);

@ -26,6 +26,7 @@ with this program; if not, write to the Free Software Foundation, Inc.,
#include "util/numeric.h" // For IntervalLimiter #include "util/numeric.h" // For IntervalLimiter
#include "util/serialize.h" #include "util/serialize.h"
#include "util/basic_macros.h" #include "util/basic_macros.h"
#include "client/sound.h"
#include "client/tile.h" #include "client/tile.h"
#include "environment.h" #include "environment.h"
#include "collision.h" #include "collision.h"
@ -1177,7 +1178,7 @@ void GenericCAO::updateAnimationSpeed()
{ {
if (!m_animated_meshnode) if (!m_animated_meshnode)
return; return;
m_animated_meshnode->setAnimationSpeed(m_animation_speed); m_animated_meshnode->setAnimationSpeed(m_animation_speed);
} }

@ -69,10 +69,10 @@ with this program; if not, write to the Free Software Foundation, Inc.,
#include "script/scripting_client.h" #include "script/scripting_client.h"
#if USE_SOUND #if USE_SOUND
#include "sound_openal.h" #include "client/sound_openal.h"
#else
#include "client/sound.h"
#endif #endif
/* /*
Text input system Text input system
*/ */

@ -27,7 +27,6 @@ class IItemDefManager;
class NodeDefManager; class NodeDefManager;
class ICraftDefManager; class ICraftDefManager;
class ITextureSource; class ITextureSource;
class ISoundManager;
class IShaderSource; class IShaderSource;
class MtEventManager; class MtEventManager;
class IRollbackManager; class IRollbackManager;

@ -31,7 +31,7 @@ with this program; if not, write to the Free Software Foundation, Inc.,
#include "settings.h" #include "settings.h"
#include "guiMainMenu.h" #include "guiMainMenu.h"
#include "sound.h" #include "sound.h"
#include "sound_openal.h" #include "client/sound_openal.h"
#include "clouds.h" #include "clouds.h"
#include "httpfetch.h" #include "httpfetch.h"
#include "log.h" #include "log.h"

@ -25,7 +25,7 @@ with this program; if not, write to the Free Software Foundation, Inc.,
#include "irrlichttypes.h" #include "irrlichttypes.h"
#include "modalMenu.h" #include "modalMenu.h"
#include "guiFormSpecMenu.h" #include "guiFormSpecMenu.h"
#include "sound.h" #include "client/sound.h"
#include "client/tile.h" #include "client/tile.h"
#include "util/enriched_string.h" #include "util/enriched_string.h"

@ -32,6 +32,7 @@ with this program; if not, write to the Free Software Foundation, Inc.,
#include "server.h" #include "server.h"
#include "util/strfnd.h" #include "util/strfnd.h"
#include "client/clientevent.h" #include "client/clientevent.h"
#include "client/sound.h"
#include "network/clientopcodes.h" #include "network/clientopcodes.h"
#include "network/connection.h" #include "network/connection.h"
#include "script/scripting_client.h" #include "script/scripting_client.h"

@ -22,6 +22,7 @@ with this program; if not, write to the Free Software Foundation, Inc.,
#include "chatmessage.h" #include "chatmessage.h"
#include "client.h" #include "client.h"
#include "client/clientevent.h" #include "client/clientevent.h"
#include "client/sound.h"
#include "clientenvironment.h" #include "clientenvironment.h"
#include "common/c_content.h" #include "common/c_content.h"
#include "common/c_converter.h" #include "common/c_converter.h"

@ -23,14 +23,6 @@ with this program; if not, write to the Free Software Foundation, Inc.,
#include <string> #include <string>
#include "irrlichttypes_bloated.h" #include "irrlichttypes_bloated.h"
class OnDemandSoundFetcher
{
public:
virtual void fetchSounds(const std::string &name,
std::set<std::string> &dst_paths,
std::set<std::string> &dst_datas) = 0;
};
struct SimpleSoundSpec struct SimpleSoundSpec
{ {
SimpleSoundSpec(const std::string &name = "", float gain = 1.0f, SimpleSoundSpec(const std::string &name = "", float gain = 1.0f,
@ -42,83 +34,8 @@ struct SimpleSoundSpec
bool exists() const { return !name.empty(); } bool exists() const { return !name.empty(); }
std::string name = ""; std::string name;
float gain = 1.0f; float gain = 1.0f;
float fade = 0.0f; float fade = 0.0f;
float pitch = 1.0f; float pitch = 1.0f;
}; };
class ISoundManager
{
public:
virtual ~ISoundManager() = default;
// Multiple sounds can be loaded per name; when played, the sound
// should be chosen randomly from alternatives
// Return value determines success/failure
virtual bool loadSoundFile(
const std::string &name, const std::string &filepath) = 0;
virtual bool loadSoundData(
const std::string &name, const std::string &filedata) = 0;
virtual void updateListener(v3f pos, v3f vel, v3f at, v3f up) = 0;
virtual void setListenerGain(float gain) = 0;
// playSound functions return -1 on failure, otherwise a handle to the
// sound. If name=="", call should be ignored without error.
virtual int playSound(const std::string &name, bool loop, float volume,
float fade = 0.0f, float pitch = 1.0f) = 0;
virtual int playSoundAt(const std::string &name, bool loop, float volume, v3f pos,
float pitch = 1.0f) = 0;
virtual void stopSound(int sound) = 0;
virtual bool soundExists(int sound) = 0;
virtual void updateSoundPosition(int sound, v3f pos) = 0;
virtual bool updateSoundGain(int id, float gain) = 0;
virtual float getSoundGain(int id) = 0;
virtual void step(float dtime) = 0;
virtual void fadeSound(int sound, float step, float gain) = 0;
int playSound(const SimpleSoundSpec &spec, bool loop)
{
return playSound(spec.name, loop, spec.gain, spec.fade, spec.pitch);
}
int playSoundAt(const SimpleSoundSpec &spec, bool loop, const v3f &pos)
{
return playSoundAt(spec.name, loop, spec.gain, pos, spec.pitch);
}
};
class DummySoundManager : public ISoundManager
{
public:
virtual bool loadSoundFile(const std::string &name, const std::string &filepath)
{
return true;
}
virtual bool loadSoundData(const std::string &name, const std::string &filedata)
{
return true;
}
void updateListener(v3f pos, v3f vel, v3f at, v3f up) {}
void setListenerGain(float gain) {}
int playSound(const std::string &name, bool loop, float volume, float fade,
float pitch)
{
return 0;
}
int playSoundAt(const std::string &name, bool loop, float volume, v3f pos,
float pitch)
{
return 0;
}
void stopSound(int sound) {}
bool soundExists(int sound) { return false; }
void updateSoundPosition(int sound, v3f pos) {}
bool updateSoundGain(int id, float gain) { return false; }
float getSoundGain(int id) { return 0; }
void step(float dtime) {}
void fadeSound(int sound, float step, float gain) {}
};
// Global DummySoundManager singleton
extern DummySoundManager dummySoundManager;

@ -19,6 +19,7 @@ with this program; if not, write to the Free Software Foundation, Inc.,
#include "test.h" #include "test.h"
#include "client/sound.h"
#include "nodedef.h" #include "nodedef.h"
#include "itemdef.h" #include "itemdef.h"
#include "gamedef.h" #include "gamedef.h"

@ -7,6 +7,7 @@ src/chat.h
src/chat_interface.h src/chat_interface.h
src/client/clientlauncher.cpp src/client/clientlauncher.cpp
src/client/clientlauncher.h src/client/clientlauncher.h
src/client/sound_openal.cpp
src/client.cpp src/client.cpp
src/clientenvironment.cpp src/clientenvironment.cpp
src/clientenvironment.h src/clientenvironment.h
@ -328,8 +329,6 @@ src/shader.cpp
src/shader.h src/shader.h
src/sky.cpp src/sky.cpp
src/sound.cpp src/sound.cpp
src/sound_openal.cpp
src/sound_openal.h
src/staticobject.cpp src/staticobject.cpp
src/staticobject.h src/staticobject.h
src/subgame.cpp src/subgame.cpp