X-Git-Url: https://hackdaworld.org/gitweb/?a=blobdiff_plain;f=src%2Fivac.c;h=f4995a791a4f5304090456064ce64cf4cd5e819f;hb=f7d9ad56ad9c10284c067cb2db36a7c72b33c5b3;hp=610ac1c5aaedaebfcba9cde60ecbf6a0e2f8006a;hpb=aea15365fab80e1d7128bdf4112440405375e29c;p=my-code%2Fivac.git diff --git a/src/ivac.c b/src/ivac.c index 610ac1c..f4995a7 100644 --- a/src/ivac.c +++ b/src/ivac.c @@ -25,7 +25,87 @@ int main(int argc,char **argv) { + /* TESTING BY NOW */ - - return 1; + t_ivac ivac; + + /* set username (futur: read from config or entered later) */ + strcpy(ivac.username,"hackbard"); + + /* set event timeout */ + ivac.event.timeout.tv_sec=IVAC_S_SEC; + ivac.event.timeout.tv_usec=IVAC_S_USEC; + + /* set listen port (futur: read from config or entered later) */ + network_set_listen_port(&(ivac.net),IVAC_LISTEN_PORT); + + /* event init */ + event_init(&(ivac.event)); + + /* input init */ + input_init(&(ivac.input)); + + /* network init */ + if(network_init(&(ivac.net))==N_ERROR) { + printf("[ivac] use 'fuser -n tcp %d' to kill that process",ivac.net.l_port); + return ERROR; + } + + /* add listening port + stdin to (read) event system */ + event_math(ivac.net.l_fd,&(ivac.event),READ,ADD); + event_math(0,&(ivac.event),READ,ADD); + + /* start event system - callbacks used: ivac_event_cb + ivac_regular_cb */ + event_start(&(ivac.event),(void *)&ivac,ivac_event_cb,ivac_regular_cb); + + network_shutdown(&(ivac.net)); + + input_shutdown(&(ivac.input)); + + return SUCCESS; +} + +int ivac_event_cb(t_event *event,void *ptr) { + + t_ivac *ivac; + int channel; + + ivac=(t_ivac *)ptr; + + if(FD_ISSET(ivac->net.l_fd,&(event->rfds))) { + /* manage incoming + send info */ + channel=network_manage_incoming(&(ivac->net)); + event_math(ivac->net.connection[channel].fd,event,READ,ADD); + send_info(channel,&(ivac->net),ivac->username); + } + + /* receive info */ + for(channel=0;channelnet.connection[channel].status&C_ESTABL) + if(FD_ISSET(ivac->net.connection[channel].fd,&(event->rfds))) + receive_info(channel,&(ivac->net)); + + /* user interaction */ + if(FD_ISSET(0,&(event->rfds))) + input_get_char(&(ivac->input),ivac_display,ivac); + + return SUCCESS; +} + +int ivac_regular_cb(t_event *event,void *ptr) { + + /* usual jobs like audio & video transmit ... */ + + return SUCCESS; +} + +int ivac_display(t_input *input,void *ptr) { + + t_ivac *ivac; + + ivac=(t_ivac *)ptr; + + if(input->content[input->c_count-1]=='q') ivac->event.status=DISABLED; + + return SUCCESS; }