added field class
This commit is contained in:
parent
2b552c4383
commit
dd94ed1020
|
|
@ -4,40 +4,107 @@
|
|||
#include "matador/sql/any_type.hpp"
|
||||
#include "matador/sql/any_type_to_visitor.hpp"
|
||||
|
||||
#include "matador/utils/types.hpp"
|
||||
|
||||
#include <optional>
|
||||
#include <string>
|
||||
|
||||
namespace matador::sql {
|
||||
|
||||
enum class field_type {
|
||||
Integer,
|
||||
FloatingPoint,
|
||||
String,
|
||||
Boolean,
|
||||
Blob,
|
||||
Null
|
||||
};
|
||||
|
||||
template < typename Type, typename Enable = void >
|
||||
struct field_traits;
|
||||
|
||||
template<typename Type>
|
||||
struct field_traits<Type, typename std::enable_if<std::is_integral<Type>::value && !std::is_same<Type, bool>::value>::type>
|
||||
{
|
||||
static field_type type() { return field_type::Integer; }
|
||||
};
|
||||
|
||||
template<typename Type>
|
||||
struct field_traits<Type, typename std::enable_if<std::is_floating_point<Type>::value>::type>
|
||||
{
|
||||
static field_type type() { return field_type::FloatingPoint; }
|
||||
};
|
||||
|
||||
template<typename Type>
|
||||
struct field_traits<Type, typename std::enable_if<std::is_same<Type, std::string>::value>::type>
|
||||
{
|
||||
static field_type type() { return field_type::String; }
|
||||
};
|
||||
|
||||
template<typename Type>
|
||||
struct field_traits<Type, typename std::enable_if<std::is_same<Type, bool>::value>::type>
|
||||
{
|
||||
static field_type type() { return field_type::Boolean; }
|
||||
};
|
||||
|
||||
template<typename Type>
|
||||
struct field_traits<Type, typename std::enable_if<std::is_same<Type, nullptr_t>::value>::type>
|
||||
{
|
||||
static field_type type() { return field_type::Null; }
|
||||
};
|
||||
|
||||
template<typename Type>
|
||||
struct field_traits<Type, typename std::enable_if<std::is_same<Type, utils::blob>::value>::type>
|
||||
{
|
||||
static field_type type() { return field_type::Blob; }
|
||||
};
|
||||
|
||||
class field
|
||||
{
|
||||
public:
|
||||
explicit field(std::string name);
|
||||
template<typename Type>
|
||||
field(std::string name, Type value)
|
||||
: name_(std::move(name))
|
||||
, value_(value)
|
||||
, type_(field_traits<Type>::type()) {}
|
||||
field(const field &x) = default;
|
||||
field& operator=(const field &x) = default;
|
||||
field(field &&x) noexcept;
|
||||
field& operator=(field &&x) noexcept;
|
||||
|
||||
template<typename Type>
|
||||
field& operator=(Type value) {
|
||||
value_ = std::move(value);
|
||||
type_ = field_traits<Type>::type();
|
||||
return *this;
|
||||
}
|
||||
|
||||
[[nodiscard]] const std::string& name() const;
|
||||
|
||||
template<class Type>
|
||||
Type as() const
|
||||
std::optional<Type> as() const
|
||||
{
|
||||
const Type* ptr= std::get_if<Type>(&value_);
|
||||
if (ptr) {
|
||||
return *ptr;
|
||||
}
|
||||
any_type_to_visitor<Type> visitor;
|
||||
std::visit(visitor, const_cast<any_type&>(value_));
|
||||
return visitor.result;
|
||||
}
|
||||
|
||||
bool is_integer() const;
|
||||
bool is_floating_point() const;
|
||||
bool is_bool() const;
|
||||
bool is_string() const;
|
||||
bool is_blob() const;
|
||||
bool is_null() const;
|
||||
[[nodiscard]] std::string str() const;
|
||||
|
||||
[[nodiscard]] bool is_integer() const;
|
||||
[[nodiscard]] bool is_floating_point() const;
|
||||
[[nodiscard]] bool is_bool() const;
|
||||
[[nodiscard]] bool is_string() const;
|
||||
[[nodiscard]] bool is_blob() const;
|
||||
[[nodiscard]] bool is_null() const;
|
||||
|
||||
friend std::ostream& operator<<(std::ostream &out, const field &col);
|
||||
|
||||
private:
|
||||
std::string name_;
|
||||
any_type value_;
|
||||
field_type type_;
|
||||
};
|
||||
|
||||
}
|
||||
|
|
|
|||
|
|
@ -2,6 +2,28 @@
|
|||
|
||||
namespace matador::sql {
|
||||
|
||||
field::field(std::string name)
|
||||
: name_(std::move(name)), value_(nullptr), type_(field_traits<nullptr_t>::type())
|
||||
{}
|
||||
|
||||
field::field(field &&x) noexcept
|
||||
: name_(std::move(x.name_)), value_(std::move(x.value_)), type_(x.type_)
|
||||
{
|
||||
x.value_ = nullptr;
|
||||
x.type_ = field_type::Null;
|
||||
}
|
||||
|
||||
field &field::operator=(field &&x) noexcept
|
||||
{
|
||||
name_ = std::move(x.name_);
|
||||
value_ = std::move(x.value_);
|
||||
type_ = x.type_;
|
||||
x.value_ = nullptr;
|
||||
x.type_ = field_type::Null;
|
||||
|
||||
return *this;
|
||||
}
|
||||
|
||||
const std::string &field::name() const
|
||||
{
|
||||
return name_;
|
||||
|
|
@ -9,36 +31,43 @@ const std::string &field::name() const
|
|||
|
||||
std::ostream &operator<<(std::ostream &out, const field &col)
|
||||
{
|
||||
out << col.str();
|
||||
return out;
|
||||
}
|
||||
|
||||
std::string field::str() const
|
||||
{
|
||||
return as<std::string>().value();
|
||||
}
|
||||
|
||||
bool field::is_integer() const
|
||||
{
|
||||
return false;
|
||||
return type_ == field_type::Integer;
|
||||
}
|
||||
|
||||
bool field::is_floating_point() const
|
||||
{
|
||||
return false;
|
||||
return type_ == field_type::FloatingPoint;
|
||||
}
|
||||
|
||||
bool field::is_bool() const
|
||||
{
|
||||
return false;
|
||||
return type_ == field_type::Boolean;
|
||||
}
|
||||
|
||||
bool field::is_string() const
|
||||
{
|
||||
return false;
|
||||
return type_ == field_type::String;
|
||||
}
|
||||
|
||||
bool field::is_blob() const
|
||||
{
|
||||
return false;
|
||||
return type_ == field_type::Blob;
|
||||
}
|
||||
|
||||
bool field::is_null() const
|
||||
{
|
||||
return false;
|
||||
return type_ == field_type::Null;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
@ -38,7 +38,8 @@ add_executable(tests
|
|||
DummyConnection.cpp
|
||||
EntityQueryBuilderTest.cpp
|
||||
models/author.hpp
|
||||
models/book.hpp)
|
||||
models/book.hpp
|
||||
FieldTest.cpp)
|
||||
|
||||
target_link_libraries(tests PRIVATE
|
||||
Catch2::Catch2WithMain
|
||||
|
|
|
|||
|
|
@ -0,0 +1,38 @@
|
|||
#include <catch2/catch_test_macros.hpp>
|
||||
|
||||
#include "matador/sql/field.hpp"
|
||||
|
||||
using namespace matador::sql;
|
||||
|
||||
TEST_CASE("Field test", "[field]") {
|
||||
field f("name");
|
||||
|
||||
REQUIRE(f.name() == "name");
|
||||
REQUIRE(f.is_null());
|
||||
REQUIRE(!f.is_integer());
|
||||
REQUIRE(!f.is_floating_point());
|
||||
REQUIRE(!f.is_blob());
|
||||
REQUIRE(!f.is_bool());
|
||||
REQUIRE(!f.is_string());
|
||||
|
||||
f = 7UL;
|
||||
REQUIRE(!f.is_null());
|
||||
REQUIRE(f.is_integer());
|
||||
REQUIRE(!f.is_floating_point());
|
||||
REQUIRE(!f.is_blob());
|
||||
REQUIRE(!f.is_bool());
|
||||
REQUIRE(!f.is_string());
|
||||
|
||||
auto int_val = f.as<int>();
|
||||
REQUIRE(int_val.has_value());
|
||||
REQUIRE(int_val.value() == 7);
|
||||
auto float_val = f.as<float>();
|
||||
REQUIRE(float_val.has_value());
|
||||
REQUIRE(float_val.value() == 7.0);
|
||||
auto str_val = f.as<std::string>();
|
||||
REQUIRE(str_val.has_value());
|
||||
REQUIRE(str_val.value() == "7");
|
||||
auto bool_val = f.as<bool>();
|
||||
REQUIRE(bool_val.has_value());
|
||||
REQUIRE(bool_val.value());
|
||||
}
|
||||
Loading…
Reference in New Issue