2014-01-18 22:50:16 +08:00
|
|
|
/*
|
2015-02-16 02:00:21 +08:00
|
|
|
* Copyright (c) 2013-2015, Roland Bock
|
2014-01-18 22:50:16 +08:00
|
|
|
* All rights reserved.
|
2015-08-05 20:43:21 +08:00
|
|
|
*
|
2014-01-18 22:50:16 +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-18 22:50:16 +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-18 22:50:16 +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-18 22:50:16 +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_DETAIL_WRAP_OPERAND_H
|
|
|
|
#define SQLPP_DETAIL_WRAP_OPERAND_H
|
|
|
|
|
2015-10-30 05:21:46 +08:00
|
|
|
namespace sqlpp
|
|
|
|
{
|
|
|
|
template <typename T, typename Enable = void>
|
|
|
|
struct wrap_operand
|
|
|
|
{
|
|
|
|
using type = T;
|
|
|
|
};
|
|
|
|
|
|
|
|
template <typename T>
|
|
|
|
using wrap_operand_t = typename wrap_operand<T>::type;
|
|
|
|
}
|
|
|
|
|
2015-10-29 03:52:43 +08:00
|
|
|
#include <date.h>
|
2014-01-18 22:50:16 +08:00
|
|
|
#include <string>
|
2015-10-08 22:08:04 +08:00
|
|
|
#include <sqlpp11/date_time_fwd.h>
|
2014-06-14 00:51:51 +08:00
|
|
|
#include <sqlpp11/serializer.h>
|
2014-05-16 05:47:16 +08:00
|
|
|
#include <sqlpp11/type_traits.h>
|
2014-08-19 03:10:58 +08:00
|
|
|
#include <sqlpp11/basic_expression_operators.h>
|
2015-10-30 05:21:46 +08:00
|
|
|
#include <sqlpp11/alias_operators.h>
|
2014-01-18 22:50:16 +08:00
|
|
|
|
|
|
|
namespace sqlpp
|
|
|
|
{
|
2015-09-14 03:33:19 +08:00
|
|
|
struct integral;
|
|
|
|
|
2015-10-29 23:41:45 +08:00
|
|
|
struct day_point_operand : public alias_operators<day_point_operand>
|
2015-10-29 22:51:26 +08:00
|
|
|
{
|
2015-10-29 23:41:45 +08:00
|
|
|
using _traits = make_traits<day_point, tag::is_expression, tag::is_wrapped_value>;
|
2015-10-29 22:51:26 +08:00
|
|
|
using _nodes = detail::type_vector<>;
|
|
|
|
using _is_aggregate_expression = std::true_type;
|
|
|
|
|
|
|
|
using _value_t = ::sqlpp::chrono::day_point;
|
|
|
|
|
2015-10-29 23:41:45 +08:00
|
|
|
day_point_operand() : _t{}
|
2015-10-29 22:51:26 +08:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2015-10-29 23:41:45 +08:00
|
|
|
day_point_operand(_value_t t) : _t(t)
|
2015-10-29 22:51:26 +08:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2015-10-29 23:41:45 +08:00
|
|
|
day_point_operand(const day_point_operand&) = default;
|
|
|
|
day_point_operand(day_point_operand&&) = default;
|
|
|
|
day_point_operand& operator=(const day_point_operand&) = default;
|
|
|
|
day_point_operand& operator=(day_point_operand&&) = default;
|
|
|
|
~day_point_operand() = default;
|
2015-10-29 22:51:26 +08:00
|
|
|
|
|
|
|
bool _is_trivial() const
|
|
|
|
{
|
|
|
|
return _t == _value_t{};
|
|
|
|
}
|
|
|
|
|
|
|
|
_value_t _t;
|
|
|
|
};
|
|
|
|
|
|
|
|
template <typename Context>
|
2015-10-29 23:41:45 +08:00
|
|
|
struct serializer_t<Context, day_point_operand>
|
2015-10-29 22:51:26 +08:00
|
|
|
{
|
|
|
|
using _serialize_check = consistent_t;
|
2015-10-29 23:41:45 +08:00
|
|
|
using Operand = day_point_operand;
|
2015-10-29 22:51:26 +08:00
|
|
|
|
|
|
|
static Context& _(const Operand& t, Context& context)
|
|
|
|
{
|
|
|
|
const auto ymd = ::date::year_month_day{t._t};
|
|
|
|
context << "DATE '" << ymd << "'";
|
|
|
|
return context;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2015-10-27 23:13:36 +08:00
|
|
|
template <typename Period>
|
2015-10-29 23:41:45 +08:00
|
|
|
struct time_point_operand : public alias_operators<time_point_operand<Period>>
|
2015-10-08 03:43:19 +08:00
|
|
|
{
|
2015-10-29 23:41:45 +08:00
|
|
|
using _traits = make_traits<time_point, tag::is_expression, tag::is_wrapped_value>;
|
2015-10-08 03:43:19 +08:00
|
|
|
using _nodes = detail::type_vector<>;
|
|
|
|
using _is_aggregate_expression = std::true_type;
|
|
|
|
|
2015-10-27 23:13:36 +08:00
|
|
|
using _value_t = std::chrono::time_point<std::chrono::system_clock, Period>;
|
2015-10-08 03:43:19 +08:00
|
|
|
|
2015-10-29 23:41:45 +08:00
|
|
|
time_point_operand() : _t{}
|
2015-10-08 03:43:19 +08:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2015-10-29 23:41:45 +08:00
|
|
|
time_point_operand(_value_t t) : _t(t)
|
2015-10-08 03:43:19 +08:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2015-10-29 23:41:45 +08:00
|
|
|
time_point_operand(const time_point_operand&) = default;
|
|
|
|
time_point_operand(time_point_operand&&) = default;
|
|
|
|
time_point_operand& operator=(const time_point_operand&) = default;
|
|
|
|
time_point_operand& operator=(time_point_operand&&) = default;
|
|
|
|
~time_point_operand() = default;
|
2015-10-08 03:43:19 +08:00
|
|
|
|
|
|
|
bool _is_trivial() const
|
|
|
|
{
|
2015-10-27 23:13:36 +08:00
|
|
|
return _t == _value_t{};
|
2015-10-08 03:43:19 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
_value_t _t;
|
|
|
|
};
|
|
|
|
|
2015-10-29 03:52:43 +08:00
|
|
|
template <typename Context, typename Period>
|
2015-10-29 23:41:45 +08:00
|
|
|
struct serializer_t<Context, time_point_operand<Period>>
|
2015-10-29 03:52:43 +08:00
|
|
|
{
|
|
|
|
using _serialize_check = consistent_t;
|
2015-10-29 23:41:45 +08:00
|
|
|
using Operand = time_point_operand<Period>;
|
2015-10-29 03:52:43 +08:00
|
|
|
|
|
|
|
static Context& _(const Operand& t, Context& context)
|
|
|
|
{
|
|
|
|
const auto dp = ::date::floor<::date::days>(t._t);
|
|
|
|
const auto time = ::date::make_time(t._t - dp);
|
|
|
|
const auto ymd = ::date::year_month_day{dp};
|
|
|
|
context << "TIMESTAMP '" << ymd << ' ' << time << "'";
|
|
|
|
return context;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2015-10-27 23:13:36 +08:00
|
|
|
template <typename Period>
|
|
|
|
struct wrap_operand<std::chrono::time_point<std::chrono::system_clock, Period>, void>
|
2015-10-08 03:43:19 +08:00
|
|
|
{
|
2015-10-29 23:41:45 +08:00
|
|
|
using type = time_point_operand<Period>;
|
2015-10-08 03:43:19 +08:00
|
|
|
};
|
|
|
|
|
2015-10-29 22:51:26 +08:00
|
|
|
template <>
|
|
|
|
struct wrap_operand<std::chrono::time_point<std::chrono::system_clock, sqlpp::chrono::days>, void>
|
|
|
|
{
|
2015-10-29 23:41:45 +08:00
|
|
|
using type = day_point_operand;
|
2015-10-29 22:51:26 +08:00
|
|
|
};
|
2014-01-18 22:50:16 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|