From 3715f1ed0089a12ac7bb5dd093d3dd8bbb0833ac Mon Sep 17 00:00:00 2001 From: Nadrieril Date: Sat, 21 Nov 2020 23:12:53 +0000 Subject: [PATCH] No need to expose `Matrix` internals --- compiler/rustc_mir_build/src/thir/pattern/_match.rs | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/compiler/rustc_mir_build/src/thir/pattern/_match.rs b/compiler/rustc_mir_build/src/thir/pattern/_match.rs index 29364107954..5dc56b72bd2 100644 --- a/compiler/rustc_mir_build/src/thir/pattern/_match.rs +++ b/compiler/rustc_mir_build/src/thir/pattern/_match.rs @@ -476,6 +476,11 @@ impl<'p, 'tcx> Matrix<'p, 'tcx> { Matrix { patterns: vec![] } } + /// Number of columns of this matrix. `None` is the matrix is empty. + fn column_count(&self) -> Option { + self.patterns.get(0).map(|r| r.len()) + } + /// Pushes a new row to the matrix. If the row starts with an or-pattern, this expands it. fn push(&mut self, row: PatStack<'p, 'tcx>) { if let Some(rows) = row.expand_or_pat() { @@ -1897,7 +1902,7 @@ impl<'tcx> IntRange<'tcx> { // Collect the span and range of all the intersecting ranges to lint on likely // incorrect range patterns. (#63987) let mut overlaps = vec![]; - let row_len = pcx.matrix.patterns.get(0).map(|r| r.len()).unwrap_or(0); + let row_len = pcx.matrix.column_count().unwrap_or(0); // `borders` is the set of borders between equivalence classes: each equivalence // class lies between 2 borders. let row_borders = pcx