mirror of
				https://github.com/isar/rusqlite.git
				synced 2025-10-31 22:08:55 +08:00 
			
		
		
		
	Merge remote-tracking branch 'jgallagher/master' into rustfmt
This commit is contained in:
		
							
								
								
									
										23
									
								
								src/lib.rs
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								src/lib.rs
									
									
									
									
									
								
							| @@ -496,6 +496,18 @@ impl Connection { | ||||
|         self.db.borrow_mut().load_extension(dylib_path.as_ref(), entry_point) | ||||
|     } | ||||
|  | ||||
|     /// Get access to the underlying SQLite database connection handle. | ||||
|     /// | ||||
|     /// # Warning | ||||
|     /// | ||||
|     /// You should not need to use this function. If you do need to, please [open an issue | ||||
|     /// on the rusqlite repository](https://github.com/jgallagher/rusqlite/issues) and describe | ||||
|     /// your use case. This function is unsafe because it gives you raw access to the SQLite | ||||
|     /// connection, and what you do with it could impact the safety of this `Connection`. | ||||
|     pub unsafe fn handle(&self) -> *mut ffi::Struct_sqlite3 { | ||||
|         self.db.borrow().db() | ||||
|     } | ||||
|  | ||||
|     fn decode_result(&self, code: c_int) -> Result<()> { | ||||
|         self.db.borrow_mut().decode_result(code) | ||||
|     } | ||||
| @@ -977,6 +989,9 @@ pub type SqliteRows<'stmt> = Rows<'stmt>; | ||||
| /// | ||||
| /// ## Warning | ||||
| /// | ||||
| /// Strongly consider using `query_map` or `query_and_then` instead of `query`; the former do not | ||||
| /// suffer from the following problem. | ||||
| /// | ||||
| /// Due to the way SQLite returns result rows of a query, it is not safe to attempt to get values | ||||
| /// from a row after it has become stale (i.e., `next()` has been called again on the `Rows` | ||||
| /// iterator). For example: | ||||
| @@ -988,7 +1003,7 @@ pub type SqliteRows<'stmt> = Rows<'stmt>; | ||||
| ///     let mut rows = try!(stmt.query(&[])); | ||||
| /// | ||||
| ///     let row0 = try!(rows.next().unwrap()); | ||||
| ///     // row 0 is value now... | ||||
| ///     // row 0 is valid for now... | ||||
| /// | ||||
| ///     let row1 = try!(rows.next().unwrap()); | ||||
| ///     // row 0 is now STALE, and row 1 is valid | ||||
| @@ -1002,12 +1017,6 @@ pub type SqliteRows<'stmt> = Rows<'stmt>; | ||||
| /// (which would result in a collection of rows, only the last of which can safely be used) and | ||||
| /// `min`/`max` (which could return a stale row unless the last row happened to be the min or max, | ||||
| /// respectively). | ||||
| /// | ||||
| /// This problem could be solved by changing the signature of `next` to tie the lifetime of the | ||||
| /// returned row to the lifetime of (a mutable reference to) the result rows handle, but this would | ||||
| /// no longer implement `Iterator`, and therefore you would lose access to the majority of | ||||
| /// functions which are useful (such as support for `for ... in ...` looping, `map`, `filter`, | ||||
| /// etc.). | ||||
| pub struct Rows<'stmt> { | ||||
|     stmt: &'stmt Statement<'stmt>, | ||||
|     current_row: Rc<Cell<c_int>>, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user