-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSimulation.java
More file actions
240 lines (192 loc) · 8.63 KB
/
Simulation.java
File metadata and controls
240 lines (192 loc) · 8.63 KB
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
import org.xml.sax.SAXParseException;
import planetes.*;
import utile.EcritureFichier;
import utile.Serveur;
import vaisseaux.VaisseauLeger;
import vaisseaux.VaisseauLourd;
import vaisseaux.VaisseauNormal;
import vaisseaux.Vaisseaux;
import utile.AttXML;
import java.io.*;
import java.net.Socket;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.nio.file.StandardOpenOption;
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.Queue;
import static com.sun.xml.internal.org.jvnet.fastinfoset.FastInfosetSerializer.UTF_8;
/**
* Created by DioAn1730700 on 2018-04-26.
*/
public class Simulation {
public static ArrayList<Planete> tabPlanetes = new ArrayList<>();
public static ArrayList<CentreTri> tabCentreTri = new ArrayList<>();
public static Queue<Vaisseaux> tabVaisseaux = new LinkedList<>();
public static boolean life = true;
public static void main(String[] args) throws Exception {
/*
apres avoir lance la simulation, il faut attendre assez longtemps
pour que le fichier soit complet, sinon
il manque une partie de la fin
*/
try {
Socket socket = new Socket("127.0.0.1", 8080);
InputStream fluxEntrant = socket.getInputStream();
BufferedReader entree = new BufferedReader(
new InputStreamReader(fluxEntrant));
String message = "";
for (int i = 0; i<78; i++){
message = entree.readLine();
Files.write(Paths.get("ControleClient.xml"), (message + System.lineSeparator()).getBytes(UTF_8),StandardOpenOption.CREATE,StandardOpenOption.APPEND);
if (i==77){
message = "</simulation>";
Files.write(Paths.get("ControleClient.xml"), (message + System.lineSeparator()).getBytes(UTF_8),StandardOpenOption.CREATE,StandardOpenOption.APPEND);
}
}
client();
OutputStream fluxSortant = socket.getOutputStream();
OutputStreamWriter sortie = new OutputStreamWriter(fluxSortant);
sortie.write(EcritureFichier.texte);
sortie.flush();
Files.delete(Paths.get("ControleClient.xml"));
}
catch (IOException e){ }
catch (Exception e) { e.printStackTrace(); }
}
public static void client() throws Exception {
try {
AttXML.constructionXML();
} catch (SAXParseException e) {
}
//creation des planètes
for (int i = 0; i < AttXML.getNbPlanetes(); i++) {
tabPlanetes.add(nouvPlanete());
}
//création des vaisseaux
for (int i = 0; i < AttXML.getNbLeger(); i++) {
char a = (char)(i+65);
tabVaisseaux.add(new VaisseauLeger("Bébé vaisseau " + a));
}
for (int i = 0; i < AttXML.nbNormal; i++) {
char a = (char)(i+65);
tabVaisseaux.add(new VaisseauNormal("Maman vaisseau " + a));
}
for (int i = 0; i < AttXML.getNbLourd(); i++) {
char a = (char)(i+65);
tabVaisseaux.add(new VaisseauLourd("Papa vaisseau " + a));
}
//disponibilité vaisseau
EcritureFichier.affichageSimulation("Il y a " + AttXML.getNbVaisseaux() + " vaisseaux disponibles");
EcritureFichier.affichageSimulation("\n");
//création des centres de tris
for (int i = 0; i < AttXML.getNbCentreTris(); i++) {
CentreTri centreTri = new CentreTri("Centre de tris " + (i + 1));
tabCentreTri.add(centreTri);
}
//disponibilité centres tri
EcritureFichier.affichageSimulation("Il y a " + tabCentreTri.size() + " centres de tris disponibles");
EcritureFichier.affichageSimulation("\n");
try {
while (life == true) {
//lancement vaisseaux
Vaisseaux enCours = null;
for (int i = 0; i < AttXML.getNbVaisseaux(); i++) {
int planete = (int) (Math.random() * 5);
EcritureFichier.affichageSimulation("Envoie d'un nouveau vaisseau");
enCours = tabVaisseaux.poll();
//charge
tabPlanetes.get(planete).charger(enCours);
Vaisseaux.algo(enCours.getMatiere());
enCours.afficher();
EcritureFichier.affichageSimulation("Les déchets proviennent de la planète : " + tabPlanetes.get(planete).getNom());
EcritureFichier.affichageSimulation("En direction du centre de tri: " + enCours.getCentreActu());
EcritureFichier.affichageSimulation("\n");
//décharge
tabCentreTri.get(enCours.getCentreActu()).déchargeDechets(enCours);
//enCours.afficher();
}
//arrête de la simulation
EcritureFichier.affichageSimulation("\n");
EcritureFichier.affichageSimulation("--------------------");
EcritureFichier.affichageSimulation("SIMULATION TERMINÉE");
EcritureFichier.affichageSimulation("--------------------");
for (int i = 0; i < tabCentreTri.size(); i++) {
tabCentreTri.get(i).afficher();
}
life = false;
}
} catch (Exceptions.DernierCentreTris dernierCentreTris) {
EcritureFichier.affichageSimulation("\n");
EcritureFichier.affichageSimulation("**ERREUR**");
EcritureFichier.affichageSimulation("Il n'y a plus de prochain centre de tri où recycler");
EcritureFichier.affichageSimulation("--------------------");
life = false;
} catch (Exceptions.CentreTrisPlein centreTrisPlein) {
EcritureFichier.affichageSimulation("\n");
EcritureFichier.affichageSimulation("**ERREUR**");
EcritureFichier.affichageSimulation("Centre de tris plein");
EcritureFichier.affichageSimulation("--------------------");
life = false;
} catch (Exceptions.ListeVideCentreTris listeVideCentreTris) {
EcritureFichier.affichageSimulation("\n");
EcritureFichier.affichageSimulation("**ERREUR**");
EcritureFichier.affichageSimulation("Il n'y a pas de vaisseaux en attente dans le centre de tris ");
EcritureFichier.affichageSimulation("--------------------");
life = false;
}
}
public static void envoieRecyclage(Vaisseaux vaisseauRecyc)
throws Exceptions.DernierCentreTris, Exceptions.ListeVideCentreTris, Exceptions.CentreTrisPlein {
vaisseauRecyc.afficher();
if (vaisseauRecyc.getCentreActu() == tabCentreTri.size()) {
throw new Exceptions.DernierCentreTris();
} else {
tabCentreTri.get(vaisseauRecyc.getCentreActu()).déchargeDechets(vaisseauRecyc);
EcritureFichier.affichageSimulation("Centre de tri: " + vaisseauRecyc.getCentreActu());
EcritureFichier.affichageSimulation("\n");
CentreTri.neptu = true;
CentreTri.pluto = true;
CentreTri.gado = true;
CentreTri.terbi = true;
CentreTri.thuli = true;
}
}
public static void envoie(Vaisseaux enCours2)
throws Exceptions.CentreTrisPlein, Exceptions.ListeVideCentreTris, Exceptions.DernierCentreTris{
int planete = (int) (Math.random() * 5);
//charge
tabPlanetes.get(planete).charger(enCours2);
Vaisseaux.algo(enCours2.getMatiere());
enCours2.afficher();
EcritureFichier.affichageSimulation("Les déchets proviennent de la planète : " + tabPlanetes.get(planete).getNom());
//décharge
if (tabCentreTri.get(enCours2.getCentreActu()).attente.size() == CentreTri.attenteMax){
throw new Exceptions.CentreTrisPlein();
}
else {
tabCentreTri.get(enCours2.getCentreActu()).déchargeDechets(enCours2);
enCours2.afficher();
}
}
public static Planete nouvPlanete (){
int aleatoire =(int) (Math.random()*5);
Planete planete = null;
if (aleatoire==0){
planete = new PlaneteBleue();
}
else if (aleatoire==1){
planete = new PlaneteJaune();
}
else if (aleatoire==2){
planete = new PlaneteNoir();
}
else if (aleatoire==3){
planete = new PlaneteRouge();
}
else if (aleatoire==4){
planete = new PlaneteVerte();
}
return planete;
}
}