object changes

This commit is contained in:
Sascha Kühl 2025-12-09 14:47:08 +01:00
parent d4a8801cd2
commit 4fcbe9c064
19 changed files with 109 additions and 92 deletions

View File

@ -26,7 +26,7 @@ public:
[[nodiscard]] std::type_index type_index() const; [[nodiscard]] std::type_index type_index() const;
[[nodiscard]] std::string name() const; [[nodiscard]] std::string name() const;
[[nodiscard]] const class object& object() const; [[nodiscard]] std::shared_ptr<class object> object() const;
[[nodiscard]] const std::list<attribute>& attributes() const; [[nodiscard]] const std::list<attribute>& attributes() const;
[[nodiscard]] const std::list<class constraint>& constraints() const; [[nodiscard]] const std::list<class constraint>& constraints() const;
@ -34,7 +34,7 @@ public:
[[nodiscard]] const utils::identifier& primary_key() const; [[nodiscard]] const utils::identifier& primary_key() const;
[[nodiscard]] attribute* primary_key_attribute() const; [[nodiscard]] attribute* primary_key_attribute() const;
void update_name(const std::string& name); void update_name(const std::string& name) const;
endpoint_iterator register_relation_endpoint(const std::type_index &type, const std::shared_ptr<relation_endpoint> &endpoint); endpoint_iterator register_relation_endpoint(const std::type_index &type, const std::shared_ptr<relation_endpoint> &endpoint);
void unregister_relation_endpoint(const std::type_index &type); void unregister_relation_endpoint(const std::type_index &type);
@ -55,10 +55,10 @@ public:
[[nodiscard]] bool endpoints_empty() const; [[nodiscard]] bool endpoints_empty() const;
protected: protected:
basic_object_info(std::shared_ptr<repository_node> node, std::unique_ptr<class object> &&obj); basic_object_info(std::shared_ptr<repository_node> node, std::shared_ptr<class object> &&obj);
protected: protected:
std::unique_ptr<class object> object_; std::shared_ptr<class object> object_;
std::shared_ptr<repository_node> node_; /**< prototype node of the represented object type */ std::shared_ptr<repository_node> node_; /**< prototype node of the represented object type */
t_endpoint_map relation_endpoints_; t_endpoint_map relation_endpoints_;
}; };

View File

@ -23,7 +23,7 @@ public:
[[nodiscard]] const std::string& name() const; [[nodiscard]] const std::string& name() const;
[[nodiscard]] const class attribute* attribute() const; [[nodiscard]] const class attribute* attribute() const;
[[nodiscard]] std::string column_name() const; [[nodiscard]] std::string column_name() const;
[[nodiscard]] const object* owner() const; [[nodiscard]] std::shared_ptr<object> owner() const;
[[nodiscard]] bool is_primary_key_constraint() const; [[nodiscard]] bool is_primary_key_constraint() const;
[[nodiscard]] bool is_foreign_key_constraint() const; [[nodiscard]] bool is_foreign_key_constraint() const;
[[nodiscard]] bool is_unique_constraint() const; [[nodiscard]] bool is_unique_constraint() const;
@ -40,7 +40,8 @@ private:
std::string name_; std::string name_;
std::variant<class attribute*, std::string> attr_; std::variant<class attribute*, std::string> attr_;
object *owner_{nullptr}; std::shared_ptr<object> owner_;
std::shared_ptr<object> reference_;
utils::constraints options_{utils::constraints::None}; utils::constraints options_{utils::constraints::None};
std::string ref_table_name_{}; std::string ref_table_name_{};
std::string ref_column_name_{}; std::string ref_column_name_{};
@ -58,7 +59,6 @@ public:
private: private:
std::string constraint_name; std::string constraint_name;
utils::constraints options_{utils::constraints::None}; utils::constraints options_{utils::constraints::None};
std::shared_ptr<object> reference_;
std::string column_name; std::string column_name;
std::string ref_table_name; std::string ref_table_name;
std::string ref_column_name; std::string ref_column_name;

View File

@ -17,7 +17,7 @@ class repository;
class constraints_generator final { class constraints_generator final {
private: private:
constraints_generator(std::list<class constraint> &constraints, const repository &repo, object &obj); constraints_generator(std::list<class constraint> &constraints, const repository &repo, const std::shared_ptr<object> &obj);
public: public:
constraints_generator() = delete; constraints_generator() = delete;
@ -71,7 +71,7 @@ private:
private: private:
std::list<class constraint> &constraints_; std::list<class constraint> &constraints_;
const repository &repo_; const repository &repo_;
object &obj_; std::shared_ptr<object> obj_;
}; };
} }

View File

@ -19,8 +19,8 @@ public:
static const attribute& create_attribute(std::string name, object& obj); static const attribute& create_attribute(std::string name, object& obj);
void add_attribute(attribute attr); // void add_attribute(attribute attr);
void add_constraint(class constraint c); // void add_constraint(class constraint c);
[[nodiscard]] attribute* primary_key_attribute() const; [[nodiscard]] attribute* primary_key_attribute() const;
[[nodiscard]] const utils::identifier& primary_key() const; [[nodiscard]] const utils::identifier& primary_key() const;

View File

@ -50,23 +50,22 @@ private:
class object_generator { class object_generator {
private: private:
explicit object_generator(const repository& repo, std::unique_ptr<object> &&object); explicit object_generator(repository& repo, const std::shared_ptr<object> &object);
public: public:
template < class Type > template < class Type >
static std::unique_ptr<object> generate(const repository &repo, const std::string &name, const std::string &alias = "") { static std::shared_ptr<object> generate(const repository &repo, const std::string &name, const std::string &alias = "") {
return generate(std::make_unique<Type>(), repo, name, alias); return generate(std::make_unique<Type>(), repo, name, alias);
} }
template < class Type > template < class Type >
static std::unique_ptr<object> generate(std::unique_ptr<Type>&& t, const repository &repo, const std::string &name, const std::string &alias = "") { static std::shared_ptr<object> generate(std::unique_ptr<Type>&& t, repository &repo, const std::string &name, const std::string &alias = "") {
object_generator gen(repo, std::make_unique<object>(name, alias)); auto obj = std::make_shared<object>(name, alias);
object_generator gen(repo, obj);
access::process(gen, *t); access::process(gen, *t);
return gen.move(); return obj;
} }
[[nodiscard]] std::unique_ptr<object> move() { return std::move(object_); }
template < class Type > template < class Type >
void on_primary_key(const char *, Type &x, const utils::primary_key_attribute& attr = utils::default_pk_attributes); void on_primary_key(const char *, Type &x, const utils::primary_key_attribute& attr = utils::default_pk_attributes);
void on_revision(const char *id, uint64_t &rev); void on_revision(const char *id, uint64_t &rev);
@ -114,9 +113,11 @@ private:
void prepare_primary_key(attribute &ref, utils::identifier &&pk) const; void prepare_primary_key(attribute &ref, utils::identifier &&pk) const;
std::shared_ptr<class object> fk_object(const std::type_index& ti) const;
private: private:
const repository &repo_; repository &repo_;
std::unique_ptr<object> object_; std::shared_ptr<object> object_;
}; };
template<typename ValueType> template<typename ValueType>

View File

@ -14,7 +14,7 @@ public:
using create_func = std::function<std::unique_ptr<Type>()>; using create_func = std::function<std::unique_ptr<Type>()>;
object_info(const std::shared_ptr<repository_node>& node, object_info(const std::shared_ptr<repository_node>& node,
std::unique_ptr<class object> &&obj, std::shared_ptr<class object> &&obj,
create_func&& creator) create_func&& creator)
: basic_object_info(node, std::move(obj)) : basic_object_info(node, std::move(obj))
, creator_(std::move(creator)){ , creator_(std::move(creator)){

View File

@ -177,16 +177,22 @@ private:
static void insert_node(const node_ptr &parent, const node_ptr &child); static void insert_node(const node_ptr &parent, const node_ptr &child);
void remove_node(const node_ptr &node); void remove_node(const node_ptr &node);
bool expecting_relation_node(const std::string &name) const; [[nodiscard]] bool expecting_relation_node(const std::string &name) const;
void expect_relation_node(const std::string &name, const std::type_index &ti); void expect_relation_node(const std::string &name, const std::type_index &ti);
void remove_expected_relation_node(const std::string &name); void remove_expected_relation_node(const std::string &name);
[[nodiscard]] std::shared_ptr<object> provide_object_in_advance(const std::type_index &ti, const std::shared_ptr<object>& obj);
[[nodiscard]] bool has_object_for_type(const std::type_index &ti) const;
[[nodiscard]] std::shared_ptr<object> object_for_type(const std::type_index &ti) const;
void remove_object_for_type(const std::type_index &ti);
private: private:
friend class internal::shadow_repository; friend class internal::shadow_repository;
friend class repository_node; friend class repository_node;
friend class attribute_generator; friend class attribute_generator;
template < typename NodeType > template < typename NodeType >
friend class foreign_node_completer; friend class foreign_node_completer;
friend class object_generator;
std::string name_; std::string name_;
std::shared_ptr<repository_node> root_; std::shared_ptr<repository_node> root_;
@ -197,6 +203,7 @@ private:
std::unordered_map<std::type_index, attribute*> missing_references_; std::unordered_map<std::type_index, attribute*> missing_references_;
std::unordered_map<std::string, std::type_index> expected_relation_nodes_; std::unordered_map<std::string, std::type_index> expected_relation_nodes_;
std::unordered_map<std::type_index, std::shared_ptr<object>> object_by_type_;
}; };
} }

View File

@ -21,7 +21,7 @@ public:
[[nodiscard]] bool equals(const column &x) const; [[nodiscard]] bool equals(const column &x) const;
column& as(std::string a); column as(std::string a);
[[nodiscard]] const std::string& name() const; [[nodiscard]] const std::string& name() const;
[[nodiscard]] const std::string& alias() const; [[nodiscard]] const std::string& alias() const;
@ -33,7 +33,8 @@ public:
[[nodiscard]] std::shared_ptr<class table> table() const; [[nodiscard]] std::shared_ptr<class table> table() const;
void table(const std::shared_ptr<query::table>& t); void table(const std::shared_ptr<query::table>& t);
operator const std::string&() const; // ReSharper disable once CppNonExplicitConversionOperator
operator const std::string&() const; // NOLINT(*-explicit-constructor)
private: private:
std::shared_ptr<query::table> table_; std::shared_ptr<query::table> table_;

View File

@ -26,6 +26,8 @@ public:
query_create_table_columns_intermediate columns(std::initializer_list<object::attribute> columns); query_create_table_columns_intermediate columns(std::initializer_list<object::attribute> columns);
query_create_table_columns_intermediate columns(const std::list<object::attribute> &columns); query_create_table_columns_intermediate columns(const std::list<object::attribute> &columns);
query_create_table_columns_intermediate columns(std::initializer_list<column> columns);
query_create_table_columns_intermediate columns(const std::list<column> &columns);
}; };
class query_create_intermediate : public query_intermediate { class query_create_intermediate : public query_intermediate {

View File

@ -10,6 +10,7 @@ namespace matador::query {
class column; class column;
// ReSharper disable CppNonExplicitConvertingConstructor
class table { class table {
public: public:
table() = default; table() = default;
@ -18,7 +19,7 @@ public:
table(std::string name, std::string as); table(std::string name, std::string as);
table(std::string name, std::string as, const std::vector<class column> &columns); table(std::string name, std::string as, const std::vector<class column> &columns);
table& as(const std::string &a); table as(const std::string &a);
[[nodiscard]] bool operator==(const table &x) const; [[nodiscard]] bool operator==(const table &x) const;
@ -30,9 +31,8 @@ public:
[[nodiscard]] const std::string& alias() const; [[nodiscard]] const std::string& alias() const;
[[nodiscard]] const std::vector<class column>& columns() const; [[nodiscard]] const std::vector<class column>& columns() const;
// [[nodiscard]] class column column(const std::string &name) const; // ReSharper disable once CppNonExplicitConversionOperator
operator const std::vector<query::column>&() const; // NOLINT(*-explicit-constructor)
operator const std::vector<query::column>&() const;
private: private:
friend class column; friend class column;

View File

@ -5,22 +5,7 @@
#include <algorithm> #include <algorithm>
namespace matador::object { namespace matador::object {
// basic_object_info::basic_object_info(std::shared_ptr<repository_node> node, basic_object_info::basic_object_info(std::shared_ptr<repository_node> node, std::shared_ptr<class object>&& obj)
// const std::vector<attribute> &attributes,
// utils::identifier &&pk,
// const std::shared_ptr<attribute> &pk_as_fk_column)
// : node_(std::move(node))
// , attributes_(attributes)
// , identifier_(std::move(pk))
// , pk_as_fk_column_(pk_as_fk_column) {
// }
//
// basic_object_info::basic_object_info(std::shared_ptr<repository_node> node,
// const std::vector<attribute> &attributes)
// : node_(std::move(node))
// , attributes_(attributes) {}
basic_object_info::basic_object_info(std::shared_ptr<repository_node> node, std::unique_ptr<class object>&& obj)
: object_(std::move(obj)) : object_(std::move(obj))
, node_(std::move(node)) {} , node_(std::move(node)) {}
@ -32,8 +17,8 @@ std::string basic_object_info::name() const {
return node_->name(); return node_->name();
} }
const class object & basic_object_info::object() const { std::shared_ptr<class object> basic_object_info::object() const {
return *object_; return object_;
} }
const std::list<attribute>& basic_object_info::attributes() const { const std::list<attribute>& basic_object_info::attributes() const {
@ -56,7 +41,7 @@ attribute* basic_object_info::primary_key_attribute() const {
return object_->primary_key_attribute(); return object_->primary_key_attribute();
} }
void basic_object_info::update_name(const std::string& name) { void basic_object_info::update_name(const std::string& name) const {
object_->update_name(name); object_->update_name(name);
} }
@ -112,4 +97,4 @@ std::size_t basic_object_info::endpoints_size() const {
bool basic_object_info::endpoints_empty() const { bool basic_object_info::endpoints_empty() const {
return relation_endpoints_.empty(); return relation_endpoints_.empty();
} }
} // namespace matador::object }

View File

@ -28,7 +28,7 @@ std::string constraint::column_name() const {
return ""; return "";
} }
const object* constraint::owner() const { std::shared_ptr<object> constraint::owner() const {
return owner_; return owner_;
} }

View File

@ -5,18 +5,18 @@
#include <algorithm> #include <algorithm>
namespace matador::object { namespace matador::object {
constraints_generator::constraints_generator(std::list<class constraint> &constraints, const repository& repo, object &obj) constraints_generator::constraints_generator(std::list<class constraint> &constraints, const repository& repo, const std::shared_ptr<object> &obj)
: constraints_(constraints) : constraints_(constraints)
, repo_(repo) , repo_(repo)
, obj_(obj) {} , obj_(obj) {}
void constraints_generator::create_pk_constraint(const std::string& name) const { void constraints_generator::create_pk_constraint(const std::string& name) const {
class constraint pk_constraint("PK_" + obj_.name()); class constraint pk_constraint("PK_" + obj_->name());
pk_constraint.options_ |= utils::constraints::PrimaryKey; pk_constraint.options_ |= utils::constraints::PrimaryKey;
if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(obj_.attributes_)) { if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(obj_->attributes_)) {
pk_constraint.attr_ = &*pk_attr; pk_constraint.attr_ = &*pk_attr;
} }
pk_constraint.owner_ = &obj_; pk_constraint.owner_ = obj_;
constraints_.emplace_back(std::move(pk_constraint)); constraints_.emplace_back(std::move(pk_constraint));
} }
@ -26,28 +26,28 @@ void constraints_generator::create_fk_constraint(const std::type_index& ti, cons
return; return;
} }
const auto *pk_attribute = result.value().get().primary_key_attribute(); const auto *pk_attribute = result.value().get().primary_key_attribute();
class constraint pk_constraint("FK_" + obj_.name() + "_" + name); class constraint pk_constraint("FK_" + obj_->name() + "_" + name);
pk_constraint.options_ |= utils::constraints::ForeignKey; pk_constraint.options_ |= utils::constraints::ForeignKey;
if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(obj_.attributes_)) { if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(obj_->attributes_)) {
pk_constraint.attr_ = &*pk_attr; pk_constraint.attr_ = &*pk_attr;
} }
pk_constraint.owner_ = &obj_; pk_constraint.owner_ = obj_;
pk_constraint.ref_column_name_ = pk_attribute->name(); pk_constraint.ref_column_name_ = pk_attribute->name();
pk_constraint.ref_table_name_ = pk_attribute->owner() ? pk_attribute->owner()->name() : ""; pk_constraint.ref_table_name_ = pk_attribute->owner() ? pk_attribute->owner()->name() : "";
constraints_.emplace_back(std::move(pk_constraint)); constraints_.emplace_back(std::move(pk_constraint));
} }
void constraints_generator::create_unique_constraint(const std::string& name) const { void constraints_generator::create_unique_constraint(const std::string& name) const {
class constraint pk_constraint("UK_" + obj_.name() + "_" + name); class constraint pk_constraint("UK_" + obj_->name() + "_" + name);
pk_constraint.options_ |= utils::constraints::Unique; pk_constraint.options_ |= utils::constraints::Unique;
if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(obj_.attributes_)) { if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(obj_->attributes_)) {
pk_constraint.attr_ = &*pk_attr; pk_constraint.attr_ = &*pk_attr;
} }
pk_constraint.owner_ = &obj_; pk_constraint.owner_ = obj_;
} }
std::list<attribute>::iterator constraints_generator::find_attribute_by_name(const std::string& name) const { std::list<attribute>::iterator constraints_generator::find_attribute_by_name(const std::string& name) const {
return std::find_if(std::begin(obj_.attributes_), std::end(obj_.attributes_), [&name](const attribute& elem) { return std::find_if(std::begin(obj_->attributes_), std::end(obj_->attributes_), [&name](const attribute& elem) {
return elem.name() == name; return elem.name() == name;
}); });
} }

View File

@ -11,15 +11,15 @@ const attribute& object::create_attribute( std::string name, object& obj ) {
return obj.attributes_.emplace_back(std::move(attr)); return obj.attributes_.emplace_back(std::move(attr));
} }
void object::add_attribute( attribute attr ) { // void object::add_attribute( attribute attr ) {
auto &ref = attributes_.emplace_back(std::move(attr)); // auto &ref = attributes_.emplace_back(std::move(attr));
ref.owner_ = this; // ref.owner_ = this;
} // }
//
void object::add_constraint( class constraint c ) { // void object::add_constraint( class constraint c ) {
auto &ref = constraints_.emplace_back(std::move(c)); // auto &ref = constraints_.emplace_back(std::move(c));
ref.owner_ = this; // ref.owner_ = this;
} // }
attribute* object::primary_key_attribute() const { attribute* object::primary_key_attribute() const {
return pk_attribute_; return pk_attribute_;

View File

@ -5,9 +5,9 @@
#include <algorithm> #include <algorithm>
namespace matador::object { namespace matador::object {
object_generator::object_generator( const repository& repo, std::unique_ptr<object>&& object ) object_generator::object_generator(repository& repo, const std::shared_ptr<object>& object)
: repo_(repo) : repo_(repo)
, object_(std::move(object)) {} , object_(object) {}
void object_generator::on_revision(const char* id, uint64_t& rev) { void object_generator::on_revision(const char* id, uint64_t& rev) {
on_attribute(id, rev); on_attribute(id, rev);
@ -19,28 +19,24 @@ void object_generator::create_pk_constraint(const std::string& name) const {
if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(object_->attributes_)) { if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(object_->attributes_)) {
pk_constraint.attr_ = &*pk_attr; pk_constraint.attr_ = &*pk_attr;
} }
pk_constraint.owner_ = object_.get(); pk_constraint.owner_ = object_;
object_->constraints_.emplace_back(std::move(pk_constraint)); object_->constraints_.emplace_back(std::move(pk_constraint));
} }
void object_generator::create_fk_constraint(const std::type_index& ti, const std::string& name) const { void object_generator::create_fk_constraint(const std::type_index& ti, const std::string& name) const {
const auto result = repo_.basic_info(ti); const auto obj = fk_object(ti);
if (!result) { const auto *pk_attribute = obj->primary_key_attribute();
repo_.provide_object_in_advance(ti, std::make_shared<object>(""));
repo_.has_object_for_type(ti);
repo_.object_for_type(ti);
repo_.remove_object_for_type(ti);
return;
}
const auto *pk_attribute = result->get().primary_key_attribute();
class constraint pk_constraint("FK_" + object_->name() + "_" + name); class constraint pk_constraint("FK_" + object_->name() + "_" + name);
pk_constraint.options_ |= utils::constraints::ForeignKey; pk_constraint.options_ |= utils::constraints::ForeignKey;
if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(object_->attributes_)) { if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(object_->attributes_)) {
pk_constraint.attr_ = &*pk_attr; pk_constraint.attr_ = &*pk_attr;
} }
pk_constraint.owner_ = object_.get(); pk_constraint.owner_ = object_;
pk_constraint.ref_column_name_ = pk_attribute->name(); pk_constraint.reference_ = obj;
pk_constraint.ref_table_name_ = pk_attribute->owner() ? pk_attribute->owner()->name() : ""; if (pk_attribute) {
pk_constraint.ref_column_name_ = pk_attribute->name();
pk_constraint.ref_table_name_ = pk_attribute->owner() ? pk_attribute->owner()->name() : "";
}
object_->constraints_.emplace_back(std::move(pk_constraint)); object_->constraints_.emplace_back(std::move(pk_constraint));
} }
@ -50,7 +46,7 @@ void object_generator::create_unique_constraint(const std::string& name) const {
if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(object_->attributes_)) { if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(object_->attributes_)) {
pk_constraint.attr_ = &*pk_attr; pk_constraint.attr_ = &*pk_attr;
} }
pk_constraint.owner_ = object_.get(); pk_constraint.owner_ = object_;
} }
std::list<attribute>::iterator object_generator::find_attribute_by_name(const std::string& name) const { std::list<attribute>::iterator object_generator::find_attribute_by_name(const std::string& name) const {
@ -63,4 +59,13 @@ void object_generator::prepare_primary_key(attribute& ref, utils::identifier &&p
object_->pk_attribute_ = &ref; object_->pk_attribute_ = &ref;
object_->pk_identifier_ = std::move(pk); object_->pk_identifier_ = std::move(pk);
} }
std::shared_ptr<class object> object_generator::fk_object(const std::type_index& ti) const {
const auto result = repo_.basic_info(ti);
if (result) {
return result->get().object();
}
return repo_.provide_object_in_advance(ti, std::make_shared<object>(""));
}
} }

View File

@ -62,7 +62,7 @@ utils::result<basic_object_info_ref, utils::error> repository::basic_info(const
return utils::ok(basic_object_info_ref{result.value()->info()}); return utils::ok(basic_object_info_ref{result.value()->info()});
} }
utils::result<basic_object_info_ref, utils::error> repository::basic_info( const std::string& name ) const { utils::result<basic_object_info_ref, utils::error> repository::basic_info(const std::string& name) const {
auto result = find_node(name); auto result = find_node(name);
if (!result) { if (!result) {
return utils::failure(result.err()); return utils::failure(result.err());
@ -213,4 +213,20 @@ void repository::expect_relation_node(const std::string &name, const std::type_i
void repository::remove_expected_relation_node( const std::string& name ) { void repository::remove_expected_relation_node( const std::string& name ) {
expected_relation_nodes_.erase(name); expected_relation_nodes_.erase(name);
} }
std::shared_ptr<object> repository::provide_object_in_advance(const std::type_index &ti, const std::shared_ptr<object>& obj) {
return object_by_type_.insert({ti, obj}).first->second;
}
bool repository::has_object_for_type(const std::type_index &ti) const {
return object_by_type_.count(ti) > 0;
}
std::shared_ptr<object> repository::object_for_type(const std::type_index &ti) const {
return object_by_type_.at(ti);
}
void repository::remove_object_for_type(const std::type_index &ti) {
object_by_type_.erase(ti);
}
} // namespace matador::object } // namespace matador::object

View File

@ -48,7 +48,7 @@ bool column::equals(const column &x) const {
function_ == x.function_; function_ == x.function_;
} }
column &column::as(std::string a) { column column::as(std::string a) {
alias_ = std::move(a); alias_ = std::move(a);
return *this; return *this;
} }

View File

@ -37,4 +37,8 @@ query_create_table_columns_intermediate query_create_table_intermediate::columns
context_->parts.push_back(std::make_unique<internal::query_create_table_columns_part>(columns)); context_->parts.push_back(std::make_unique<internal::query_create_table_columns_part>(columns));
return {context_}; return {context_};
} }
query_create_table_columns_intermediate query_create_table_intermediate::columns( std::initializer_list<column> columns ) {}
query_create_table_columns_intermediate query_create_table_intermediate::columns( const std::list<column>& columns ) {}
} }

View File

@ -24,7 +24,7 @@ bool table::operator==( const table& x ) const {
return name_ == x.name_; return name_ == x.name_;
} }
table & table::as(const std::string &a) { table table::as(const std::string &a) {
alias_ = a; alias_ = a;
return *this; return *this;
} }
@ -49,10 +49,6 @@ const std::vector<column>& table::columns() const {
return columns_; return columns_;
} }
// column table::column(const std::string& name) const {
// return {std::shared_ptr<table>(const_cast<table*>(this)), name};
// }
table::operator const std::vector<query::column>&() const { table::operator const std::vector<query::column>&() const {
return columns_; return columns_;
} }