/* * Copyright (c) 2013-2015, Roland Bock * All rights reserved. * * Redistribution and use in source and binary forms, with or without modification, * are permitted provided that the following conditions are met: * * Redistributions of source code must retain the above copyright notice, this * list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright notice, this * list of conditions and the following disclaimer in the documentation and/or * other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #ifndef SQLPP_SUM_H #define SQLPP_SUM_H #include #include namespace sqlpp { template struct sum_t: public expression_operators, value_type_of>, public alias_operators> { using _traits = make_traits, tag::is_expression, tag::is_selectable>; using _nodes = detail::type_vector; static_assert(is_noop::value or std::is_same::value, "sum() used with flag other than 'distinct'"); static_assert(is_numeric_t::value, "sum() requires a numeric expression as argument"); struct _alias_t { static constexpr const char _literal[] = "sum_"; using _name_t = sqlpp::make_char_sequence; template struct _member_t { T sum; T& operator()() { return sum; } const T& operator()() const { return sum; } }; }; sum_t(Expr expr): _expr(expr) {} sum_t(const sum_t&) = default; sum_t(sum_t&&) = default; sum_t& operator=(const sum_t&) = default; sum_t& operator=(sum_t&&) = default; ~sum_t() = default; Expr _expr; }; template struct serializer_t> { using _serialize_check = serialize_check_of; using T = sum_t; static Context& _(const T& t, Context& context) { context << "SUM("; if (std::is_same::value) { serialize(Flag(), context); context << ' '; serialize_operand(t._expr, context); } else serialize(t._expr, context); context << ")"; return context; } }; template auto sum(T t) -> sum_t> { static_assert(not contains_aggregate_function_t>::value, "sum() cannot be used on an aggregate function"); static_assert(is_numeric_t>::value, "sum() requires a numeric expression as argument"); return { t }; } template auto sum(const distinct_t&, T t) -> sum_t> { static_assert(not contains_aggregate_function_t>::value, "sum() cannot be used on an aggregate function"); static_assert(is_numeric_t>::value, "sum() requires a numeric expression as argument"); return { t }; } } #endif