Merge pull request #1 from yoboujon/simon

Simon
This commit is contained in:
sparis1206 2023-01-11 17:55:04 +01:00 committed by GitHub
commit 006d70b685
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

56
puit.c
View file

@ -11,27 +11,21 @@
#define _OE_SOCKETS
#define PORT_NUM 9000
void initSocket();
void initSocketAddr(struct sockaddr_in *socketServerTemp, int source);
void creationSocket(int *socketTemp, struct sockaddr_in *socketTempStruct);
int sock;
char buffer[1024];
struct hostent *hp;
struct sockaddr_in socketClient,socketServer;
struct sockaddr_in socketClient;
int main(void)
{
if((sock=socket(AF_INET,SOCK_DGRAM,0)) == -1)
{
printf("échec création du socket\n");
exit(1);
}
memset(&socketClient, 0, sizeof(socketClient));
memset(&socketServer, 0, sizeof(socketServer));
initSocket();
int sock;
creationSocket(&sock,&socketClient);
initSocketAddr(&socketClient,0);
if (bind(sock, (const struct sockaddr *)&socketServer, sizeof(socketServer)) < 0 )
if (bind(sock, (const struct sockaddr *)&socketClient, sizeof(socketClient)) < 0 )
{
perror("bind failed");
exit(EXIT_FAILURE);
@ -47,14 +41,34 @@ int main(void)
return 0;
}
void initSocket()
{
socketServer.sin_family=AF_INET;
socketServer.sin_port=htons(PORT_NUM);
if((hp = gethostbyname("localhost")) == NULL)
void initSocketAddr(struct sockaddr_in *socketTempStruct, int source)
{
socketTempStruct->sin_family=AF_INET;
socketTempStruct->sin_port=htons(PORT_NUM);
if(source)
{
struct hostent *hp;
if((hp = gethostbyname("localhost")) == NULL)
{
printf("erreur gethostbyname\n");
exit(1);
}
memcpy((char*)&(socketTempStruct->sin_addr.s_addr),hp->h_addr_list[0],hp->h_length);
}
else
{
printf("erreur gethostbyname\n");
socketTempStruct->sin_addr.s_addr=INADDR_ANY;
}
}
void creationSocket(int *socketTemp, struct sockaddr_in *socketTempStruct){
if((*socketTemp=socket(AF_INET,SOCK_DGRAM,0)) == -1)
{
printf("échec création du socket\n");
exit(1);
}
memcpy((char*)&(socketServer.sin_addr.s_addr),hp->h_addr_list[0],hp->h_length);
memset(socketTempStruct, 0, sizeof(*socketTempStruct));
}