mattn/go-sqlite3

SetFileControlInt performs unsafe conversion from Go int to C int

rittneje opened this issue · 0 comments

Go int and C int are not guaranteed to be the same size. But right now SetFileControlInt blindly casts an int to a C.int, which can overflow or underflow. This is partially responsible for the issue described in #1298. (Even if they were the same size, it still would have been wrong for that op code because SQLite always wants a 64-bit argument even on a 32-bit architecture.)

Fix SetFileControlInt to do explicit bounds checking before casting, and return an error if the number would overflow or underflow.