{
CFDefinition.Name name = cfDef.get(columnNames.get(i));
if (name == null)
throw new InvalidRequestException(String.format("Unknown identifier %s", columnNames.get(i)));
Operation operation = columnOperations.get(i);
operation.addBoundNames(name, boundNames);
switch (name.kind)
{
case KEY_ALIAS:
case COLUMN_ALIAS:
if (processedKeys.containsKey(name.name))
throw new InvalidRequestException(String.format("Multiple definitions found for PRIMARY KEY part %s", name));
// We know collection are not accepted for key and column aliases
if (operation.getType() != Operation.Type.COLUMN && operation.getType() != Operation.Type.PREPARED)
throw new InvalidRequestException(String.format("Invalid definition for %s, not a collection type", name));
processedKeys.put(name.name, operation.getValues());
break;
case VALUE_ALIAS:
case COLUMN_METADATA:
if (processedColumns.containsKey(name))
throw new InvalidRequestException(String.format("Multiple definitions found for column %s", name));
addNewOperation(name, operation);
break;
}
}
}
else
{
// Created from an UPDATE
for (Pair<ColumnIdentifier, Operation> entry : columns)
{
CFDefinition.Name name = cfDef.get(entry.left);
if (name == null)
throw new InvalidRequestException(String.format("Unknown identifier %s", entry.left));
Operation operation = entry.right;
switch (operation.getType())
{
case COUNTER:
if (type != Type.COUNTER)
throw new InvalidRequestException("Invalid counter operation on non-counter table.");
break;
case LIST:
case SET:
case MAP:
if (!name.type.isCollection())
throw new InvalidRequestException("Cannot apply collection operation on column " + name + " with " + name.type + " type.");
// Fallthrough on purpose
case COLUMN:
if (type == Type.COUNTER)
throw new InvalidRequestException("Invalid non-counter operation on counter table.");
break;
case PREPARED:
if (type == Type.COUNTER && !((PreparedOperation)operation).isPotentialCounterOperation())
throw new InvalidRequestException("Invalid non-counter operation on counter table.");
break;
}
switch (name.kind)
{
case KEY_ALIAS:
case COLUMN_ALIAS:
throw new InvalidRequestException(String.format("PRIMARY KEY part %s found in SET part", entry.left));
case VALUE_ALIAS:
case COLUMN_METADATA:
for (Operation otherOp : processedColumns.get(name))
if (otherOp.getType() == Operation.Type.COLUMN)
throw new InvalidRequestException(String.format("Multiple definitions found for column %s", name));
operation.addBoundNames(name, boundNames);
addNewOperation(name, operation);
break;
}
}
processKeys(cfDef, whereClause, processedKeys, boundNames);