mirror of
https://github.com/isar/rusqlite.git
synced 2024-11-26 11:31:37 +08:00
Expose version(), version_number(), and source_id() functions.
This commit is contained in:
parent
e971f63553
commit
eb099952ac
@ -1,6 +1,8 @@
|
|||||||
# Version UPCOMING (TBD)
|
# Version UPCOMING (TBD)
|
||||||
|
|
||||||
* Re-export the `ErrorCode` enum from `libsqlite3-sys`.
|
* Re-export the `ErrorCode` enum from `libsqlite3-sys`.
|
||||||
|
* Adds `version()`, `version_number()`, and `source_id()` functions for querying the version of
|
||||||
|
SQLite in use.
|
||||||
|
|
||||||
# Version 0.9.5 (2017-01-26)
|
# Version 0.9.5 (2017-01-26)
|
||||||
|
|
||||||
|
15
src/lib.rs
15
src/lib.rs
@ -89,12 +89,14 @@ pub use error::Error;
|
|||||||
pub use ffi::ErrorCode;
|
pub use ffi::ErrorCode;
|
||||||
|
|
||||||
pub use cache::CachedStatement;
|
pub use cache::CachedStatement;
|
||||||
|
pub use version::*;
|
||||||
|
|
||||||
#[cfg(feature = "load_extension")]
|
#[cfg(feature = "load_extension")]
|
||||||
#[allow(deprecated)]
|
#[allow(deprecated)]
|
||||||
pub use load_extension_guard::{SqliteLoadExtensionGuard, LoadExtensionGuard};
|
pub use load_extension_guard::{SqliteLoadExtensionGuard, LoadExtensionGuard};
|
||||||
|
|
||||||
pub mod types;
|
pub mod types;
|
||||||
|
mod version;
|
||||||
mod transaction;
|
mod transaction;
|
||||||
mod cache;
|
mod cache;
|
||||||
mod named_params;
|
mod named_params;
|
||||||
@ -1511,8 +1513,7 @@ mod test {
|
|||||||
|
|
||||||
// extended error codes for constraints were added in SQLite 3.7.16; if we're
|
// extended error codes for constraints were added in SQLite 3.7.16; if we're
|
||||||
// running on a version at least that new, check for the extended code
|
// running on a version at least that new, check for the extended code
|
||||||
let version = unsafe { ffi::sqlite3_libversion_number() };
|
if version_number() >= 3007016 {
|
||||||
if version >= 3007016 {
|
|
||||||
assert_eq!(err.extended_code, ffi::SQLITE_CONSTRAINT_NOTNULL)
|
assert_eq!(err.extended_code, ffi::SQLITE_CONSTRAINT_NOTNULL)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1520,6 +1521,16 @@ mod test {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_version_string() {
|
||||||
|
let n = version_number();
|
||||||
|
let major = n / 1_000_000;
|
||||||
|
let minor = (n % 1_000_000) / 1_000;
|
||||||
|
let patch = n % 1_000;
|
||||||
|
|
||||||
|
assert_eq!(version(), format!("{}.{}.{}", major, minor, patch));
|
||||||
|
}
|
||||||
|
|
||||||
mod query_and_then_tests {
|
mod query_and_then_tests {
|
||||||
extern crate libsqlite3_sys as ffi;
|
extern crate libsqlite3_sys as ffi;
|
||||||
use super::*;
|
use super::*;
|
||||||
|
25
src/version.rs
Normal file
25
src/version.rs
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
use ffi;
|
||||||
|
use std::ffi::CStr;
|
||||||
|
|
||||||
|
/// Returns the SQLite version as an integer; e.g., `3016002` for version 3.16.2.
|
||||||
|
///
|
||||||
|
/// See [sqlite3_libversion_number()](https://www.sqlite.org/c3ref/libversion.html).
|
||||||
|
pub fn version_number() -> i32 {
|
||||||
|
unsafe { ffi::sqlite3_libversion_number() }
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Returns the SQLite version as a string; e.g., `"3.16.2"` for version 3.16.2.
|
||||||
|
///
|
||||||
|
/// See [sqlite3_libversion()](https://www.sqlite.org/c3ref/libversion.html).
|
||||||
|
pub fn version() -> &'static str {
|
||||||
|
let cstr = unsafe { CStr::from_ptr(ffi::sqlite3_libversion()) };
|
||||||
|
cstr.to_str().expect("SQLite version string is not valid UTF8 ?!")
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Returns the source ID of SQLite, identifying the commit of SQLite for the current version.
|
||||||
|
///
|
||||||
|
/// See [sqlite3_sourceid()](https://www.sqlite.org/c3ref/libversion.html).
|
||||||
|
pub fn source_id() -> &'static str {
|
||||||
|
let cstr = unsafe { CStr::from_ptr(ffi::sqlite3_sourceid()) };
|
||||||
|
cstr.to_str().expect("SQLite source ID is not valid UTF8 ?!")
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user