Skip to content

Commit

Permalink
Minor: make it clearer that clone() is not slow
Browse files Browse the repository at this point in the history
  • Loading branch information
alamb committed Aug 5, 2024
1 parent 5162833 commit 62fb091
Showing 1 changed file with 7 additions and 8 deletions.
15 changes: 7 additions & 8 deletions datafusion/core/src/datasource/statistics.rs
Original file line number Diff line number Diff line change
Expand Up @@ -91,10 +91,10 @@ pub async fn get_statistics_with_limit(
// counts across all the files in question. If any file does not
// provide any information or provides an inexact value, we demote
// the statistic precision to inexact.
num_rows = add_row_stats(file_stats.num_rows.clone(), num_rows);
num_rows = add_row_stats(&file_stats.num_rows, &num_rows);

total_byte_size =
add_row_stats(file_stats.total_byte_size.clone(), total_byte_size);
add_row_stats(&file_stats.total_byte_size, &total_byte_size);

for (file_col_stats, col_stats) in file_stats
.column_statistics
Expand All @@ -108,8 +108,7 @@ pub async fn get_statistics_with_limit(
distinct_count: _,
} = file_col_stats;

col_stats.null_count =
add_row_stats(file_nc.clone(), col_stats.null_count.clone());
col_stats.null_count = add_row_stats(file_nc, &col_stats.null_count);
set_max_if_greater(file_max, &mut col_stats.max_value);
set_min_if_lesser(file_min, &mut col_stats.min_value)
}
Expand Down Expand Up @@ -163,12 +162,12 @@ pub(crate) fn create_max_min_accs(
}

fn add_row_stats(
file_num_rows: Precision<usize>,
num_rows: Precision<usize>,
file_num_rows: &Precision<usize>,
num_rows: &Precision<usize>,
) -> Precision<usize> {
match (file_num_rows, &num_rows) {
(Precision::Absent, _) => num_rows.to_inexact(),
(lhs, Precision::Absent) => lhs.to_inexact(),
(Precision::Absent, _) => num_rows.clone().to_inexact(),
(lhs, Precision::Absent) => lhs.clone().to_inexact(),
(lhs, rhs) => lhs.add(rhs),
}
}
Expand Down

0 comments on commit 62fb091

Please sign in to comment.