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,17 +9,20 @@
#include <Nazara/Prerequesites.hpp> #include <Nazara/Prerequesites.hpp>
class NAZARA_API NzClassName namespace Nz
{ {
public: class NAZARA_MODULENAME_API API ClassName
NzClassName(); {
public:
ClassName();
int GetAttribute() const; int GetAttribute() const;
void SetAttribute(int attribute); void SetAttribute(int attribute);
private: private:
int m_attribute; int m_attribute;
}; };
}
#endif // NAZARA_CLASSNAME_HPP #endif // NAZARA_CLASSNAME_HPP

View File

@ -10,20 +10,23 @@
#include <Nazara/Prerequesites.hpp> #include <Nazara/Prerequesites.hpp>
#include <Nazara/Core/Initializer.hpp> #include <Nazara/Core/Initializer.hpp>
class NAZARA_API NzModuleName namespace Nz
{ {
public: class NAZARA_MODULENAME_API ModuleName
NzModuleName() = delete; {
~NzModuleName() = delete; public:
ModuleName() = delete;
~ModuleName() = delete;
static bool Initialize(); static bool Initialize();
static bool IsInitialized(); static bool IsInitialized();
static void Uninitialize(); static void Uninitialize();
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 ClassName::GetAttribute() const
{
return m_attribute;
}
void ClassName::SetAttribute(int attribute)
{
m_attribute = attribute;
}
} }
int NzClassName::GetAttribute() const
{
return m_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,55 +10,61 @@
#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
{ {
if (s_moduleReferenceCounter > 0) bool ModuleName::Initialize()
{ {
if (s_moduleReferenceCounter > 0)
{
s_moduleReferenceCounter++;
return true; // Already initialized
}
// Initialize module dependencies
if (!NzCore::Initialize())
{
NazaraError("Failed to initialize core module");
return false;
}
s_moduleReferenceCounter++; s_moduleReferenceCounter++;
return true; // Déjà initialisé
CallOnExit onExit(ModuleName::Uninitialize);
// Initialize module here
onExit.Reset();
NazaraNotice("Initialized: ModuleName module");
return true;
} }
// Initialisation des dépendances bool ModuleName::IsInitialized()
if (!NzCore::Initialize())
{ {
NazaraError("Failed to initialize core module"); return s_moduleReferenceCounter != 0;
return false;
} }
s_moduleReferenceCounter++; void ModuleName::Uninitialize()
// Initialisation du module
NzCallOnExit onExit(NzModuleName::Uninitialize);
onExit.Reset();
NazaraNotice("Initialized: ModuleName module");
return true;
}
bool NzModuleName::IsInitialized()
{
return s_moduleReferenceCounter != 0;
}
void NzModuleName::Uninitialize()
{
if (s_moduleReferenceCounter != 1)
{ {
// Le module est soit encore utilisé, soit pas initialisé if (s_moduleReferenceCounter != 1)
if (s_moduleReferenceCounter > 1) {
s_moduleReferenceCounter--; // Le module est soit encore utilisé, soit pas initialisé
if (s_moduleReferenceCounter > 1)
s_moduleReferenceCounter--;
return; return;
}
s_moduleReferenceCounter = 0;
// Uninitialize module here
NazaraNotice("Uninitialized: ModuleName module");
// Free module dependencies
Core::Uninitialize();
} }
// Libération du module unsigned int ModuleName::s_moduleReferenceCounter = 0;
s_moduleReferenceCounter = 0;
NazaraNotice("Uninitialized: ModuleName module");
// Libération des dépendances
NzCore::Uninitialize();
} }
unsigned int NzModuleName::s_moduleReferenceCounter = 0;