/* * 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_INTO_H #define SQLPP_INTO_H #include #include #include #include #include #include namespace sqlpp { // A SINGLE TABLE DATA template struct into_data_t { into_data_t(Table table): _table(table) {} into_data_t(const into_data_t&) = default; into_data_t(into_data_t&&) = default; into_data_t& operator=(const into_data_t&) = default; into_data_t& operator=(into_data_t&&) = default; ~into_data_t() = default; Table _table; }; // A SINGLE TABLE template struct into_t { using _traits = make_traits; using _recursive_traits = make_recursive_traits; static_assert(is_table_t
::value, "argument has to be a table"); static_assert(required_tables_of
::size::value == 0, "table depends on another table"); using _data_t = into_data_t; struct _name_t {}; // Member implementation with data and methods template struct _impl_t { _data_t _data; }; // Member template for adding the named member to a statement template struct _member_t { using _data_t = into_data_t; _impl_t into; _impl_t& operator()() { return into; } const _impl_t& operator()() const { return into; } template static auto _get_member(T t) -> decltype(t.into) { return t.into; } }; // Additional methods for the statement template struct _methods_t { }; template struct _result_methods_t { using _statement_t = typename Policies::_statement_t; const _statement_t& _get_statement() const { return static_cast(*this); } template auto _run(Db& db) const -> decltype(db.insert(_get_statement())) { _statement_t::_check_consistency(); static_assert(_statement_t::_get_static_no_of_parameters() == 0, "cannot run insert directly with parameters, use prepare instead"); return db.insert(_get_statement()); } template auto _prepare(Db& db) const -> prepared_insert_t { _statement_t::_check_consistency(); return {{}, db.prepare_insert(_get_statement())}; } }; }; // NO INTO YET struct no_into_t { using _traits = make_traits; using _recursive_traits = make_recursive_traits<>; // Data using _data_t = no_data_t; // Member implementation with data and methods template struct _impl_t { _data_t _data; }; // Member template for adding the named member to a statement template struct _member_t { using _data_t = no_data_t; _impl_t no_into; _impl_t& operator()() { return no_into; } const _impl_t& operator()() const { return no_into; } template static auto _get_member(T t) -> decltype(t.no_into) { return t.no_into; } }; template struct _methods_t { using _database_t = typename Policies::_database_t; template using _new_statement_t = typename Policies::template _new_statement_t; template auto into(Args... args) -> _new_statement_t> { return { *static_cast(this), into_data_t{args...} }; } }; }; // Interpreters template struct serializer_t> { using T = into_data_t; static Context& _(const T& t, Context& context) { context << " INTO "; serialize(t._table, context); return context; } }; } #endif