diff options
author | Andreas Rumpf <rumpf_a@web.de> | 2017-01-26 10:41:40 +0100 |
---|---|---|
committer | Andreas Rumpf <rumpf_a@web.de> | 2017-01-26 11:26:02 +0100 |
commit | 303c49b9f3bfe90b248fb414dc514b8e61d4ad0f (patch) | |
tree | 1c22c03c6f1b97ac91b410c3cf4f586f2aec012e /lib/pure/nimtracker.nim | |
parent | 5421ec8dae713a37dde2401a8681e2d1f3265b01 (diff) | |
download | Nim-303c49b9f3bfe90b248fb414dc514b8e61d4ad0f.tar.gz |
memory tracker is aware of threads (still not threadsafe though)
Diffstat (limited to 'lib/pure/nimtracker.nim')
-rw-r--r-- | lib/pure/nimtracker.nim | 20 |
1 files changed, 15 insertions, 5 deletions
diff --git a/lib/pure/nimtracker.nim b/lib/pure/nimtracker.nim index 52fa9da77..acc242257 100644 --- a/lib/pure/nimtracker.nim +++ b/lib/pure/nimtracker.nim @@ -19,7 +19,15 @@ import sqlite3 var dbHandle: PSqlite3 - insertStmt: Pstmt + insertStmt {.threadvar.}: Pstmt + +const insertQuery = "INSERT INTO tracking(op, address, size, file, line) values (?, ?, ?, ?, ?)" + +when compileOption("threads"): + onThreadCreation do(): + if prepare_v2(dbHandle, insertQuery, + insertQuery.len, insertStmt, nil) != SQLITE_OK: + quit "could not bind query to insertStmt " & $sqlite3.errmsg(dbHandle) template sbind(x: int; value) = when value is cstring: @@ -32,7 +40,7 @@ template sbind(x: int; value) = quit "could not bind value" when defined(memTracker): - proc logEntries(log: TrackLog) {.nimcall, locks: 0, tags: [].} = + proc logEntries(log: TrackLog) {.nimcall, locks: 0, tags: [], gcsafe.} = for i in 0..log.count-1: var success = false let e = log.data[i] @@ -46,7 +54,7 @@ when defined(memTracker): if step(insertStmt) == SQLITE_DONE: success = true if not success: - quit "could not write to database!" + quit "could not write to database! " & $sqlite3.errmsg(dbHandle) proc execQuery(q: string) = var s: Pstmt @@ -71,10 +79,12 @@ proc setupDb() = if sqlite3.open("memtrack.db", dbHandle) == SQLITE_OK: setupDb() const query = "INSERT INTO tracking(op, address, size, file, line) values (?, ?, ?, ?, ?)" - if prepare_v2(dbHandle, query, - query.len, insertStmt, nil) == SQLITE_OK: + if prepare_v2(dbHandle, insertQuery, + insertQuery.len, insertStmt, nil) == SQLITE_OK: when defined(memTracker): setTrackLogger logEntries else: quit "could not prepare statement B " & $sqlite3.errmsg(dbHandle) +else: + quit "could not setup sqlite " & $sqlite3.errmsg(dbHandle) {.pop.} |