mirror of
https://github.com/nillerusr/source-engine.git
synced 2025-01-05 15:06:48 +00:00
57 lines
1.5 KiB
C
57 lines
1.5 KiB
C
|
//========= Copyright Valve Corporation, All rights reserved. ============//
|
||
|
//
|
||
|
// Purpose:
|
||
|
//
|
||
|
//=============================================================================//
|
||
|
|
||
|
#ifndef MYSQL_ASYNC_H
|
||
|
#define MYSQL_ASYNC_H
|
||
|
#ifdef _WIN32
|
||
|
#pragma once
|
||
|
#endif
|
||
|
|
||
|
|
||
|
#include "tier0/fasttimer.h"
|
||
|
|
||
|
|
||
|
class IMySQL;
|
||
|
|
||
|
|
||
|
class CQueryResults
|
||
|
{
|
||
|
public:
|
||
|
IMySQLRowSet *m_pResults;
|
||
|
void *m_pUserData; // This is the value passed to Execute.
|
||
|
CCycleCount m_ExecuteTime; // How long it took to execute this query in MySQL.
|
||
|
CCycleCount m_QueueTime; // How long it spent in the queue.
|
||
|
};
|
||
|
|
||
|
|
||
|
// This provides a way to do asynchronous MySQL queries. They are executed in a thread,
|
||
|
// then you can pop the results off as they arrive.
|
||
|
class IMySQLAsync
|
||
|
{
|
||
|
public:
|
||
|
|
||
|
virtual void Release() = 0;
|
||
|
|
||
|
// After finishing the current query, if there is one, this immediately executes
|
||
|
// the specified query and returns its results.
|
||
|
virtual IMySQLRowSet* ExecuteBlocking( const char *pStr ) = 0;
|
||
|
|
||
|
// Queue up a query.
|
||
|
virtual void Execute( const char *pStr, void *pUserData ) = 0;
|
||
|
|
||
|
// Poll this to pick up results from Execute().
|
||
|
// NOTE: if this returns true, but pResults is set to NULL, then that query had an error.
|
||
|
virtual bool GetNextResults( CQueryResults &results ) = 0;
|
||
|
};
|
||
|
|
||
|
// Create an async mysql interface. Note: if this call returns a non-null value,
|
||
|
// then after this call, you do NOT own pSQL anymore and you shouldn't ever call
|
||
|
// a function in it again.
|
||
|
IMySQLAsync* CreateMySQLAsync( IMySQL *pSQL );
|
||
|
|
||
|
|
||
|
#endif // MYSQL_ASYNC_H
|