X-Git-Url: https://ruin.nu/git/?a=blobdiff_plain;f=src%2Fsortaction.h;h=66c337ca625cac468b113debc86c1cd224029a76;hb=6ed5c4682ee599c7d03d8c67dcca3ac4033a63ec;hp=b6c5df74278f85d08540678674ffb6c7d384a650;hpb=47b1f5c0294e079bc120dc8366977951aa0778bf;p=germs.git diff --git a/src/sortaction.h b/src/sortaction.h index b6c5df7..66c337c 100644 --- a/src/sortaction.h +++ b/src/sortaction.h @@ -21,20 +21,59 @@ #ifndef __SORTACTION_H__ #define __SORTACTION_H__ +#include +#include +class GeneOrder; /** - * Abstraction of a sort action, keeping track of score + * Abstraction of a sort action, all child actions has to be immutable. * * \author Michael Andreen */ class SortAction{ public: + typedef std::tr1::shared_ptr ActionPointer; + /** + * Creates a new sort action, given a specified action. + * SortAction promises to remove the given action. + */ + SortAction(SortAction* sa): _action(sa){ + } + + SortAction(const SortAction& sa): _action(sa._action){ + } + + virtual const SortAction& operator=(const SortAction& sa){ + if (this != &sa) + _action = sa._action; + return *this; + } + virtual ~SortAction(){}; /** - * Sort SortActions by score + * Applies the action on the GeneOrder and returning it. + */ + virtual GeneOrder& operator()(GeneOrder& go) const{ + return (*_action)(go); + } + + /** + * Compares sort actions. */ - virtual operator<(const SortAction& sa) const; + virtual bool operator==(const SortAction& sa) const{ + return (*_action) == (sa._action.get() == 0 ? sa : *sa._action); + } + + /** + * Gives a string representation of the action, for output + */ + virtual std::string toString() const{ + return _action->toString(); + } + private: + ActionPointer _action; + }; #endif