mirror of
https://github.com/VCMP-SqMod/SqMod.git
synced 2024-11-14 11:47:15 +01:00
281 lines
8.2 KiB
C++
281 lines
8.2 KiB
C++
#ifndef _SQMMDB_COMMON_HPP_
|
|
#define _SQMMDB_COMMON_HPP_
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
#include "Base/Utility.hpp"
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
#include <maxminddb.h>
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
namespace SqMod {
|
|
|
|
/* ------------------------------------------------------------------------------------------------
|
|
* SOFTWARE INFORMATION
|
|
*/
|
|
#define SQMMDB_NAME "Squirrel MaxmindDB Module"
|
|
#define SQMMDB_AUTHOR "Sandu Liviu Catalin (S.L.C)"
|
|
#define SQMMDB_COPYRIGHT "Copyright (C) 2016 Sandu Liviu Catalin"
|
|
#define SQMMDB_HOST_NAME "SqModMMDBHost"
|
|
#define SQMMDB_VERSION 001
|
|
#define SQMMDB_VERSION_STR "0.0.1"
|
|
#define SQMMDB_VERSION_MAJOR 0
|
|
#define SQMMDB_VERSION_MINOR 0
|
|
#define SQMMDB_VERSION_PATCH 1
|
|
|
|
/* ------------------------------------------------------------------------------------------------
|
|
* Forward declarations.
|
|
*/
|
|
class Database;
|
|
class SockAddr;
|
|
class EntryDataList;
|
|
class LookupResult;
|
|
|
|
/* ------------------------------------------------------------------------------------------------
|
|
* Manages a reference counted INI document instance.
|
|
*/
|
|
class DbRef
|
|
{
|
|
// --------------------------------------------------------------------------------------------
|
|
friend class Database;
|
|
|
|
public:
|
|
|
|
// --------------------------------------------------------------------------------------------
|
|
typedef MMDB_s Type; // The managed type.
|
|
|
|
// --------------------------------------------------------------------------------------------
|
|
typedef Type* Pointer; // Pointer to the managed type.
|
|
typedef const Type* ConstPtr; // Constant pointer to the managed type.
|
|
|
|
// --------------------------------------------------------------------------------------------
|
|
typedef Type& Reference; // Reference to the managed type.
|
|
typedef const Type& ConstRef; // Constant reference to the managed type.
|
|
|
|
// --------------------------------------------------------------------------------------------
|
|
typedef unsigned int Counter; // Reference counter type.
|
|
|
|
private:
|
|
|
|
// --------------------------------------------------------------------------------------------
|
|
Pointer m_Ptr; // The document reader, writer and manager instance.
|
|
Counter* m_Ref; // Reference count to the managed instance.
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Creates a database structure.
|
|
*/
|
|
static Pointer Create();
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Destroyes the specified database structure.
|
|
*/
|
|
static void Destroy(Pointer db);
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Grab a strong reference to a document instance.
|
|
*/
|
|
void Grab()
|
|
{
|
|
if (m_Ptr)
|
|
++(*m_Ref);
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Drop a strong reference to a document instance.
|
|
*/
|
|
void Drop()
|
|
{
|
|
if (m_Ptr && --(*m_Ref) == 0)
|
|
{
|
|
MMDB_close(m_Ptr);
|
|
Destroy(m_Ptr);
|
|
delete m_Ref;
|
|
m_Ptr = NULL;
|
|
m_Ref = NULL;
|
|
}
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Base constructor.
|
|
*/
|
|
DbRef(bool make)
|
|
: m_Ptr(make ? Create() : NULL), m_Ref(m_Ptr ? new Counter(1) : NULL)
|
|
{
|
|
/* ... */
|
|
}
|
|
|
|
public:
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Default constructor (null).
|
|
*/
|
|
DbRef()
|
|
: m_Ptr(NULL), m_Ref(NULL)
|
|
{
|
|
/* ... */
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Copy constructor.
|
|
*/
|
|
DbRef(const DbRef & o)
|
|
: m_Ptr(o.m_Ptr), m_Ref(o.m_Ref)
|
|
|
|
{
|
|
Grab();
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Move constructor.
|
|
*/
|
|
DbRef(DbRef && o)
|
|
: m_Ptr(o.m_Ptr), m_Ref(o.m_Ref)
|
|
|
|
{
|
|
o.m_Ptr = NULL;
|
|
o.m_Ref = NULL;
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Destructor.
|
|
*/
|
|
~DbRef()
|
|
{
|
|
Drop();
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Copy assignment operator.
|
|
*/
|
|
DbRef & operator = (const DbRef & o)
|
|
{
|
|
if (m_Ptr != o.m_Ptr)
|
|
{
|
|
Drop();
|
|
m_Ptr = o.m_Ptr;
|
|
m_Ref = o.m_Ref;
|
|
Grab();
|
|
}
|
|
return *this;
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Move assignment operator.
|
|
*/
|
|
DbRef & operator = (DbRef && o)
|
|
{
|
|
if (m_Ptr != o.m_Ptr)
|
|
{
|
|
m_Ptr = o.m_Ptr;
|
|
m_Ref = o.m_Ref;
|
|
o.m_Ptr = NULL;
|
|
o.m_Ref = NULL;
|
|
}
|
|
return *this;
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Perform an equality comparison between two document instances.
|
|
*/
|
|
bool operator == (const DbRef & o) const
|
|
{
|
|
return (m_Ptr == o.m_Ptr);
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Perform an inequality comparison between two document instances.
|
|
*/
|
|
bool operator != (const DbRef & o) const
|
|
{
|
|
return (m_Ptr != o.m_Ptr);
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Implicit conversion to boolean for use in boolean operations.
|
|
*/
|
|
operator bool () const
|
|
{
|
|
return m_Ptr;
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Implicit conversion to the managed instance pointer.
|
|
*/
|
|
operator Pointer ()
|
|
{
|
|
return m_Ptr;
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Implicit conversion to the managed instance pointer.
|
|
*/
|
|
operator ConstPtr () const
|
|
{
|
|
return m_Ptr;
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Implicit conversion to the managed instance reference.
|
|
*/
|
|
operator Reference ()
|
|
{
|
|
assert(m_Ptr);
|
|
return *m_Ptr;
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Implicit conversion to the managed instance reference.
|
|
*/
|
|
operator ConstRef () const
|
|
{
|
|
assert(m_Ptr);
|
|
return *m_Ptr;
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Member operator for dereferencing the managed pointer.
|
|
*/
|
|
Pointer operator -> () const
|
|
{
|
|
assert(m_Ptr);
|
|
return m_Ptr;
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Indirection operator for obtaining a reference of the managed pointer.
|
|
*/
|
|
Reference operator * () const
|
|
{
|
|
assert(m_Ptr);
|
|
return *m_Ptr;
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Retrieve the raw handle structure pointer.
|
|
*/
|
|
Pointer DbPtr()
|
|
{
|
|
return m_Ptr;
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Retrieve the raw handle structure pointer.
|
|
*/
|
|
Pointer DbPtr() const
|
|
{
|
|
return m_Ptr;
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Retrieve the number of active references to the managed instance.
|
|
*/
|
|
Counter Count() const
|
|
{
|
|
return (m_Ptr && m_Ref) ? (*m_Ref) : 0;
|
|
}
|
|
};
|
|
|
|
} // Namespace:: SqMod
|
|
|
|
#endif // _SQMMDB_COMMON_HPP_
|