5a42e15c4a
Squashed messages from 9 commits: 9. Properties now uses PropertyFamily and contained classes. Fetching,seting,clearing properties can be done with PropertyFamilyKey or PropertyTypeKey. Hierarchy of newly added clases is: Vertices -n-> PropertyFamily {name: String} <-1-n-> PropertyType {type: Property::Flags} Edges -n-> PropertyFamily {name: String} <-1-n-> PropertyType {type: Property::Flags} PropertyFamilyKey -> PropertyType PropertyTypeKey -> PropertyType PropertyType t0,t1; let t0!=t1 be true let t0.family==t1.family be true then next is true PropertyTypeKey{&t0}!=PropertyTypeKey{&t1} PropertyFamilyKey{&t0}==PropertyFamilyKey{&t1} PropertyFamilyKey{&t0}==PropertyTypeKey{&t1} PropertyTypeKey{&t0}==PropertyFamilyKey{&t1} 8. Intermedate commit. Noticed that integration queries throw SEGFAULT. 7. Defined interface for indexes. Fixed three memory leaks. Fixed integration_queries test which now passes. 6. Commit which return Xorshift128plus to valid shape. 5. Tmp commit. 4. Label Index is compiling. 3. tmp 2. Vertex::Accessor now updates Label index. 1. Applied changes for code review.
36 lines
863 B
C++
36 lines
863 B
C++
#pragma once
|
|
|
|
#include "storage/model/properties/all.hpp"
|
|
#include "storage/model/properties/property.hpp"
|
|
|
|
template <class Handler>
|
|
void accept(const Property &property, Handler &h)
|
|
{
|
|
switch (property.flags) {
|
|
|
|
case Flags::True:
|
|
return h.handle(static_cast<const Bool &>(property));
|
|
|
|
case Flags::False:
|
|
return h.handle(static_cast<const Bool &>(property));
|
|
|
|
case Flags::String:
|
|
return h.handle(static_cast<const String &>(property));
|
|
|
|
case Flags::Int32:
|
|
return h.handle(static_cast<const Int32 &>(property));
|
|
|
|
case Flags::Int64:
|
|
return h.handle(static_cast<const Int64 &>(property));
|
|
|
|
case Flags::Float:
|
|
return h.handle(static_cast<const Float &>(property));
|
|
|
|
case Flags::Double:
|
|
return h.handle(static_cast<const Double &>(property));
|
|
|
|
default:
|
|
return;
|
|
}
|
|
}
|