diff --git a/Makefile b/Makefile
index e69de29..0b30417 100644
--- a/Makefile
+++ b/Makefile
@@ -0,0 +1,16 @@
+CC = gcc
+CFLAGS = -Wall -Wextra
+
+all: prog
+
+prog: main.o evenement.o
+	$(CC) -o $@ $^ -lgraph
+
+main.o: main.c evenement.h
+	$(CC) $(CFLAGS) -c $< -o $@
+
+evenement.o: evenement.c evenement.h
+	$(CC) $(CFLAGS) -c $< -o $@
+
+clean:
+	rm -f *.o prog
diff --git a/evenement.c b/evenement.c
index a3cf5e9..fe150e9 100644
--- a/evenement.c
+++ b/evenement.c
@@ -2,6 +2,7 @@
 #include <stdio.h>
 #include <stdlib.h>
 #include "main.h"
+#include <time.h>   
 
 
 void AfficherTimerEtScore(int m,int n,int score)   /*Afficher le temps passé et le score*/
@@ -21,18 +22,41 @@ void AfficherTimerEtScore(int m,int n,int score)   /*Afficher le temps passé et
 	CopierZone(1,0,0,0,930,710,0,0);
 }
 
+void InitialiserPastilles(PIXELS *pastilles) {
+    int i;
+    couleur r;
 
-void MangerPastille(int *serpent, int* pastilles, int longueur_serpent, int longueur_pastilles)
+    r = CouleurParNom("red");
+    ChoisirCouleurDessin(r);
+
+    srand(time(NULL));
+
+    for (i = 0; i < PASTILLES; i++) {
+        pastilles[i] = gen_pastille();
+        RemplirRectangle(pastilles[i].x,pastilles[i].y,T_PIXEL,T_PIXEL);
+
+    }
+}
+
+void MangerPastille(int *serpent, PIXELS* pastilles, int longueur_serpent, int longueur_pastilles)
     {
+        couleur r;
         int i = 0;
 
-        for(i=0;i<longueur_pastilles;i+=2)
+        r = CouleurParNom("red");
+        ChoisirCouleurDessin(r);
+
+        for(i=0;i<PASTILLES;i++)
         {
-            if(serpent[0] == pastilles[i] && serpent[1] == pastilles[i+1])
+            if(serpent[0] == pastilles[i].x && serpent[1] == pastilles[i].y)
             {
-                
+                printf("\nMANGER !\n");
+                pastilles[i] = gen_pastille();
+                RemplirRectangle(pastilles[i].x,pastilles[i].y,T_PIXEL,T_PIXEL);
+
             }
         }
+
         
     }
 
@@ -64,27 +88,22 @@ void DeplacementSerpent(int direction ,int *serpent, int longueur)
     ChoisirCouleurDessin(j);
     if(direction == 0) /* Direction vers la gauche */
     {
-        printf("Gauche %d\n",direction);
         serpent[0]-=T_PIXEL;
         
         RemplirRectangle(serpent[0],serpent[1],T_PIXEL,T_PIXEL);
-        printf("Longueur = %d | x %d | y %d",longueur,serpent[longueur-1],serpent[longueur-2]);
     }
     else if(direction == 1) /* Direction vers le haut */
     {
-        printf("Haut %d\n",direction);
         serpent[1]-=T_PIXEL;
         RemplirRectangle(serpent[0],serpent[1],T_PIXEL,T_PIXEL);
     }
     else if(direction == 2) /* Direction vers la droite */
     {
-        printf("Droite %d\n",direction);
         serpent[0]+=T_PIXEL;
         RemplirRectangle(serpent[0],serpent[1],T_PIXEL,T_PIXEL);
     }
     else if(direction == 3) /* Direction vers le bas */
     {
-        printf("Bas %d\n",direction);
         serpent[1]+=T_PIXEL;
         RemplirRectangle(serpent[0],serpent[1],T_PIXEL,T_PIXEL);
     }
diff --git a/evenement.h b/evenement.h
index 274b155..a7a8cdd 100644
--- a/evenement.h
+++ b/evenement.h
@@ -1,6 +1,14 @@
+#include "main.h"
+
+#ifndef EVENEMENT_H
+#define EVENEMENT_H
+
+void MangerPastille(int *serpent, PIXELS* pastilles, int longueur_serpent, int longueur_pastilles);
+
+void DeplacementSerpent(int direction ,int *serpent, int longueur);
+
+void InitialiserPastilles(PIXELS *pastilles);
 
 void AfficherTimerEtScore(int m,int n,int score);
 
-void MangerPastille(int *serpent, int* pastilles, int longueur_serpent, int longueur_pastilles);
-
-void DeplacementSerpent(int direction ,int *serpent, int longueur);
\ No newline at end of file
+#endif
\ No newline at end of file
diff --git a/main.c b/main.c
index c9710cb..a6babb8 100644
--- a/main.c
+++ b/main.c
@@ -3,17 +3,7 @@
 #include <graph.h>
 #include <time.h>
 #include "evenement.h"
-
-
-#define W_WINDOW 930 /* Largeur de la fenêtre*/
-#define H_WINDOW 710 /* Hauteur de la fenêtre*/
-
-#define W_GAME 900
-#define H_GAME 600
-
-#define T_PIXEL 15 /* Taille d'un pixel*/ 
-
-#define DECALEMENT 30
+#include "main.h"
 
 #define delta 100000L
 
@@ -28,70 +18,46 @@ int ArrondirPixel(int nombre) /* Calcule un arrondi du pixel pour pouvoir respec
     return arrondi;
 }
 
-void gen_pastille(int nb_pastille, int *p_pastilles)
+PIXELS gen_pastille()
 
                                    /* nb_pastille = int nombre de pastille voulue , p_pastilles est un pointeur d'un tableau de pixels qui sont des pastilles*/
                                    /*Générer une pastille dans la grid*/
                                    /*Code n'est pas complet*/
                                    /*-Elles se génèrent à des endroits qui peuvent être les mêmes ou gêner le snake*/
-
 {
-    couleur r;
-    int x_pastille,y_pastille,i;
-    r=CouleurParNom("red");
+    int x_pastille,y_pastille;
+    PIXELS pastille;
 
-    srand(time(NULL));
+    x_pastille= ArrondirPixel(rand()%W_GAME);
+    y_pastille = ArrondirPixel(rand()%H_GAME);
 
-    for(i=0;i<nb_pastille*2;i+=2)
+    if(x_pastille < DECALEMENT)
     {
-
-        x_pastille= ArrondirPixel(rand()%W_GAME);
-        y_pastille = ArrondirPixel(rand()%H_GAME);
-
-        if(x_pastille < DECALEMENT)
-        {
-            x_pastille =+ DECALEMENT;
-        }
-        else if(x_pastille >W_GAME-DECALEMENT)
-        {
-            x_pastille - DECALEMENT;
-        }
-        if(y_pastille < DECALEMENT)
-        {
-            y_pastille =+ DECALEMENT;
-        }
-        else if(y_pastille > H_GAME-DECALEMENT)
-        {
-            y_pastille - DECALEMENT;
-        }
-
-        p_pastilles[i] = x_pastille ;
-        p_pastilles[i+1] = y_pastille ;
-
-        printf("x : %d ; y : %d\n",p_pastilles[i],p_pastilles[i+1]);
-        ChoisirEcran(2);
-        ChoisirCouleurDessin(r);
-        RemplirRectangle(x_pastille,y_pastille,T_PIXEL,T_PIXEL);
+        x_pastille =+ DECALEMENT;
+    }
+    else if(x_pastille >W_GAME-DECALEMENT)
+    {
+        x_pastille - DECALEMENT;
+    }
+    if(y_pastille < DECALEMENT)
+    {
+        y_pastille =+ DECALEMENT;
+    }
+    else if(y_pastille > H_GAME-DECALEMENT)
+    {
+        y_pastille - DECALEMENT;
     }
 
-}
+    pastille.x = x_pastille ;
+    pastille.y = y_pastille ;
 
-void DessinerScene(int* pastilles) /* Dessine la scène */
-{
-    couleur c;
-    ChoisirEcran(2);
-    c=CouleurParNom("lightgreen");
-    ChoisirCouleurDessin(c);
-    RemplirRectangle(T_PIXEL,T_PIXEL,W_GAME,H_GAME);
-    gen_pastille(5,pastilles);
-    
+    return pastille;
 }
 
 void InitialisationDuSerpent(int *p_serpent) /* L'initialisation du serpent */
 {
     int x_millieu = 0, y_millieu = 0 , compteur = 0;
     couleur j;
-    int i = 0;
     j=CouleurParNom("yellow");
     ChoisirCouleurDessin(j);
     x_millieu = T_PIXEL*30; /* 30 = 60 colonnes divisé par 2*/
@@ -103,7 +69,7 @@ void InitialisationDuSerpent(int *p_serpent) /* L'initialisation du serpent */
 
     p_serpent[0] = x_millieu;
     p_serpent[1] = y_millieu;
-    for(compteur=0;compteur<=18;compteur+=2) /* Commence par 1 car p_serpent index 0 initialisées pour la tête et 2 + 2x9 = 10 couples de coordonnées 2D */
+    for(compteur=0;compteur<=16;compteur+=2) /* Commence par 1 car p_serpent index 0 initialisées pour la tête et 2 + 2x9 = 10 couples de coordonnées 2D */
     {
         p_serpent[compteur+2] = p_serpent[compteur]+T_PIXEL;
         p_serpent[compteur+3] = p_serpent[compteur+1];
@@ -112,12 +78,18 @@ void InitialisationDuSerpent(int *p_serpent) /* L'initialisation du serpent */
 
         RemplirRectangle(p_serpent[compteur+2],p_serpent[compteur+3],T_PIXEL,T_PIXEL);
     }
-    printf("Avant \n");
-	for (i = 0; i < 20; i += 2) {
-        printf("(%d, %d) ", p_serpent[i], p_serpent[i + 1]);
-    }
-    printf("\n");
+}
 
+void DessinerScene(PIXELS *pastilles, int *serpent) /* Dessine la scène */
+{
+    couleur c;
+    ChoisirEcran(2);
+    c=CouleurParNom("lightgreen");
+    ChoisirCouleurDessin(c);
+    RemplirRectangle(T_PIXEL,T_PIXEL,W_GAME,H_GAME);
+    InitialiserPastilles(pastilles);
+    InitialisationDuSerpent(serpent);
+    
 }
 
 int main()
@@ -126,13 +98,14 @@ int main()
     int score =0;
     unsigned long suivant;
     int go_on=1;
-    int x_pastille,y_pastille;
     int n = 0;
     int m = 0;
+
     size_t longueur_serpent = 20;
     size_t longueur_pastilles = 10;
     int *serpent = (int *)malloc(longueur_serpent * sizeof(int));
-    int *pastilles = (int *)malloc(longueur_pastilles * sizeof(int));
+    PIXELS *pastilles = (PIXELS *)malloc(longueur_pastilles * sizeof(PIXELS));
+
     int direction = 0;
     int direction_davant = 0;
 
@@ -149,8 +122,7 @@ int main()
     InitialiserGraphique();
     CreerFenetre(10,10,W_WINDOW,H_WINDOW); /* Peut être changer cette ligne avec la fonction Maxx et Maxy fournie dans graph.h ??*/
     ChoisirTitreFenetre("SNAKE SAE11 IN C");
-    DessinerScene(pastilles);
-    InitialisationDuSerpent(serpent);
+    DessinerScene(pastilles,serpent);
 
     while(go_on) /* Lancement du cycle pour les Inputs et le Jeu*/
 	{   
@@ -220,10 +192,9 @@ int main()
                 suivant=Microsecondes()+delta;
 
                 direction_davant = direction; /* Check si le serpent à le droit de changer de direction */
-                MangerPastille(serpent,pastilles,longueur_serpent,longueur_pastilles);
+
                 DeplacementSerpent(direction,serpent,longueur_serpent);
-               
-			
+                MangerPastille(serpent,pastilles,longueur_serpent,longueur_pastilles);
 	            }
             }
             
diff --git a/main.h b/main.h
index 6adf711..031d981 100644
--- a/main.h
+++ b/main.h
@@ -7,5 +7,18 @@
 #define H_GAME 600
 #define T_PIXEL 15
 #define DECALEMENT 30
+#define PASTILLES 5
 
-#endif
\ No newline at end of file
+
+
+
+struct PIXELS {
+    int x;
+    int y;
+};
+
+typedef struct PIXELS PIXELS;
+
+PIXELS gen_pastille();
+
+#endif
diff --git a/prog b/prog
new file mode 100755
index 0000000..e4c8f94
Binary files /dev/null and b/prog differ