1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
// Copyright 2015-2017 Aerospike, Inc. // // Portions may be licensed to Aerospike, Inc. under one or more contributor // license agreements. // // Licensed under the Apache License, Version 2.0 (the "License"); you may not // use this file except in compliance with the License. You may obtain a copy of // the License at http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the // License for the specific language governing permissions and limitations under // the License. use Bins; use Key; use Record; /// Key and bin names used in batch read commands where variable bins are needed for each key. pub struct BatchRead<'a> { /// Key. pub key: Key, /// Bins to retrieve for this key. pub bins: Bins<'a>, /// Will contain the record after the batch read operation. pub record: Option<Record>, } impl<'a> BatchRead<'a> { /// Create a new `BatchRead` instance for the given key and bin selector. pub fn new<T>(key: Key, bins: T) -> Self where T: Into<Bins<'a>> { let bins = bins.into(); BatchRead { key: key, bins: bins, record: None, } } #[doc(hidden)] pub fn match_header(&self, other: &BatchRead<'a>, match_set: bool) -> bool { let key = &self.key; let other_key = &other.key; (key.namespace == other_key.namespace) && (match_set && (key.set_name == other_key.set_name)) && (self.bins == other.bins) } }