|  |  |  | @ -1,3 +1,5 @@ | 
		
	
		
			
				|  |  |  |  | //! Access to a MongoDB database.
 | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  | use std::ffi::{CString,CStr}; | 
		
	
		
			
				|  |  |  |  | use std::borrow::Cow; | 
		
	
		
			
				|  |  |  |  | use std::ptr; | 
		
	
	
		
			
				
					|  |  |  | @ -14,19 +16,25 @@ use super::collection; | 
		
	
		
			
				|  |  |  |  | use super::collection::Collection; | 
		
	
		
			
				|  |  |  |  | use super::cursor; | 
		
	
		
			
				|  |  |  |  | use super::cursor::Cursor; | 
		
	
		
			
				|  |  |  |  | use super::read_prefs::ReadPrefs; | 
		
	
		
			
				|  |  |  |  | use flags::FlagsValue; | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  | #[doc(hidden)] | 
		
	
		
			
				|  |  |  |  | pub enum CreatedBy<'a> { | 
		
	
		
			
				|  |  |  |  |     BorrowedClient(&'a Client<'a>), | 
		
	
		
			
				|  |  |  |  |     OwnedClient(Client<'a>) | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  | /// Provides access to a MongoDB database.
 | 
		
	
		
			
				|  |  |  |  | ///
 | 
		
	
		
			
				|  |  |  |  | /// A database instance can be created by calling `get_database` or `take_database` on a `Client` instance.
 | 
		
	
		
			
				|  |  |  |  | pub struct Database<'a> { | 
		
	
		
			
				|  |  |  |  |     _created_by: CreatedBy<'a>, | 
		
	
		
			
				|  |  |  |  |     inner:   *mut bindings::mongoc_database_t | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  | impl<'a> Database<'a> { | 
		
	
		
			
				|  |  |  |  |     #[doc(ignore)] | 
		
	
		
			
				|  |  |  |  |     pub fn new( | 
		
	
		
			
				|  |  |  |  |         created_by: CreatedBy<'a>, | 
		
	
		
			
				|  |  |  |  |         inner: *mut bindings::mongoc_database_t | 
		
	
	
		
			
				
					|  |  |  | @ -38,9 +46,8 @@ impl<'a> Database<'a> { | 
		
	
		
			
				|  |  |  |  |         } | 
		
	
		
			
				|  |  |  |  |     } | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |     /// Execute a command on the database
 | 
		
	
		
			
				|  |  |  |  |     ///
 | 
		
	
		
			
				|  |  |  |  |     /// See: http://api.mongodb.org/c/current/mongoc_database_command.html
 | 
		
	
		
			
				|  |  |  |  |     /// Execute a command on the database.
 | 
		
	
		
			
				|  |  |  |  |     /// This is performed lazily and therefore requires calling `next` on the resulting cursor.
 | 
		
	
		
			
				|  |  |  |  |     pub fn command( | 
		
	
		
			
				|  |  |  |  |         &'a self, | 
		
	
		
			
				|  |  |  |  |         command: Document, | 
		
	
	
		
			
				
					|  |  |  | @ -82,19 +89,14 @@ impl<'a> Database<'a> { | 
		
	
		
			
				|  |  |  |  |         )) | 
		
	
		
			
				|  |  |  |  |     } | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |     /// Simplified version of command that returns the first document
 | 
		
	
		
			
				|  |  |  |  |     ///
 | 
		
	
		
			
				|  |  |  |  |     /// See: http://api.mongodb.org/c/current/mongoc_database_command_simple.html
 | 
		
	
		
			
				|  |  |  |  |     /// Simplified version of `command` that returns the first document immediately.
 | 
		
	
		
			
				|  |  |  |  |     pub fn command_simple( | 
		
	
		
			
				|  |  |  |  |         &'a self, | 
		
	
		
			
				|  |  |  |  |         command: Document, | 
		
	
		
			
				|  |  |  |  |         options: Option<&CommandAndFindOptions> | 
		
	
		
			
				|  |  |  |  |         read_prefs: Option<&ReadPrefs> | 
		
	
		
			
				|  |  |  |  |     ) -> Result<Document> { | 
		
	
		
			
				|  |  |  |  |         assert!(!self.inner.is_null()); | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |         let default_options = CommandAndFindOptions::default(); | 
		
	
		
			
				|  |  |  |  |         let options         = options.unwrap_or(&default_options); | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |         // Bsonc to store the reply
 | 
		
	
		
			
				|  |  |  |  |         let mut reply = Bsonc::new(); | 
		
	
		
			
				|  |  |  |  |         // Empty error that might be filled
 | 
		
	
	
		
			
				
					|  |  |  | @ -104,7 +106,7 @@ impl<'a> Database<'a> { | 
		
	
		
			
				|  |  |  |  |             bindings::mongoc_database_command_simple( | 
		
	
		
			
				|  |  |  |  |                 self.inner, | 
		
	
		
			
				|  |  |  |  |                 try!(Bsonc::from_document(&command)).inner(), | 
		
	
		
			
				|  |  |  |  |                 match options.read_prefs { | 
		
	
		
			
				|  |  |  |  |                 match read_prefs { | 
		
	
		
			
				|  |  |  |  |                     Some(ref prefs) => prefs.inner(), | 
		
	
		
			
				|  |  |  |  |                     None => ptr::null() | 
		
	
		
			
				|  |  |  |  |                 }, | 
		
	
	
		
			
				
					|  |  |  | @ -123,6 +125,7 @@ impl<'a> Database<'a> { | 
		
	
		
			
				|  |  |  |  |         } | 
		
	
		
			
				|  |  |  |  |     } | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |     /// Create a new collection in this database.
 | 
		
	
		
			
				|  |  |  |  |     pub fn create_collection<S: Into<Vec<u8>>>( | 
		
	
		
			
				|  |  |  |  |         &self, | 
		
	
		
			
				|  |  |  |  |         name:    S, | 
		
	
	
		
			
				
					|  |  |  | @ -179,6 +182,7 @@ impl<'a> Database<'a> { | 
		
	
		
			
				|  |  |  |  |         ) | 
		
	
		
			
				|  |  |  |  |     } | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |     /// Get the name of this database.
 | 
		
	
		
			
				|  |  |  |  |     pub fn get_name(&self) -> Cow<str> { | 
		
	
		
			
				|  |  |  |  |         let cstr = unsafe { | 
		
	
		
			
				|  |  |  |  |             CStr::from_ptr(bindings::mongoc_database_get_name(self.inner)) | 
		
	
	
		
			
				
					|  |  |  | 
 |