class
FunctionVAR
Base classes
- class FunctionExpression
Derived classes
- class FunctionSTDEV
Public static functions
- static auto arity() -> int
- static auto help() -> const char*
-
static auto number(double) -> std::
shared_ptr<SQLExpression>
Constructors, destructors, conversion operators
-
FunctionVAR(const std::
string&, const expression:: Expressions&) - FunctionVAR(const FunctionVAR&)
- ~FunctionVAR()
Public functions
-
auto type() const -> const eckit::
sql:: type:: SQLType* override - void prepare(SQLSelect&) override
- void cleanup(SQLSelect&) override
- void partialResult() override
- auto isAggregate() const -> bool override
-
auto clone() const -> std::
shared_ptr<SQLExpression> override -
void print(std::
ostream& s) const override - void preprepare(SQLSelect&) override
- void updateType(SQLSelect& sql) override
- auto isConstant() const -> bool override
-
auto simplify(bool&) -> std::
shared_ptr<SQLExpression> override -
auto reshift(int minColumnShift) const -> std::
shared_ptr<SQLExpression> override -
auto args() -> expression::
Expressions& - void eval(double* out, bool& missing) const virtual
-
auto evalAsString(bool& missing) const -> std::
string virtual -
auto andSplit(expression::
Expressions&) -> bool virtual - auto isNumber() const -> bool virtual
-
void title(const std::
string&) virtual -
auto title() const -> std::
string virtual - void output(SQLOutput&) const virtual
-
void expandStars(const std::
vector<std:: reference_wrapper<const SQLTable>>&, expression:: Expressions&) virtual - auto isBitfield() const -> bool virtual
- auto bitfieldDef() const -> BitfieldDef
- auto hasMissingValue() const -> bool virtual
- auto missingValue() const -> double
- auto shared_from_this(T... args) -> T
- auto weak_from_this(T... args) -> T
Private functions
- auto eval(bool& missing) const -> double override
Function documentation
static const char* eckit:: sql:: expression:: function:: FunctionVAR:: help()
static std:: shared_ptr<SQLExpression> eckit:: sql:: expression:: function:: FunctionVAR:: number(double)
void eckit:: sql:: expression:: function:: FunctionVAR:: print(std:: ostream& s) const override
void eckit:: sql:: expression:: function:: FunctionVAR:: preprepare(SQLSelect&) override
pre-prepare ideally wouldn't exist. To enable a two-pass prepare of SQL columns for SQLSelect, this is here.
void eckit:: sql:: expression:: function:: FunctionVAR:: updateType(SQLSelect& sql) override
bool eckit:: sql:: expression:: function:: FunctionVAR:: isConstant() const override
std:: shared_ptr<SQLExpression> eckit:: sql:: expression:: function:: FunctionVAR:: simplify(bool&) override
std:: shared_ptr<SQLExpression> eckit:: sql:: expression:: function:: FunctionVAR:: reshift(int minColumnShift) const override
expression:: Expressions& eckit:: sql:: expression:: function:: FunctionVAR:: args()
void eckit:: sql:: expression:: function:: FunctionVAR:: eval(double* out,
bool& missing) const virtual
std:: string eckit:: sql:: expression:: function:: FunctionVAR:: evalAsString(bool& missing) const virtual
bool eckit:: sql:: expression:: function:: FunctionVAR:: andSplit(expression:: Expressions&) virtual
bool eckit:: sql:: expression:: function:: FunctionVAR:: isNumber() const virtual
void eckit:: sql:: expression:: function:: FunctionVAR:: title(const std:: string&) virtual
std:: string eckit:: sql:: expression:: function:: FunctionVAR:: title() const virtual
void eckit:: sql:: expression:: function:: FunctionVAR:: expandStars(const std:: vector<std:: reference_wrapper<const SQLTable>>&,
expression:: Expressions&) virtual
bool eckit:: sql:: expression:: function:: FunctionVAR:: isBitfield() const virtual
BitfieldDef eckit:: sql:: expression:: function:: FunctionVAR:: bitfieldDef() const
bool eckit:: sql:: expression:: function:: FunctionVAR:: hasMissingValue() const virtual
double eckit:: sql:: expression:: function:: FunctionVAR:: missingValue() const