/* * Copyright (c) 2013-2014, 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_PARAMETER_H #define SQLPP_PARAMETER_H #include #include #include namespace sqlpp { template struct parameter_t: public ValueType::template expression_operators> { using _traits = make_traits; using _recursive_traits = make_recursive_traits<>; using _instance_t = typename NameType::_name_t::template _member_t; parameter_t() {} parameter_t(const parameter_t&) = default; parameter_t(parameter_t&&) = default; parameter_t& operator=(const parameter_t&) = default; parameter_t& operator=(parameter_t&&) = default; ~parameter_t() = default; }; namespace vendor { template struct serializer_t> { using T = parameter_t; static Context& _(const T& t, Context& context) { context << "?"; return context; } }; } template auto parameter(const NamedExpr&) -> parameter_t { static_assert(is_named_expression_t::value, "not a named expression"); return {}; } template auto parameter(const ValueType&, const AliasProvider&) -> parameter_t { static_assert(is_expression_t::value, "first argument is not a value type"); static_assert(is_alias_provider_t::value, "second argument is not an alias provider"); return {}; } } #endif