Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/trunk/src/modules/wagnis/WagnisGameboard.cc @ 12316

Last change on this file since 12316 was 12170, checked in by stadlero, 6 years ago

Reinforcements counter works

File size: 5.2 KB
Line 
1#include "WagnisGameboard.h"
2#include "core/CoreIncludes.h"
3#include "BulletDynamics/Dynamics/btRigidBody.h"
4#include <vector>
5#include <string>
6
7
8namespace orxonox
9{
10    RegisterClass(WagnisGameboard);
11   
12    WagnisGameboard::WagnisGameboard(Context* context) : StaticEntity(context){
13        RegisterObject(WagnisGameboard);
14        this->connections_string = "";
15    }
16    WagnisGameboard::~WagnisGameboard(){
17        for(std::vector<WagnisProvince*>* vec: this->continents){
18            delete vec;
19        }
20    }
21
22    void WagnisGameboard::XMLPort(Element& xmlelement,XMLPort::Mode mode){
23        SUPER(WagnisGameboard, XMLPort, xmlelement, mode);
24
25        XMLPortObject(WagnisGameboard, WagnisProvince, "Provinces", addProvince, getProvince, xmlelement, mode);
26        XMLPortParam(WagnisGameboard, "connections_string", setConnections_string, getConnections_string, xmlelement, mode);
27    }
28
29
30
31
32
33
34
35    //XML FUNCTIONS
36    //Adds a Province to the Gameboard
37    void WagnisGameboard::addProvince(WagnisProvince* province){
38        orxout() << "added" << endl;
39        orxout() << province->getID() << endl;
40        this->provs.push_back(province);
41    }
42    //XML get province
43    WagnisProvince* WagnisGameboard::getProvince(unsigned int index) const{
44        if(this->provs.size() <= index) return nullptr;
45        return this->provs.at(index);
46    }
47    //XML set connections_string
48    void WagnisGameboard::setConnections_string(const std::string& str){
49        this->connections_string = str;
50    }
51    //XML get connections_string
52    std::string WagnisGameboard::getConnections_string() const{
53        return this -> connections_string;
54    }
55
56
57
58
59
60
61
62    //Parses the string and initializes the neigbors vector of all provinces according
63    //Syntax: 32=7-8-4  , 2=33+5+7+1+4
64    void WagnisGameboard::initializeNeighbors(){
65       
66        std::string str = this->connections_string;
67        orxout() << "inizializing started" << endl;
68        orxout() << "String size:" << endl;
69        orxout() << str.size() << endl;
70        orxout() << str<<endl;
71        unsigned int n = 0;
72        while(n < str.size()){
73            int tmp = parse_int(str,n);
74            n = tmp & 0x0000FFFF;
75            int origin_ID = tmp >> 16;
76            if(n == str.size() || str[n] != '='){
77                orxout() << "Error while parsing neighbors-string: '=' expected at position: "<< n << endl;
78                orxout() << "Correct syntax: 32=4+2+5+67, 54=8+1+12" << endl;
79            }
80            int other_ID;
81            do{
82                n++;
83                tmp = parse_int(str,n);
84                n = tmp & 0x0000FFFF;
85                other_ID = tmp >> 16;
86
87                for(WagnisProvince* orig:this->provs){
88                    if(orig->getID() == origin_ID){
89                        for(WagnisProvince* other:this->provs){
90                            if(other->getID() == other_ID){
91                                orig->addNeighbor(other);
92                                //orxout() << "Added neighbor province "<< other_ID << " to province " << origin_ID << endl;
93                                break;
94                            }
95                        }
96                    }
97                }
98            }while((n < str.size()) && (str[n] == '+'));
99
100            if(n == str.size()) return;
101            while((n < str.size()) && (str[n] == ' ')) n++;
102            if(n == str.size()) return;
103            if(str[n] != ','){
104                orxout() << "Error while parsing neighbors-string: ',' expected at position: "<< n << endl;
105                orxout() << "Correct syntax: 32=4+2+5+67, 54=8+1+12" << endl;
106            }
107            n++;
108            while(n < str.size() && str[n] == ' ') n++;
109            orxout()<<"One province finished"<<endl;
110        }
111    }
112
113    void WagnisGameboard::initializeContinents(){
114        int maxconts=0;
115        for(WagnisProvince* p:this->provs){
116            if(p->getContinent() > maxconts){
117                maxconts = p->getContinent();
118            }
119        }
120        for(int i=0;i<=maxconts;i++){
121            this->continents.push_back(new std::vector<WagnisProvince*>());
122            for(WagnisProvince* p:this->provs){
123                if(p->getContinent() == i){
124                    this->continents[i]->push_back(p);
125                }
126            }
127            orxout()<<"There are "<<this->continents[i]->size()<<" Provinces in Continent "<< i << endl;
128        }
129    }
130
131    //Returns the parsed int and the offset encoded in an int. the upper 16bit(incl MSB) is the number
132    //and the lower 16 bits is the new n(after the last digit)
133    int WagnisGameboard::parse_int(std::string str,unsigned int n){
134        if(n >= str.size()){
135            orxout() << "Error while parsing neighbors-string: Internal error at WagnisGameboard::parse_int() "<< endl;
136        }
137        int digit = str[n] - '0';
138        int number = digit;
139        if(digit < 0 || digit > 9){
140            orxout() << "Error while parsing neighbors-string: Digit expected at position: "<< n << endl;
141            orxout() << "Correct syntax: 32=4+2+5+67, 54=8+1+12" << endl;
142        }
143
144        n++;
145        while(n < str.size() && str[n] - '0' >= 0 && str[n] - '0' < 10){
146            digit = str[n] - '0';
147            number = 10 * number;
148            number += digit;
149            n++;
150        }
151        return (number << 16)+n;
152    }
153}
Note: See TracBrowser for help on using the repository browser.