pg: use unsafe
parent
394d64bfd0
commit
c72e505fe4
|
@ -121,16 +121,19 @@ pub fn (db DB) exec_one(query string) ?pg.Row {
|
||||||
return row
|
return row
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
// The entire function can be considered unsafe because of the malloc and the
|
||||||
|
// free. This prevents warnings and doesn't seem to affect behavior.
|
||||||
pub fn (db DB) exec_param_many(query string, params []string) []pg.Row {
|
pub fn (db DB) exec_param_many(query string, params []string) []pg.Row {
|
||||||
|
unsafe {
|
||||||
mut param_vals := &byteptr( malloc( params.len * sizeof(byteptr) ) )
|
mut param_vals := &byteptr( malloc( params.len * sizeof(byteptr) ) )
|
||||||
for i in 0..params.len {
|
for i in 0..params.len {
|
||||||
param_vals[i] = params[i].str
|
param_vals[i] = params[i].str
|
||||||
}
|
}
|
||||||
res := C.PQexecParams(db.conn, query.str, params.len, 0, param_vals, 0, 0, 0)
|
res := C.PQexecParams(db.conn, query.str, params.len, 0, param_vals, 0, 0, 0)
|
||||||
unsafe{ free(param_vals) }
|
free(param_vals)
|
||||||
return db.handle_error_or_result(res, 'exec_param_many')
|
return db.handle_error_or_result(res, 'exec_param_many')
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub fn (db DB) exec_param2(query string, param, param2 string) []pg.Row {
|
pub fn (db DB) exec_param2(query string, param, param2 string) []pg.Row {
|
||||||
mut param_vals := [2]byteptr
|
mut param_vals := [2]byteptr
|
||||||
|
|
Loading…
Reference in New Issue