0
0
mirror of https://github.com/rbock/sqlpp11.git synced 2024-11-16 21:04:15 +08:00
sqlpp11/include/sqlpp11/select_flags.h

97 lines
2.8 KiB
C
Raw Normal View History

2014-01-22 06:42:27 +08:00
/*
2015-02-16 02:00:21 +08:00
* Copyright (c) 2013-2015, Roland Bock
2014-01-22 06:42:27 +08:00
* All rights reserved.
2015-08-05 20:43:21 +08:00
*
2014-01-22 06:42:27 +08:00
* Redistribution and use in source and binary forms, with or without modification,
* are permitted provided that the following conditions are met:
2015-08-05 20:43:21 +08:00
*
2014-01-22 06:42:27 +08:00
* Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
2015-08-05 20:43:21 +08:00
*
2014-01-22 06:42:27 +08:00
* 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.
2015-08-05 20:43:21 +08:00
*
2014-01-22 06:42:27 +08:00
* 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_SELECT_FLAGS_H
#define SQLPP_SELECT_FLAGS_H
#include <sqlpp11/type_traits.h>
2014-02-02 21:58:08 +08:00
#include <sqlpp11/detail/type_set.h>
#include <sqlpp11/interpret_tuple.h>
2014-01-22 06:42:27 +08:00
#include <tuple>
namespace sqlpp
{
// standard select flags
struct all_t
{
using _traits = make_traits<no_value_t, tag::is_select_flag>;
using _nodes = detail::type_vector<>;
};
static constexpr all_t all = {};
2014-01-22 06:42:27 +08:00
template <typename Context>
struct serializer_t<Context, all_t>
{
using _serialize_check = consistent_t;
2014-11-26 00:43:55 +08:00
static Context& _(const all_t&, Context& context)
{
context << "ALL";
return context;
}
};
2014-01-22 06:42:27 +08:00
struct distinct_t
{
using _traits = make_traits<no_value_t, tag::is_select_flag>;
using _nodes = detail::type_vector<>;
};
static constexpr distinct_t distinct = {};
2014-01-22 06:42:27 +08:00
template <typename Context>
struct serializer_t<Context, distinct_t>
{
using _serialize_check = consistent_t;
2014-11-26 00:43:55 +08:00
static Context& _(const distinct_t&, Context& context)
{
context << "DISTINCT";
return context;
}
};
2014-01-22 06:42:27 +08:00
struct straight_join_t
{
using _traits = make_traits<no_value_t, tag::is_select_flag>;
using _nodes = detail::type_vector<>;
};
static constexpr straight_join_t straight_join = {};
2014-01-22 06:42:27 +08:00
template <typename Context>
struct serializer_t<Context, straight_join_t>
{
using _serialize_check = consistent_t;
2014-01-22 06:42:27 +08:00
static Context& _(const straight_join_t&, Context& context)
{
context << "STRAIGHT_JOIN";
return context;
}
};
2014-01-22 06:42:27 +08:00
}
#endif