##// END OF EJS Templates
rust: stop putting NULL_REVISION in MissingAncestors.bases...
Georges Racinet -
r41865:97743297 default
parent child Browse files
Show More
@@ -209,15 +209,11 impl<G: Graph + Clone> LazyAncestors<G>
209 209
210 210 impl<G: Graph> MissingAncestors<G> {
211 211 pub fn new(graph: G, bases: impl IntoIterator<Item = Revision>) -> Self {
212 let mut bases: HashSet<Revision> = bases.into_iter().collect();
213 if bases.is_empty() {
214 bases.insert(NULL_REVISION);
215 }
216 MissingAncestors { graph, bases }
212 MissingAncestors { graph: graph, bases: bases.into_iter().collect() }
217 213 }
218 214
219 215 pub fn has_bases(&self) -> bool {
220 self.bases.iter().any(|&b| b != NULL_REVISION)
216 !self.bases.is_empty()
221 217 }
222 218
223 219 /// Return a reference to current bases.
@@ -245,7 +241,8 impl<G: Graph> MissingAncestors<G> {
245 241 &mut self,
246 242 new_bases: impl IntoIterator<Item = Revision>,
247 243 ) {
248 self.bases.extend(new_bases);
244 self.bases
245 .extend(new_bases.into_iter().filter(|&rev| rev != NULL_REVISION));
249 246 }
250 247
251 248 /// Remove all ancestors of self.bases from the revs set (in place)
@@ -254,7 +251,10 impl<G: Graph> MissingAncestors<G> {
254 251 revs: &mut HashSet<Revision>,
255 252 ) -> Result<(), GraphError> {
256 253 revs.retain(|r| !self.bases.contains(r));
257 // the null revision is always an ancestor
254 // the null revision is always an ancestor. Logically speaking
255 // it's debatable in case bases is empty, but the Python
256 // implementation always adds NULL_REVISION to bases, making it
257 // unconditionnally true.
258 258 revs.remove(&NULL_REVISION);
259 259 if revs.is_empty() {
260 260 return Ok(());
@@ -265,8 +265,7 impl<G: Graph> MissingAncestors<G> {
265 265 // we shouldn't need to iterate each time on bases
266 266 let start = match self.bases.iter().cloned().max() {
267 267 Some(m) => m,
268 None => {
269 // bases is empty (shouldn't happen, but let's be safe)
268 None => { // self.bases is empty
270 269 return Ok(());
271 270 }
272 271 };
General Comments 0
You need to be logged in to leave comments. Login now