-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathCell.cpp
58 lines (43 loc) · 1.6 KB
/
Cell.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
/////////////////////////////////////////////////////////////////////////////////////////
//
// gro is protected by the UW OPEN SOURCE LICENSE, which is summarized here.
// Please see the file LICENSE.txt for the complete license.
//
// THE SOFTWARE (AS DEFINED BELOW) AND HARDWARE DESIGNS (AS DEFINED BELOW) IS PROVIDED
// UNDER THE TERMS OF THIS OPEN SOURCE LICENSE (“LICENSE”). THE SOFTWARE IS PROTECTED
// BY COPYRIGHT AND/OR OTHER APPLICABLE LAW. ANY USE OF THIS SOFTWARE OTHER THAN AS
// AUTHORIZED UNDER THIS LICENSE OR COPYRIGHT LAW IS PROHIBITED.
//
// BY EXERCISING ANY RIGHTS TO THE SOFTWARE AND/OR HARDWARE PROVIDED HERE, YOU ACCEPT AND
// AGREE TO BE BOUND BY THE TERMS OF THIS LICENSE. TO THE EXTENT THIS LICENSE MAY BE
// CONSIDERED A CONTRACT, THE UNIVERSITY OF WASHINGTON (“UW”) GRANTS YOU THE RIGHTS
// CONTAINED HERE IN CONSIDERATION OF YOUR ACCEPTANCE OF SUCH TERMS AND CONDITIONS.
//
// TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
//
//
#ifndef NOGUI
#include <GroThread.h>
#endif
#include "Micro.h"
static int max_id = 0;
Cell::Cell ( World * w ) : world ( w ), gro_program(NULL), marked(false), selected(false) {
parameters = w->get_param_map();
compute_parameter_derivatives();
program = w->get_program();
space = w->get_space();
body = NULL;
int i;
for ( i=0; i<MAX_STATE_NUM; i++ ) q[i] = 0;
for ( i=0; i<MAX_REP_NUM; i++ ) rep[i] = 0;
divided = false;
daughter = false;
set_id ( max_id++ );
}
Cell::~Cell ( void ) {
cpSpaceRemoveShape(world->get_space(),shape);
cpShapeFree ( shape );
if ( gro_program != NULL ) {
delete gro_program;
}
}