mirror of
https://github.com/fulpstation/fulpstation.git
synced 2025-12-10 10:01:40 +00:00
* Add BSQL library v1.1.1.0 * Modify dbcore to use BSQL * Add missing QDEL_NULL for connectOperation * Moves BSQL_Shutdown() call to dbcore shutdown * Fix passing the wrong argument to DBQuery/New() * Darn it @Jordie0608. Fixes db calls without Connect check No seriously please make sure I'm not breaking anything * Queries with a null connection won't runtime * Fix quoting * Fix mistake * Update BSQL to v1.1.2.0 * Update BSQL DMAPI to v1.0.1.0 * Fix connection instatiation * Does the smart thing in regards to quoting * Fix braces * Update BSQL to 1.2.0.0. DMAPI to 1.1.0.0 * Execute/NextRow/MassInsert now have async parameter * Build BSQL for tests * Add missing apt source * Def still need gcc-multilib * Wut * Revert "Wut" This reverts commit d7c98a9a6b27f6db03e9f5cc534650d59d018048. * Try this then * Could it really be that simple? * Literally running out of ideas here * Update BSQL to v1.2.1.0 DMAPI to v1.1.1.0 * Update BSQL travis version * Nothing about this makes sense tbqhwyfam * Whoo boy * No idea why this isn't working tbh * Absolute madness * Ahhhhhhhhhhhhh * *deep breath* * "though yet again i was frustrated by failure" * Add BSQL to Dockerfile * Pass through MassInsert async param * BSQL to v1.3.0.0 DMAPI to 1.2.0.0 * Add timeout support * Wait, something's fucky * Wtf is this meme? * Just get good lmao * Just stop being shit lol * Stupid verbose logging * Remove verbosity * Good god * BSQL to v1.3.0.1 DMAPI to v1.2.0.1 * BSQL to v1.3.0.2 * Update BSQL travis version * Update BSQL docker version * Didn't mean to change that * Strip connection information from debug logs and make it configgable * Move this to where CONFIG_GET is defined
48 lines
1.4 KiB
Plaintext
48 lines
1.4 KiB
Plaintext
/datum/BSQL_Operation
|
|
var/datum/BSQL_Connection/connection
|
|
var/id
|
|
|
|
BSQL_PROTECT_DATUM(/datum/BSQL_Operation)
|
|
|
|
/datum/BSQL_Operation/New(datum/BSQL_Connection/connection, id)
|
|
src.connection = connection
|
|
src.id = id
|
|
|
|
BSQL_DEL_PROC(/datum/BSQL_Operation)
|
|
var/error
|
|
if(!BSQL_IS_DELETED(connection))
|
|
error = world._BSQL_Internal_Call("ReleaseOperation", connection.id, id)
|
|
. = ..()
|
|
if(error)
|
|
BSQL_ERROR(error)
|
|
|
|
/datum/BSQL_Operation/IsComplete()
|
|
if(BSQL_IS_DELETED(connection))
|
|
return TRUE
|
|
var/result = world._BSQL_Internal_Call("OpComplete", connection.id, id)
|
|
if(!result)
|
|
BSQL_ERROR("Error fetching operation [id] for connection [connection.id]!")
|
|
return
|
|
return result == "DONE"
|
|
|
|
/datum/BSQL_Operation/GetError()
|
|
if(BSQL_IS_DELETED(connection))
|
|
return "Connection deleted!"
|
|
return world._BSQL_Internal_Call("GetError", connection.id, id)
|
|
|
|
/datum/BSQL_Operation/GetErrorCode()
|
|
if(BSQL_IS_DELETED(connection))
|
|
return -2
|
|
return text2num(world._BSQL_Internal_Call("GetErrorCode", connection.id, id))
|
|
|
|
/datum/BSQL_Operation/WaitForCompletion()
|
|
if(BSQL_IS_DELETED(connection))
|
|
return
|
|
var/error = world._BSQL_Internal_Call("BlockOnOperation", connection.id, id)
|
|
if(error)
|
|
if(error == "Operation timed out!") //match this with the implementation
|
|
return FALSE
|
|
BSQL_ERROR("Error waiting for operation [id] for connection [connection.id]! [error]")
|
|
return
|
|
return TRUE
|