Completion de la liste de liste en boîte aux lettres. fonction nouveauMessage.

This commit is contained in:
Yohan Boujon 2023-01-16 18:26:37 +01:00
parent 7885ac7bb6
commit cfd79b575d
3 changed files with 128 additions and 16 deletions

View file

@ -6,7 +6,7 @@
typedef struct{ typedef struct{
char *data; char *data;
int tailleData; int tailleData;
int idEmeteur; int idEmetteur;
}messageBAL; }messageBAL;
struct elementMessage{ struct elementMessage{
@ -20,10 +20,35 @@ struct listeMessage{
struct elementMessage * fin; struct elementMessage * fin;
}; };
messageBAL * creeMessage(char *data,int idEmeteur); typedef struct{
int idRecepteur;
struct listeMessage * actualMessages;
}BAL;
struct elementBAL{
BAL * BALActuel;
struct elementBAL * suiv;
};
struct listeBAL{
struct elementBAL * debut;
struct elementBAL * courant;
struct elementBAL * fin;
};
messageBAL * creeMessage(char *data,int idEmetteur);
struct elementMessage * initElementMessage(void); struct elementMessage * initElementMessage(void);
struct listeMessage initListeMessage(void); struct listeMessage * initListeMessage(void);
void ajoutListe(struct listeMessage * listeActuel,messageBAL * leMessage); void ajoutListeMessage(struct listeMessage * listeActuel,messageBAL * leMessage);
void afficheListeMessage(struct listeMessage listeActuel); void afficheListeMessage(struct listeMessage listeActuel);
BAL * creerBAL(int idRecepteur, struct listeMessage * messageRecepteur);
struct elementBAL * initElementBAL(void);
struct listeBAL initListeBAL(void);
void ajoutListeBAL(struct listeBAL * listeActuel,BAL * laBoiteAuxLettres);
void afficheListeBAL(struct listeBAL listeActuel);
struct elementBAL * existInListBAL(struct listeBAL listeActuel, int idRecepteur, bool * boolRetour);
void nouveauMessage(struct listeBAL * b,int idEmetteur,int idRecepteur,char *data);
#endif #endif

View file

@ -12,6 +12,7 @@
#include <netdb.h> #include <netdb.h>
#include <errno.h> #include <errno.h>
#include <arpa/inet.h> #include <arpa/inet.h>
#include <stdbool.h>
void setNbMessage(int * nb, int source); void setNbMessage(int * nb, int source);
void printInfo(int source, int isTCP, int nbMessage, int taille, int portNumber, char ipAddress[]); void printInfo(int source, int isTCP, int nbMessage, int taille, int portNumber, char ipAddress[]);

110
src/bal.c
View file

@ -1,18 +1,22 @@
#include "../header/bal.h" #include "../header/bal.h"
int main(void){ int main(void){
struct listeMessage l = initListeMessage(); struct listeBAL boiteAuxLettres = initListeBAL();
messageBAL * messageBAL = creeMessage("Renvoi moi mon pdf asap. -Simon",1); nouveauMessage(&boiteAuxLettres,2,1,"Renvoi moi mon pdf asap. -Simon");
ajoutListe(&l,messageBAL); nouveauMessage(&boiteAuxLettres,2,1,"Mon anniversaire c'est demain !");
afficheListeMessage(l); nouveauMessage(&boiteAuxLettres,1,2,"Ok joyeux anniv alors !");
nouveauMessage(&boiteAuxLettres,1,2,"ok c'est fait. -Yohan");
nouveauMessage(&boiteAuxLettres,3,1,"C'est trop, yohan me soule");
nouveauMessage(&boiteAuxLettres,1,3,"Yoyo l'asticot");
afficheListeBAL(boiteAuxLettres);
return 0; return 0;
} }
messageBAL * creeMessage(char *data,int idEmeteur) messageBAL * creeMessage(char *data,int idEmetteur)
{ {
messageBAL * message = malloc(sizeof(messageBAL)); messageBAL * message = malloc(sizeof(messageBAL));
message->idEmeteur=idEmeteur; message->idEmetteur=idEmetteur;
message->tailleData=strlen(data); message->tailleData=strlen(data);
message->data=(char*)malloc(sizeof(char)*message->tailleData); message->data=(char*)malloc(sizeof(char)*message->tailleData);
strcpy(message->data,data); strcpy(message->data,data);
@ -27,16 +31,16 @@ struct elementMessage * initElementMessage(void)
return returnElement; return returnElement;
} }
struct listeMessage initListeMessage(void) struct listeMessage * initListeMessage(void)
{ {
struct listeMessage l; struct listeMessage * l=malloc(sizeof(struct listeMessage));
l.debut=initElementMessage(); l->debut=initElementMessage();
l.fin=initElementMessage(); l->fin=initElementMessage();
l.courant=initElementMessage(); l->courant=initElementMessage();
return l; return l;
} }
void ajoutListe(struct listeMessage * listeActuel,messageBAL * leMessage) void ajoutListeMessage(struct listeMessage * listeActuel,messageBAL * leMessage)
{ {
struct elementMessage * elementActuel = malloc(sizeof(struct elementMessage)); struct elementMessage * elementActuel = malloc(sizeof(struct elementMessage));
elementActuel->messageBALActuel=leMessage; elementActuel->messageBALActuel=leMessage;
@ -55,3 +59,85 @@ void afficheListeMessage(struct listeMessage listeActuel)
elementCourant=elementCourant->suiv; elementCourant=elementCourant->suiv;
} }
} }
BAL * creerBAL(int idRecepteur, struct listeMessage * messageRecepteur)
{
BAL * boiteAuxLettres = malloc(sizeof(BAL));
boiteAuxLettres->idRecepteur=idRecepteur;
boiteAuxLettres->actualMessages=messageRecepteur;
return boiteAuxLettres;
}
struct elementBAL * initElementBAL(void)
{
struct elementBAL * returnElement = malloc(sizeof(struct elementBAL));
struct listeMessage * lVide = initListeMessage();
returnElement->BALActuel = creerBAL(0,lVide);
returnElement->suiv = NULL;
return returnElement;
}
struct listeBAL initListeBAL(void)
{
struct listeBAL l;
l.debut=initElementBAL();
l.fin=initElementBAL();
l.courant=initElementBAL();
return l;
}
void ajoutListeBAL(struct listeBAL * listeActuel,BAL * laBoiteAuxLettres)
{
struct elementBAL * elementActuel = malloc(sizeof(struct elementBAL));
elementActuel->BALActuel=laBoiteAuxLettres;
elementActuel->suiv=listeActuel->courant;
listeActuel->debut=elementActuel;
listeActuel->courant=elementActuel;
}
void afficheListeBAL(struct listeBAL listeActuel)
{
struct elementBAL * elementFinal = listeActuel.fin;
struct elementBAL * elementCourant = listeActuel.courant;
while(elementCourant->suiv != elementFinal->suiv)
{
printf("Recepteur : %d\n",elementCourant->BALActuel->idRecepteur);
afficheListeMessage(*(elementCourant->BALActuel->actualMessages));
elementCourant=elementCourant->suiv;
}
}
struct elementBAL * existInListBAL(struct listeBAL listeActuel, int idRecepteur, bool * boolRetour)
{
struct elementBAL * elementFinal = listeActuel.fin;
struct elementBAL * elementCourant = listeActuel.courant;
while(elementCourant->suiv != elementFinal->suiv)
{
if(elementCourant->BALActuel->idRecepteur == idRecepteur)
{
*boolRetour = true;
return elementCourant;
}
elementCourant=elementCourant->suiv;
};
*boolRetour = false;
return elementFinal;
}
void nouveauMessage(struct listeBAL * b,int idEmetteur,int idRecepteur,char *data)
{
bool testExistInList;
struct elementBAL * elementNouveauMessage = existInListBAL(*b,idRecepteur,&testExistInList);
printf("testExistInList = %d\n",testExistInList);
if(testExistInList)
{
ajoutListeMessage(elementNouveauMessage->BALActuel->actualMessages,creeMessage(data,idEmetteur));
}
else
{
struct listeMessage * newListMessage = initListeMessage();
ajoutListeMessage(newListMessage,creeMessage(data,idEmetteur));
ajoutListeBAL(b,creerBAL(idRecepteur,newListMessage));
}
}