Develop Biology
The language of life
Tissue.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/cellular/Tissue.h"
23#include "bio/cellular/Cell.h"
24
25namespace bio {
26namespace cellular {
27
28Tissue::~Tissue()
29{
30
31}
32
34{
35 Code ret = code::Success();
36 Container* cells = GetAll< Cell* >();
37 BIO_SANITIZE(cells, ,
39 Cell* cellBuffer;
40 for (
41 SmartIterator cel = cells->Begin();
42 !cel.IsAtEnd();
43 ++cel
44 )
45 {
46 cellBuffer = cel;
47 cellBuffer->SetEnvironment(this);
48 cellBuffer->Import< genetic::Plasmid* >(this);
49 if (cellBuffer->ExpressGenes() != code::Success() && ret == code::Success())
50 {
51 ret = code::UnknownError();
52 }
53 }
54
55 Container* tissues = GetAll< Tissue* >();
56 BIO_SANITIZE(tissues, ,
58 Tissue* tissueBuffer;
59 for (
60 SmartIterator tis = tissues->Begin();
61 !tis.IsAtEnd();
62 ++tis
63 )
64 {
65 tissueBuffer = tis;
66 tissueBuffer->SetEnvironment(this);
67 if (tissueBuffer->DifferentiateCells() != code::Success() && ret == code::Success())
68 {
69 ret = code::UnknownError();
70 }
71 }
72 return ret;
73}
74
75} //cellular namespace
76} //bio namespace
#define BIO_SANITIZE(test, success, failure)
virtual SmartIterator Begin() const
Definition: Container.cpp:295
bool IsAtEnd() const
virtual Code DifferentiateCells()
Definition: Tissue.cpp:33
void Import(const UnorderedMotif< T > *other)
virtual Code ExpressGenes()
Definition: Expressor.cpp:48
virtual void SetEnvironment(T *environment)
Code CouldNotFindValue1()
Code UnknownError()
Code Success()
Definition: Cell.h:31