com.scalar.db.sql.common.ColumnDefinitionsImpl Maven / Gradle / Ivy
package com.scalar.db.sql.common;
import com.google.common.base.Suppliers;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap;
import com.google.common.collect.ImmutableSet;
import com.scalar.db.sql.ColumnDefinition;
import com.scalar.db.sql.ColumnDefinitions;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import java.util.Objects;
import java.util.Set;
import java.util.function.Supplier;
import javax.annotation.concurrent.Immutable;
@Immutable
public class ColumnDefinitionsImpl implements ColumnDefinitions {
private final Supplier> columnDefinitionsMap;
private final Supplier> columnDefinitionsList;
private final Supplier> columnNames;
ColumnDefinitionsImpl(Collection columnDefinitions) {
Objects.requireNonNull(columnDefinitions);
columnDefinitionsMap = Suppliers.memoize(() -> createColumnDefinitionsMap(columnDefinitions));
columnDefinitionsList = Suppliers.memoize(() -> ImmutableList.copyOf(columnDefinitions));
columnNames =
Suppliers.memoize(
() -> {
ImmutableSet.Builder builder = ImmutableSet.builder();
for (ColumnDefinition columnDefinition : columnDefinitions) {
String columnName = columnDefinition.getColumnName();
if (columnDefinition.getTableName().isPresent()) {
columnName = columnDefinition.getTableName().get() + "." + columnName;
}
if (columnDefinition.getNamespaceName().isPresent()) {
columnName = columnDefinition.getNamespaceName().get() + "." + columnName;
}
builder.add(columnName);
}
return builder.build();
});
}
private ImmutableMap createColumnDefinitionsMap(
Collection columnDefinitions) {
Map map = new HashMap<>();
for (ColumnDefinition columnDefinition : columnDefinitions) {
// Put an entry for a column name to a column object
map.putIfAbsent(columnDefinition.getColumnName(), columnDefinition);
// Put an entry for a table name and a column name to a column object if a table name exists
columnDefinition
.getTableName()
.ifPresent(
t -> map.putIfAbsent(t + "." + columnDefinition.getColumnName(), columnDefinition));
// Put an entry for a namespace name, a table name, and a column name to a column object if a
// namespace name exists
columnDefinition
.getNamespaceName()
.ifPresent(
n -> {
assert columnDefinition.getTableName().isPresent();
map.putIfAbsent(
n
+ "."
+ columnDefinition.getTableName().get()
+ "."
+ columnDefinition.getColumnName(),
columnDefinition);
});
}
return ImmutableMap.copyOf(map);
}
@Override
public ColumnDefinition getColumnDefinition(String columnName) {
if (!contains(columnName)) {
throw new IllegalArgumentException(SqlError.COLUMN_NOT_FOUND.buildMessage(columnName));
}
return columnDefinitionsMap.get().get(columnName);
}
@Override
public ColumnDefinition getColumnDefinition(int i) {
return columnDefinitionsList.get().get(i);
}
@Override
public boolean contains(String columnName) {
return columnDefinitionsMap.get().containsKey(columnName);
}
@Override
public Set getColumnNames() {
return columnNames.get();
}
@Override
public int size() {
return columnDefinitionsList.get().size();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy