Struct sqlite_rs::runtime::SqliteRuntime
source · pub struct SqliteRuntime { /* private fields */ }Implementations§
source§impl SqliteRuntime
impl SqliteRuntime
pub fn start(pager: SqlitePager) -> SqliteResult<Self>
sourcepub fn header(&self) -> &SqliteHeader
pub fn header(&self) -> &SqliteHeader
Examples found in repository?
examples/sqlite_info.rs (line 40)
36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162
fn print_sqlite_info(conn: &SqliteConnection) -> AppResult<()> {
const LABEL_WIDTH: usize = 21;
// TODO:
let sqlite_header = conn.runtime().header();
let mut output = "".to_owned();
output.push_str(&format!(
"{label: <w$}{value}\n",
w = LABEL_WIDTH,
label = "database page size:",
value = u32::from(sqlite_header.page_size())
));
output.push_str(&format!(
"{label: <w$}{value}\n",
w = LABEL_WIDTH,
label = "write format:",
value =
u8::from(sqlite_header.file_format_version_numbers().write_version())
));
output.push_str(&format!(
"{label: <w$}{value}\n",
w = LABEL_WIDTH,
label = "read format:",
value =
u8::from(sqlite_header.file_format_version_numbers().read_version())
));
output.push_str(&format!(
"{label: <w$}{value}\n",
w = LABEL_WIDTH,
label = "reserved bytes:",
value = **sqlite_header.reserved_bytes_per_page()
));
output.push_str(&format!(
"{label: <w$}{value}\n",
w = LABEL_WIDTH,
label = "file change counter:",
value = **sqlite_header.file_change_counter()
));
output.push_str(&format!(
"{label: <w$}{value}\n",
w = LABEL_WIDTH,
label = "database page count:",
value = **sqlite_header.db_filesize_in_pages()
));
output.push_str(&format!(
"{label: <w$}{value}\n",
w = LABEL_WIDTH,
label = "freelist page count:",
value = **sqlite_header.freelist_pages().total()
));
output.push_str(&format!(
"{label: <w$}{value}\n",
w = LABEL_WIDTH,
label = "schema cookie:",
value = **sqlite_header.schema_cookie()
));
output.push_str(&format!(
"{label: <w$}{value}\n",
w = LABEL_WIDTH,
label = "schema format:",
value = u32::from(sqlite_header.schema_format())
));
output.push_str(&format!(
"{label: <w$}{value}\n",
w = LABEL_WIDTH,
label = "default cache size:",
value = **sqlite_header.suggested_cache_size()
));
output.push_str(&format!(
"{label: <w$}{value}\n",
w = LABEL_WIDTH,
label = "autovacuum top root:",
value = **sqlite_header
.incremental_vacuum_settings()
.largest_root_btree_page()
));
output.push_str(&format!(
"{label: <w$}{value}\n",
w = LABEL_WIDTH,
label = "incremental vacuum:",
value = u32::from(
sqlite_header
.incremental_vacuum_settings()
.incremental_vacuum_mode()
)
));
output.push_str(&format!(
"{label: <w$}{value}\n",
w = LABEL_WIDTH,
label = "text encoding:",
value = sqlite_header.database_text_encoding()
));
output.push_str(&format!(
"{label: <w$}{value}\n",
w = LABEL_WIDTH,
label = "user version:",
value = **sqlite_header.user_version()
));
output.push_str(&format!(
"{label: <w$}{value}\n",
w = LABEL_WIDTH,
label = "application id:",
value = **sqlite_header.application_id()
));
output.push_str(&format!(
"{label: <w$}{value}\n",
w = LABEL_WIDTH,
label = "software version:",
value = **sqlite_header.write_library_version()
));
println!("{output}");
Ok(())
}pub fn tables(&self) -> SqliteResult<Vec<SqliteSchema>>
pub fn pager(&self) -> &SqlitePager
pub fn pager_mut(&mut self) -> &mut SqlitePager
Trait Implementations§
Auto Trait Implementations§
impl !RefUnwindSafe for SqliteRuntime
impl Send for SqliteRuntime
impl Sync for SqliteRuntime
impl Unpin for SqliteRuntime
impl !UnwindSafe for SqliteRuntime
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more