Merge from Git repository

--HG--
branch : develop
feature/streamed-package
NO-BREAK SPACE OÜ 5 years ago
commit 8100f15ce7

@ -48,15 +48,15 @@ CHECK_OUT_OF_SOURCE()
IF(CMAKE_VERSION VERSION_GREATER "2.8.10") IF(CMAKE_VERSION VERSION_GREATER "2.8.10")
STRING(TIMESTAMP CURRENT_YEAR "%Y") STRING(TIMESTAMP CURRENT_YEAR "%Y")
ELSE() ELSE()
SET(CURRENT_YEAR "2016") SET(CURRENT_YEAR "2019")
ENDIF() ENDIF()
CMAKE_MINIMUM_REQUIRED(VERSION 2.6) CMAKE_MINIMUM_REQUIRED(VERSION 2.6)
PROJECT(RyzomCore CXX C) PROJECT(RyzomCore CXX C)
SET(NL_VERSION_MAJOR 1) SET(NL_VERSION_MAJOR 1)
SET(NL_VERSION_MINOR 0) SET(NL_VERSION_MINOR 0)
SET(NL_VERSION_PATCH 1) SET(NL_VERSION_PATCH 2)
SET(YEAR "2004-${CURRENT_YEAR}") SET(YEAR "2001-${CURRENT_YEAR}")
SET(AUTHOR "Winch Gate and The Ryzom Core Community") SET(AUTHOR "Winch Gate and The Ryzom Core Community")
SET(RYZOM_VERSION_MAJOR 3) SET(RYZOM_VERSION_MAJOR 3)

@ -21,7 +21,6 @@
#include "nel/misc/string_mapper.h" #include "nel/misc/string_mapper.h"
#include "nel/3d/ps_located.h" #include "nel/3d/ps_located.h"
#include "nel/3d/ps_attrib.h" #include "nel/3d/ps_attrib.h"
#include "nel/misc/sheet_id.h"
@ -64,13 +63,13 @@ public:
virtual void step(TPSProcessPass pass); virtual void step(TPSProcessPass pass);
/// set the name of the sound /// set the name of the sound
void setSoundName(const NLMISC::CSheetId &soundName) void setSoundName(const NLMISC::TStringId &soundName)
{ {
_SoundName = soundName; _SoundName = soundName;
} }
/// get the name of the sound /// get the name of the sound
const NLMISC::CSheetId &getSoundName(void) const const NLMISC::TStringId &getSoundName(void) const
{ {
return _SoundName; return _SoundName;
} }
@ -162,7 +161,7 @@ protected:
void removeAllSources(); void removeAllSources();
CPSAttrib<UPSSoundInstance *> _Sounds; CPSAttrib<UPSSoundInstance *> _Sounds;
NLMISC::CSheetId _SoundName; NLMISC::TStringId _SoundName;
float _Gain; float _Gain;
CPSAttribMaker<float> * _GainScheme; CPSAttribMaker<float> * _GainScheme;
float _Pitch; float _Pitch;

@ -162,7 +162,7 @@ public:
/// inherited from IPSSoundServer /// inherited from IPSSoundServer
UPSSoundInstance *createSound(const NLMISC::CSheetId &soundName, bool spawned = true) UPSSoundInstance *createSound(const NLMISC::TStringId &soundName, bool spawned = true)
{ {
if (!_AudioMixer) if (!_AudioMixer)
return NULL; return NULL;

@ -19,7 +19,6 @@
#include "nel/misc/types_nl.h" #include "nel/misc/types_nl.h"
#include "nel/misc/string_mapper.h" #include "nel/misc/string_mapper.h"
#include "nel/misc/sheet_id.h"
#include <string> #include <string>
namespace NLMISC namespace NLMISC
@ -51,7 +50,7 @@ struct UPSSoundServer
* \param spawn true if the sound must be spawned e.g it continues after this interface is removed * \param spawn true if the sound must be spawned e.g it continues after this interface is removed
* \param cb useful only for spawned sound, it tells when a spawned sound has been removed * \param cb useful only for spawned sound, it tells when a spawned sound has been removed
*/ */
virtual UPSSoundInstance *createSound(const NLMISC::CSheetId &soundName, bool spawn = false) = 0; virtual UPSSoundInstance *createSound(const NLMISC::TStringId &soundName, bool spawn = false) = 0;
}; };

@ -25,7 +25,6 @@
#include <nel/misc/time_nl.h> #include <nel/misc/time_nl.h>
#include <nel/misc/stream.h> #include <nel/misc/stream.h>
#include <nel/misc/singleton.h> #include <nel/misc/singleton.h>
#include <nel/misc/sheet_id.h>
#include <nel/sound/u_audio_mixer.h> #include <nel/sound/u_audio_mixer.h>
#include <nel/georges/u_form.h> #include <nel/georges/u_form.h>
@ -181,7 +180,7 @@ public:
// Load environment sounds ; treeRoot can be null if you don't want an access to the envsounds // Load environment sounds ; treeRoot can be null if you don't want an access to the envsounds
// virtual void loadEnvSounds( const char *filename, UEnvSound **treeRoot=NULL ); // virtual void loadEnvSounds( const char *filename, UEnvSound **treeRoot=NULL );
/// Get a TSoundId from a name (returns NULL if not found) /// Get a TSoundId from a name (returns NULL if not found)
virtual TSoundId getSoundId( const NLMISC::CSheetId &name ); virtual TSoundId getSoundId( const NLMISC::TStringId &name );
/// Gets the group controller for the given group tree path with separator '/', if it doesn't exist yet it will be created. /// Gets the group controller for the given group tree path with separator '/', if it doesn't exist yet it will be created.
/// Examples: "music", "effects", "dialog", "music/background", "music/loading", "music/player", etcetera /// Examples: "music", "effects", "dialog", "music/background", "music/loading", "music/player", etcetera
@ -193,7 +192,7 @@ public:
* pass a callback function that will be called (if not NULL) just before deleting the spawned * pass a callback function that will be called (if not NULL) just before deleting the spawned
* source. * source.
*/ */
virtual USource *createSource( const NLMISC::CSheetId &name, bool spawn=false, TSpawnEndCallback cb=NULL, void *cbUserParam = NULL, NL3D::CCluster *cluster = 0, CSoundContext *context = 0, UGroupController *groupController = NULL); virtual USource *createSource( const NLMISC::TStringId &name, bool spawn=false, TSpawnEndCallback cb=NULL, void *cbUserParam = NULL, NL3D::CCluster *cluster = 0, CSoundContext *context = 0, UGroupController *groupController = NULL);
/// Add a logical sound source (by sound id). To remove a source, just delete it. See createSource(const char*) /// Add a logical sound source (by sound id). To remove a source, just delete it. See createSource(const char*)
virtual USource *createSource( TSoundId id, bool spawn=false, TSpawnEndCallback cb=NULL, void *cbUserParam = NULL, NL3D::CCluster *cluster = 0, CSoundContext *context = 0, UGroupController *groupController = NULL); virtual USource *createSource( TSoundId id, bool spawn=false, TSpawnEndCallback cb=NULL, void *cbUserParam = NULL, NL3D::CCluster *cluster = 0, CSoundContext *context = 0, UGroupController *groupController = NULL);
/// Add a source which was created by an EnvSound /// Add a source which was created by an EnvSound
@ -224,7 +223,7 @@ public:
/// Return the names of the sounds (call this method after loadSounds()) /// Return the names of the sounds (call this method after loadSounds())
virtual void getSoundNames( std::vector<NLMISC::CSheetId> &names ) const; virtual void getSoundNames( std::vector<NLMISC::TStringId> &names ) const;
/// Return the number of mixing tracks (voices) /// Return the number of mixing tracks (voices)
virtual uint getPolyphony() const { return (uint)_Tracks.size(); } virtual uint getPolyphony() const { return (uint)_Tracks.size(); }
/// Return the number of sources instance. /// Return the number of sources instance.
@ -445,7 +444,7 @@ private:
/// Witch parameter to control /// Witch parameter to control
TControledParamId ParamId; TControledParamId ParamId;
/// The controled sounds names. /// The controled sounds names.
std::vector<NLMISC::CSheetId> SoundNames; std::vector<NLMISC::TStringId> SoundNames;
/// Current parameter value /// Current parameter value
float Value; float Value;
/// All the sources controled by this variable /// All the sources controled by this variable

@ -64,12 +64,22 @@ public:
/// Associtation clas for storage of sound / filter. /// Associtation clas for storage of sound / filter.
struct TSoundInfo struct TSoundInfo
{ {
NLMISC::CSheetId SoundName; NLMISC::TStringId SoundName;
UAudioMixer::TBackgroundFlags Filter; UAudioMixer::TBackgroundFlags Filter;
void serial(NLMISC::IStream &s) void serial(NLMISC::IStream &s)
{ {
SoundName.serialString(s, "sound"); std::string soundName;
if (s.isReading())
{
s.serial(soundName);
SoundName = NLMISC::CStringMapper::map(soundName);
}
else
{
soundName = NLMISC::CStringMapper::unmap(SoundName);
s.serial(soundName);
}
s.serial(Filter); s.serial(Filter);
} }
}; };

@ -229,7 +229,7 @@ private:
struct TSoundData struct TSoundData
{ {
/// The name of the sound. /// The name of the sound.
NLMISC::CSheetId SoundName; NLMISC::TStringId SoundName;
/// The reference to the sound. /// The reference to the sound.
CSound *Sound; CSound *Sound;
/// A source instance of the sound (may be NULL). /// A source instance of the sound (may be NULL).

@ -19,7 +19,6 @@
#include "nel/misc/types_nl.h" #include "nel/misc/types_nl.h"
#include "nel/misc/string_mapper.h" #include "nel/misc/string_mapper.h"
#include "nel/misc/sheet_id.h"
#include <vector> #include <vector>
#include <map> #include <map>
@ -254,9 +253,9 @@ private:
/// The current cluster playing source indexed with sound group id /// The current cluster playing source indexed with sound group id
TClusterSoundCont _Sources; TClusterSoundCont _Sources;
typedef CHashMap<NLMISC::TStringId, NLMISC::CSheetId, NLMISC::CStringIdHashMapTraits> TStringSheetMap; typedef CHashMap<NLMISC::TStringId, NLMISC::TStringId, NLMISC::CStringIdHashMapTraits> TStringStringMap;
/// The sound_group to sound assoc /// The sound_group to sound assoc
TStringSheetMap _SoundGroupToSound; TStringStringMap _SoundGroupToSound;
}; };
} // NLSOUND } // NLSOUND

@ -52,8 +52,8 @@ public:
const std::vector<uint32> &getSoundSeq() const { return _SoundSeq;} const std::vector<uint32> &getSoundSeq() const { return _SoundSeq;}
const std::vector<uint32> &getDelaySeq() const { return _DelaySeq;} const std::vector<uint32> &getDelaySeq() const { return _DelaySeq;}
NLMISC::CSheetId getSound(uint index) const { return !_Sounds.empty() ? _Sounds[index%_Sounds.size()]:NLMISC::CSheetId::Unknown;} NLMISC::TStringId getSound(uint index) const { return !_Sounds.empty() ? _Sounds[index%_Sounds.size()]:0;}
const std::vector<NLMISC::CSheetId> &getSounds() const { return _Sounds;} const std::vector<NLMISC::TStringId> &getSounds() const { return _Sounds;}
uint32 getFadeLength() const { return _XFadeLength;} uint32 getFadeLength() const { return _XFadeLength;}
@ -87,7 +87,7 @@ private:
virtual float getMaxDistance() const; virtual float getMaxDistance() const;
TPATTERN_MODE _PatternMode; TPATTERN_MODE _PatternMode;
std::vector<NLMISC::CSheetId> _Sounds; std::vector<NLMISC::TStringId> _Sounds;
float _TicksPerSeconds; float _TicksPerSeconds;
std::vector<uint32> _SoundSeq; std::vector<uint32> _SoundSeq;
/// Sequence of delay in millisec. /// Sequence of delay in millisec.

@ -144,7 +144,7 @@ class CContextSoundContainer : public IContextSoundContainer
virtual void addSound(CSound *sound, const std::string &baseName) virtual void addSound(CSound *sound, const std::string &baseName)
{ {
const std::string &patternName = sound->getName().toString(); /*NLMISC::CStringMapper::unmap(sound->getName())*/; const std::string &patternName = NLMISC::CStringMapper::unmap(sound->getName());
nlassert(patternName.size() >= baseName.size()); nlassert(patternName.size() >= baseName.size());
std::string arg; std::string arg;
@ -183,7 +183,7 @@ class CContextSoundContainer : public IContextSoundContainer
if (i != NbJoker) if (i != NbJoker)
return; return;
nlassertex(i==NbJoker, ("Error while adding sound '%s' into context sound container", sound->getName().toString().c_str()/*NLMISC::CStringMapper::unmap(sound->getName()).c_str()*/)); nlassertex(i==NbJoker, ("Error while adding sound '%s' into context sound container", NLMISC::CStringMapper::unmap(sound->getName()).c_str()));
sint randomValue = 0; sint randomValue = 0;
if (UseRandom) if (UseRandom)
@ -198,7 +198,7 @@ class CContextSoundContainer : public IContextSoundContainer
} }
else if (!arg.empty()) else if (!arg.empty())
{ {
nlassertex (!ok, ("Error while adding sound '%s' into context sound container", sound->getName().toString().c_str()/*NLMISC::CStringMapper::unmap(sound->getName()).c_str()*/)); nlassertex (!ok, ("Error while adding sound '%s' into context sound container", NLMISC::CStringMapper::unmap(sound->getName()).c_str()));
// end of the argument. // end of the argument.
NLMISC::fromString(arg, randomValue); NLMISC::fromString(arg, randomValue);
arg.clear(); arg.clear();
@ -210,13 +210,13 @@ class CContextSoundContainer : public IContextSoundContainer
// read the potential last arg. // read the potential last arg.
if (!arg.empty()) if (!arg.empty())
{ {
nlassertex (!ok, ("Error while adding sound '%s' into context sound container", sound->getName().toString().c_str()/*NLMISC::CStringMapper::unmap(sound->getName()).c_str()*/)); nlassertex (!ok, ("Error while adding sound '%s' into context sound container", NLMISC::CStringMapper::unmap(sound->getName()).c_str()));
// end of the argument. // end of the argument.
NLMISC::fromString(arg, randomValue); NLMISC::fromString(arg, randomValue);
arg.clear(); arg.clear();
ok = true; ok = true;
} }
nlassertex (ok, ("Error while adding sound '%s' into context sound container", sound->getName().toString().c_str()/*NLMISC::CStringMapper::unmap(sound->getName()).c_str()*/)); nlassertex (ok, ("Error while adding sound '%s' into context sound container", NLMISC::CStringMapper::unmap(sound->getName()).c_str()));
} }
else else
@ -232,9 +232,9 @@ class CContextSoundContainer : public IContextSoundContainer
if (!ret.second) if (!ret.second)
{ {
typename THashContextSound::iterator it = _ContextSounds.find(cm); typename THashContextSound::iterator it = _ContextSounds.find(cm);
nlassertex(it != _ContextSounds.end(), ("Error wile adding soudn '%s' into context sound container", sound->getName().toString().c_str()/*NLMISC::CStringMapper::unmap(sound->getName()).c_str()*/)); nlassertex(it != _ContextSounds.end(), ("Error wile adding soudn '%s' into context sound container", NLMISC::CStringMapper::unmap(sound->getName()).c_str()));
nlwarning("Sound %s has the same context matcher as the sound %s", sound->getName().toString().c_str()/*NLMISC::CStringMapper::unmap(sound->getName()).c_str()*/, it->second->getName().toString().c_str() /*NLMISC::CStringMapper::unmap(it->second->getName()).c_str()*/); nlwarning("Sound %s has the same context matcher as the sound %s", NLMISC::CStringMapper::unmap(sound->getName()).c_str(), NLMISC::CStringMapper::unmap(it->second->getName()).c_str());
} }
} }
@ -260,7 +260,7 @@ class CContextSoundContainer : public IContextSoundContainer
typename THashContextSound::const_iterator first(_ContextSounds.begin()), last(_ContextSounds.end()); typename THashContextSound::const_iterator first(_ContextSounds.begin()), last(_ContextSounds.end());
for (; first != last; ++first) for (; first != last; ++first)
{ {
subsounds.push_back(std::make_pair(first->second->getName().toString()/*NLMISC::CStringMapper::unmap(first->second->getName())*/, first->second)); subsounds.push_back(std::make_pair(NLMISC::CStringMapper::unmap(first->second->getName()), first->second));
} }
} }

@ -22,7 +22,6 @@
#include "nel/misc/string_mapper.h" #include "nel/misc/string_mapper.h"
#include "nel/sound/u_source.h" #include "nel/sound/u_source.h"
#include "nel/georges/u_form_elm.h" #include "nel/georges/u_form_elm.h"
#include "nel/misc/sheet_id.h"
#include <string> #include <string>
namespace NLSOUND { namespace NLSOUND {
@ -36,7 +35,7 @@ class CGroupController;
/// Sound names hash map /// Sound names hash map
//typedef std::hash_map<std::string, CSound*> TSoundMap; //typedef std::hash_map<std::string, CSound*> TSoundMap;
typedef CHashMap<NLMISC::CSheetId, CSound*, NLMISC::CStringIdHashMapTraits> TSoundMap; typedef CHashMap<NLMISC::TStringId, CSound*, NLMISC::CStringIdHashMapTraits> TSoundMap;
/// Sound names set (for ambiant sounds) /// Sound names set (for ambiant sounds)
typedef std::set<CSound*> TSoundSet; typedef std::set<CSound*> TSoundSet;
@ -54,7 +53,7 @@ class CSound
friend class CAudioMixerUser; friend class CAudioMixerUser;
public: public:
/// Factory for specialized sound. /// Factory for specialized sound.
static CSound *createSound(const std::string &name, NLGEORGES::UFormElm& formRoot); static CSound *createSound(const std::string &filename, NLGEORGES::UFormElm& formRoot);
enum TSOUND_TYPE enum TSOUND_TYPE
{ {
@ -100,7 +99,7 @@ public:
/// Return the length of the sound in ms /// Return the length of the sound in ms
virtual uint32 getDuration() = 0; virtual uint32 getDuration() = 0;
/// Return the name (must be unique) /// Return the name (must be unique)
const NLMISC::CSheetId& getName() const { return _Name; } const NLMISC::TStringId& getName() const { return _Name; }
/// Return the min distance (if detailed()) (default 1.0f if not implemented by sound type) /// Return the min distance (if detailed()) (default 1.0f if not implemented by sound type)
virtual float getMinDistance() const { return _MinDist; } virtual float getMinDistance() const { return _MinDist; }
@ -122,8 +121,7 @@ public:
bool operator<( const CSound& otherSound ) const bool operator<( const CSound& otherSound ) const
{ {
//return NLMISC::CStringMapper::unmap(_Name) < NLMISC::CStringMapper::unmap(otherSound._Name); return NLMISC::CStringMapper::unmap(_Name) < NLMISC::CStringMapper::unmap(otherSound._Name);
return _Name.toString() < otherSound._Name.toString();
} }
protected: protected:
@ -144,7 +142,7 @@ protected:
float _MaxDist; float _MaxDist;
// Sound name. // Sound name.
NLMISC::CSheetId _Name; NLMISC::TStringId _Name;
/// An optional user var controler. /// An optional user var controler.
NLMISC::TStringId _UserVarControler; NLMISC::TStringId _UserVarControler;

@ -20,7 +20,6 @@
#include "nel/misc/string_mapper.h" #include "nel/misc/string_mapper.h"
#include "nel/3d/cluster.h" #include "nel/3d/cluster.h"
#include "nel/sound/u_source.h" #include "nel/sound/u_source.h"
#include "nel/misc/sheet_id.h"
namespace NLMISC namespace NLMISC
@ -32,7 +31,7 @@ namespace NLMISC
namespace NLSOUND { namespace NLSOUND {
typedef std::set<NLMISC::CSheetId> TMarkerSoundSet; typedef std::set<NLMISC::TStringId> TMarkerSoundSet;
class UAudioMixer; class UAudioMixer;
@ -51,13 +50,13 @@ public:
virtual float getTime() const { return _Time; } virtual float getTime() const { return _Time; }
/** Add a new sound in the set of to-be-played sounds for this marker */ /** Add a new sound in the set of to-be-played sounds for this marker */
virtual void addSound(const NLMISC::CSheetId &soundName); virtual void addSound(const NLMISC::TStringId &soundName);
/** Remove a sound */ /** Remove a sound */
virtual void removeSound(const NLMISC::CSheetId &soundName); virtual void removeSound(const NLMISC::TStringId &soundName);
/** Return the set of sounds of this marker */ /** Return the set of sounds of this marker */
virtual void getSounds(std::vector<NLMISC::CSheetId> &sounds); virtual void getSounds(std::vector<NLMISC::TStringId> &sounds);
/** Play all the sounds of this marker */ /** Play all the sounds of this marker */
virtual void play(UAudioMixer* mixer, NL3D::CCluster *cluster, CSoundContext &context); virtual void play(UAudioMixer* mixer, NL3D::CCluster *cluster, CSoundContext &context);

@ -20,7 +20,6 @@
#include "nel/misc/types_nl.h" #include "nel/misc/types_nl.h"
#include "nel/misc/string_mapper.h" #include "nel/misc/string_mapper.h"
#include "nel/sound/audio_mixer_user.h" #include "nel/sound/audio_mixer_user.h"
#include "nel/misc/sheet_id.h"
#include <string> #include <string>
namespace NLSOUND { namespace NLSOUND {
@ -68,16 +67,16 @@ public:
bool isLoaded(); bool isLoaded();
/// Return a sound corresponding to a name. /// Return a sound corresponding to a name.
CSound *getSound(const NLMISC::CSheetId &sheetId); CSound *getSound(const NLMISC::TStringId &name);
/// Return the names of the sounds /// Return the names of the sounds
void getNames( std::vector<NLMISC::CSheetId> &sheetIds ); void getNames( std::vector<NLMISC::TStringId> &names );
/// Return the number of sounds in this bank. /// Return the number of sounds in this bank.
uint countSounds(); uint countSounds();
void addSound(CSound *sound); void addSound(CSound *sound);
void removeSound(const NLMISC::CSheetId &sheetId); void removeSound(const NLMISC::TStringId &name);
private: private:
@ -89,8 +88,7 @@ private:
typedef CHashMap<NLMISC::TStringId, TSimpleSoundContainer, NLMISC::CStringIdHashMapTraits> TBufferAssocContainer; typedef CHashMap<NLMISC::TStringId, TSimpleSoundContainer, NLMISC::CStringIdHashMapTraits> TBufferAssocContainer;
/// Sound names hash map /// Sound names hash map
// typedef std::hash_map<std::string, CSound*> TSoundTable; // typedef std::hash_map<std::string, CSound*> TSoundTable;
// typedef CHashMap<NLMISC::CSheetId, CSound*, NLMISC::CSheetIdHashMapTraits> TSoundTable; typedef CHashMap<NLMISC::TStringId, CSound*, NLMISC::CStringIdHashMapTraits> TSoundTable;
typedef std::vector<CSound *> TSoundTable; // list the sheets by shortId of the sheetId
/// Assoc from buffer to sound. Used for sound unloading. /// Assoc from buffer to sound. Used for sound unloading.
TBufferAssocContainer _BufferAssoc; TBufferAssocContainer _BufferAssoc;

@ -23,7 +23,6 @@
#include "nel/3d/cluster.h" #include "nel/3d/cluster.h"
#include "nel/sound/sound.h" #include "nel/sound/sound.h"
#include "nel/sound/group_controller.h" #include "nel/sound/group_controller.h"
#include "nel/misc/sheet_id.h"
namespace NLSOUND { namespace NLSOUND {

@ -19,7 +19,6 @@
#include "nel/misc/types_nl.h" #include "nel/misc/types_nl.h"
#include "nel/misc/string_mapper.h" #include "nel/misc/string_mapper.h"
#include "nel/misc/sheet_id.h"
#include "nel/sound/u_source.h" #include "nel/sound/u_source.h"
#include "nel/sound/u_group_controller.h" #include "nel/sound/u_group_controller.h"
#include "nel/ligo/primitive.h" #include "nel/ligo/primitive.h"
@ -285,7 +284,7 @@ public:
//@} //@}
/// Get a TSoundId from a name (returns NULL if not found) /// Get a TSoundId from a name (returns NULL if not found)
virtual TSoundId getSoundId( const NLMISC::CSheetId &name ) = 0; virtual TSoundId getSoundId( const NLMISC::TStringId &name ) = 0;
/// Gets the group controller for the given group tree path with separator '/', if it doesn't exist yet it will be created. /// Gets the group controller for the given group tree path with separator '/', if it doesn't exist yet it will be created.
/// Examples: "music", "effects", "dialog", "music/background", "music/loading", "music/player", etcetera /// Examples: "music", "effects", "dialog", "music/background", "music/loading", "music/player", etcetera
@ -297,7 +296,7 @@ public:
* pass a callback function that will be called (if not NULL) just before deleting the spawned * pass a callback function that will be called (if not NULL) just before deleting the spawned
* source. * source.
*/ */
virtual USource *createSource(const NLMISC::CSheetId &name, bool spawn=false, TSpawnEndCallback cb=NULL, void *callbackUserParam = NULL, NL3D::CCluster *cluster = 0, CSoundContext *context = 0, UGroupController *groupController = NULL) = 0; virtual USource *createSource(const NLMISC::TStringId &name, bool spawn=false, TSpawnEndCallback cb=NULL, void *callbackUserParam = NULL, NL3D::CCluster *cluster = 0, CSoundContext *context = 0, UGroupController *groupController = NULL) = 0;
/// Add a logical sound source (by sound id). To remove a source, just delete it. See createSource(const char*) /// Add a logical sound source (by sound id). To remove a source, just delete it. See createSource(const char*)
virtual USource *createSource(TSoundId id, bool spawn=false, TSpawnEndCallback cb=NULL, void *callbackUserParam = NULL, NL3D::CCluster *cluster = 0, CSoundContext *context = 0, UGroupController *groupController = NULL) = 0; virtual USource *createSource(TSoundId id, bool spawn=false, TSpawnEndCallback cb=NULL, void *callbackUserParam = NULL, NL3D::CCluster *cluster = 0, CSoundContext *context = 0, UGroupController *groupController = NULL) = 0;
@ -321,7 +320,7 @@ public:
//@{ //@{
//@name Statistic and utility methods //@name Statistic and utility methods
/// Fill a vector with the names of all loaded sounds. /// Fill a vector with the names of all loaded sounds.
virtual void getSoundNames( std::vector<NLMISC::CSheetId> &names ) const = 0; virtual void getSoundNames( std::vector<NLMISC::TStringId> &names ) const = 0;
/// Return the number of mixing tracks (voices) /// Return the number of mixing tracks (voices)
virtual uint getPolyphony() const = 0; virtual uint getPolyphony() const = 0;
/// Return the number of sources /// Return the number of sources

@ -1,5 +1,13 @@
/**
* UStreamSource
* \file u_stream_source.h
* \brief UStreamSource
* \date 2010-01-28 12:58GMT
* \author Jan Boon (Kaetemi)
*/
// NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/> // NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/>
// Copyright (C) 2010 Winch Gate Property Limited // Copyright (C) 2010 by authors
// //
// This program is free software: you can redistribute it and/or modify // This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as // it under the terms of the GNU Affero General Public License as

@ -49,7 +49,6 @@ void Init()
{ {
try try
{ {
CSheetId::initWithoutSheet();
CPath::addSearchPath(NL_SOUND_DATA"/data", true, false); CPath::addSearchPath(NL_SOUND_DATA"/data", true, false);
@ -101,7 +100,7 @@ USource *OnAddSource( const char *name, float x, float y, float z )
/* /*
* Create a source with sound 'name', and set some of its initial properties, if successful * Create a source with sound 'name', and set some of its initial properties, if successful
*/ */
USource *source = AudioMixer->createSource(CSheetId(name, "sound")); USource *source = AudioMixer->createSource( CStringMapper::map(name) );
if ( source != NULL ) if ( source != NULL )
{ {
source->setPos( CVector(x,y,z) ); source->setPos( CVector(x,y,z) );

@ -62,7 +62,6 @@ static void initSample()
{ {
if (!INelContext::isContextInitialised()) if (!INelContext::isContextInitialised())
new CApplicationContext(); new CApplicationContext();
CSheetId::initWithoutSheet();
CPath::addSearchPath(NL_SOUND_DATA"/data", true, false); CPath::addSearchPath(NL_SOUND_DATA"/data", true, false);
printf("Sample demonstrating OGG playback using stream file .sound sheets."); printf("Sample demonstrating OGG playback using stream file .sound sheets.");
@ -98,7 +97,7 @@ static void initSample()
//NLMISC::CHTimer::startBench(); //NLMISC::CHTimer::startBench();
s_Source = s_AudioMixer->createSource(CSheetId("stream_file.sound")); s_Source = s_AudioMixer->createSource(CStringMapper::map("stream_file"));
nlassert(s_Source); nlassert(s_Source);
s_StreamFileSource = dynamic_cast<CStreamFileSource *>(s_Source); s_StreamFileSource = dynamic_cast<CStreamFileSource *>(s_Source);
nlassert(s_StreamFileSource); nlassert(s_StreamFileSource);

@ -59,7 +59,6 @@ static void initSample()
{ {
if (!INelContext::isContextInitialised()) if (!INelContext::isContextInitialised())
new CApplicationContext(); new CApplicationContext();
CSheetId::initWithoutSheet();
CPath::addSearchPath(NL_SOUND_DATA"/database/build/", true, false); CPath::addSearchPath(NL_SOUND_DATA"/database/build/", true, false);
printf("Sample demonstrating OGG playback using UStreamSource."); printf("Sample demonstrating OGG playback using UStreamSource.");
@ -88,7 +87,7 @@ static void initSample()
//NLMISC::CHTimer::startBench(); //NLMISC::CHTimer::startBench();
USource *source = s_AudioMixer->createSource(CSheetId("default_stream.sound")); USource *source = s_AudioMixer->createSource(CStringMapper::map("default_stream"));
nlassert(source); nlassert(source);
s_StreamSource = dynamic_cast<UStreamSource *>(source); s_StreamSource = dynamic_cast<UStreamSource *>(source);
nlassert(s_StreamSource); nlassert(s_StreamSource);

@ -49,7 +49,7 @@ CPSSound::CPSSound() : _Gain(1.f),
{ {
NL_PS_FUNC(CPSSound_CPSSound) NL_PS_FUNC(CPSSound_CPSSound)
if (CParticleSystem::getSerializeIdentifierFlag()) _Name = std::string("sound"); if (CParticleSystem::getSerializeIdentifierFlag()) _Name = std::string("sound");
_SoundName = NLMISC::CSheetId::Unknown /*NLMISC::CStringMapper::emptyId()*/; _SoundName = NLMISC::CStringMapper::emptyId();
} }
// *************************************************************************************************** // ***************************************************************************************************
@ -270,13 +270,18 @@ void CPSSound::serial(NLMISC::IStream &f)
// FIXME: CPSSound is reserialized from the _ParticleSystemProto // FIXME: CPSSound is reserialized from the _ParticleSystemProto
// cache when a non-_Shared particle system is instanced, this // cache when a non-_Shared particle system is instanced, this
// causes unnecessary sheet id lookups from string. // causes unnecessary id lookups from string.
// SLN1: Serialize as uint32, but this requires the editor to know if (f.isReading())
// the correct sheet id (and thus requires a built sheet_id.bin). {
// SLN2: Create a tool that reserializes all ps with sound sheet id std::string soundName;
// instead of sheet names, based on a global flag, and serialize f.serial(soundName);
// a flag that specifies if the ps is serialized with id or name. _SoundName = NLMISC::CStringMapper::map(soundName);
_SoundName.serialString(f, "sound"); }
else
{
std::string soundName = NLMISC::CStringMapper::unmap(_SoundName);
f.serial(soundName);
}
sint32 nbSounds; sint32 nbSounds;
bool hasScheme; bool hasScheme;

@ -33,7 +33,8 @@ using namespace std;
#define new DEBUG_NEW #define new DEBUG_NEW
#endif #endif
namespace NLMISC { namespace NLMISC
{
CSheetId::CChar CSheetId::_AllStrings; CSheetId::CChar CSheetId::_AllStrings;
CStaticMap<uint32, CSheetId::CChar> CSheetId::_SheetIdToName; CStaticMap<uint32, CSheetId::CChar> CSheetId::_SheetIdToName;
@ -48,12 +49,6 @@ std::map<std::string, uint32> CSheetId::_DevTypeNameToId;
std::vector<std::vector<std::string>> CSheetId::_DevSheetIdToName; std::vector<std::vector<std::string>> CSheetId::_DevSheetIdToName;
std::map<std::string, uint32> CSheetId::_DevSheetNameToId; std::map<std::string, uint32> CSheetId::_DevSheetNameToId;
#define NL_TEMP_YUBO_NO_SOUND_SHEET_ID
#ifdef NL_TEMP_YUBO_NO_SOUND_SHEET_ID
namespace { bool a_NoSoundSheetId = false; const uint32 a_NoSoundSheetType = 80; }
#endif
const CSheetId CSheetId::Unknown(0); const CSheetId CSheetId::Unknown(0);
void CSheetId::cbFileChange(const std::string &filename) void CSheetId::cbFileChange(const std::string &filename)
@ -91,7 +86,6 @@ CSheetId::CSheetId( uint32 sheetRef)
#endif #endif
} }
//----------------------------------------------- //-----------------------------------------------
// CSheetId // CSheetId
// //
@ -135,7 +129,6 @@ CSheetId::CSheetId( const std::string& sheetName, const std::string &defaultType
} }
} }
//----------------------------------------------- //-----------------------------------------------
// Build // Build
// //
@ -218,25 +211,6 @@ bool CSheetId::buildSheetId(const std::string& sheetName)
} }
} }
#ifdef NL_TEMP_YUBO_NO_SOUND_SHEET_ID
if (a_NoSoundSheetId && sheetName.find(".sound") != std::string::npos)
{
std::string sheetNameLc = toLower(sheetName);
std::map<std::string, uint32>::iterator it = _DevSheetNameToId.find(sheetNameLc);
if (it == _DevSheetNameToId.end())
{
// nldebug("SHEETID: Creating a temporary sheet id for '%s'", sheetName.c_str());
_DevSheetIdToName[0].push_back(sheetName);
_Id.IdInfos.Type = a_NoSoundSheetType;
_Id.IdInfos.Id = _DevSheetIdToName[0].size() - 1;
_DevSheetNameToId[sheetNameLc] = _Id.Id;
return true;
}
_Id.Id = it->second;
return true;
}
#endif
return false; return false;
} }
@ -368,7 +342,6 @@ void CSheetId::loadSheetId ()
nldebug("Finished loading sheet_id.bin: %u entries read", _SheetIdToName.size()); nldebug("Finished loading sheet_id.bin: %u entries read", _SheetIdToName.size());
} }
//----------------------------------------------- //-----------------------------------------------
// init // init
// //
@ -390,24 +363,6 @@ void CSheetId::init(bool removeUnknownSheet)
loadSheetId(); loadSheetId();
_Initialised = true; _Initialised = true;
#ifdef NL_TEMP_YUBO_NO_SOUND_SHEET_ID
if (typeFromFileExtension("sound") == std::numeric_limits<uint32>::max())
{
nlwarning("SHEETID: Loading without known sound sheet id, please update sheet_id.bin with .sound sheets");
nlassert(_FileExtensions.size() == 1 << (NL_SHEET_ID_TYPE_BITS));
nlassert(_FileExtensions[a_NoSoundSheetType].empty());
_FileExtensions[a_NoSoundSheetType] = "sound";
_DevSheetIdToName.push_back(std::vector<std::string>());
_DevSheetIdToName[0].push_back("unknown.sound");
TSheetId id;
id.IdInfos.Type = a_NoSoundSheetType;
id.IdInfos.Id = _DevSheetIdToName[0].size() - 1;
nlassert(id.IdInfos.Id == 0);
_DevSheetNameToId["unknown.sound"] = id.Id;
a_NoSoundSheetId = true;
}
#endif
} // init // } // init //
void CSheetId::initWithoutSheet() void CSheetId::initWithoutSheet()
@ -422,12 +377,10 @@ void CSheetId::initWithoutSheet()
_DontHaveSheetKnowledge = true; _DontHaveSheetKnowledge = true;
// Initialize id 0,0 as unknown.unknown // Initialize id 0,0 as unknown.unknown
CSheetId unknownunknown = CSheetId("unknown.unknown"); CSheetId unknownUnknown = CSheetId("unknown.unknown");
nlassert(unknownunknown == CSheetId::Unknown); nlassert(unknownUnknown == CSheetId::Unknown);
} }
//----------------------------------------------- //-----------------------------------------------
// uninit // uninit
// //
@ -447,7 +400,8 @@ void CSheetId::uninit()
//----------------------------------------------- //-----------------------------------------------
CSheetId &CSheetId::operator=(const CSheetId &sheetId) CSheetId &CSheetId::operator=(const CSheetId &sheetId)
{ {
if (!_Initialised) init(false); if (!_Initialised)
init(false);
if (this == &sheetId) if (this == &sheetId)
{ {
@ -462,10 +416,8 @@ CSheetId& CSheetId::operator=( const CSheetId& sheetId )
return *this; return *this;
} // operator= // } // operator= //
//----------------------------------------------- //-----------------------------------------------
// operator= // operator=
// //
@ -482,14 +434,14 @@ CSheetId& CSheetId::operator=( const string& sheetName )
} // operator= // } // operator= //
//----------------------------------------------- //-----------------------------------------------
// operator= // operator=
// //
//----------------------------------------------- //-----------------------------------------------
CSheetId &CSheetId::operator=(uint32 sheetRef) CSheetId &CSheetId::operator=(uint32 sheetRef)
{ {
if (!_Initialised) init(false); if (!_Initialised)
init(false);
_Id.Id = sheetRef; _Id.Id = sheetRef;
@ -497,15 +449,14 @@ CSheetId& CSheetId::operator=( uint32 sheetRef )
} // operator= // } // operator= //
//----------------------------------------------- //-----------------------------------------------
// operator< // operator<
// //
//----------------------------------------------- //-----------------------------------------------
bool CSheetId::operator<(const CSheetId &sheetRef) const bool CSheetId::operator<(const CSheetId &sheetRef) const
{ {
if (!_Initialised) init(false); if (!_Initialised)
init(false);
if (_Id.Id < sheetRef.asInt()) if (_Id.Id < sheetRef.asInt())
{ {
@ -516,22 +467,34 @@ bool CSheetId::operator < (const CSheetId& sheetRef ) const
} // operator< // } // operator< //
//----------------------------------------------- //-----------------------------------------------
// toString // toString
// //
//----------------------------------------------- //-----------------------------------------------
string CSheetId::toString(bool ifNotFoundUseNumericId) const string CSheetId::toString(bool ifNotFoundUseNumericId) const
{ {
if (!_Initialised) init(false); if (!_Initialised)
init(false);
if (_DontHaveSheetKnowledge) if (_DontHaveSheetKnowledge)
{ {
// FIXME: When someone punches in a fake sheet id this will if (_Id.IdInfos.Type < _DevSheetIdToName.size()
// fail. && _Id.IdInfos.Id < _DevSheetIdToName[_Id.IdInfos.Type].size())
{
return _DevSheetIdToName[_Id.IdInfos.Type][_Id.IdInfos.Id]; return _DevSheetIdToName[_Id.IdInfos.Type][_Id.IdInfos.Id];
} }
else
{
if (ifNotFoundUseNumericId)
{
return NLMISC::toString("#%u", _Id.Id);
}
else
{
return NLMISC::toString("<Sheet %u not found in loaded sheets>", _Id.Id);
}
}
}
CStaticMap<uint32, CChar>::const_iterator itStr = _SheetIdToName.find(_Id.Id); CStaticMap<uint32, CChar>::const_iterator itStr = _SheetIdToName.find(_Id.Id);
if (itStr != _SheetIdToName.end()) if (itStr != _SheetIdToName.end())
@ -540,12 +503,6 @@ string CSheetId::toString(bool ifNotFoundUseNumericId) const
} }
else else
{ {
#ifdef NL_TEMP_YUBO_NO_SOUND_SHEET_ID
if (a_NoSoundSheetId && _Id.IdInfos.Type == a_NoSoundSheetType)
{
return _DevSheetIdToName[0][_Id.IdInfos.Id];
}
#endif
// This nlwarning is commented out because the loggers are mutexed, therefore // This nlwarning is commented out because the loggers are mutexed, therefore
// you couldn't use toString() within a nlwarning(). // you couldn't use toString() within a nlwarning().
//nlwarning("<CSheetId::toString> The sheet %08x is not in sheet_id.bin",_Id.Id); //nlwarning("<CSheetId::toString> The sheet %08x is not in sheet_id.bin",_Id.Id);
@ -595,14 +552,14 @@ void CSheetId::serialString(NLMISC::IStream &f, const std::string &defaultType)
} }
} }
//----------------------------------------------- //-----------------------------------------------
// display // display
// //
//----------------------------------------------- //-----------------------------------------------
void CSheetId::display() void CSheetId::display()
{ {
if (!_Initialised) init(false); if (!_Initialised)
init(false);
CStaticMap<uint32, CChar>::const_iterator itStr; CStaticMap<uint32, CChar>::const_iterator itStr;
for (itStr = _SheetIdToName.begin(); itStr != _SheetIdToName.end(); ++itStr) for (itStr = _SheetIdToName.begin(); itStr != _SheetIdToName.end(); ++itStr)
@ -613,15 +570,14 @@ void CSheetId::display()
} // display // } // display //
//----------------------------------------------- //-----------------------------------------------
// display // display
// //
//----------------------------------------------- //-----------------------------------------------
void CSheetId::display(uint32 type) void CSheetId::display(uint32 type)
{ {
if (!_Initialised) init(false); if (!_Initialised)
init(false);
CStaticMap<uint32, CChar>::const_iterator itStr; CStaticMap<uint32, CChar>::const_iterator itStr;
for (itStr = _SheetIdToName.begin(); itStr != _SheetIdToName.end(); ++itStr) for (itStr = _SheetIdToName.begin(); itStr != _SheetIdToName.end(); ++itStr)
@ -640,15 +596,14 @@ void CSheetId::display(uint32 type)
} // display // } // display //
//----------------------------------------------- //-----------------------------------------------
// buildIdVector // buildIdVector
// //
//----------------------------------------------- //-----------------------------------------------
void CSheetId::buildIdVector(std::vector<CSheetId> &result) void CSheetId::buildIdVector(std::vector<CSheetId> &result)
{ {
if (!_Initialised) init(false); if (!_Initialised)
init(false);
CStaticMap<uint32, CChar>::const_iterator itStr; CStaticMap<uint32, CChar>::const_iterator itStr;
for (itStr = _SheetIdToName.begin(); itStr != _SheetIdToName.end(); ++itStr) for (itStr = _SheetIdToName.begin(); itStr != _SheetIdToName.end(); ++itStr)
@ -658,14 +613,14 @@ void CSheetId::buildIdVector(std::vector <CSheetId> &result)
} // buildIdVector // } // buildIdVector //
//----------------------------------------------- //-----------------------------------------------
// buildIdVector // buildIdVector
// //
//----------------------------------------------- //-----------------------------------------------
void CSheetId::buildIdVector(std::vector<CSheetId> &result, uint32 type) void CSheetId::buildIdVector(std::vector<CSheetId> &result, uint32 type)
{ {
if (!_Initialised) init(false); if (!_Initialised)
init(false);
nlassert(type < (1 << (NL_SHEET_ID_TYPE_BITS))); nlassert(type < (1 << (NL_SHEET_ID_TYPE_BITS)));
CStaticMap<uint32, CChar>::const_iterator itStr; CStaticMap<uint32, CChar>::const_iterator itStr;
@ -690,7 +645,8 @@ void CSheetId::buildIdVector(std::vector <CSheetId> &result, uint32 type)
//----------------------------------------------- //-----------------------------------------------
void CSheetId::buildIdVector(std::vector<CSheetId> &result, std::vector<std::string> &resultFilenames, uint32 type) void CSheetId::buildIdVector(std::vector<CSheetId> &result, std::vector<std::string> &resultFilenames, uint32 type)
{ {
if (!_Initialised) init(false); if (!_Initialised)
init(false);
nlassert(type < (1 << (NL_SHEET_ID_TYPE_BITS))); nlassert(type < (1 << (NL_SHEET_ID_TYPE_BITS)));
CStaticMap<uint32, CChar>::const_iterator itStr; CStaticMap<uint32, CChar>::const_iterator itStr;
@ -734,14 +690,14 @@ void CSheetId::buildIdVector(std::vector <CSheetId> &result, std::vector <std::s
} // buildIdVector // } // buildIdVector //
//----------------------------------------------- //-----------------------------------------------
// typeFromFileExtension // typeFromFileExtension
// //
//----------------------------------------------- //-----------------------------------------------
uint32 CSheetId::typeFromFileExtension(const std::string &fileExtension) uint32 CSheetId::typeFromFileExtension(const std::string &fileExtension)
{ {
if (!_Initialised) init(false); if (!_Initialised)
init(false);
uint i; uint i;
for (i = 0; i < _FileExtensions.size(); i++) for (i = 0; i < _FileExtensions.size(); i++)
@ -751,14 +707,14 @@ uint32 CSheetId::typeFromFileExtension(const std::string &fileExtension)
return std::numeric_limits<uint32>::max(); return std::numeric_limits<uint32>::max();
} // typeFromFileExtension // } // typeFromFileExtension //
//----------------------------------------------- //-----------------------------------------------
// fileExtensionFromType // fileExtensionFromType
// //
//----------------------------------------------- //-----------------------------------------------
const std::string &CSheetId::fileExtensionFromType(uint32 type) const std::string &CSheetId::fileExtensionFromType(uint32 type)
{ {
if (!_Initialised) init(false); if (!_Initialised)
init(false);
nlassert(type < (1 << (NL_SHEET_ID_TYPE_BITS))); nlassert(type < (1 << (NL_SHEET_ID_TYPE_BITS)));
return _FileExtensions[type]; return _FileExtensions[type];
@ -786,7 +742,6 @@ void CSheetId::buildSheetId(uint32 shortId, uint32 type)
else else
_DebugSheetName = NULL; _DebugSheetName = NULL;
#endif #endif
} }
} // NLMISC } // NLMISC

@ -23,7 +23,6 @@
#include "nel/misc/command.h" #include "nel/misc/command.h"
#include "nel/misc/file.h" #include "nel/misc/file.h"
#include "nel/misc/path.h" #include "nel/misc/path.h"
#include "nel/misc/sheet_id.h"
#include "nel/georges/u_form_loader.h" #include "nel/georges/u_form_loader.h"
#include "nel/georges/u_form_elm.h" #include "nel/georges/u_form_elm.h"
@ -769,8 +768,11 @@ std::string UAudioMixer::buildSampleBank(const std::vector<std::string> &sampleL
} }
// Sample number MUST be even // Sample number MUST be even
nlassert(mono16Data.size() == (mono16Data.size() & 0xfffffffe)); // nlassert(mono16Data.size() == (mono16Data.size() & 0xfffffffe));
nlassert(adpcmData.size() == mono16Data.size() / 2); if (mono16Data.size() & 1)
nlwarning("Uneven sample numbers, ADPCM will miss a sample. File: %s, Samples: %i, ADPCM Size: %i",
sampleList[j].c_str(), (int)mono16Data.size(), (int)adpcmData.size());
nlassert(adpcmData.size() == (mono16Data.size() >> 1));
adpcmBuffers[j].swap(adpcmData); adpcmBuffers[j].swap(adpcmData);
mono16Buffers[j].swap(mono16Data); mono16Buffers[j].swap(mono16Data);
@ -1058,8 +1060,9 @@ public:
for (uint i=0; i<size; ++i) for (uint i=0; i<size; ++i)
{ {
items->getArrayValue(soundName, i); items->getArrayValue(soundName, i);
nlassert(soundName.find(".sound") != std::string::npos); soundName = soundName.substr(0, soundName.find(".sound"));
cs.SoundNames.push_back(CSheetId(soundName));
cs.SoundNames.push_back(CStringMapper::map(soundName));
} }
if (!cs.SoundNames.empty()) if (!cs.SoundNames.empty())
@ -1109,7 +1112,7 @@ void CAudioMixerUser::initUserVar()
TUserVarControlsContainer::iterator first(_UserVarControls.begin()), last(_UserVarControls.end()); TUserVarControlsContainer::iterator first(_UserVarControls.begin()), last(_UserVarControls.end());
for(; first != last; ++first) for(; first != last; ++first)
{ {
std::vector<NLMISC::CSheetId>::iterator first2(first->second.SoundNames.begin()), last2(first->second.SoundNames.end()); std::vector<NLMISC::TStringId>::iterator first2(first->second.SoundNames.begin()), last2(first->second.SoundNames.end());
for (; first2 != last2; ++first2) for (; first2 != last2; ++first2)
{ {
CSound *sound = getSoundId(*first2); CSound *sound = getSoundId(*first2);
@ -1140,7 +1143,7 @@ void CAudioMixerUser::CControledSources::serial(NLMISC::IStream &s)
for (uint i=0; i<size; ++i) for (uint i=0; i<size; ++i)
{ {
s.serial(soundName); s.serial(soundName);
SoundNames.push_back(CSheetId(soundName, "sound")); SoundNames.push_back(CStringMapper::map(soundName));
} }
} }
else else
@ -1154,7 +1157,7 @@ void CAudioMixerUser::CControledSources::serial(NLMISC::IStream &s)
for (uint i=0; i<size; ++i) for (uint i=0; i<size; ++i)
{ {
soundName = SoundNames[i].toString();; soundName = CStringMapper::unmap(SoundNames[i]);
s.serial(soundName); s.serial(soundName);
} }
} }
@ -1788,7 +1791,7 @@ void CAudioMixerUser::update()
// ****************************************************************** // ******************************************************************
TSoundId CAudioMixerUser::getSoundId( const NLMISC::CSheetId &name ) TSoundId CAudioMixerUser::getSoundId( const NLMISC::TStringId &name )
{ {
return _SoundBank->getSound(name); return _SoundBank->getSound(name);
} }
@ -1902,7 +1905,7 @@ retrySound:
if (invalid) if (invalid)
{ {
nlwarning("The sound %s contain an infinite recursion !", id->getName().toString().c_str()/*CStringMapper::unmap(id->getName()).c_str()*/); nlwarning("The sound %s contain an infinite recursion !", CStringMapper::unmap(id->getName()).c_str());
return NULL; return NULL;
} }
@ -2043,7 +2046,7 @@ retrySound:
// ****************************************************************** // ******************************************************************
USource *CAudioMixerUser::createSource( const NLMISC::CSheetId &name, bool spawn, TSpawnEndCallback cb, void *userParam, NL3D::CCluster *cluster, CSoundContext *context, UGroupController *groupController) USource *CAudioMixerUser::createSource( const NLMISC::TStringId &name, bool spawn, TSpawnEndCallback cb, void *userParam, NL3D::CCluster *cluster, CSoundContext *context, UGroupController *groupController)
{ {
return createSource( getSoundId( name ), spawn, cb, userParam, cluster, context, groupController); return createSource( getSoundId( name ), spawn, cb, userParam, cluster, context, groupController);
} }
@ -2170,7 +2173,7 @@ bool CAudioMixerUser::unloadSampleBank(const std::string &name)
// ****************************************************************** // ******************************************************************
void CAudioMixerUser::getSoundNames( std::vector<NLMISC::CSheetId> &names ) const void CAudioMixerUser::getSoundNames( std::vector<NLMISC::TStringId> &names ) const
{ {
_SoundBank->getNames(names); _SoundBank->getNames(names);
} }
@ -2320,6 +2323,7 @@ void CAudioMixerUser::getLoadedSampleBankInfo(std::vector<std::pair<std::strin
} }
void CAudioMixerUser::setListenerPos (const NLMISC::CVector &pos) void CAudioMixerUser::setListenerPos (const NLMISC::CVector &pos)
{ {
_Listener.setPos(pos); _Listener.setPos(pos);

@ -84,8 +84,7 @@ void CBackgroundSound::importForm(const std::string& filename, NLGEORGES::UFormE
// Read the sound name. // Read the sound name.
std::string soundName; std::string soundName;
psoundItem->getValueByName(soundName, "Sound"); psoundItem->getValueByName(soundName, "Sound");
nlassert(soundName.find(".sound") != std::string::npos); sound.SoundName = CStringMapper::map(CFile::getFilenameWithoutExtension(soundName));
sound.SoundName = NLMISC::CSheetId(soundName);
// Read the environnement flag. // Read the environnement flag.
@ -134,7 +133,7 @@ void CBackgroundSound::getSubSoundList(std::vector<std::pair<std::string, CSound
for (; first != last; ++first) for (; first != last; ++first)
{ {
CSound *sound = mixer->getSoundId(first->SoundName); CSound *sound = mixer->getSoundId(first->SoundName);
subsounds.push_back(make_pair(first->SoundName.toString()/*CStringMapper::unmap(first->SoundName)*/, sound)); subsounds.push_back(make_pair(CStringMapper::unmap(first->SoundName), sound));
} }
} }

@ -86,7 +86,7 @@ void CBackgroundSoundManager::addSound(const std::string &soundName, uint layerI
CAudioMixerUser *mixer = CAudioMixerUser::instance(); CAudioMixerUser *mixer = CAudioMixerUser::instance();
TSoundData sd; TSoundData sd;
sd.SoundName = NLMISC::CSheetId(soundName, "sound"); // note: loaded from .primitive sd.SoundName = CStringMapper::map(soundName);
sd.Sound = mixer->getSoundId(sd.SoundName); sd.Sound = mixer->getSoundId(sd.SoundName);
sd.Source = 0; sd.Source = 0;
@ -133,7 +133,7 @@ void CBackgroundSoundManager::addSound(const std::string &soundName, uint layerI
} }
else else
{ {
nlwarning ("The sound '%s' can't be loaded", sd.SoundName.toString().c_str()/*CStringMapper::unmap(sd.SoundName).c_str()*/); nlwarning ("The sound '%s' can't be loaded", CStringMapper::unmap(sd.SoundName).c_str());
} }
} }
@ -1431,15 +1431,21 @@ void CBackgroundSoundManager::TBanksData::serial(NLMISC::IStream &s)
void CBackgroundSoundManager::TSoundData::serial(NLMISC::IStream &s) void CBackgroundSoundManager::TSoundData::serial(NLMISC::IStream &s)
{ {
//std::string str; std::string str;
SoundName.serialString(s, "sound");
if (s.isReading()) if (s.isReading())
{ {
CAudioMixerUser *mixer = CAudioMixerUser::instance(); CAudioMixerUser *mixer = CAudioMixerUser::instance();
s.serial(str);
SoundName = NLMISC::CStringMapper::map(str);
Sound = mixer->getSoundId(SoundName); Sound = mixer->getSoundId(SoundName);
Source = NULL; Source = NULL;
Selected = false; Selected = false;
} }
else
{
s.serial(const_cast<std::string&>(NLMISC::CStringMapper::unmap(SoundName)));
}
s.serial(MinBox); s.serial(MinBox);
s.serial(MaxBox); s.serial(MaxBox);
s.serial(Surface); s.serial(Surface);

@ -70,7 +70,7 @@ float EAX_MATERIAL_PARAM[] =
class CSoundGroupSerializer class CSoundGroupSerializer
{ {
public: public:
std::vector<std::pair<NLMISC::TStringId, NLMISC::CSheetId> > _SoundGroupAssoc; std::vector<std::pair<NLMISC::TStringId, NLMISC::TStringId> > _SoundGroupAssoc;
// load the values using the george sheet (called by GEORGE::loadForm) // load the values using the george sheet (called by GEORGE::loadForm)
void readGeorges (const NLMISC::CSmartPtr<NLGEORGES::UForm> &form, const std::string &/* name */) void readGeorges (const NLMISC::CSmartPtr<NLGEORGES::UForm> &form, const std::string &/* name */)
@ -95,9 +95,15 @@ public:
item->getValueByName(soundGroup, ".SoundGroup"); item->getValueByName(soundGroup, ".SoundGroup");
item->getValueByName(sound, ".Sound"); item->getValueByName(sound, ".Sound");
nlassert(sound.find(".sound") != std::string::npos); string::size_type n = sound.rfind(".sound");
_SoundGroupAssoc.push_back(make_pair(CStringMapper::map(soundGroup), CSheetId(sound))); if (n != string::npos)
{
// remove the tailing .sound
sound = sound.substr(0, n);
}
_SoundGroupAssoc.push_back(make_pair(CStringMapper::map(soundGroup), CStringMapper::map(sound)));
} }
} }
catch(...) catch(...)
@ -119,18 +125,24 @@ public:
{ {
if (s.isReading()) if (s.isReading())
{ {
TStringId soundGroup; std::string soundGroup;
CSheetId sound; std::string sound;
CStringMapper::serialString(s, soundGroup); s.serial(soundGroup);
sound.serialString(s, "sound"); s.serial(sound);
_SoundGroupAssoc.push_back(make_pair(soundGroup, sound)); _SoundGroupAssoc.push_back(make_pair(CStringMapper::map(soundGroup), CStringMapper::map(sound)));
} }
else else
{ {
CStringMapper::serialString(s, _SoundGroupAssoc[i].first); std::string soundGroup;
_SoundGroupAssoc[i].second.serialString(s, "sound"); std::string sound;
soundGroup = CStringMapper::unmap(_SoundGroupAssoc[i].first);
sound = CStringMapper::unmap(_SoundGroupAssoc[i].second);
s.serial(soundGroup);
s.serial(sound);
} }
} }
} }
@ -277,10 +289,10 @@ void CClusteredSound::update(const CVector &listenerPos, const CVector &/* view
// nldebug("Searching sound assoc for group [%s]", CStringMapper::unmap(soundGroup).c_str()); // nldebug("Searching sound assoc for group [%s]", CStringMapper::unmap(soundGroup).c_str());
TStringSheetMap::iterator it2(_SoundGroupToSound.find(soundGroup)); TStringStringMap::iterator it2(_SoundGroupToSound.find(soundGroup));
if (it2 != _SoundGroupToSound.end()) if (it2 != _SoundGroupToSound.end())
{ {
NLMISC::CSheetId soundName = it2->second; NLMISC::TStringId soundName = it2->second;
CClusterSound cs; CClusterSound cs;
// nldebug("Found the sound [%s] for sound group [%s]", CStringMapper::unmap(soundName).c_str(), CStringMapper::unmap(soundGroup).c_str()); // nldebug("Found the sound [%s] for sound group [%s]", CStringMapper::unmap(soundName).c_str(), CStringMapper::unmap(soundGroup).c_str());

@ -19,7 +19,6 @@
#include "nel/misc/path.h" #include "nel/misc/path.h"
#include "nel/misc/common.h" #include "nel/misc/common.h"
#include "nel/sound/audio_mixer_user.h" #include "nel/sound/audio_mixer_user.h"
#include "nel/misc/sheet_id.h"
using namespace std; using namespace std;
using namespace NLMISC; using namespace NLMISC;
@ -64,11 +63,11 @@ void CComplexSound::parseSequence(const std::string &str, std::vector<uint32> &s
void CComplexSound::getSubSoundList(std::vector<std::pair<std::string, CSound*> > &subsounds) const void CComplexSound::getSubSoundList(std::vector<std::pair<std::string, CSound*> > &subsounds) const
{ {
CAudioMixerUser *mixer = CAudioMixerUser::instance(); CAudioMixerUser *mixer = CAudioMixerUser::instance();
std::vector<NLMISC::CSheetId>::const_iterator first(_Sounds.begin()), last(_Sounds.end()); std::vector<NLMISC::TStringId>::const_iterator first(_Sounds.begin()), last(_Sounds.end());
for (; first != last; ++first) for (; first != last; ++first)
{ {
CSound *sound = mixer->getSoundId(*first); CSound *sound = mixer->getSoundId(*first);
subsounds.push_back(make_pair((*first).toString()/*CStringMapper::unmap(*first)*/, sound)); subsounds.push_back(make_pair(CStringMapper::unmap(*first), sound));
} }
} }
@ -84,7 +83,7 @@ uint32 CComplexSound::getDuration()
CAudioMixerUser *mixer = CAudioMixerUser::instance(); CAudioMixerUser *mixer = CAudioMixerUser::instance();
vector<sint32> durations; vector<sint32> durations;
std::vector<NLMISC::CSheetId>::iterator first(_Sounds.begin()), last(_Sounds.end()); std::vector<NLMISC::TStringId>::iterator first(_Sounds.begin()), last(_Sounds.end());
for (; first != last; ++first) for (; first != last; ++first)
{ {
CSound *sound = mixer->getSoundId(*first); CSound *sound = mixer->getSoundId(*first);
@ -205,7 +204,7 @@ float CComplexSound::getMaxDistance() const
CComplexSound *This = const_cast<CComplexSound*>(this); CComplexSound *This = const_cast<CComplexSound*>(this);
This->_MaxDist = 0.0f; This->_MaxDist = 0.0f;
std::vector<NLMISC::CSheetId>::const_iterator first(_Sounds.begin()), last(_Sounds.end()); std::vector<NLMISC::TStringId>::const_iterator first(_Sounds.begin()), last(_Sounds.end());
for (; first != last; ++first) for (; first != last; ++first)
{ {
@ -237,7 +236,7 @@ void CComplexSound::serial(NLMISC::IStream &s)
{ {
std::string name; std::string name;
s.serial(name); s.serial(name);
_Sounds.push_back(NLMISC::CSheetId(name, "sound")); _Sounds.push_back(CStringMapper::map(name));
} }
} }
else else
@ -246,7 +245,7 @@ void CComplexSound::serial(NLMISC::IStream &s)
s.serial(nb); s.serial(nb);
for (uint i=0; i<nb; ++i) for (uint i=0; i<nb; ++i)
{ {
std::string name = _Sounds[i].toString(); std::string name = CStringMapper::unmap(_Sounds[i]);
s.serial(name); s.serial(name);
} }
} }
@ -301,8 +300,8 @@ void CComplexSound::importForm(const std::string& filename, NLGEORGES::UFormElm&
string soundname; string soundname;
if (psoundsArray->getArrayValue(soundname, i)) if (psoundsArray->getArrayValue(soundname, i))
{ {
nlassert(soundname.find(".sound") != std::string::npos); soundname = CFile::getFilenameWithoutExtension(soundname);
_Sounds.push_back(NLMISC::CSheetId(soundname)); _Sounds.push_back(CStringMapper::map(soundname));
} }
} }
} }

@ -191,9 +191,9 @@ void CComplexSource::playStuf()
case CComplexSound::MODE_ALL_IN_ONE: case CComplexSound::MODE_ALL_IN_ONE:
{ {
// just spanw all the listed source. // just spanw all the listed source.
const std::vector<NLMISC::CSheetId> &sounds = _PatternSound->getSounds(); const std::vector<NLMISC::TStringId> &sounds = _PatternSound->getSounds();
std::vector<NLMISC::CSheetId>::const_iterator first(sounds.begin()), last(sounds.end()); std::vector<NLMISC::TStringId>::const_iterator first(sounds.begin()), last(sounds.end());
if (_AllSources.empty()) if (_AllSources.empty())
{ {
@ -525,7 +525,7 @@ void CComplexSource::onUpdate()
else else
{ {
// no sound after, just set an event at end of current sound to stop the complex sound. // no sound after, just set an event at end of current sound to stop the complex sound.
nldebug("Setting last event for sound %s in %u millisec.", _Source1->getSound()->getName().toString().c_str()/*CStringMapper::unmap(_Source1->getSound()->getName()).c_str()*/, _Source1->getSound()->getDuration()); nldebug("Setting last event for sound %s in %u millisec.", CStringMapper::unmap(_Source1->getSound()->getName()).c_str(), _Source1->getSound()->getDuration());
if (_PatternSound->doFadeOut()) if (_PatternSound->doFadeOut())
{ {
// set the event to begin fade out. // set the event to begin fade out.

@ -187,7 +187,7 @@ void CContextSound::init()
} }
else else
{ {
nlassertex(nbJoker < SoundContextNbArgs, ("Error will trying to play ContextSound '%s'", _Name.toString().c_str()/*CStringMapper::unmap(_Name).c_str()*/)); nlassertex(nbJoker < SoundContextNbArgs, ("Error will trying to play ContextSound '%s'", CStringMapper::unmap(_Name).c_str()));
fromString(index, contextArgIndex[nbJoker++]); fromString(index, contextArgIndex[nbJoker++]);
parseArg = false; parseArg = false;
index.clear(); index.clear();
@ -195,13 +195,13 @@ void CContextSound::init()
} }
else if (*first == 'r') else if (*first == 'r')
{ {
nlassertex(useRandom == false, ("Error will trying to play ContextSound '%s'", _Name.toString().c_str()/*CStringMapper::unmap(_Name).c_str()*/)); nlassertex(useRandom == false, ("Error will trying to play ContextSound '%s'", CStringMapper::unmap(_Name).c_str()));
useRandom = true; useRandom = true;
} }
} }
else if (*first == '%') else if (*first == '%')
{ {
nlassertex(useRandom == false, ("Error will trying to play ContextSound '%s'", _Name.toString().c_str()/*CStringMapper::unmap(_Name).c_str()*/)); nlassertex(useRandom == false, ("Error will trying to play ContextSound '%s'", CStringMapper::unmap(_Name).c_str()));
parseArg = true; parseArg = true;
} }
} }
@ -215,7 +215,7 @@ void CContextSound::init()
} }
else else
{ {
nlassertex(nbJoker < SoundContextNbArgs, ("Error will trying to play ContextSound '%s'", _Name.toString().c_str()/*CStringMapper::unmap(_Name).c_str()*/)); nlassertex(nbJoker < SoundContextNbArgs, ("Error will trying to play ContextSound '%s'", CStringMapper::unmap(_Name).c_str()));
fromString(index, contextArgIndex[nbJoker++]); fromString(index, contextArgIndex[nbJoker++]);
parseArg = false; parseArg = false;
} }
@ -247,7 +247,7 @@ void CContextSound::init()
LM_CASE_CONTAINER_CREATOR(9) LM_CASE_CONTAINER_CREATOR(9)
LM_CASE_CONTAINER_CREATOR(10) LM_CASE_CONTAINER_CREATOR(10)
default: default:
nlwarning("Unsuported number of context argument in context sound '%s'!", _Name.toString().c_str()/*CStringMapper::unmap(_Name).c_str()*/); nlwarning("Unsuported number of context argument in context sound '%s'!", CStringMapper::unmap(_Name).c_str());
return; return;
} }
// cleanup macro // cleanup macro
@ -257,14 +257,14 @@ void CContextSound::init()
// ok, we have the container, now fill it with the sound // ok, we have the container, now fill it with the sound
{ {
std::vector<NLMISC::CSheetId> allSounds; std::vector<NLMISC::TStringId> allSounds;
// CSoundBank::getSoundNames(allSounds); // CSoundBank::getSoundNames(allSounds);
CAudioMixerUser::instance()->getSoundNames(allSounds); CAudioMixerUser::instance()->getSoundNames(allSounds);
std::vector<NLMISC::CSheetId>::iterator first(allSounds.begin()), last(allSounds.end()); std::vector<NLMISC::TStringId>::iterator first(allSounds.begin()), last(allSounds.end());
for (; first != last; ++first) for (; first != last; ++first)
{ {
const std::string &soundName = first->toString()/*CStringMapper::unmap(*first)*/; const std::string &soundName = CStringMapper::unmap(*first);
if (soundName.size() > _BaseName.size()) if (soundName.size() > _BaseName.size())
{ {
uint i; uint i;

@ -133,8 +133,17 @@ void CSound::serial(NLMISC::IStream &s)
s.serial(_Direction); s.serial(_Direction);
s.serial(_Looping); s.serial(_Looping);
s.serial(_MaxDist); s.serial(_MaxDist);
if (s.isReading())
_Name.serialString(s, "sound"); {
std::string name;
s.serial(name);
_Name = CStringMapper::map(name);
}
else
{
std::string name = CStringMapper::unmap(_Name);
s.serial(name);
}
nlassert(CGroupControllerRoot::isInitialized()); // not sure nlassert(CGroupControllerRoot::isInitialized()); // not sure
#if NLSOUND_SHEET_VERSION_BUILT < 2 #if NLSOUND_SHEET_VERSION_BUILT < 2
@ -161,8 +170,7 @@ void CSound::serial(NLMISC::IStream &s)
void CSound::importForm(const std::string& filename, NLGEORGES::UFormElm& root) void CSound::importForm(const std::string& filename, NLGEORGES::UFormElm& root)
{ {
// Name // Name
nlassert(filename.find(".sound") != std::string::npos); _Name = CStringMapper::map(CFile::getFilenameWithoutExtension(filename));
_Name = NLMISC::CSheetId(filename);
// InternalConeAngle // InternalConeAngle
uint32 inner; uint32 inner;

@ -53,19 +53,19 @@ void CSoundAnimMarker::play(UAudioMixer* mixer, NL3D::CCluster *cluster, CSoundC
// ******************************************************** // ********************************************************
void CSoundAnimMarker::addSound(const NLMISC::CSheetId& soundName) void CSoundAnimMarker::addSound(const NLMISC::TStringId& soundName)
{ {
pair<TMarkerSoundSet::iterator, bool> inserted; pair<TMarkerSoundSet::iterator, bool> inserted;
inserted = _Sounds.insert(soundName); inserted = _Sounds.insert(soundName);
if (inserted.second == false) if (inserted.second == false)
{ {
nlwarning("Duplicate sound (%s)",/* CStringMapper::unmap(soundName).c_str()*/soundName.toString().c_str()); nlwarning("Duplicate sound (%s)", CStringMapper::unmap(soundName).c_str());
} }
} }
// ******************************************************** // ********************************************************
void CSoundAnimMarker::removeSound(const NLMISC::CSheetId &soundName) void CSoundAnimMarker::removeSound(const NLMISC::TStringId &soundName)
{ {
TMarkerSoundSet::iterator iter = _Sounds.find(soundName); TMarkerSoundSet::iterator iter = _Sounds.find(soundName);
if (iter != _Sounds.end()) if (iter != _Sounds.end())
@ -74,13 +74,13 @@ void CSoundAnimMarker::removeSound(const NLMISC::CSheetId &soundName)
} }
else else
{ {
nlwarning("No sound was removed (%s)", soundName.toString().c_str()/*CStringMapper::unmap(soundName).c_str()*/); nlwarning("No sound was removed (%s)", CStringMapper::unmap(soundName).c_str());
} }
} }
// ******************************************************** // ********************************************************
void CSoundAnimMarker::getSounds(vector<NLMISC::CSheetId> &sounds) void CSoundAnimMarker::getSounds(vector<NLMISC::TStringId> &sounds)
{ {
sounds.insert(sounds.end(), _Sounds.begin(), _Sounds.end()); sounds.insert(sounds.end(), _Sounds.begin(), _Sounds.end());

@ -73,7 +73,7 @@ void CSoundAnimation::save()
{ {
// File stream // File stream
COFile file; COFile file;
vector<NLMISC::CSheetId> sounds; vector<NLMISC::TStringId> sounds;
// Open the file // Open the file
if (!file.open(_Filename.c_str())) if (!file.open(_Filename.c_str()))
@ -108,11 +108,11 @@ void CSoundAnimation::save()
marker->getSounds(sounds); marker->getSounds(sounds);
vector<NLMISC::CSheetId>::iterator iter2; vector<NLMISC::TStringId>::iterator iter2;
for (iter2 = sounds.begin(); iter2 != sounds.end(); iter2++) for (iter2 = sounds.begin(); iter2 != sounds.end(); iter2++)
{ {
xmlNodePtr soundNode = xmlNewChild ( markerNode, NULL, (const xmlChar*)"SOUND", NULL ); xmlNodePtr soundNode = xmlNewChild ( markerNode, NULL, (const xmlChar*)"SOUND", NULL );
xmlSetProp (soundNode, (const xmlChar*)"name", (const xmlChar*)iter2->toString().c_str() /*CStringMapper::unmap(*iter2).c_str()*/); xmlSetProp (soundNode, (const xmlChar*)"name", (const xmlChar*) CStringMapper::unmap(*iter2).c_str());
} }
sounds.clear(); sounds.clear();
@ -193,7 +193,7 @@ void CSoundAnimation::load()
throw NLMISC::Exception("Invalid sound animation marker"); throw NLMISC::Exception("Invalid sound animation marker");
} }
marker->addSound(NLMISC::CSheetId(string(name), "sound")); marker->addSound(CStringMapper::map(string(name)));
xmlFree ((void*)name); xmlFree ((void*)name);

@ -127,16 +127,14 @@ CSoundBank::~CSoundBank()
void CSoundBank::addSound(CSound *sound) void CSoundBank::addSound(CSound *sound)
{ {
// nlassert(_Sounds.size() > sound->getName().getShortId()); std::pair<TSoundTable::iterator, bool> ret;
// nldebug("SOUNDBANK: Add %s", sound->getName().toString().c_str()); ret = _Sounds.insert(make_pair(sound->getName(), sound));
if (_Sounds.size() <= sound->getName().getShortId()) nlassert(ret.second);
_Sounds.resize(sound->getName().getShortId() + 1);
_Sounds[sound->getName().getShortId()] = sound;
} }
void CSoundBank::removeSound(const NLMISC::CSheetId &sheetId) void CSoundBank::removeSound(const NLMISC::TStringId &name)
{ {
_Sounds[sheetId.getShortId()] = NULL; _Sounds.erase(name);
} }
@ -264,46 +262,21 @@ public:
void CSoundBank::load(const std::string &packedSheetDir, bool packedSheetUpdate) void CSoundBank::load(const std::string &packedSheetDir, bool packedSheetUpdate)
{ {
// this structure is fill by the loadForm() function and will contain all you need // this structure is fill by the loadForm() function and will contain all you need
std::map<std::string, CSoundSerializer> container; // load the old way for compatibility std::map<std::string, CSoundSerializer> Container;
nlassert(!_Loaded); nlassert(!_Loaded);
// Just call the GEORGE::loadFrom method to read all available sounds // Just call the GEORGE::loadFrom method to read all available sounds
::loadForm("sound", packedSheetDir + "sounds.packed_sheets", container, packedSheetUpdate, false); ::loadForm("sound", packedSheetDir + "sounds.packed_sheets", Container, packedSheetUpdate, false);
_Loaded = true; _Loaded = true;
// get the largest sheet id needed and init the sound bank
uint32 maxShortId = 0;
{
std::map<std::string, CSoundSerializer>::iterator first(container.begin()), last(container.end());
for (; first != last; ++first)
{
if (first->second.Sound != 0)
if (first->second.Sound->getName().getShortId() > maxShortId)
maxShortId = first->second.Sound->getName().getShortId();
}
++maxShortId; // inc for size = last idx + 1
if (container.empty())
{
nlwarning("NLSOUND: No sound sheets have been loaded, missing sound sheet directory or packed sound sheets file");
}
else
{
nlassert(maxShortId < (container.size() * 8)); // ensure no ridiculous sheet id values
if (maxShortId > _Sounds.size())
_Sounds.resize(maxShortId);
}
}
// add all the loaded sound in the sound banks // add all the loaded sound in the sound banks
{ std::map<std::string, CSoundSerializer>::iterator first(Container.begin()), last(Container.end());
std::map<std::string, CSoundSerializer>::iterator first(container.begin()), last(container.end());
for (; first != last; ++first) for (; first != last; ++first)
{ {
if (first->second.Sound != 0) if (first->second.Sound != 0)
addSound(first->second.Sound); addSound(first->second.Sound);
} }
}
container.clear(); Container.clear();
} }
@ -314,9 +287,10 @@ void CSoundBank::unload()
{ {
nlassert(_Loaded); nlassert(_Loaded);
for (TSoundTable::size_type i = 0; i < _Sounds.size(); ++i) TSoundTable::iterator first(_Sounds.begin()), last(_Sounds.end());
for (; first != last; ++first)
{ {
delete _Sounds[i]; delete first->second;
} }
_Sounds.clear(); _Sounds.clear();
@ -358,31 +332,30 @@ bool CSoundBank::isLoaded()
/* /*
* Return a sound sample corresponding to a name. * Return a sound sample corresponding to a name.
*/ */
CSound* CSoundBank::getSound(const NLMISC::CSheetId &sheetId) CSound* CSoundBank::getSound(const NLMISC::TStringId &name)
{ {
if (sheetId == NLMISC::CSheetId::Unknown) // Find sound
return NULL; TSoundTable::iterator iter = _Sounds.find(name);
if ( iter == _Sounds.end() )
// nlassert(sheetId.getShortId() < _Sounds.size());
if (sheetId.getShortId() >= _Sounds.size())
{ {
std::string sheetName = sheetId.toString(); return 0;
nldebug("NLSOUND: Sound sheet id '%s' exceeds loaded sound sheets", sheetName.c_str()); }
return NULL; else
{
return (*iter).second;
} }
return _Sounds[sheetId.getShortId()];
} }
/** /**
* Return the names of the sounds * Return the names of the sounds
*/ */
void CSoundBank::getNames( std::vector<NLMISC::CSheetId> &sheetIds ) void CSoundBank::getNames( std::vector<NLMISC::TStringId> &names )
{ {
for (TSoundTable::size_type i = 0; i < _Sounds.size(); ++i) TSoundTable::const_iterator iter;
for (iter = _Sounds.begin(); iter != _Sounds.end(); ++iter)
{ {
if (_Sounds[i]) names.push_back((*iter).first);
sheetIds.push_back(_Sounds[i]->getName()); //nlwarning("getting sound %s", (*iter).first);
} }
} }

@ -73,13 +73,11 @@ void CStreamFileSound::serial(NLMISC::IStream &s)
void CStreamFileSound::setMusicFilePath(const std::string &filePath, bool async, bool loop) void CStreamFileSound::setMusicFilePath(const std::string &filePath, bool async, bool loop)
{ {
/*#if !FINAL_VERSION #if !FINAL_VERSION
//_Name = NLMISC::CStringMapper::map(std::string("<MusicChannel:") + NLMISC::CFile::getFilenameWithoutExtension(filePath) + ">"); _Name = NLMISC::CStringMapper::map(std::string("<MusicChannel:") + NLMISC::CFile::getFilenameWithoutExtension(filePath) + ">");
_Name = NLMISC::CSheetId(std::string("<MusicChannel:") + NLMISC::CFile::getFilenameWithoutExtension(filePath) + ">");
#else #else
//_Name = NLMISC::CStringMapper::map("<MusicChannel>"); _Name = NLMISC::CStringMapper::map("<MusicChannel>");
#endif*/ #endif
_Name = NLMISC::CSheetId("music_channel.sound");
_ConeInnerAngle = NLMISC::Pi * 2; _ConeInnerAngle = NLMISC::Pi * 2;
_ConeOuterAngle = NLMISC::Pi * 2; _ConeOuterAngle = NLMISC::Pi * 2;
_Looping = loop; _Looping = loop;

@ -159,7 +159,7 @@ END_MESSAGE_MAP()
void CEditPSSound::OnBrowseSound() void CEditPSSound::OnBrowseSound()
{ {
// CPickSound::TNameVect names; // CPickSound::TNameVect names;
vector<NLMISC::CSheetId> names; vector<NLMISC::TStringId> names;
NLSOUND::UAudioMixer *audioMixer = CSoundSystem::getAudioMixer(); NLSOUND::UAudioMixer *audioMixer = CSoundSystem::getAudioMixer();
@ -172,7 +172,7 @@ void CEditPSSound::OnBrowseSound()
if (ps.DoModal() == IDOK) if (ps.DoModal() == IDOK)
{ {
m_SoundName = ps.getName().toString().c_str(); m_SoundName = NLMISC::CStringMapper::unmap(ps.getName()).c_str();
_Sound->setSoundName(ps.getName()); _Sound->setSoundName(ps.getName());
updateModifiedFlag(); updateModifiedFlag();
UpdateData(FALSE); UpdateData(FALSE);
@ -184,7 +184,7 @@ BOOL CEditPSSound::OnInitDialog()
CDialog::OnInitDialog(); CDialog::OnInitDialog();
nlassert(_Sound); nlassert(_Sound);
m_SoundName = _Sound->getSoundName().toString().c_str(); m_SoundName = NLMISC::CStringMapper::unmap(_Sound->getSoundName()).c_str();
UpdateData(FALSE); UpdateData(FALSE);
return TRUE; // return TRUE unless you set the focus to a control return TRUE; // return TRUE unless you set the focus to a control
@ -195,7 +195,7 @@ void CEditPSSound::OnChangeSoundName()
{ {
nlassert(_Sound); nlassert(_Sound);
UpdateData(); UpdateData();
_Sound->setSoundName(NLMISC::CSheetId(NLMISC::tStrToUtf8(m_SoundName), "sound")); _Sound->setSoundName(NLMISC::CStringMapper::map(NLMISC::tStrToUtf8(m_SoundName)));
updateModifiedFlag(); updateModifiedFlag();
} }

@ -606,7 +606,6 @@ bool CObjectViewer::initUI (HWND parent)
{ {
new NLMISC::CApplicationContext(); new NLMISC::CApplicationContext();
nldebug("NeL Object Viewer: initUI"); nldebug("NeL Object Viewer: initUI");
NLMISC::CSheetId::initWithoutSheet();
} }
// The fonts manager // The fonts manager

@ -74,7 +74,7 @@ BOOL CPickSound::OnInitDialog()
for (TNameVect::iterator it = _Names.begin(); it != _Names.end(); ++it) for (TNameVect::iterator it = _Names.begin(); it != _Names.end(); ++it)
{ {
m_NameList.AddString(nlUtf8ToTStr((*it).toString())); m_NameList.AddString(nlUtf8ToTStr(NLMISC::CStringMapper::unmap(*it).c_str()));
} }
_Timer = SetTimer (1, 100, NULL); _Timer = SetTimer (1, 100, NULL);
@ -111,7 +111,7 @@ void CPickSound::OnSelchange()
nlassert(m_NameList.GetTextLen(m_NameList.GetCurSel()) < 1024); nlassert(m_NameList.GetTextLen(m_NameList.GetCurSel()) < 1024);
m_NameList.GetText(m_NameList.GetCurSel(), str); m_NameList.GetText(m_NameList.GetCurSel(), str);
_CurrName = NLMISC::CSheetId(NLMISC::tStrToUtf8(str), "sound"); _CurrName = NLMISC::CStringMapper::map(NLMISC::tStrToUtf8(str));
} }

@ -23,7 +23,7 @@
#endif // _MSC_VER > 1000 #endif // _MSC_VER > 1000
// pick_sound.h : header file // pick_sound.h : header file
// //
#include "nel/misc/sheet_id.h" #include "nel/misc/string_mapper.h"
#include <vector> #include <vector>
#include <string> #include <string>
@ -40,11 +40,11 @@ class CPickSound : public CDialog
{ {
// Construction // Construction
public: public:
typedef std::vector<NLMISC::CSheetId> TNameVect; typedef std::vector<NLMISC::TStringId> TNameVect;
CPickSound(const TNameVect &names, CWnd* pParent = NULL); // standard constructor CPickSound(const TNameVect &names, CWnd* pParent = NULL); // standard constructor
const NLMISC::CSheetId &getName(void) const { return _CurrName; } const NLMISC::TStringId &getName(void) const { return _CurrName; }
// Dialog Data // Dialog Data
//{{AFX_DATA(CPickSound) //{{AFX_DATA(CPickSound)
@ -63,7 +63,7 @@ public:
// Implementation // Implementation
protected: protected:
TNameVect _Names; TNameVect _Names;
NLMISC::CSheetId _CurrName; NLMISC::TStringId _CurrName;
UINT_PTR _Timer; UINT_PTR _Timer;

@ -125,18 +125,18 @@ void CSoundAnimDlg::updateSounds()
{ {
if (_SelectedMarker != 0) if (_SelectedMarker != 0)
{ {
vector<NLMISC::CSheetId> sounds; vector<NLMISC::TStringId> sounds;
_SelectedMarker->getSounds(sounds); _SelectedMarker->getSounds(sounds);
CListBox* list = (CListBox*) GetDlgItem(IDC_SOUND_ANIM_LIST); CListBox* list = (CListBox*) GetDlgItem(IDC_SOUND_ANIM_LIST);
list->ResetContent(); list->ResetContent();
vector<NLMISC::CSheetId>::iterator iter; vector<NLMISC::TStringId>::iterator iter;
for (iter = sounds.begin(); iter != sounds.end(); iter++) for (iter = sounds.begin(); iter != sounds.end(); iter++)
{ {
list->AddString(nlUtf8ToTStr((*iter).toString())); list->AddString(nlUtf8ToTStr(CStringMapper::unmap(*iter).c_str()));
} }
list->UpdateData(); list->UpdateData();
@ -150,7 +150,7 @@ void CSoundAnimDlg::OnAddSound()
if (_SelectedMarker != 0) if (_SelectedMarker != 0)
{ {
// CPickSound::TNameVect names; // CPickSound::TNameVect names;
vector<NLMISC::CSheetId> names; vector<NLMISC::TStringId> names;
NLSOUND::UAudioMixer *audioMixer = CSoundSystem::getAudioMixer(); NLSOUND::UAudioMixer *audioMixer = CSoundSystem::getAudioMixer();
@ -181,7 +181,7 @@ void CSoundAnimDlg::OnRemoveSound()
if (list->GetText(list->GetCurSel(), s) != LB_ERR) if (list->GetText(list->GetCurSel(), s) != LB_ERR)
{ {
_SelectedMarker->removeSound(NLMISC::CSheetId(tStrToUtf8(s), "sound")); _SelectedMarker->removeSound(CStringMapper::map(tStrToUtf8(s)));
updateSounds(); updateSounds();
} }
} }

@ -168,7 +168,7 @@ void CSoundSystem::play(const string &soundName)
{ {
if (_AudioMixer) if (_AudioMixer)
{ {
NLSOUND::USource *src = _AudioMixer->createSource(NLMISC::CSheetId(soundName, "sound"), true); NLSOUND::USource *src = _AudioMixer->createSource(CStringMapper::map(soundName), true);
if (src) if (src)
{ {
src->setLooping(false); src->setLooping(false);
@ -187,7 +187,7 @@ USource *CSoundSystem::create(const std::string &soundName)
{ {
if (_AudioMixer) if (_AudioMixer)
{ {
NLSOUND::USource *src = _AudioMixer->createSource(NLMISC::CSheetId(soundName, "sound"), false); NLSOUND::USource *src = _AudioMixer->createSource(CStringMapper::map(soundName), false);
if (src) if (src)
{ {
src->setLooping(false); src->setLooping(false);

@ -20,7 +20,6 @@
#include "nel/misc/app_context.h" #include "nel/misc/app_context.h"
#include "../nel_3dsmax_shared/nel_3dsmax_shared.h" #include "../nel_3dsmax_shared/nel_3dsmax_shared.h"
#include <maxversion.h> #include <maxversion.h>
#include "nel/misc/sheet_id.h"
extern ClassDesc2* GetCNelExportDesc(); extern ClassDesc2* GetCNelExportDesc();
@ -35,7 +34,6 @@ BOOL WINAPI DllMain(HINSTANCE hinstDLL,ULONG fdwReason,LPVOID lpvReserved)
{ {
new NLMISC::CLibraryContext(GetSharedNelContext()); new NLMISC::CLibraryContext(GetSharedNelContext());
nldebug("NeL Export: DllMain"); nldebug("NeL Export: DllMain");
NLMISC::CSheetId::initWithoutSheet();
} }
hInstance = hinstDLL; // Hang on to this DLL's instance handle. hInstance = hinstDLL; // Hang on to this DLL's instance handle.

@ -21,7 +21,6 @@
#include "nel/misc/app_context.h" #include "nel/misc/app_context.h"
#include "../nel_3dsmax_shared/nel_3dsmax_shared.h" #include "../nel_3dsmax_shared/nel_3dsmax_shared.h"
#include <maxversion.h> #include <maxversion.h>
#include "nel/misc/sheet_id.h"
extern ClassDesc2* GetPO2RPODesc(); extern ClassDesc2* GetPO2RPODesc();
extern ClassDesc* GetRPODesc(); extern ClassDesc* GetRPODesc();
@ -45,7 +44,6 @@ BOOL WINAPI DllMain(HINSTANCE hinstDLL,ULONG fdwReason,LPVOID lpvReserved)
{ {
new NLMISC::CLibraryContext(GetSharedNelContext()); new NLMISC::CLibraryContext(GetSharedNelContext());
nldebug("NeL Export: DllMain"); nldebug("NeL Export: DllMain");
NLMISC::CSheetId::initWithoutSheet();
} }
if(fdwReason == DLL_PROCESS_ATTACH) if(fdwReason == DLL_PROCESS_ATTACH)

@ -18,7 +18,6 @@
#include "../nel_3dsmax_shared/nel_3dsmax_shared.h" #include "../nel_3dsmax_shared/nel_3dsmax_shared.h"
#include <maxversion.h> #include <maxversion.h>
#include "nel/misc/sheet_id.h"
HINSTANCE hInstance; HINSTANCE hInstance;
int controlsInit = FALSE; int controlsInit = FALSE;
@ -33,7 +32,6 @@ BOOL WINAPI DllMain(HINSTANCE hinstDLL,ULONG fdwReason,LPVOID lpvReserved)
{ {
new NLMISC::CLibraryContext(GetSharedNelContext()); new NLMISC::CLibraryContext(GetSharedNelContext());
nldebug("NeL Patch Edit: DllMain"); nldebug("NeL Patch Edit: DllMain");
NLMISC::CSheetId::initWithoutSheet();
} }
if (fdwReason == DLL_PROCESS_ATTACH) if (fdwReason == DLL_PROCESS_ATTACH)

@ -4,7 +4,6 @@
#include "nel/misc/app_context.h" #include "nel/misc/app_context.h"
#include "../nel_3dsmax_shared/nel_3dsmax_shared.h" #include "../nel_3dsmax_shared/nel_3dsmax_shared.h"
#include <maxversion.h> #include <maxversion.h>
#include "nel/misc/sheet_id.h"
HINSTANCE hInstance; HINSTANCE hInstance;
int controlsInit = FALSE; int controlsInit = FALSE;
@ -23,7 +22,6 @@ BOOL WINAPI DllMain(HINSTANCE hinstDLL,ULONG fdwReason,LPVOID lpvReserved)
{ {
new NLMISC::CLibraryContext(GetSharedNelContext()); new NLMISC::CLibraryContext(GetSharedNelContext());
nldebug("NeL Patch Paint: DllMain"); nldebug("NeL Patch Paint: DllMain");
NLMISC::CSheetId::initWithoutSheet();
} }
hInstance = hinstDLL; hInstance = hinstDLL;

@ -1,7 +1,6 @@
#include "vertex_tree_paint.h" #include "vertex_tree_paint.h"
#include "../nel_3dsmax_shared/nel_3dsmax_shared.h" #include "../nel_3dsmax_shared/nel_3dsmax_shared.h"
#include <maxversion.h> #include <maxversion.h>
#include "nel/misc/sheet_id.h"
HINSTANCE hInstance; HINSTANCE hInstance;
@ -13,7 +12,6 @@ BOOL WINAPI DllMain(HINSTANCE hinstDLL,ULONG fdwReason,LPVOID lpvReserved)
{ {
new NLMISC::CLibraryContext(GetSharedNelContext()); new NLMISC::CLibraryContext(GetSharedNelContext());
nldebug("NeL Vertex Tree Paint: DllMain"); nldebug("NeL Vertex Tree Paint: DllMain");
NLMISC::CSheetId::initWithoutSheet();
} }
hInstance = hinstDLL; // Hang on to this DLL's instance handle. hInstance = hinstDLL; // Hang on to this DLL's instance handle.

@ -21,7 +21,6 @@
#include "../nel_3dsmax_shared/nel_3dsmax_shared.h" #include "../nel_3dsmax_shared/nel_3dsmax_shared.h"
#include <vector> #include <vector>
#include <maxversion.h> #include <maxversion.h>
#include "nel/misc/sheet_id.h"
extern ClassDesc2* GetTile_utilityDesc(); extern ClassDesc2* GetTile_utilityDesc();
extern ClassDesc* GetRGBAddDesc(); extern ClassDesc* GetRGBAddDesc();
@ -42,7 +41,6 @@ BOOL WINAPI DllMain(HINSTANCE hinstDLL,ULONG fdwReason,LPVOID lpvReserved)
{ {
new NLMISC::CLibraryContext(GetSharedNelContext()); new NLMISC::CLibraryContext(GetSharedNelContext());
nldebug("NeL Tile Utility: DllMain"); nldebug("NeL Tile Utility: DllMain");
NLMISC::CSheetId::initWithoutSheet();
} }
hInstance = hinstDLL; // Hang on to this DLL's instance handle. hInstance = hinstDLL; // Hang on to this DLL's instance handle.

@ -6,7 +6,7 @@ ELSE()
ADD_EXECUTABLE(zviewer ${SRC}) ADD_EXECUTABLE(zviewer ${SRC})
ENDIF() ENDIF()
ADD_DEFINITIONS(-DNL_ZVIEWER_CFG="\\"${NL_ETC_PREFIX}/\\"") ADD_DEFINITIONS(-DNL_ZVIEWER_CFG="${NL_ETC_PREFIX}/")
TARGET_LINK_LIBRARIES(zviewer nelmisc nel3d) TARGET_LINK_LIBRARIES(zviewer nelmisc nel3d)
NL_DEFAULT_PROPS(zviewer "NeL, Tools, 3D: Zone Viewer") NL_DEFAULT_PROPS(zviewer "NeL, Tools, 3D: Zone Viewer")

@ -83,6 +83,18 @@ if not args.noconf:
DatabaseDirectory DatabaseDirectory
except NameError: except NameError:
DatabaseDirectory = "W:/database" DatabaseDirectory = "W:/database"
try:
SoundDirectory
except NameError:
SoundDirectory = "V:"
try:
SoundSheetsDirectory
except NameError:
SoundSheetsDirectory = "V:"
try:
SoundSheetsDfnDirectory
except NameError:
SoundSheetsDfnDirectory = "V:/DFN"
try: try:
ExportBuildDirectory ExportBuildDirectory
except NameError: except NameError:
@ -218,6 +230,9 @@ if not args.noconf:
ScriptDirectory = askVar(log, "[IN] Script Directory", os.getcwd().replace("\\", "/")).replace("\\", "/") ScriptDirectory = askVar(log, "[IN] Script Directory", os.getcwd().replace("\\", "/")).replace("\\", "/")
WorkspaceDirectory = askVar(log, "[IN] Workspace Directory", WorkspaceDirectory).replace("\\", "/") WorkspaceDirectory = askVar(log, "[IN] Workspace Directory", WorkspaceDirectory).replace("\\", "/")
DatabaseDirectory = askVar(log, "[IN] Database Directory", DatabaseDirectory).replace("\\", "/") DatabaseDirectory = askVar(log, "[IN] Database Directory", DatabaseDirectory).replace("\\", "/")
SoundDirectory = askVar(log, "[IN] Sound Directory", SoundDirectory).replace("\\", "/")
SoundSheetsDirectory = askVar(log, "[IN] Sound Sheets Directory", SoundSheetsDirectory).replace("\\", "/")
SoundSheetsDfnDirectory = askVar(log, "[IN] Sound Sheets DFN Directory", SoundSheetsDfnDirectory).replace("\\", "/")
ExportBuildDirectory = askVar(log, "[OUT] Export Build Directory", ExportBuildDirectory).replace("\\", "/") ExportBuildDirectory = askVar(log, "[OUT] Export Build Directory", ExportBuildDirectory).replace("\\", "/")
InstallDirectory = askVar(log, "[OUT] Install Directory", InstallDirectory).replace("\\", "/") InstallDirectory = askVar(log, "[OUT] Install Directory", InstallDirectory).replace("\\", "/")
ClientDevDirectory = askVar(log, "[OUT] Client Dev Directory", ClientDevDirectory).replace("\\", "/") ClientDevDirectory = askVar(log, "[OUT] Client Dev Directory", ClientDevDirectory).replace("\\", "/")
@ -301,6 +316,9 @@ if not args.noconf:
sf.write("\n") sf.write("\n")
sf.write("# Data build directories\n") sf.write("# Data build directories\n")
sf.write("DatabaseDirectory = \"" + str(DatabaseDirectory) + "\"\n") sf.write("DatabaseDirectory = \"" + str(DatabaseDirectory) + "\"\n")
sf.write("SoundDirectory = \"" + str(SoundDirectory) + "\"\n")
sf.write("SoundSheetsDirectory = \"" + str(SoundSheetsDirectory) + "\"\n")
sf.write("SoundSheetsDfnDirectory = \"" + str(SoundSheetsDfnDirectory) + "\"\n")
sf.write("ExportBuildDirectory = \"" + str(ExportBuildDirectory) + "\"\n") sf.write("ExportBuildDirectory = \"" + str(ExportBuildDirectory) + "\"\n")
sf.write("\n") sf.write("\n")
sf.write("# Install directories\n") sf.write("# Install directories\n")
@ -415,6 +433,9 @@ if not args.noverify:
findTool(log, ToolDirectories, MakeSheetIdTool, ToolSuffix) findTool(log, ToolDirectories, MakeSheetIdTool, ToolSuffix)
# findTool(log, ToolDirectories, BuildSheetsTool, ToolSuffix) # kaetemi stuff, ignore this # findTool(log, ToolDirectories, BuildSheetsTool, ToolSuffix) # kaetemi stuff, ignore this
# findTool(log, ToolDirectories, BuildSoundTool, ToolSuffix) # kaetemi stuff, ignore this # findTool(log, ToolDirectories, BuildSoundTool, ToolSuffix) # kaetemi stuff, ignore this
# findTool(log, ToolDirectories, BuildSoundTool, ToolSuffix)
findTool(log, ToolDirectories, BuildSoundbankTool, ToolSuffix)
findTool(log, ToolDirectories, BuildSamplebankTool, ToolSuffix)
findTool(log, ToolDirectories, BuildCoarseMeshTool, ToolSuffix) findTool(log, ToolDirectories, BuildCoarseMeshTool, ToolSuffix)
findTool(log, ToolDirectories, LightmapOptimizerTool, ToolSuffix) findTool(log, ToolDirectories, LightmapOptimizerTool, ToolSuffix)
findTool(log, ToolDirectories, BuildClodtexTool, ToolSuffix) findTool(log, ToolDirectories, BuildClodtexTool, ToolSuffix)

@ -1,3 +1,5 @@
title Ryzom Core: 0_setup.py --noconf
0_setup.py --noconf
title Ryzom Core: 1_export.py title Ryzom Core: 1_export.py
1_export.py 1_export.py
title Ryzom Core: 2_build.py title Ryzom Core: 2_build.py

@ -73,6 +73,9 @@ TileEditTool = "tile_edit"
MakeSheetIdTool = "make_sheet_id" MakeSheetIdTool = "make_sheet_id"
# BuildSheetsTool = "th_build_sheets" # kaetemi stuff, ignore this # BuildSheetsTool = "th_build_sheets" # kaetemi stuff, ignore this
# BuildSoundTool = "th_build_sound" # kaetemi stuff, ignore this # BuildSoundTool = "th_build_sound" # kaetemi stuff, ignore this
# BuildSoundTool = "build_sound"
BuildSoundbankTool = "build_soundbank"
BuildSamplebankTool = "build_samplebank"
BuildCoarseMeshTool = "build_coarse_mesh" BuildCoarseMeshTool = "build_coarse_mesh"
LightmapOptimizerTool = "lightmap_optimizer" LightmapOptimizerTool = "lightmap_optimizer"
BuildClodtexTool = "build_clodtex" BuildClodtexTool = "build_clodtex"

@ -1,11 +1,11 @@
#!/usr/bin/python #!/usr/bin/python
# #
# \file 0_setup.py # \file 0_setup.py
# \brief Setup sound # \brief Setup samplebank
# \date 2009-06-03 10:47GMT # \date 2009-06-03 10:47GMT
# \author Jan Boon (Kaetemi) # \author Jan Boon (Kaetemi)
# Python port of game data build pipeline. # Python port of game data build pipeline.
# Setup sound # Setup samplebank
# #
# NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/> # NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/>
# Copyright (C) 2009-2014 by authors # Copyright (C) 2009-2014 by authors
@ -38,29 +38,25 @@ from directories import *
printLog(log, "") printLog(log, "")
printLog(log, "-------") printLog(log, "-------")
printLog(log, "--- Setup sound") printLog(log, "--- Setup samplebank")
printLog(log, "-------") printLog(log, "-------")
printLog(log, time.strftime("%Y-%m-%d %H:%MGMT", time.gmtime(time.time()))) printLog(log, time.strftime("%Y-%m-%d %H:%MGMT", time.gmtime(time.time())))
printLog(log, "") printLog(log, "")
# Setup source directories # Setup source directories
printLog(log, ">>> Setup source directories <<<") printLog(log, ">>> Setup source directories <<<")
mkPath(log, LeveldesignDirectory) mkPath(log, SoundDirectory + "/" + SoundSamplebanksSourceDirectory)
mkPath(log, LeveldesignDfnDirectory)
mkPath(log, DatabaseDirectory + "/" + SoundSamplebanksSourceDirectory)
# Setup export directories # Setup export directories
printLog(log, ">>> Setup export directories <<<") printLog(log, ">>> Setup export directories <<<")
# Setup build directories # Setup build directories
printLog(log, ">>> Setup build directories <<<") printLog(log, ">>> Setup build directories <<<")
mkPath(log, ExportBuildDirectory + "/" + SoundSheetsBuildDirectory)
mkPath(log, ExportBuildDirectory + "/" + SoundSamplebanksBuildDirectory) mkPath(log, ExportBuildDirectory + "/" + SoundSamplebanksBuildDirectory)
# Setup client directories # Setup client directories
printLog(log, ">>> Setup client directories <<<") printLog(log, ">>> Setup client directories <<<")
mkPath(log, InstallDirectory + "/" + SoundSheetsInstallDirectory) mkPath(log, InstallDirectory + "/" + SoundInstallDirectory)
mkPath(log, InstallDirectory + "/" + SoundSamplebanksInstallDirectory)
log.close() log.close()

@ -1,11 +1,11 @@
#!/usr/bin/python #!/usr/bin/python
# #
# \file 1_export.py # \file 1_export.py
# \brief Export sound # \brief Export samplebank
# \date 2009-06-03 10:47GMT # \date 2009-06-03 10:47GMT
# \author Jan Boon (Kaetemi) # \author Jan Boon (Kaetemi)
# Python port of game data build pipeline. # Python port of game data build pipeline.
# Export sound # Export samplebank
# #
# NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/> # NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/>
# Copyright (C) 2009-2014 by authors # Copyright (C) 2009-2014 by authors
@ -38,7 +38,7 @@ from directories import *
printLog(log, "") printLog(log, "")
printLog(log, "-------") printLog(log, "-------")
printLog(log, "--- Export sound") printLog(log, "--- Export samplebank")
printLog(log, "-------") printLog(log, "-------")
printLog(log, time.strftime("%Y-%m-%d %H:%MGMT", time.gmtime(time.time()))) printLog(log, time.strftime("%Y-%m-%d %H:%MGMT", time.gmtime(time.time())))
printLog(log, "") printLog(log, "")

@ -1,11 +1,11 @@
#!/usr/bin/python #!/usr/bin/python
# #
# \file 2_build.py # \file 2_build.py
# \brief Build sound # \brief Build samplebank
# \date 2009-06-03 10:47GMT # \date 2009-06-03 10:47GMT
# \author Jan Boon (Kaetemi) # \author Jan Boon (Kaetemi)
# Python port of game data build pipeline. # Python port of game data build pipeline.
# Build sound # Build samplebank
# #
# NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/> # NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/>
# Copyright (C) 2009-2014 by authors # Copyright (C) 2009-2014 by authors
@ -38,28 +38,33 @@ from directories import *
printLog(log, "") printLog(log, "")
printLog(log, "-------") printLog(log, "-------")
printLog(log, "--- Build sound") printLog(log, "--- Build samplebank")
printLog(log, "-------") printLog(log, "-------")
printLog(log, time.strftime("%Y-%m-%d %H:%MGMT", time.gmtime(time.time()))) printLog(log, time.strftime("%Y-%m-%d %H:%MGMT", time.gmtime(time.time())))
printLog(log, "") printLog(log, "")
# Find tools # Find tools
BuildSound = findTool(log, ToolDirectories, BuildSoundTool, ToolSuffix) BuildSamplebank = findTool(log, ToolDirectories, BuildSamplebankTool, ToolSuffix)
printLog(log, "") printLog(log, "")
# For each sound directory # For each samplebank directory
printLog(log, ">>> Build sound <<<") printLog(log, ">>> Build samplebank <<<")
if BuildSound == "": if BuildSamplebank == "":
toolLogFail(log, BuildSoundTool, ToolSuffix) toolLogFail(log, BuildSamplebankTool, ToolSuffix)
else: else:
mkPath(log, LeveldesignDirectory) sourcePath = SoundDirectory + "/" + SoundSamplebanksSourceDirectory
mkPath(log, LeveldesignDfnDirectory) buildPath = ExportBuildDirectory + "/" + SoundSamplebanksBuildDirectory
mkPath(log, DatabaseDirectory + "/" + SoundSamplebanksSourceDirectory) mkPath(log, sourcePath)
mkPath(log, ExportBuildDirectory + "/" + SoundSheetsBuildDirectory) mkPath(log, buildPath)
mkPath(log, ExportBuildDirectory + "/" + SoundSamplebanksBuildDirectory) for dir in os.listdir(sourcePath):
subprocess.call([ BuildSound, LeveldesignDirectory, LeveldesignDfnDirectory, DatabaseDirectory + "/" + SoundSamplebanksSourceDirectory, ExportBuildDirectory + "/" + SoundSheetsBuildDirectory ]) dirPath = sourcePath + "/" + dir
moveFilesExtNoTree(log, DatabaseDirectory + "/" + SoundSamplebanksSourceDirectory, ExportBuildDirectory + "/" + SoundSamplebanksBuildDirectory, ".sample_bank") if (os.path.isdir(dirPath)) and dir != ".svn" and dir != "*.*":
printLog(log, "") samplebankPath = buildPath + "/" + dir + ".sample_bank"
if needUpdateDirNoSubdirFile(log, dirPath, samplebankPath):
# build_samplebank <source_samplebank> <build_samplebank> <samplebank_name>
subprocess.call([ BuildSamplebank, dirPath, buildPath, dir ])
else:
printLog(log, "SKIP " + samplebankPath)
log.close() log.close()

@ -1,11 +1,11 @@
#!/usr/bin/python #!/usr/bin/python
# #
# \file 3_install.py # \file 3_install.py
# \brief Install sound # \brief Install samplebank
# \date 2009-06-03 10:47GMT # \date 2009-06-03 10:47GMT
# \author Jan Boon (Kaetemi) # \author Jan Boon (Kaetemi)
# Python port of game data build pipeline. # Python port of game data build pipeline.
# Install sound # Install samplebank
# #
# NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/> # NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/>
# Copyright (C) 2009-2014 by authors # Copyright (C) 2009-2014 by authors
@ -38,20 +38,15 @@ from directories import *
printLog(log, "") printLog(log, "")
printLog(log, "-------") printLog(log, "-------")
printLog(log, "--- Install sound") printLog(log, "--- Install samplebank")
printLog(log, "-------") printLog(log, "-------")
printLog(log, time.strftime("%Y-%m-%d %H:%MGMT", time.gmtime(time.time()))) printLog(log, time.strftime("%Y-%m-%d %H:%MGMT", time.gmtime(time.time())))
printLog(log, "") printLog(log, "")
printLog(log, ">>> Install sound packed_sheets <<<") printLog(log, ">>> Install samplebank <<<")
mkPath(log, ExportBuildDirectory + "/" + SoundSheetsBuildDirectory)
mkPath(log, InstallDirectory + "/" + SoundSheetsInstallDirectory)
copyFilesExtNoTreeIfNeeded(log, ExportBuildDirectory + "/" + SoundSheetsBuildDirectory, InstallDirectory + "/" + SoundSheetsInstallDirectory, ".packed_sheets")
printLog(log, ">>> Install sound samplebanks <<<")
mkPath(log, ExportBuildDirectory + "/" + SoundSamplebanksBuildDirectory) mkPath(log, ExportBuildDirectory + "/" + SoundSamplebanksBuildDirectory)
mkPath(log, InstallDirectory + "/" + SoundSamplebanksInstallDirectory) mkPath(log, InstallDirectory + "/" + SoundInstallDirectory)
copyFilesExtNoTreeIfNeeded(log, ExportBuildDirectory + "/" + SoundSamplebanksBuildDirectory, InstallDirectory + "/" + SoundSamplebanksInstallDirectory, ".sample_bank") copyFilesExtNoTreeIfNeeded(log, ExportBuildDirectory + "/" + SoundSamplebanksBuildDirectory, InstallDirectory + "/" + SoundInstallDirectory, ".sample_bank")
printLog(log, "") printLog(log, "")
log.close() log.close()

@ -4,7 +4,7 @@ SOURCE_GROUP("" FILES ${SRC})
ADD_EXECUTABLE(make_sheet_id ${SRC}) ADD_EXECUTABLE(make_sheet_id ${SRC})
ADD_DEFINITIONS(-DNL_MK_SH_ID_CFG="\\"${NL_ETC_PREFIX}/\\"") ADD_DEFINITIONS(-DNL_MK_SH_ID_CFG="${NL_ETC_PREFIX}/")
TARGET_LINK_LIBRARIES(make_sheet_id nelmisc) TARGET_LINK_LIBRARIES(make_sheet_id nelmisc)
NL_DEFAULT_PROPS(make_sheet_id "NeL, Tools, Misc: make_sheet_id") NL_DEFAULT_PROPS(make_sheet_id "NeL, Tools, Misc: make_sheet_id")

@ -147,10 +147,8 @@ void readFormId( string& outputFileName )
{ {
// get the file type from form name // get the file type from form name
TFormId fid = (*itIF).first; TFormId fid = (*itIF).first;
string fileType;
bool fileTypeGet = getFileType((*itIF).second, fileType);
if((*itIF).second.empty() || (*itIF).second=="." || (*itIF).second==".." || ((*itIF).second[0]=='_' && fileType != "sound") || (*itIF).second.find(".#")==0) if ((*itIF).second.empty() || (*itIF).second=="." || (*itIF).second==".." || (*itIF).second[0]=='_' || (*itIF).second.find(".#")==0)
{ {
map<TFormId,string>::iterator itErase = itIF; map<TFormId,string>::iterator itErase = itIF;
++itIF; ++itIF;
@ -158,7 +156,8 @@ void readFormId( string& outputFileName )
} }
else else
{ {
if(fileTypeGet) string fileType;
if (getFileType((*itIF).second, fileType))
{ {
// insert the association (file type/file type id) // insert the association (file type/file type id)
map<string,uint8>::iterator itFT = FileTypeToId.find(fileType); map<string,uint8>::iterator itFT = FileTypeToId.find(fileType);
@ -294,8 +293,7 @@ void makeId( list<string>& dirs )
//----------------------------------------------- //-----------------------------------------------
void addId( string fileName ) void addId( string fileName )
{ {
string extStr = CFile::getExtension( fileName ); if (fileName.empty() || fileName == "." || fileName == ".." || fileName[0] == '_' || fileName.find(".#") == 0)
if(fileName.empty() || fileName=="." || fileName==".." || (fileName[0]=='_' && extStr != "sound") || fileName.find(".#")==0)
{ {
// nlinfo("Discarding file '%s'", fileName.c_str()); // nlinfo("Discarding file '%s'", fileName.c_str());
NbFilesDiscarded++; NbFilesDiscarded++;
@ -305,6 +303,7 @@ void addId( string fileName )
{ {
if (!ExtensionsAllowed.empty()) if (!ExtensionsAllowed.empty())
{ {
string extStr = CFile::getExtension(fileName);
if (ExtensionsAllowed.find(extStr) == ExtensionsAllowed.end()) if (ExtensionsAllowed.find(extStr) == ExtensionsAllowed.end())
{ {
NbFilesDiscarded++; NbFilesDiscarded++;

@ -8,7 +8,7 @@ SET(WORDS_DIC_HDR words_dicDlg.h)
SET(WORDS_DIC_UIS words_dic_Qt.ui) SET(WORDS_DIC_UIS words_dic_Qt.ui)
SET(WORDS_DIC_RCS words_dic_Qt.qrc) SET(WORDS_DIC_RCS words_dic_Qt.qrc)
ADD_DEFINITIONS(-DNL_WORDS_DIC_CFG="\\"${NL_ETC_PREFIX}/\\"") ADD_DEFINITIONS(-DNL_WORDS_DIC_CFG="${NL_ETC_PREFIX}/")
IF(WITH_QT) IF(WITH_QT)
INCLUDE_DIRECTORIES(${QT_INCLUDES}) INCLUDE_DIRECTORIES(${QT_INCLUDES})

@ -4,7 +4,7 @@ SOURCE_GROUP("" FILES ${SRC})
ADD_EXECUTABLE(build_ig_boxes ${SRC}) ADD_EXECUTABLE(build_ig_boxes ${SRC})
ADD_DEFINITIONS(-DNL_BIB_CFG="\\"${NL_ETC_PREFIX}/\\"") ADD_DEFINITIONS(-DNL_BIB_CFG="${NL_ETC_PREFIX}/")
TARGET_LINK_LIBRARIES(build_ig_boxes nelmisc nelpacs nel3d) TARGET_LINK_LIBRARIES(build_ig_boxes nelmisc nelpacs nel3d)
NL_DEFAULT_PROPS(build_ig_boxes "NeL, Tools, PACS: build_ig_boxes") NL_DEFAULT_PROPS(build_ig_boxes "NeL, Tools, PACS: build_ig_boxes")

@ -4,7 +4,7 @@ SOURCE_GROUP("" FILES ${SRC})
ADD_EXECUTABLE(build_indoor_rbank ${SRC}) ADD_EXECUTABLE(build_indoor_rbank ${SRC})
ADD_DEFINITIONS(-DNL_BIRB_CFG="\\"${NL_ETC_PREFIX}/\\"") ADD_DEFINITIONS(-DNL_BIRB_CFG="${NL_ETC_PREFIX}/")
TARGET_LINK_LIBRARIES(build_indoor_rbank nelmisc nelpacs) TARGET_LINK_LIBRARIES(build_indoor_rbank nelmisc nelpacs)
NL_DEFAULT_PROPS(build_indoor_rbank "NeL, Tools, PACS: build_indoor_rbank") NL_DEFAULT_PROPS(build_indoor_rbank "NeL, Tools, PACS: build_indoor_rbank")

@ -4,7 +4,7 @@ SOURCE_GROUP("" FILES ${SRC})
ADD_EXECUTABLE(build_rbank ${SRC}) ADD_EXECUTABLE(build_rbank ${SRC})
ADD_DEFINITIONS(-DNL_BRB_CFG="\\"${NL_ETC_PREFIX}/\\"") ADD_DEFINITIONS(-DNL_BRB_CFG="${NL_ETC_PREFIX}/")
TARGET_LINK_LIBRARIES(build_rbank nelpacs nel3d nelligo nelmisc) TARGET_LINK_LIBRARIES(build_rbank nelpacs nel3d nelligo nelmisc)
NL_DEFAULT_PROPS(build_rbank "NeL, Tools, PACS: build_rbank") NL_DEFAULT_PROPS(build_rbank "NeL, Tools, PACS: build_rbank")

@ -1,5 +1,13 @@
/**
* Build Samplebank
* \file build_samplebank.cpp
* \brief Build Samplebank
* \date 2010-03-06 21:36GMT
* \author Jan Boon (Kaetemi)
*/
// NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/> // NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/>
// Copyright (C) 2010 Winch Gate Property Limited // Copyright (C) 2010 Jan Boon (Kaetemi)
// //
// This program is free software: you can redistribute it and/or modify // This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as // it under the terms of the GNU Affero General Public License as

@ -1,5 +1,13 @@
/**
* Build Sound
* \file build_sound.cpp
* \brief Build Sound
* \date 2009-06-02 21:25GMT
* \author Jan Boon (Kaetemi)
*/
// NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/> // NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/>
// Copyright (C) 2010 Winch Gate Property Limited // Copyright (C) 2009 Jan Boon (Kaetemi)
// //
// This program is free software: you can redistribute it and/or modify // This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as // it under the terms of the GNU Affero General Public License as
@ -48,6 +56,10 @@ namespace {
// your build script system. // // your build script system. //
//////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////////
// this tool is deprecated by build_samplebank and build_soundbank //
/////////////////////////////////////////////////////////////////////
int main(int nNbArg, char **ppArgs) int main(int nNbArg, char **ppArgs)
{ {
// create debug stuff // create debug stuff
@ -95,6 +107,8 @@ int main(int nNbArg, char **ppArgs)
// add search paths // add search paths
CPath::addSearchPath(leveldesignDir, true, false); CPath::addSearchPath(leveldesignDir, true, false);
std::string relativeDfnDir = dfnDir; // only add dfn if not a subdir of leveldesignDir
if (!CPath::makePathRelative(leveldesignDir, dfnDir) || relativeDfnDir.size() < 2 || (relativeDfnDir[0] == '.' && relativeDfnDir[1] == '.'))
CPath::addSearchPath(dfnDir, true, false); CPath::addSearchPath(dfnDir, true, false);
// create the audio mixer // create the audio mixer

@ -1,5 +1,13 @@
/**
* Build Soundbank
* \file build_soundbank.cpp
* \brief Build Soundbank
* \date 2010-03-06 21:43GMT
* \author Jan Boon (Kaetemi)
*/
// NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/> // NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/>
// Copyright (C) 2010 Winch Gate Property Limited // Copyright (C) 2010 Jan Boon (Kaetemi)
// //
// This program is free software: you can redistribute it and/or modify // This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as // it under the terms of the GNU Affero General Public License as
@ -29,7 +37,6 @@
#include <nel/misc/log.h> #include <nel/misc/log.h>
#include <nel/misc/path.h> #include <nel/misc/path.h>
#include <nel/sound/u_audio_mixer.h> #include <nel/sound/u_audio_mixer.h>
#include <nel/misc/sheet_id.h>
// Project includes // Project includes
// ... // ...
@ -75,11 +82,10 @@ int main(int nNbArg, char **ppArgs)
// add search paths // add search paths
CPath::addSearchPath(leveldesignDir, true, false); CPath::addSearchPath(leveldesignDir, true, false);
std::string relativeDfnDir = dfnDir; // only add dfn if not a subdir of leveldesignDir
if (!CPath::makePathRelative(leveldesignDir, dfnDir) || relativeDfnDir.size() < 2 || (relativeDfnDir[0] == '.' && relativeDfnDir[1] == '.'))
CPath::addSearchPath(dfnDir, true, false); CPath::addSearchPath(dfnDir, true, false);
// init sheet_id.bin
NLMISC::CSheetId::initWithoutSheet();
// build the sound bank // build the sound bank
UAudioMixer::buildSoundBank(exportDir); UAudioMixer::buildSoundBank(exportDir);

@ -4,7 +4,7 @@ ADD_EXECUTABLE(nel_launcher_ext2 WIN32 ${SRC} nel_launcher.rc)
IF(CURL_FOUND) IF(CURL_FOUND)
ADD_DEFINITIONS(-DUSE_CURL) ADD_DEFINITIONS(-DUSE_CURL)
ENDIF() ENDIF()
ADD_DEFINITIONS(-DNL_LAUNCHER_CFG="\\"${NL_ETC_PREFIX}/\\"") ADD_DEFINITIONS(-DNL_LAUNCHER_CFG="${NL_ETC_PREFIX}/")
TARGET_LINK_LIBRARIES(nel_launcher_ext2 TARGET_LINK_LIBRARIES(nel_launcher_ext2
nelnet nelnet

@ -5165,14 +5165,14 @@ NLMISC_COMMAND(reloadFogMaps, "Force to reload all the fog maps", "<>")
NLMISC_COMMAND(dumpSounds, "Dump names of all loaded sound", "<>") NLMISC_COMMAND(dumpSounds, "Dump names of all loaded sound", "<>")
{ {
if (!args.empty()) return false; if (!args.empty()) return false;
std::vector<NLMISC::CSheetId> sounds; std::vector<NLMISC::TStringId> sounds;
extern CSoundManager *SoundMngr; extern CSoundManager *SoundMngr;
if (!SoundMngr) return false; if (!SoundMngr) return false;
if (!SoundMngr->getMixer()) return false; if (!SoundMngr->getMixer()) return false;
SoundMngr->getMixer()->getSoundNames(sounds); SoundMngr->getMixer()->getSoundNames(sounds);
for(uint k = 0; k < sounds.size(); ++k) for(uint k = 0; k < sounds.size(); ++k)
{ {
nlinfo(sounds[k].toString()/*NLMISC::CStringMapper::unmap(sounds[k])*/.c_str()); nlinfo(NLMISC::CStringMapper::unmap(sounds[k]).c_str());
} }
return true; return true;
} }

@ -2017,7 +2017,7 @@ public:
virtual void execute (CCtrlBase * /* pCaller */, const string &Params) virtual void execute (CCtrlBase * /* pCaller */, const string &Params)
{ {
string sName = getParam(Params, "name"); string sName = getParam(Params, "name");
CSheetId id = CSheetId(sName, "sound"); TStringId id = CStringMapper::map(sName);
if (SoundMngr != NULL) if (SoundMngr != NULL)
SoundMngr->spawnSource(id,CVector(0,0,0)); SoundMngr->spawnSource(id,CVector(0,0,0));
} }

@ -1534,19 +1534,6 @@ void postlogInit()
// set the primitive context // set the primitive context
CPrimitiveContext::instance().CurrentLigoConfig = &LigoConfig; CPrimitiveContext::instance().CurrentLigoConfig = &LigoConfig;
{
H_AUTO(InitRZShIdI)
nmsg = "Initializing sheets...";
ProgressBar.newMessage ( ClientCfg.buildLoadingString(nmsg) );
// Initialize Sheet IDs.
CSheetId::init (ClientCfg.UpdatePackedSheet);
initLast = initCurrent;
initCurrent = ryzomGetLocalTime();
}
{ {
H_AUTO(InitRZSound) H_AUTO(InitRZSound)
@ -1597,7 +1584,13 @@ void postlogInit()
} }
{ {
H_AUTO(InitRZSheetL) H_AUTO(InitRZShIdI)
nmsg = "Initializing sheets...";
ProgressBar.newMessage ( ClientCfg.buildLoadingString(nmsg) );
// Initialize Sheet IDs.
CSheetId::init (ClientCfg.UpdatePackedSheet);
// load packed sheets // load packed sheets
nmsg = "Loading sheets..."; nmsg = "Loading sheets...";

@ -628,7 +628,7 @@ void CSoundManager::init(IProgressCallback *progressCallBack)
// add a new source to the world, attached to the specified entity // add a new source to the world, attached to the specified entity
// return 0 if creation failed, sound id if creation was successful // return 0 if creation failed, sound id if creation was successful
//----------------------------------------------- //-----------------------------------------------
CSoundManager::TSourceId CSoundManager::addSource( const NLMISC::CSheetId &soundName, const NLMISC::CVector &position, bool play, bool loop, const CEntityId &id) CSoundManager::TSourceId CSoundManager::addSource(const NLMISC::TStringId &soundName, const NLMISC::CVector &position, bool play, bool loop, const CEntityId &id)
{ {
uint32 retValue = 0; uint32 retValue = 0;
@ -638,7 +638,7 @@ CSoundManager::TSourceId CSoundManager::addSource( const NLMISC::CSheetId &sound
// If the source is valid. // If the source is valid.
if(pSource == 0) if(pSource == 0)
{ {
nlwarning("Sound '%s' not found !", /*CStringMapper::unmap(soundName).c_str()*/soundName.toString().c_str()); nlwarning("Sound '%s' not found !", CStringMapper::unmap(soundName).c_str());
return retValue; return retValue;
} }
@ -676,7 +676,7 @@ CSoundManager::TSourceId CSoundManager::addSource( const NLMISC::CSheetId &sound
// spawn a new source to the world // spawn a new source to the world
// return false if creation failed, true if creation was successful // return false if creation failed, true if creation was successful
//----------------------------------------------- //-----------------------------------------------
bool CSoundManager::spawnSource(const NLMISC::CSheetId &soundName, CSoundContext &context) bool CSoundManager::spawnSource(const NLMISC::TStringId &soundName, CSoundContext &context)
{ {
if (!_PlaySound) return false; if (!_PlaySound) return false;
@ -687,7 +687,7 @@ bool CSoundManager::spawnSource(const NLMISC::CSheetId &soundName, CSoundContext
// If the source is valid. // If the source is valid.
if(pSource == 0) if(pSource == 0)
{ {
nlwarning("Sound '%s' not found !", soundName.toString().c_str()); nlwarning("Sound '%s' not found !", soundName);
return false; return false;
} }
@ -706,7 +706,7 @@ bool CSoundManager::spawnSource(const NLMISC::CSheetId &soundName, CSoundContext
// spawn a new source to the world // spawn a new source to the world
// return false if creation failed, true if creation was successful // return false if creation failed, true if creation was successful
//----------------------------------------------- //-----------------------------------------------
bool CSoundManager::spawnSource(const NLMISC::CSheetId &soundName, const NLMISC::CVector &position) bool CSoundManager::spawnSource(const NLMISC::TStringId &soundName, const NLMISC::CVector &position)
{ {
if (!_PlaySound) return false; if (!_PlaySound) return false;
@ -716,7 +716,7 @@ bool CSoundManager::spawnSource(const NLMISC::CSheetId &soundName, const NLMISC:
// If the source is valid. // If the source is valid.
if(pSource == 0) if(pSource == 0)
{ {
nlwarning("Sound '%s' not found !", /*CStringMapper::unmap(soundName).c_str ()*/soundName.toString().c_str()); nlwarning("Sound '%s' not found !", CStringMapper::unmap(soundName).c_str ());
return false; return false;
} }

@ -32,7 +32,6 @@
// sound // sound
#include "nel/sound/u_audio_mixer.h" #include "nel/sound/u_audio_mixer.h"
#include "nel/sound/u_listener.h" #include "nel/sound/u_listener.h"
#include "nel/misc/sheet_id.h"
extern class CSoundManager *SoundMngr; extern class CSoundManager *SoundMngr;
@ -89,13 +88,13 @@ public:
/// Return the audio mixer instance pointer. /// Return the audio mixer instance pointer.
NLSOUND::UAudioMixer *getMixer(); NLSOUND::UAudioMixer *getMixer();
TSourceId addSource( const NLMISC::CSheetId &soundName, const NLMISC::CVector &position, bool play = true , bool loop = false, const NLMISC::CEntityId &id = NLMISC::CEntityId::Unknown ); TSourceId addSource( const NLMISC::TStringId &soundName, const NLMISC::CVector &position, bool play = true , bool loop = false, const NLMISC::CEntityId &id = NLMISC::CEntityId::Unknown );
/// spawn a new source to the world but sound manager don't keep any link and the sound will be automatically deleted when finnished /// spawn a new source to the world but sound manager don't keep any link and the sound will be automatically deleted when finnished
bool spawnSource (const NLMISC::CSheetId &soundName, NLSOUND::CSoundContext &context); bool spawnSource (const NLMISC::TStringId &soundName, NLSOUND::CSoundContext &context);
/// spawn a new source to the world but sound manager don't keep any link and the sound will be automatically deleted when finnished /// spawn a new source to the world but sound manager don't keep any link and the sound will be automatically deleted when finnished
bool spawnSource( const NLMISC::CSheetId &soundName, const NLMISC::CVector &position ); bool spawnSource( const NLMISC::TStringId &soundName, const NLMISC::CVector &position );
/** /**
* remove a source * remove a source

@ -68,9 +68,6 @@ CSoundPlugin::CSoundPlugin(IEdit *globalInterface)
{ {
AFX_MANAGE_STATE(AfxGetStaticModuleState()); AFX_MANAGE_STATE(AfxGetStaticModuleState());
// Initialize without sheet id bin
NLMISC::CSheetId::initWithoutSheet();
CVector dir; CVector dir;
_GlobalInterface = globalInterface; _GlobalInterface = globalInterface;
@ -340,7 +337,7 @@ void CSoundPlugin::setActiveDocument(IEditDocument *pdoc)
_Dialog.setName(_Filename); _Dialog.setName(_Filename);
// 1st, try to found the sound in the preloaded sound bank. // 1st, try to found the sound in the preloaded sound bank.
_Sound = _Mixer->getSoundId(CSheetId(_Filename, "sound")); _Sound = _Mixer->getSoundId(CStringMapper::map(_Filename));
if (_Sound == NULL) if (_Sound == NULL)
{ {
// not found, create a new one. // not found, create a new one.
@ -540,7 +537,7 @@ void CSoundPlugin::play(std::string &filename)
// point.Name = string("simulation-")+_Sound->getName()+"-000"; // point.Name = string("simulation-")+_Sound->getName()+"-000";
region.VPoints.push_back(point); region.VPoints.push_back(point);
string name = string("simulation-")+NLMISC::CFile::getFilenameWithoutExtension(_Sound->getName().toString())+"-000"; string name = string("simulation-")+CStringMapper::unmap(_Sound->getName())+"-000";
if (region.VPoints.back().checkProperty("name")) if (region.VPoints.back().checkProperty("name"))
region.VPoints.back().removePropertyByName("name"); region.VPoints.back().removePropertyByName("name");

@ -302,8 +302,6 @@ void initCore()
LoadedCore = true; LoadedCore = true;
// Seed the randomizer // Seed the randomizer
srand(uint(time(0))); srand(uint(time(0)));
// Sheet Id
CSheetId::initWithoutSheet(); // Temporary for sound
// Load configuration file, set paths, extension remapping // Load configuration file, set paths, extension remapping
CConfiguration::init(); CConfiguration::init();
// Load language file // Load language file
@ -524,8 +522,6 @@ void releaseCore()
CInternationalization::release(); CInternationalization::release();
// Release the configuration // Release the configuration
CConfiguration::release(); CConfiguration::release();
// Release sheet id
CSheetId::uninit(); // Temporary for sound
} }
} }

Loading…
Cancel
Save