X-Git-Url: https://ruin.nu/git/?p=germs.git;a=blobdiff_plain;f=src%2Fmodel.cpp;h=efd5c5f4d9ae6fc85d2b1e8cb6ac0177a32c0aa3;hp=715d7c2f1a9f5a5ee068d88ca74e95726ad29ebc;hb=6c059509f0e7230c2352963e559b623fadd27810;hpb=296f9306aff8a11a49f4e0cc2322eadd66e4b85a diff --git a/src/model.cpp b/src/model.cpp index 715d7c2..efd5c5f 100644 --- a/src/model.cpp +++ b/src/model.cpp @@ -21,6 +21,8 @@ #include "model.h" #include "models.h" +#include + Model::Model(Models::ModelImpl* model): _impl(model){ } @@ -35,3 +37,18 @@ const char* Model::name() const{ bool operator<(const Model& lh,const Model& rh){ return &lh < &rh; } + +Model Model::modelFactory(const std::string& name){ + if (name == "X"){ + return Model(new Models::X()); + }else if(name == "Whirl" || name == "Standard"){ + return Model(new Models::ModelImpl()); + }else if(name == "Zipper"){ + return Model(new Models::Zipper()); + }else if(name == "FatX"){ + return Model(new Models::FatX()); + }else if(name == "Cloud"){ + return Model(new Models::Cloud()); + } + throw std::invalid_argument(name + " is not a valid model"); +}