Merge branch 'hfm_prep' into hfm_prep_graphics (VaryingSet1 removed)

This commit is contained in:
sabrina-shanman 2018-12-14 10:47:16 -08:00
commit e7b0b345e9
3 changed files with 9 additions and 29 deletions

View file

@ -71,13 +71,14 @@ namespace baker {
class BakerEngineBuilder {
public:
using Input = VaryingSet1<hfm::Model::Pointer>;
using Output = VaryingSet1<hfm::Model::Pointer>;
using Input = hfm::Model::Pointer;
using Output = hfm::Model::Pointer;
using JobModel = Task::ModelIO<BakerEngineBuilder, Input, Output>;
void build(JobModel& model, const Varying& in, Varying& out) {
const auto hfmModelIn = in.getN<Input>(0);
const auto hfmModelIn = in;
// Split up the inputs from hfm::Model
const auto getModelPartsInputs = GetModelPartsTask::Input(hfmModelIn).asVarying();
const auto getModelPartsInputs = hfmModelIn;
const auto modelPartsIn = model.addJob<GetModelPartsTask>("GetModelParts", getModelPartsInputs);
const auto meshesIn = modelPartsIn.getN<GetModelPartsTask::Output>(0);
const auto url = modelPartsIn.getN<GetModelPartsTask::Output>(1);
@ -98,19 +99,19 @@ namespace baker {
const auto buildModelInputs = BuildModelTask::Input(hfmModelIn, meshesOut).asVarying();
const auto buildModelOutputs = model.addJob<BuildModelTask>("BuildModel", buildModelInputs);
const auto hfmModelOut = buildModelOutputs.getN<BuildModelTask::Output>(0);
out = Output(hfmModelOut);
out = hfmModelOut;
}
};
Baker::Baker(const hfm::Model::Pointer& hfmModel) :
_engine(std::make_shared<Engine>(BakerEngineBuilder::JobModel::create("Baker"), std::make_shared<BakeContext>())) {
_engine->feedInput<BakerEngineBuilder::Input>(0, hfmModel);
_engine->feedInput<BakerEngineBuilder::Input>(hfmModel);
}
void Baker::run() {
_engine->run();
auto& output = _engine->getOutput().get<BakerEngineBuilder::Output>();
hfmModel = output.get0();
hfmModel = _engine->getOutput().get<BakerEngineBuilder::Output>();
}
};

View file

@ -411,7 +411,6 @@ protected:
using Task = task::Task<ContextType, TimeProfiler>; \
using Engine = task::Engine<ContextType, TimeProfiler>; \
using Varying = task::Varying; \
template < typename T0 > using VaryingSet1 = task::VaryingSet1<T0>; \
template < typename T0, typename T1 > using VaryingSet2 = task::VaryingSet2<T0, T1>; \
template < typename T0, typename T1, typename T2 > using VaryingSet3 = task::VaryingSet3<T0, T1, T2>; \
template < typename T0, typename T1, typename T2, typename T3 > using VaryingSet4 = task::VaryingSet4<T0, T1, T2, T3>; \

View file

@ -69,26 +69,6 @@ protected:
std::shared_ptr<Concept> _concept;
};
template < typename T0 >
class VaryingSet1 : public std::tuple<Varying> {
public:
using Parent = std::tuple<Varying>;
VaryingSet1() : Parent(Varying(T0())) {}
VaryingSet1(const VaryingSet1& src) : Parent(std::get<0>(src)) {}
VaryingSet1(const Varying& first) : Parent(first) {}
const T0& get0() const { return std::get<0>((*this)).template get<T0>(); }
T0& edit0() { return std::get<0>((*this)).template edit<T0>(); }
virtual Varying operator[] (uint8_t index) const {
return std::get<0>((*this));
}
virtual uint8_t length() const { return 1; }
Varying asVarying() const { return Varying((*this)); }
};
using VaryingPairBase = std::pair<Varying, Varying>;
template < typename T0, typename T1 >
class VaryingSet2 : public VaryingPairBase {