X-Git-Url: https://hackdaworld.org/gitweb/?p=my-code%2Fivac.git;a=blobdiff_plain;f=src%2Fivac.c;h=281b1a567bd8a70b9bbcd48af814d58f563e24c7;hp=49fc97d1b262104e5ffbe8ec8f1eecc877c6071a;hb=99e577ce594ed343397276ac6c2dd9729ac10d6d;hpb=dce17a68190aa256fcc9ccee5059f659ae37a3a9 diff --git a/src/ivac.c b/src/ivac.c index 49fc97d..281b1a5 100644 --- a/src/ivac.c +++ b/src/ivac.c @@ -21,10 +21,6 @@ * */ -// #define USE_NCURSES -/* dont care about ncurses .. go for gtk(2)! */ -#define USE_GTK - #include "ivac.h" int usage(void) { @@ -36,6 +32,9 @@ int usage(void) { puts("-h \t\t show this help"); puts("-n \t specify your name"); puts("-p \t specify port to listen for incoming connections"); + puts("-u \t specify udp data port"); + puts("-d \t specify audio device"); + puts("-i \t specify network interface"); puts(""); return SUCCESS; @@ -51,6 +50,9 @@ int main(int argc,char **argv) { /* default values */ strcpy(ivac.username,"ivac"); ivac.net.l_port=IVAC_LISTEN_PORT; + ivac.net.l_udp_port=IVAC_UDP_PORT; + strcpy(ivac.audio.dsp_dev,SOUND_DEVICE); + strcpy(ivac.net.nic,"eth0"); /* parse argv and change default values */ for(i=1;idisplay)); network_shutdown(&(ivac->net)); + network_udp_shutdown(&(ivac->net)); input_shutdown(&(ivac->input)); event_stop(&(ivac->event)); -#ifdef USE_NCURSES - display_shutdown(&(ivac->display)); -#endif + audio_shutdown(&(ivac->audio)); return SUCCESS; } @@ -197,7 +227,7 @@ int ivac_receive_info(int channel,t_ivac *ivac) { switch(data[count]) { case IVAC_SEND_NAME: strncpy(ivac->challenger[channel].name,data+count+2,data[count+1]); - ivac->challenger[channel].name[data[count+1]]='\0'; + ivac->challenger[channel].name[(int)data[count+1]]='\0'; count+=(data[count+1]+2); break; case IVAC_SEND_G_CAP: @@ -256,6 +286,7 @@ int ivac_event_cb(t_event *event,void *ptr) { ivac_send_info(channel,ivac); } ivac_display_content(ivac); + ivac_display_draw(ivac); } /* wait for user info */ @@ -270,6 +301,7 @@ int ivac_event_cb(t_event *event,void *ptr) { ivac_add_to_monitor(ivac,c_str); } ivac_display_content(ivac); + ivac_display_draw(ivac); } } } @@ -297,16 +329,36 @@ int ivac_parse_command(t_input *input,void *ptr) { char *data,valid; char c_str[IVAC_CONSOLE_STRING_LEN]; char arg[IVAC_ARG_COUNT][IVAC_ARG_LEN]; + char debug_string[128]; ivac=(t_ivac *)ptr; data=input->content; valid=0; - /* refresh prompt content only! */ + /* refresh prompt content only */ ivac_display_prompt_content(ivac); + ivac_display_draw(ivac); + +#ifdef DEBUG + ivac_add_to_monitor(ivac,"nach display refresh"); +#endif + +#ifdef DEBUG + ivac_add_to_monitor(ivac,"nach display refresh"); +#endif + +#ifdef DEBUG + + strcpy(debug_string,"hahahaha!"); + ivac_add_to_monitor(ivac,debug_string); +#endif /* parse command routines */ - if(data[input->c_count-1]=='\n') { + if(data[input->c_count-1]=='\n' || data[input->c_count-1]=='\r') { + +#ifdef DEBUG + ivac_add_to_monitor(ivac,"got newline or carriage return!"); +#endif /* delete console string + args */ memset(c_str,0,IVAC_CONSOLE_STRING_LEN); @@ -329,6 +381,7 @@ int ivac_parse_command(t_input *input,void *ptr) { i+=k; } + /* parse command aka arg[0] */ if(!(strncmp(arg[0],"quit",4))) { valid=1; @@ -404,7 +457,7 @@ int ivac_parse_command(t_input *input,void *ptr) { network_select(&(ivac->net),channel); sprintf(c_str,"selected channel %d",channel); } - else if(arg[1][0]='*') { + else if(arg[1][0]=='*') { network_select(&(ivac->net),MAX_CONNECTIONS); strcpy(c_str,"selected all channels"); } @@ -418,7 +471,7 @@ int ivac_parse_command(t_input *input,void *ptr) { network_deselect(&(ivac->net),channel); sprintf(c_str,"deselected channel %d",channel); } - else if(arg[1][0]='*') { + else if(arg[1][0]=='*') { network_deselect(&(ivac->net),MAX_CONNECTIONS); strcpy(c_str,"deselected all channels"); } @@ -436,181 +489,153 @@ int ivac_parse_command(t_input *input,void *ptr) { /* refresh whole display content */ ivac_display_content(ivac); + ivac_display_draw(ivac); - /* delete content buffer + reset counter */ + /* delete input content buffer + reset counter */ memset(input->content,0,input->c_count-1); input->c_count=0; } + ivac_add_to_monitor(ivac,"debug: end of parse function"); + return SUCCESS; } -int ivac_display_head(t_display *display) { - -#ifdef USE_NCURSES - int x,y; - - move(0,0); - for(x=0;xmax_x;x++) addch('#'); - mvaddstr(1,0,"##"); - mvaddstr(1,(display->max_x-4)/2-4,"- ivac -"); - mvaddstr(1,(display->max_x-2),"##"); - move(2,0); - for(x=0;xmax_x;x++) addch('#'); - refresh(); -#else - puts("#########################################################"); - puts("##### ivac - - Copyright (C) 2004 Frank Zirkelbach #####"); - puts("#########################################################"); -#endif +int ivac_display_head(t_ivac *ivac) { + + display_line(&(ivac->display),0,0,ivac->display.max_x,0,'#'); + display_string(&(ivac->display),(ivac->display.max_x-strlen(PROG_NAME))/2,1, + PROG_NAME,strlen(PROG_NAME)); + display_line(&(ivac->display),0,2,ivac->display.max_x,2,'#'); return SUCCESS; } -int ivac_display_box(t_display *display) { - -#ifdef USE_NCURSES - int x,y; - - for(y=IVAC_PROMPT_LEN;ymax_y-IVAC_PROMPT_LEN;y++) { - mvaddch(y,0,'#'); - mvaddch(y,display->max_x-1,'#'); - } -#endif +int ivac_display_box(t_ivac *ivac) { + display_line(&(ivac->display),0,3,ivac->display.max_x,3,'-'); + display_line(&(ivac->display),0,5,ivac->display.max_x,5,'-'); + display_string(&(ivac->display),0,6,"connections:",12); + display_line(&(ivac->display), + 0,ivac->display.max_y-IVAC_PROMPT_LEN-IVAC_CONSOLE_LEN-1, + ivac->display.max_x, + ivac->display.max_y-IVAC_PROMPT_LEN-IVAC_CONSOLE_LEN-1,'-'); + return SUCCESS; } int ivac_display_box_content(t_ivac *ivac) { int channel; + char string[MAX_BOX_CHARS]; /* prepare challenger names */ for(channel=0;channelchallenger[channel].name[0]==0) strcpy(ivac->challenger[channel].name,""); -#ifdef USE_NCURSES -#else + sprintf(string,"username: %s, capabilities: %02x|%04x", + ivac->username,ivac->g_cap,ivac->av_cap); + display_string(&(ivac->display),0,4,string,strlen(string)); + for(channel=0;channelnet.connection[channel].status&C_INFO_A) - printf("channel %02d: ip:%s port:%d status: %02x - name: %s\n",channel, - ivac->net.connection[channel].ip, - ivac->net.connection[channel].port, - ivac->net.connection[channel].status, - ivac->challenger[channel].name); + if(ivac->net.connection[channel].status&C_INFO_A) { + snprintf(string,MAX_BOX_CHARS, + "channel %02d: %s:%d, status: %02x, name: %s\n",channel, + ivac->net.connection[channel].ip, + ivac->net.connection[channel].port, + ivac->net.connection[channel].status, + ivac->challenger[channel].name); + display_string(&(ivac->display),0,IVAC_HEAD_LEN+4+channel, + string,strlen(string)); + } } -#endif return SUCCESS; } -int ivac_display_console(t_display *display) { +int ivac_display_console(t_ivac *ivac) { + + display_string(&(ivac->display), + 0,ivac->display.max_y-IVAC_PROMPT_LEN-IVAC_CONSOLE_LEN, + "console messages:",17); -#ifdef USE_NCURSES - int x,y; - - move(display->max_y-IVAC_CONSOLE_LEN-IVAC_PROMPT_LEN-1,0); - for(x=0;xmax_x;x++) addch('#'); -#endif - return SUCCESS; } int ivac_display_console_content(t_ivac *ivac) { -#ifdef USE_NCURSES - int x,y; - int len; - - for(y=0;yconsole[y]); - move(ivac->display.max_y-IVAC_CONSOLE_LEN-IVAC_PROMPT_LEN+y,2); - for(x=0;xconsole[y][x]>' ')||(ivac->console[y][x]<='~')) - ?ivac->console[y][x]:' '); - for(x=len;xconsole[i]); -#endif + for(i=0;iconsole[i]); + display_string(&(ivac->display), + 0,ivac->display.max_y-IVAC_PROMPT_LEN-IVAC_CONSOLE_LEN+1+i, + string,strlen(string)); + } return SUCCESS; } -int ivac_display_prompt(t_display *display) { +int ivac_display_prompt(t_ivac *ivac) { -#ifdef USE_NCURSES - int x,y; - - move(display->max_y-3,0); - for(x=0;xmax_x;x++) addch('#'); - mvaddstr(display->max_y-2,0,"## command: "); - mvaddstr(display->max_y-2,display->max_x-2,"##"); - move(display->max_y-1,0); - for(x=0;xmax_x;x++) addch('#'); - refresh(); -#endif + display_string(&(ivac->display),0,ivac->display.max_y-1,"prompt: ",8); return SUCCESS; } int ivac_display_prompt_content(t_ivac *ivac) { -#ifdef USE_NCURSES - int x,y; + char string[IVAC_CONSOLE_STRING_LEN]; + int count; - /* delete old command */ - if(ivac->input.c_count==0) { - move(ivac->display.max_y-2,12); - for(x=12;xdisplay.max_x-1;x++) addch(' '); - } + for(count=0;countinput.c_count;count++) + string[count]=ivac->input.content[count]; + for(;countdisplay.max_x-8;count++) string[count]=' '; + display_string(&(ivac->display),8,ivac->display.max_y-1, + string,ivac->display.max_x); + + return SUCCESS; +} - for(x=0;xinput.c_count;x++) - mvaddch(ivac->display.max_y-2,x+12,ivac->input.content[x]); - refresh(); -#else - printf("%c",ivac->input.content[ivac->input.c_count-1]); - fflush(NULL); -#endif +int ivac_display_content(t_ivac *ivac) { + + /* display box content */ + ivac_display_box_content(ivac); + + /* display console content */ + ivac_display_console_content(ivac); + + /* display prompt content */ + ivac_display_prompt_content(ivac); return SUCCESS; } -int ivac_display(t_display *display) { +int ivac_display(t_ivac *ivac) { - int x,y; + /* display static head */ + ivac_display_head(ivac); - /* display head */ - ivac_display_head(display); + /* display static box */ + ivac_display_box(ivac); - /* display box */ - ivac_display_box(display); - - /* display console */ - ivac_display_console(display); + /* display static console */ + ivac_display_console(ivac); /* display command prompt */ - ivac_display_prompt(display); + ivac_display_prompt(ivac); return SUCCESS; } -int ivac_display_content(t_ivac *ivac) { - - /* display box content */ - ivac_display_box_content(ivac); - - /* display console content */ - ivac_display_console_content(ivac); - - /* display prompt content */ - ivac_display_prompt_content(ivac); +int ivac_display_draw(t_ivac *ivac) { + + display_draw(&(ivac->display)); + display_set_cursor(&(ivac->display),ivac->input.c_count+8, + ivac->display.max_y-1); return SUCCESS; } @@ -623,5 +648,8 @@ int ivac_add_to_monitor(t_ivac *ivac,char *msg) { memcpy(ivac->console[i],ivac->console[i+1],IVAC_CONSOLE_STRING_LEN); memcpy(ivac->console[IVAC_CONSOLE_LEN-1],msg,IVAC_CONSOLE_STRING_LEN); + ivac_display_console_content(ivac); + ivac_display_draw(ivac); + return SUCCESS; }