Update module template

Former-commit-id: 49040d563978c2b565f55cab38c92cf7d0a8496a
This commit is contained in:
Lynix 2015-09-27 18:28:43 +02:00
parent 24e5141cbe
commit 20e8ef1436
7 changed files with 102 additions and 104 deletions

View File

@ -1,33 +0,0 @@
if (not _OPTIONS["united"]) then
project "NazaraModuleName"
end
files
{
"../include/Nazara/ModuleName/**.hpp",
"../include/Nazara/ModuleName/**.inl",
"../src/Nazara/ModuleName/**.hpp",
"../src/Nazara/ModuleName/**.cpp"
}
if (os.is("windows")) then
excludes { "../src/Nazara/ModuleName/Posix/*.hpp", "../src/Nazara/ModuleName/Posix/*.cpp" }
else
excludes { "../src/Nazara/ModuleName/Win32/*.hpp", "../src/Nazara/ModuleName/Win32/*.cpp" }
end
if (_OPTIONS["united"]) then
excludes "../src/Nazara/ModuleName/Debug/NewOverload.cpp"
else
configuration "DebugStatic"
links "NazaraCore-s-d"
configuration "ReleaseStatic"
links "NazaraCore-s"
configuration "DebugDLL"
links "NazaraCore-d"
configuration "ReleaseDLL"
links "NazaraCore"
end

View File

@ -0,0 +1,15 @@
MODULE.Name = "ModuleName"
MODULE.Libraries = {
"NazaraCore"
}
MODULE.OsFiles.Windows = {
"../src/Nazara/ModuleName/Win32/**.hpp",
"../src/Nazara/ModuleName/Win32/**.cpp"
}
MODULE.OsFiles.Posix = {
"../src/Nazara/ModuleName/Posix/**.hpp",
"../src/Nazara/ModuleName/Posix/**.cpp"
}

View File

@ -9,10 +9,12 @@
#include <Nazara/Prerequesites.hpp> #include <Nazara/Prerequesites.hpp>
class NAZARA_API NzClassName namespace Nz
{ {
class NAZARA_MODULENAME_API API ClassName
{
public: public:
NzClassName(); ClassName();
int GetAttribute() const; int GetAttribute() const;
@ -20,6 +22,7 @@ class NAZARA_API NzClassName
private: private:
int m_attribute; int m_attribute;
}; };
}
#endif // NAZARA_CLASSNAME_HPP #endif // NAZARA_CLASSNAME_HPP

View File

@ -10,11 +10,13 @@
#include <Nazara/Prerequesites.hpp> #include <Nazara/Prerequesites.hpp>
#include <Nazara/Core/Initializer.hpp> #include <Nazara/Core/Initializer.hpp>
class NAZARA_API NzModuleName namespace Nz
{ {
class NAZARA_MODULENAME_API ModuleName
{
public: public:
NzModuleName() = delete; ModuleName() = delete;
~NzModuleName() = delete; ~ModuleName() = delete;
static bool Initialize(); static bool Initialize();
@ -24,6 +26,7 @@ class NAZARA_API NzModuleName
private: private:
static unsigned int s_moduleReferenceCounter; static unsigned int s_moduleReferenceCounter;
}; };
}
#endif // NAZARA_MODULENAME_HPP #endif // NAZARA_MODULENAME_HPP

View File

@ -5,17 +5,21 @@
#include <Nazara/ModuleName/ClassName.hpp> #include <Nazara/ModuleName/ClassName.hpp>
#include <Nazara/ModuleName/Debug.hpp> #include <Nazara/ModuleName/Debug.hpp>
NzClassName::NzClassName() : namespace Nz
m_attribute(42)
{ {
} ClassName::ClassName() :
m_attribute(42)
{
}
int NzClassName::GetAttribute() const int ClassName::GetAttribute() const
{ {
return m_attribute; return m_attribute;
}
void ClassName::SetAttribute(int attribute)
{
m_attribute = attribute;
}
} }
void NzClassName::SetAttribute(int attribute)
{
m_attribute = attribute;
}

View File

@ -10,22 +10,22 @@
void* operator new(std::size_t size) void* operator new(std::size_t size)
{ {
return NzMemoryManager::Allocate(size, false); return Nz::MemoryManager::Allocate(size, false);
} }
void* operator new[](std::size_t size) void* operator new[](std::size_t size)
{ {
return NzMemoryManager::Allocate(size, true); return Nz::MemoryManager::Allocate(size, true);
} }
void operator delete(void* pointer) noexcept void operator delete(void* pointer) noexcept
{ {
NzMemoryManager::Free(pointer, false); Nz::MemoryManager::Free(pointer, false);
} }
void operator delete[](void* pointer) noexcept void operator delete[](void* pointer) noexcept
{ {
NzMemoryManager::Free(pointer, true); Nz::MemoryManager::Free(pointer, true);
} }
#endif // NAZARA_MODULENAME_MANAGE_MEMORY #endif // NAZARA_MODULENAME_MANAGE_MEMORY

View File

@ -10,15 +10,17 @@
#include <Nazara/ModuleName/Config.hpp> #include <Nazara/ModuleName/Config.hpp>
#include <Nazara/ModuleName/Debug.hpp> #include <Nazara/ModuleName/Debug.hpp>
bool NzModuleName::Initialize() namespace Nz
{ {
bool ModuleName::Initialize()
{
if (s_moduleReferenceCounter > 0) if (s_moduleReferenceCounter > 0)
{ {
s_moduleReferenceCounter++; s_moduleReferenceCounter++;
return true; // Déjà initialisé return true; // Already initialized
} }
// Initialisation des dépendances // Initialize module dependencies
if (!NzCore::Initialize()) if (!NzCore::Initialize())
{ {
NazaraError("Failed to initialize core module"); NazaraError("Failed to initialize core module");
@ -27,22 +29,23 @@ bool NzModuleName::Initialize()
s_moduleReferenceCounter++; s_moduleReferenceCounter++;
// Initialisation du module CallOnExit onExit(ModuleName::Uninitialize);
NzCallOnExit onExit(NzModuleName::Uninitialize);
// Initialize module here
onExit.Reset(); onExit.Reset();
NazaraNotice("Initialized: ModuleName module"); NazaraNotice("Initialized: ModuleName module");
return true; return true;
} }
bool NzModuleName::IsInitialized() bool ModuleName::IsInitialized()
{ {
return s_moduleReferenceCounter != 0; return s_moduleReferenceCounter != 0;
} }
void NzModuleName::Uninitialize() void ModuleName::Uninitialize()
{ {
if (s_moduleReferenceCounter != 1) if (s_moduleReferenceCounter != 1)
{ {
// Le module est soit encore utilisé, soit pas initialisé // Le module est soit encore utilisé, soit pas initialisé
@ -52,13 +55,16 @@ void NzModuleName::Uninitialize()
return; return;
} }
// Libération du module
s_moduleReferenceCounter = 0; s_moduleReferenceCounter = 0;
// Uninitialize module here
NazaraNotice("Uninitialized: ModuleName module"); NazaraNotice("Uninitialized: ModuleName module");
// Libération des dépendances // Free module dependencies
NzCore::Uninitialize(); Core::Uninitialize();
}
unsigned int ModuleName::s_moduleReferenceCounter = 0;
} }
unsigned int NzModuleName::s_moduleReferenceCounter = 0;