mirror of
https://github.com/scylladb/scylladb.git
synced 2026-04-23 01:50:35 +00:00
189 lines
6.1 KiB
C++
189 lines
6.1 KiB
C++
/*
|
|
* Licensed to the Apache Software Foundation (ASF) under one
|
|
* or more contributor license agreements. See the NOTICE file
|
|
* distributed with this work for additional information
|
|
* regarding copyright ownership. The ASF licenses this file
|
|
* to you 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.
|
|
*/
|
|
|
|
/*
|
|
* Copyright 2015 Cloudius Systems
|
|
*
|
|
* Modified by Cloudius Systems
|
|
*/
|
|
|
|
#ifndef CQL3_SELECTION_SELECTABLE_HH
|
|
#define CQL3_SELECTION_SELECTABLE_HH
|
|
|
|
#include "schema.hh"
|
|
#include "core/shared_ptr.hh"
|
|
#include "cql3/selection/selector.hh"
|
|
#include "cql3/functions/function_name.hh"
|
|
|
|
namespace cql3 {
|
|
|
|
namespace selection {
|
|
|
|
#if 0
|
|
import java.util.ArrayList;
|
|
import java.util.List;
|
|
|
|
import org.apache.cassandra.config.CFMetaData;
|
|
import org.apache.cassandra.config.ColumnDefinition;
|
|
import org.apache.cassandra.cql3.ColumnIdentifier;
|
|
import org.apache.cassandra.cql3.functions.Function;
|
|
import org.apache.cassandra.cql3.functions.FunctionName;
|
|
import org.apache.cassandra.cql3.functions.Functions;
|
|
import org.apache.cassandra.db.marshal.AbstractType;
|
|
import org.apache.cassandra.db.marshal.UserType;
|
|
import org.apache.cassandra.exceptions.InvalidRequestException;
|
|
import org.apache.commons.lang3.text.StrBuilder;
|
|
#endif
|
|
|
|
class selectable {
|
|
public:
|
|
virtual ~selectable() {}
|
|
virtual ::shared_ptr<selector::factory> new_selector_factory(schema_ptr schema, std::vector<const column_definition*>& defs) = 0;
|
|
protected:
|
|
static size_t add_and_get_index(const column_definition& def, std::vector<const column_definition*>& defs) {
|
|
auto i = std::find(defs.begin(), defs.end(), &def);
|
|
if (i != defs.end()) {
|
|
return std::distance(defs.begin(), i);
|
|
}
|
|
defs.push_back(&def);
|
|
return defs.size() - 1;
|
|
}
|
|
public:
|
|
class raw {
|
|
public:
|
|
virtual ~raw() {}
|
|
|
|
virtual ::shared_ptr<selectable> prepare(schema_ptr s) = 0;
|
|
|
|
/**
|
|
* Returns true if any processing is performed on the selected column.
|
|
**/
|
|
virtual bool processes_selection() const = 0;
|
|
};
|
|
|
|
class writetime_or_ttl;
|
|
|
|
class with_function;
|
|
|
|
#if 0
|
|
public static class WithFieldSelection extends Selectable
|
|
{
|
|
public final Selectable selected;
|
|
public final ColumnIdentifier field;
|
|
|
|
public WithFieldSelection(Selectable selected, ColumnIdentifier field)
|
|
{
|
|
this.selected = selected;
|
|
this.field = field;
|
|
}
|
|
|
|
@Override
|
|
public String toString()
|
|
{
|
|
return String.format("%s.%s", selected, field);
|
|
}
|
|
|
|
public Selector.Factory newSelectorFactory(CFMetaData cfm,
|
|
List<ColumnDefinition> defs) throws InvalidRequestException
|
|
{
|
|
Selector.Factory factory = selected.newSelectorFactory(cfm, defs);
|
|
AbstractType<?> type = factory.newInstance().getType();
|
|
if (!(type instanceof UserType))
|
|
throw new InvalidRequestException(
|
|
String.format("Invalid field selection: %s of type %s is not a user type",
|
|
selected,
|
|
type.asCQL3Type()));
|
|
|
|
UserType ut = (UserType) type;
|
|
for (int i = 0; i < ut.size(); i++)
|
|
{
|
|
if (!ut.fieldName(i).equals(field.bytes))
|
|
continue;
|
|
return FieldSelector.newFactory(ut, i, factory);
|
|
}
|
|
throw new InvalidRequestException(String.format("%s of type %s has no field %s",
|
|
selected,
|
|
type.asCQL3Type(),
|
|
field));
|
|
}
|
|
|
|
public static class Raw implements Selectable.Raw
|
|
{
|
|
private final Selectable.Raw selected;
|
|
private final ColumnIdentifier.Raw field;
|
|
|
|
public Raw(Selectable.Raw selected, ColumnIdentifier.Raw field)
|
|
{
|
|
this.selected = selected;
|
|
this.field = field;
|
|
}
|
|
|
|
public WithFieldSelection prepare(CFMetaData cfm)
|
|
{
|
|
return new WithFieldSelection(selected.prepare(cfm), field.prepare(cfm));
|
|
}
|
|
|
|
public boolean processesSelection()
|
|
{
|
|
return true;
|
|
}
|
|
}
|
|
}
|
|
#endif
|
|
};
|
|
|
|
class selectable::with_function : public selectable {
|
|
functions::function_name _function_name;
|
|
std::vector<shared_ptr<selectable>> _args;
|
|
public:
|
|
with_function(functions::function_name fname, std::vector<shared_ptr<selectable>> args)
|
|
: _function_name(std::move(fname)), _args(std::move(args)) {
|
|
}
|
|
|
|
#if 0
|
|
@Override
|
|
public String toString()
|
|
{
|
|
return new StrBuilder().append(functionName)
|
|
.append("(")
|
|
.appendWithSeparators(args, ", ")
|
|
.append(")")
|
|
.toString();
|
|
}
|
|
#endif
|
|
|
|
virtual shared_ptr<selector::factory> new_selector_factory(schema_ptr s, std::vector<const column_definition*>& defs) override;
|
|
class raw : public selectable::raw {
|
|
functions::function_name _function_name;
|
|
std::vector<shared_ptr<selectable::raw>> _args;
|
|
public:
|
|
raw(functions::function_name function_name, std::vector<shared_ptr<selectable::raw>> args)
|
|
: _function_name(std::move(function_name)), _args(std::move(args)) {
|
|
}
|
|
virtual shared_ptr<selectable> prepare(schema_ptr s) override;
|
|
virtual bool processes_selection() const override;
|
|
};
|
|
};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|