Develop Biology
The language of life
Axis.cpp
Go to the documentation of this file.
1/*
2 * This file is a part of the Biology project by eons LLC.
3 * Biology (aka Develop Biology) is a framework for approaching software
4 * development from a natural sciences perspective.
5 *
6 * Copyright (C) 2021 Séon O'Shannon & eons LLC
7 *
8 * This program is free software: you can redistribute it and/or modify
9 * it under the terms of the GNU Affero General Public License as
10 * published by the Free Software Foundation, either version 3 of the
11 * License, or (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU Affero General Public License for more details.
17 *
18 * You should have received a copy of the GNU Affero General Public License
19 * along with this program. If not, see <https://www.gnu.org/licenses/>.
20 */
21
22#include "bio/chemical/Axis.h"
25
26namespace bio {
27namespace chemical {
28
30{
31
32}
33
35{
36
37}
38
39std::string Axis::Rotate(Symmetry* symmetry) const
40{
41 std::string ret = "";
42 ret += Encode(symmetry);
43 Container* toRotate = symmetry->GetAll< Symmetry* >();
44 for (
45 SmartIterator sym = toRotate->Begin();
46 !sym.IsAtEnd();
47 ++sym
48 )
49 {
50 ret += Rotate(sym.As< Symmetry* >());
51 }
52
53 return ret;
54}
55
56} //chemical namespace
57} //bio namespace
virtual SmartIterator Begin() const
Definition: Container.cpp:295
bool IsAtEnd() const
virtual std::string Rotate(Symmetry *symmetry) const
Definition: Axis.cpp:39
virtual ~Axis()
Definition: Axis.cpp:34
virtual std::string Encode(Symmetry *symmetry) const
Definition: Axis.cpp:66
Definition: Cell.h:31