PDA

View Full Version : [C] non mi rilascia la shell


Mond0
08-05-2012, 11:13
ciao, sono in situazione al limite dell'assurdo O_o

memset(buffer, 0, BUFSIZE);
printf("Inserire il comando:\n");
fgets(buffer, BUFSIZE, stdin);
printf("la stringa inserita è: %s", buffer);
buffer[strlen(buffer)-1] = '\0';
printf("ciao");
strcat(buffer, "\r\n"); //CR LF

praticamente lancio da terminale il programma, va tutto bene fino a quando mi chiede di inserire la stringa, eseguo e lui la stampa correttamente. Ma poi si blocca: non mi rilascia + la shell --> in sostanza non mi stampa neanche più la stringa "ciao".

Nota:
inizialmente si bloccava subito dopo la richiesta di inserimento della stringa (senza quindi stamparla subito dopo con la seconda printf), poi, ipotizzando un qualche problema di buffer pieni o simili, ho inserito varie fflush() ed è migliorata la situazione (di ben 1 istruzione!) O_o riavviando non cambia nulla...

voi avete qualche idea? magari è qualcosa di banale che mi sfugge (spero)...
grazie

lorenzo001
08-05-2012, 11:26
Ma il codice completo qual è? Quando termina il programma?

Mond0
08-05-2012, 11:33
Ma il codice completo qual è? Quando termina il programma?

ammesso che qualcuno abbia voglia di leggere per intero il codice lo posto :P

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <sys/select.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <errno.h>

#define BUFSIZE 100

int main(int argc, char **argv)
{
fflush(stdin);
fflush(stdout);
fflush(stderr);
struct sockaddr_in s_addr;
char buffer, filename[100], *filebuffer;
int s, res, filesize;
FILE *f_ptr;

if(argc!=3){
printf("Errore nel passaggio dei parametri!\n");
exit(1);
}else{
s_addr.sin_family = AF_INET;
s_addr.sin_port = htons(atoi(argv[2]));
inet_aton(argv[1], &(s_addr.sin_addr)); //ricordo come inet_aton mi converte da stringa in formato "IP" a campo in in_addr
}
s = socket(PF_INET, SOCK_STREAM, IPPROTO_TCP);
connect(s, (struct sockaddr*) &s_addr, sizeof(s_addr));

while(1)
{
[B]memset(buffer, 0, BUFSIZE);
printf("Inserire il comando:\n");
fgets(buffer, BUFSIZE, stdin);
printf("la stringa inserita è: %s", buffer);
buffer[strlen(buffer)-1] = '\0';
printf("ciao");
strcat(buffer, "\r\n"); //CR LF
if(strncmp(buffer,"QUIT\n\r",6)==0){ //se comando è QUIT usciamo
printf("Hai digitato QUIT!\n");
break;
}
sscanf(buffer, "GET %s\r\n", filename); //in filename ci metto il nome del file che ho specificato
res = send(s, buffer, strlen(buffer),0);
if(res == 0)
{
printf("send() fallita, connessione chiusa dal server\n");
break;
}
if(res < 0)
{
printf("send() fallita con errore %d", errno);
break;
}
memset(buffer,0,BUFSIZE); //azzero il buffer
res = recv(s, &buffer, BUFSIZE, 0);
if(res == 0)
{
printf("recv() fallita, connessione chiusa dal server\n");
break;
}
if(res < 0)
{
printf("recv() fallita con errore %d\n", errno);
break;
}
buffer[res] = '\0'; // terminazione stringa
printf("%s", buffer); // stampo il messaggio inviato dal server
memset(buffer,0,BUFSIZE);
if(strcmp(buffer, "OK\r\n")==0)
{
res = recv(s, &buffer, BUFSIZE,0);
sscanf(buffer, "%d", &filesize);
printf("La dimesione del file inviato dal server è: %d\n", filesize);
filebuffer = (char*)malloc((filesize+1)*sizeof(char));
recv(s, &filebuffer, filesize, 0);
f_ptr = fopen(filename, "wb");
fprintf(f_ptr, "%s", filebuffer);
fclose(f_ptr);
free(filebuffer);
}
}
printf("Chiusura della connessione...\n");
close(s);

return 0;
}



praticamente è un semplice client che invia ad un server in attesa dei comandi che quest'ultimo deve eseguire...
il programma non termina, non mi rilascia più la shell dopo avermi chiesto il comando da usare (ed averlo stampato). si blocca, infatti il server mi rileva che si è connesso con il client ma non riceve nulla (dalle send() che seguono nel client dopo il codice in grassetto)...

AllerITA
08-05-2012, 12:00
Non so se il riferimento alla documentazione e' quello più esatto,
ma se sei in Microsoft OS hai mica guardato qui:

http://msdn.microsoft.com/en-us/library/c37dh6kf(v=VS.71).aspx

che dice chiaramente se gets fallisce( la funzione ritorna NULL), di guardare:

feof o ferror

per determinare cosa non gli piace?
In parole povere.