mirror of
https://github.com/VCMP-SqMod/SqMod.git
synced 2025-01-19 12:07:13 +01:00
174 lines
6.1 KiB
C++
174 lines
6.1 KiB
C++
#ifndef _SQMMDB_LOOKUPRESULT_HPP_
|
|
#define _SQMMDB_LOOKUPRESULT_HPP_
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
#include "Handle/Database.hpp"
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
namespace SqMod {
|
|
|
|
/* ------------------------------------------------------------------------------------------------
|
|
* Class that can hold and be used to work with lookup results.
|
|
*/
|
|
class LookupResult
|
|
{
|
|
// --------------------------------------------------------------------------------------------
|
|
friend class Database; // Only a valid database instance can construct this type.
|
|
|
|
protected:
|
|
|
|
// --------------------------------------------------------------------------------------------
|
|
typedef MMDB_lookup_result_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.
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Validate the managed database handle and throw an error if invalid.
|
|
*/
|
|
#if defined(_DEBUG) || defined(SQMOD_EXCEPTLOC)
|
|
void Validate(CCStr file, Int32 line) const;
|
|
#else
|
|
void Validate() const;
|
|
#endif // _DEBUG
|
|
|
|
private:
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Validate the managed database handle and throw an error if invalid.
|
|
*/
|
|
#if defined(_DEBUG) || defined(SQMOD_EXCEPTLOC)
|
|
const DbRef & GetValid(CCStr file, Int32 line) const;
|
|
#else
|
|
const DbRef & GetValid() const;
|
|
#endif // _DEBUG
|
|
|
|
private:
|
|
|
|
// ---------------------------------------------------------------------------------------------
|
|
DbRef m_Handle; // The database from which this result comes from.
|
|
Type m_Result; // The managed result structure.
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Construct and take ownership of a certain result.
|
|
*/
|
|
LookupResult(const DbRef & db, Reference result)
|
|
: m_Handle(db), m_Result(result)
|
|
{
|
|
/* ... */
|
|
}
|
|
|
|
public:
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Default constructor. (null)
|
|
*/
|
|
LookupResult();
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Copy constructor.
|
|
*/
|
|
LookupResult(const LookupResult &) = default;
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Move constructor.
|
|
*/
|
|
LookupResult(LookupResult &&) = default;
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Destructor.
|
|
*/
|
|
~LookupResult()
|
|
{
|
|
/* We let the smart reference deal with deallocations if necessary. */
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Copy assignment operator.
|
|
*/
|
|
LookupResult & operator = (const LookupResult &) = default;
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Move assignment operator.
|
|
*/
|
|
LookupResult & operator = (LookupResult &&) = default;
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Retrieve the internal result structure reference.
|
|
*/
|
|
Reference GetHandle()
|
|
{
|
|
return m_Result;
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Retrieve the internal result structure reference.
|
|
*/
|
|
ConstRef GetHandle() const
|
|
{
|
|
return m_Result;
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Used by the script engine to convert an instance of this type to a string.
|
|
*/
|
|
CSStr ToString() const
|
|
{
|
|
return FmtStr("%u", m_Result.entry.offset);
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Used by the script engine to retrieve the name from instances of this type.
|
|
*/
|
|
static SQInteger Typename(HSQUIRRELVM vm);
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* See whether this instance references a valid database and result structure.
|
|
*/
|
|
bool IsValid() const
|
|
{
|
|
return m_Handle && m_Result.found_entry;
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* See whether the result contains a valid entry in the associated database.
|
|
*/
|
|
bool FoundEntry() const
|
|
{
|
|
// Validate the database handle
|
|
SQMOD_VALIDATE(*this);
|
|
// Return the requested information
|
|
return m_Result.found_entry;
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Retrieve the net-mask from the result structure.
|
|
*/
|
|
SQInteger GetNetMask() const
|
|
{
|
|
// Validate the database handle
|
|
SQMOD_VALIDATE(*this);
|
|
// Return the requested information
|
|
return static_cast< SQInteger >(m_Result.netmask);
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Retrieve the entire entry data list.
|
|
*/
|
|
Object GetEntryDataList();
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
* Lookup data in the associated result using the specified path.
|
|
*/
|
|
static SQInteger GetValue(HSQUIRRELVM vm);
|
|
};
|
|
|
|
} // Namespace:: SqMod
|
|
|
|
#endif // _SQMMDB_LOOKUPRESULT_HPP_
|