#define americano 0 #define europeo 1 #define lmax 200 #define posin 18 #define ladat 90+posin #define estac 35+posin // llamadas entrantes #define linea 15+posin #define durac 26+posin #define hor 9+posin #define fech 0 #define tranf 3+posin #define numero 46+posin #define ccost 0 #define proye 0 #define cuenta 0 #define pulsos 0 #define ruta 0 #define prinum 0 #define ring 63+posin #define antran 0 // anexo transferido (pendiente) #define fofech europeo // formato de fecha extern void gua_rut(char *buf); char ruanex[(lmax+1)*2][7] ; /* Rutas Consideradas como Anexos */ extern char rgua[]; // Procesos Inicialiales (Inicializar Variables, Abrir // Archivos especiales, etc) void in_central() { rgua[0] = '\0'; } // Procesos de Finalización (Cerrar Archivos especiales, etc) void fi_central() { } // Driver Propiamente tal. Las posiciones de los campos se // ingresan como parámetros, lo que permite modificar desde // Aplicación de Tarificación la posición de estos en el // Registro de Llamados. void DatCentral(char *buf, char *tel, int vestac, int vlinea,int vdurac,int vhor, int vfech, int vtranf, int vnumero, int vccost,int vproye, int vcuenta, int vpulsos, int vruta, int vprinum, int vring, int vantran, int vfofech) { int i=strlen(buf),j,k,cont; char aux; aux = 0; cont=0; if (i>vring && buf[vhor+2]==':') { k = 0 ; for (j=0;j<4;j++) { if (isdigit(buf[vestac+j])) {tel[k++] = buf[vestac+j] ; cont++;} } if(cont==0)tel[k++] = '*';cont=0; tel[k++] = ' ' ; for (j=0;j<10;j++) {if (isdigit(buf[vlinea+j])) { tel[k++]=buf[vlinea+j]; cont++;}} if(cont==0) tel[k++] = '*';cont=0; tel[k++]=' '; if (buf[vdurac+2]==':') { for (j=0;j<8;j++) tel[k++] = buf[vdurac+j]; } else { tel[k++]='0'; tel[k++]='0'; tel[k++]=':'; tel[k++]='0'; tel[k++]='0'; tel[k++]=':'; tel[k++]='0'; tel[k++]='0'; } tel[k++] = ' ' ; for (j=0;j<5;j++) tel[k++] = buf[vhor+j]; tel[k++] = ' ' ; for (j=0;j<8;j++) tel[k++] = buf[vfech+j]; //del PC tel[k++] = ' ' ; if(buf[vring+1]==':') tel[k++]='I'; else tel[k++]='O'; tel[k++] = ' ' ; if (isdigit(buf[vlinea+4])) { for (j=0;j<10 && buf[vlinea+j]!=' ';j++) tel[k++]=buf[vlinea+j]; } else if (isdigit(buf[vnumero])) { for (j=0;j<10 && buf[vnumero+j]!=' ';j++) tel[k++]=buf[vnumero+j]; } else tel[k++]='*'; tel[k++] = ' ' ; tel[k++] = '*';tel[k++] = '*';tel[k++] = '*'; tel[k++] = ' ' ; tel[k++] = '*' ; /* proyecto */ tel[k++] = ' ' ; tel[k++] = '*' ; // Código de Cuenta tel[k++] = ' ' ; for (j=0 ; j<5 ; j++) tel[k++]='0'; tel[k++] = ' ' ; tel[k++] = '*';tel[k++] = '*';tel[k++] = '*'; tel[k++] = ' ' ; tel[k++] = '*'; /* central */ tel[k++] = ' ' ; /* tiempo ring */ if(buf[vring+1]==':') { tel[k++]='0'; for (j=0;j<4;j++) tel[k++]=buf[vring+j]; } else { tel[k++] = '0';tel[k++] = '0';tel[k++] = ':';tel[k++] = '0';tel[k++] = '0'; } tel[k++] = ' ' ; tel[k++] = '*' ; // anexo transferido tel[k++] = ' ' ; if (buf[vring+8]=='N') tel[k++]='N'; //servicio else tel[k++]='*'; tel[k++] = '\r' ; tel[k++] = '\n' ; tel[k++] = '\0' ; } }