X-Git-Url: https://ruin.nu/git/?a=blobdiff_plain;f=src%2Fmodel.cpp;h=efd5c5f4d9ae6fc85d2b1e8cb6ac0177a32c0aa3;hb=43b1052d74a207fe667b75e41d0c70c1189c2cc8;hp=715d7c2f1a9f5a5ee068d88ca74e95726ad29ebc;hpb=d7c119fefaf9cce07974afbefb4b6a017689a961;p=germs.git 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"); +}