use mongo_c_driver_wrapper::bindings; use std::collections::BTreeSet; pub struct Flags { flags: BTreeSet } impl Flags where T: Ord { pub fn new() -> Flags { Flags { flags: BTreeSet::new() } } pub fn add(&mut self, flag: T) { self.flags.insert(flag); } } pub trait FlagsValue { fn flags(&self) -> u32; } /// Flags for insert operations /// See: http://api.mongodb.org/c/current/mongoc_insert_flags_t.html #[derive(Eq,PartialEq,Ord,PartialOrd)] pub enum InsertFlag { ContinueOnError, NoValidate } impl FlagsValue for Flags { fn flags(&self) -> u32 { if self.flags.is_empty() { bindings::MONGOC_INSERT_NONE } else { self.flags.iter().fold(0, { |flags, flag| flags | match flag { &InsertFlag::ContinueOnError => bindings::MONGOC_INSERT_CONTINUE_ON_ERROR, &InsertFlag::NoValidate => 1 | 31 // MONGOC_INSERT_NO_VALIDATE defined in macro } }) } } } /// Flags for query operations /// See: http://api.mongodb.org/c/current/mongoc_query_flags_t.html #[derive(Eq,PartialEq,Ord,PartialOrd)] pub enum QueryFlag { TailableCursor, SlaveOk, OplogReplay, NoCursorTimeout, AwaitData, Exhaust, Partial } impl FlagsValue for Flags { fn flags(&self) -> u32 { if self.flags.is_empty() { bindings::MONGOC_QUERY_NONE } else { self.flags.iter().fold(0, { |flags, flag| flags | match flag { &QueryFlag::TailableCursor => bindings::MONGOC_QUERY_TAILABLE_CURSOR, &QueryFlag::SlaveOk => bindings::MONGOC_QUERY_SLAVE_OK, &QueryFlag::OplogReplay => bindings::MONGOC_QUERY_OPLOG_REPLAY, &QueryFlag::NoCursorTimeout => bindings::MONGOC_QUERY_NO_CURSOR_TIMEOUT, &QueryFlag::AwaitData => bindings::MONGOC_QUERY_AWAIT_DATA, &QueryFlag::Exhaust => bindings::MONGOC_QUERY_EXHAUST, &QueryFlag::Partial => bindings::MONGOC_QUERY_PARTIAL } }) } } } /// Flags for deletion operations /// See: http://api.mongodb.org/c/1.1.8/mongoc_remove_flags_t.html #[derive(Eq,PartialEq,Ord,PartialOrd)] pub enum RemoveFlag { SingleRemove } impl FlagsValue for Flags { fn flags(&self) -> u32 { if self.flags.is_empty() { bindings::MONGOC_REMOVE_NONE } else { bindings::MONGOC_REMOVE_SINGLE_REMOVE } } }