blob: d176a63b079b8c9ac4bb0c1ce658f1ae723d188c [file]
// Copyright (C) 2025 The Android Open Source Project
//
// 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.
import {sqlColumnId} from '../table/sql_column';
import type {TableColumn} from '../table/table_column';
import type {Aggregation} from './aggregations';
// Unique identifier for a pivot column.
export function pivotId(p: TableColumn): string {
return sqlColumnId(p.column);
}
// Unique identifier for an aggregation.
// The column is always included to prevent ID collisions: expanding a non-associative
// aggregation (e.g. average(dur) -> sum(dur) + count(dur)) must not produce a
// count(dur) that collides with the built-in count(1), otherwise values are
// accumulated twice, inflating counts 2x per row.
export function aggregationId(a: Aggregation): string {
return `${a.op}(${sqlColumnId(a.column.column)})`;
}
// Human-readable label for an aggregation, used in column headers.
// Returns 'count' for the built-in count(1) instead of the full 'count(1)'.
export function aggregationLabel(a: Aggregation): string {
const id = aggregationId(a);
return id === 'count(1)' ? 'count' : id;
}