|
131
|
Programación / Programación C/C++ / Re: Process returned 0
|
en: 21 Enero 2014, 04:06 am
|
ohhh si ya me fije lo que le falto, se me olvido ponerle los encabezados de las funciones #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX 8 typedef enum {INS,OP,DIR,MAQ,CAL,X_CAL,TOTAL} tabla; typedef struct nodo { char *instruccion; char *operando; char *modo_direccionamiento[MAX]; char *codigo_maquina[MAX]; char *bytes_calculados[MAX]; char *bytes_x_calcular[MAX]; char *suma_bytes[MAX]; struct nodo *sig; }COD; void quitarSaltosLinea(char *cadena); void buscarFinLinea(FILE *fd); void ignorarEspacios(FILE *fd); void imprimirLista(COD *cabeza); char *Tabla_Operandos(FILE *hc12,int tabla); int main() { int car,i; FILE *hc12; COD *cabeza = NULL,*ultimo; char *ins,*op,*dir[MAX],*maq[MAX],*cal[MAX],*x_cal[MAX],*suma[MAX]; if((hc12 = fopen("archivo.txt","r"))!= NULL ) { while((car = fgetc(hc12 ))!= EOF ) { i = 0; ins = Tabla_Operandos(hc12,INS); ignorarEspacios(hc12); op = Tabla_Operandos(hc12,OP); do { ignorarEspacios(hc12); dir[i] = Tabla_Operandos(hc12,DIR); ignorarEspacios(hc12); maq[i] = Tabla_Operandos(hc12,MAQ); ignorarEspacios(hc12); cal[i] = Tabla_Operandos(hc12,CAL); ignorarEspacios(hc12); x_cal[i] = Tabla_Operandos(hc12,X_CAL); ignorarEspacios(hc12); suma[i] = Tabla_Operandos(hc12,TOTAL); buscarFinLinea(hc12); i++; }while(car == '\t'); } } return 0; } void buscarFinLinea(FILE *hc12) { int car; while((car = fgetc(hc12 ))!= '\n' && car != EOF ) ; } void ignorarEspacios(FILE *hc12) { int car; do { }while(car == '\t' || car == ' '); } char *Tabla_Operandos(FILE *hc12,int tabla) { int car,lon = 0,pos; char *cadena; if((tabla==INS)||(tabla==OP)||(tabla==DIR)||(tabla==MAQ)||(tabla==CAL)||(tabla==X_CAL)) { do { lon++; }while(car != '\t' && car != EOF); } else { do { lon++; }while(car != '\n' && car != EOF); lon--; } fseek(hc12 ,pos ,SEEK_SET ); cadena = (char*)calloc((lon +1),sizeof(char)); fgets(cadena ,lon +1,hc12 ); quitarSaltosLinea(cadena); return cadena; } void quitarSaltosLinea(char *cadena) { char *ptr; if(((ptr =strchr(cadena ,'\n'))!=NULL )||((ptr =strchr(cadena ,'\t'))!=NULL )||((ptr =strchr(cadena ,' '))!=NULL )) *ptr = '\0'; }
y el problema esta en que no imprime el archivo como deberia
|
|
|
132
|
Programación / Programación C/C++ / Re: Process returned 0
|
en: 21 Enero 2014, 01:08 am
|
leosansan si tienes razon el primer codigo me falto poner varias cosas, pero ahora el codigo que me da problemas es el ultimo que postee, el que tiene algunas cosas modificadas
|
|
|
133
|
Programación / Programación C/C++ / Re: Process returned 0
|
en: 20 Enero 2014, 21:36 pm
|
Saludos amchacon y gracias por tu respuesta, tenias razon el problema es que tenia que agregarle la condicion de car != EOF, y ahora ya funciona, solo que ahora cambie un poco el codigo porque le agregue unas lineas al archivo, el archivo es el siguiente: ADCA SI IMM 89ii 1 1 2 DIR 99dd 1 1 2 EXT B9hhll 1 2 3 IDX A9xb 1 1 2 IDX1 A9xbff 1 2 3 IDX2 A9xbeeff 1 3 4 [D,IDX] A9xb 1 1 2 [IDX2] A9xbeeff 1 3 4 ADCB SI IMM C9ii 1 1 2 DIR D9dd 1 1 2 EXT F9hhll 1 2 3 IDX E9xb 1 1 2 IDX1 E9xbff 1 2 3 IDX2 E9xbeeff 1 3 4 [D,IDX] E9xb 1 1 2 [IDX2] E9xbeeff 1 3 4
antes el archivo solo tenia la informacion del codop ADCA pero para que me leyera el de ADCB tambien, tuve que modificarlo, el codigo si me imprime ,solo que me imprime unos espacios en blanco que sobran despues de leer la ultima linea del archivo y tambien la informacion del [D,IDX] del codop ADCB no la imprime completa y tampoco la del IMM del ADCB, por que sera esto?? el codigo es: #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX 8 typedef enum {INS,OP,DIR,MAQ,CAL,X_CAL,TOTAL} tabla; int main() { int car,i; FILE *hc12; COD *cabeza = NULL,*ultimo; char *ins,*op,*dir[MAX],*maq[MAX],*cal[MAX],*x_cal[MAX],*suma[MAX]; if((hc12 = fopen("archivo.txt","r"))!= NULL ) { while((car = fgetc(hc12 ))!= EOF ) { i = 0; ins = Tabla_Operandos(hc12,INS); ignorarEspacios(hc12); op = Tabla_Operandos(hc12,OP); do { ignorarEspacios(hc12); dir[i] = Tabla_Operandos(hc12,DIR); ignorarEspacios(hc12); maq[i] = Tabla_Operandos(hc12,MAQ); ignorarEspacios(hc12); cal[i] = Tabla_Operandos(hc12,CAL); ignorarEspacios(hc12); x_cal[i] = Tabla_Operandos(hc12,X_CAL); ignorarEspacios(hc12); suma[i] = Tabla_Operandos(hc12,TOTAL); buscarFinLinea(hc12); i++; }while(car == '\t' && car != EOF); } } return 0; } void buscarFinLinea(FILE *fd) { int car; while((car = fgetc(fd ))!= '\n' && car != EOF ) ; } void ignorarEspacios(FILE *fd) { int car; do { }while(car == '\t' || car == ' '); } char *Tabla_Operandos(FILE *hc12,int tabla) { int car,lon = 0,pos; char *cadena; if((tabla==INS)||(tabla==OP)||(tabla==DIR)||(tabla==MAQ)||(tabla==CAL)||(tabla==X_CAL)) { do { lon++; }while(car != '\t' && car != EOF); } else { do { lon++; }while(car != '\n' && car != EOF); lon--; } fseek(hc12 ,pos ,SEEK_SET ); cadena = (char*)calloc((lon +1),sizeof(char)); fgets(cadena ,lon +1,hc12 ); quitarSaltosLinea(cadena); return cadena; } void quitarSaltosLinea(char *cadena) { char *ptr; if(((ptr =strchr(cadena ,'\n'))!=NULL )||((ptr =strchr(cadena ,'\t'))!=NULL )||((ptr =strchr(cadena ,' '))!=NULL )) *ptr = '\0'; }
gracias
|
|
|
134
|
Programación / Programación C/C++ / Process returned 0
|
en: 19 Enero 2014, 23:40 pm
|
Saludos, tengo entendido que al compilar un programa si te aparece un mensaje que diga Process returned 0 (0x0) quiere decir que compilo bien y sin errores, pero a mi en el siguiente codigo no me aparece ese mensaje, pero tampoco me aparecen mensajes de error o warnings, el programa tiene que leer un archivo y almacenar algunos datos en la variable que le corresponda, pero no se donde esta el error?? y por que el programa no termina como deberia int main() { int car,i; FILE *hc12; COD *cabeza = NULL,*ultimo; char *ins,*op,*dir[MAX],*maq[MAX],*cal[MAX],*x_cal[MAX],*suma[MAX]; if((hc12 = fopen("archivo.txt","r"))!= NULL ) { while((car = fgetc(hc12 ))!= EOF ) { i = 0; ins = Tabla_Operandos(hc12); ignorarEspacios(hc12); op = Tabla_Operandos(hc12); do { ignorarEspacios(hc12); dir[i] = Tabla_Operandos(hc12); ignorarEspacios(hc12); maq[i] = Tabla_Operandos(hc12); ignorarEspacios(hc12); cal[i] = Tabla_Operandos(hc12); ignorarEspacios(hc12); x_cal[i] = Tabla_Operandos(hc12); ignorarEspacios(hc12); suma[i] = Tabla_Operandos(hc12); buscarFinLinea(hc12); i++; }while(car == '\t'); } } return 0; } void buscarFinLinea(FILE *fd) { int car; while((car = fgetc(fd ))!= '\n') ; } void ignorarEspacios(FILE *fd) { int car; do { }while(car == '\t' || car == ' '); } char *Tabla_Operandos(FILE *hc12) { int car,lon = 0,pos; char *cadena; do { lon++; }while(car != '\t' && car != ' '); fseek(hc12 ,pos ,SEEK_SET ); fgets(cadena ,lon +1,hc12 ); quitarSaltosLinea(cadena); return cadena; }
de antemano gracias
|
|
|
135
|
Programación / Programación C/C++ / Re: Lista con arrays
|
en: 16 Enero 2014, 19:19 pm
|
gracias rir3760 tratare de pensar en alguna manera de sustituir el fseek aunque por ahora no se me ocurre nada, tambien le hice modificaciones al codigo y ya no me aparecen errores ni warnings pero el codigo me truena no entiendo por que #include <stdio.h> #include <stdlib.h> #include <string.h> typedef struct nodo { char *codigo; char *Operando; char *modo_direccionamiento[8]; char *codigo_maquina[8]; char *bytes_calculados[8]; char *bytes_x_calcular[8]; char *total_bytes[8]; struct nodo *sig; }COD; void imprimirLista(COD *cabeza); void buscarFinLinea(FILE *hc12); void ignorarEspacios(FILE *hc12); char *Tabla_Operandos(FILE *hc12); void insertarFinal(char *ins,char *op,char **dir,char **maq,char **calculado,char **calcular,char **total,COD *ultimo,int i); COD *ultimoElemento(COD *cabeza); COD *crearNodo(char *ins,char *op,char **dir,char **maq,char **calculado,char **calcular,char **total,int i); void quitarSaltosLinea(char *cadena); int main() { COD *cabeza = NULL,*ultimo; FILE *hc12; int car,i; char *ins,*op,*dir[8],*maq[8],*calculado[8],*calcular[8],*total[8]; if((hc12 = fopen("archivo.txt","r"))!= NULL ) { i = 0; while((car = fgetc(hc12 ))!= EOF ) { if(car != '\t') { ins = Tabla_Operandos(hc12); ignorarEspacios(hc12); op = Tabla_Operandos(hc12); ignorarEspacios(hc12); dir[i] = Tabla_Operandos(hc12); ignorarEspacios(hc12); maq[i] = Tabla_Operandos(hc12); ignorarEspacios(hc12); calculado[i] = Tabla_Operandos(hc12); ignorarEspacios(hc12); calcular[i] = Tabla_Operandos(hc12); ignorarEspacios(hc12); total[i] = Tabla_Operandos(hc12); buscarFinLinea(hc12); i++; if(cabeza == NULL) cabeza = crearNodo(ins,op,dir,maq,calculado,calcular,total,i); else { ultimo = ultimoElemento(cabeza); insertarFinal(ins,op,dir,maq,calculado,calcular,total,ultimo,i); } } else {/* dir[i] = Tabla_Operandos(hc12); ignorarEspacios(hc12); maq[i] = Tabla_Operandos(hc12); ignorarEspacios(hc12); calculado[i] = Tabla_Operandos(hc12); ignorarEspacios(hc12); calcular[i] = Tabla_Operandos(hc12); ignorarEspacios(hc12); total[i] = Tabla_Operandos(hc12); i++;*/ buscarFinLinea(hc12); } } //imprimirLista(cabeza); } else printf("No se pudo abrir archivo\n"); return 0; } void buscarFinLinea(FILE *fd) { int car; while((car = fgetc(fd ))!= '\n') ; } void ignorarEspacios(FILE *fd) { int car; do { }while(car == '\t' || car == ' '); } char *Tabla_Operandos(FILE *hc12) { int car,lon = 0,pos; char *cadena; do { lon++; }while(car != '\t'); fseek(hc12 ,pos ,SEEK_SET ); cadena = (char*)calloc((lon +1),sizeof(char)); fgets(cadena ,lon +1,hc12 ); quitarSaltosLinea(cadena); return cadena; } void quitarSaltosLinea(char *cadena) { char *ptr; if(((ptr =strchr(cadena ,'\n'))!=NULL )||((ptr =strchr(cadena ,'\t'))!=NULL )||((ptr =strchr(cadena ,' '))!=NULL )) *ptr = '\0'; } void insertarFinal(char *ins,char *op,char **dir,char **maq,char **calculado,char **calcular,char **total,COD *ultimo,int i) { ultimo->sig = crearNodo(ins,op,dir,maq,calculado,calcular,total,i); ultimo->sig->sig = NULL; ultimo = ultimo->sig; } COD *ultimoElemento(COD *cabeza) { COD *ptr; ptr = cabeza; while(ptr->sig != NULL) ptr = ptr->sig; return ptr; } COD *crearNodo(char *ins,char *op,char **dir,char **maq,char **calculado,char **calcular,char **total,int i) { COD *x; int tam,tam1,tam2,tam3,tam4,tam5,tam6; x ->codigo = (char*)malloc(tam +1); x ->Operando = (char*)malloc(tam1 +1); x ->modo_direccionamiento [i ] = (char*)malloc(tam2 +1); x ->codigo_maquina [i ] = (char*)malloc(tam3 +1); x ->bytes_calculados [i ] = (char*)malloc(tam4 +1); x ->bytes_x_calcular [i ] = (char*)malloc(tam5 +1); x ->total_bytes [i ] = (char*)malloc(tam6 +1); strcpy(x ->modo_direccionamiento [i ],dir [i ]); strcpy(x ->codigo_maquina [i ],maq [i ]); strcpy(x ->bytes_calculados [i ],calculado [i ]); strcpy(x ->bytes_x_calcular [i ],calcular [i ]); strcpy(x ->total_bytes [i ],total [i ]); x->sig = NULL; return x; }
|
|
|
136
|
Programación / Programación C/C++ / Re: Lista con arrays
|
en: 16 Enero 2014, 01:18 am
|
las lineas de warning aparecen en las variables calculado[i] = Tabla_Operandos(hc12);
y tambien en calcular[i] = Tabla_Operandos(hc12);
y la de total. si hago el codigo de esta manera: #include <stdio.h> #include <stdlib.h> #include <string.h> typedef struct nodo { char *codigo; char *Operando; char *modo_direccionamiento; char *codigo_maquina; char *bytes_calculados; char *bytes_x_calcular; char *total_bytes; struct nodo *sig; }COD; void imprimirLista(COD *cabeza); void buscarFinLinea(FILE *hc12); void ignorarEspacios(FILE *hc12); char *Tabla_Operandos(FILE *hc12); void insertarFinal(char *ins,char *op,char *dir,char *maq,char *calculado,char *calcular,char *total,COD *ultimo); COD *ultimoElemento(COD *cabeza); COD *crearNodo(char *ins,char *op,char *dir,char *maq,char *calculado,char *calcular,char *total); void quitarSaltosLinea(char *cadena); int main() { COD *cabeza = NULL,*ultimo; FILE *hc12; int car; char *ins,*op,*dir,*maq,*calculado,*calcular,*total; if((hc12 = fopen("archivo.txt","r"))!= NULL ) { while((car = fgetc(hc12 ))!= EOF ) { if(car != '\t') { ins = Tabla_Operandos(hc12); ignorarEspacios(hc12); op = Tabla_Operandos(hc12); ignorarEspacios(hc12); dir = Tabla_Operandos(hc12); ignorarEspacios(hc12); maq = Tabla_Operandos(hc12); ignorarEspacios(hc12); calculado = Tabla_Operandos(hc12); ignorarEspacios(hc12); calcular = Tabla_Operandos(hc12); ignorarEspacios(hc12); total = Tabla_Operandos(hc12); buscarFinLinea(hc12); if(cabeza == NULL) cabeza = crearNodo(ins,op,dir,maq,calculado,calcular,total); else { ultimo = ultimoElemento(cabeza); insertarFinal(ins,op,dir,maq,calculado,calcular,total,ultimo); } } else buscarFinLinea(hc12); } imprimirLista(cabeza); } else printf("No se pudo abrir archivo\n"); return 0; } void buscarFinLinea(FILE *fd) { int car; while((car = fgetc(fd ))!= '\n') ; } void ignorarEspacios(FILE *fd) { int car; do { }while(car == '\t' || car == ' '); } char *Tabla_Operandos(FILE *hc12) { int car,lon = 0,pos; char *cadena; do { lon++; }while(car != '\t'); fseek(hc12 ,pos ,SEEK_SET ); cadena = (char*)calloc((lon +1),sizeof(char)); fgets(cadena ,lon +1,hc12 ); quitarSaltosLinea(cadena); return cadena; } void quitarSaltosLinea(char *cadena) { char *ptr; if(((ptr =strchr(cadena ,'\n'))!=NULL )||((ptr =strchr(cadena ,'\t'))!=NULL )||((ptr =strchr(cadena ,' '))!=NULL )) *ptr = '\0'; } void insertarFinal(char *ins,char *op,char *dir,char *maq,char *calculado,char *calcular,char *total,COD *ultimo) { ultimo->sig = crearNodo(ins,op,dir,maq,calculado,calcular,total); ultimo->sig->sig = NULL; ultimo = ultimo->sig; } COD *ultimoElemento(COD *cabeza) { COD *ptr; ptr = cabeza; while(ptr->sig != NULL) ptr = ptr->sig; return ptr; } COD *crearNodo(char *ins,char *op,char *dir,char *maq,char *calculado,char *calcular,char *total) { COD *x; int tam,tam1,tam2,tam3,tam4,tam5,tam6; x = (COD *)malloc(sizeof(COD )); x ->codigo = (char*)malloc((tam +1)*sizeof(char)); x ->Operando = (char*)malloc((tam1 +1)*sizeof(char)); x ->modo_direccionamiento = (char*)malloc((tam2 +1)*sizeof(char)); x ->codigo_maquina = (char*)malloc((tam3 +1)*sizeof(char)); x ->bytes_calculados = (char*)malloc((tam4 +1)*sizeof(char)); x ->bytes_x_calcular = (char*)malloc((tam5 +1)*sizeof(char)); x ->total_bytes = (char*)malloc((tam6 +1)*sizeof(char)); strcpy(x ->modo_direccionamiento ,dir ); strcpy(x ->codigo_maquina ,maq ); strcpy(x ->bytes_calculados ,calculado ); strcpy(x ->bytes_x_calcular ,calcular ); x->sig = NULL; return x; } void imprimirLista(COD *cabeza) { COD *ptr; for(ptr = cabeza;ptr != NULL;ptr = ptr->sig) { printf("%s\t",ptr ->modo_direccionamiento ); printf("%s\t\t",ptr ->codigo_maquina ); printf("%s\t",ptr ->bytes_calculados ); printf("%s\t",ptr ->bytes_x_calcular ); printf("%s\n",ptr ->total_bytes ); } }
funciona correctamente y me imprime la primer linea del archivo: codop operan direccionamiento cod maquina bytes etc etc ADCA SI IMM 89ii 1 1 2 pero no me imprime los demas lineas, es por eso que queria que los direccionamientos, codigos maquina, etc... fueran arrays para que asi cupieran todos, pero no se como hacer para que las variables dir, maq, calculado, calcular, total me puedan almacenar un solo elemento y despues poder modificarla para que sea un array, no se si me di a entender espero que si
|
|
|
137
|
Programación / Programación C/C++ / Lista con arrays
|
en: 15 Enero 2014, 19:51 pm
|
Saludos tengo el siguiente archivo de texto: ADCA****SI***IMM***89ii******1***1***2 **************DIR***99dd*****1***1***2 **************EXT***B9hhll****1***2***3 **************IDX***A9xb*****1***1***2 **************IDX1**A9xbff****1***2***3 **************IDX2**A9xbeeff**1***3***4 los * son espacios Y tengo que leer este archivo y que me guarde cada uno de los elementos en una variable para esto se me ocurrio que podia hacer una lista simplemente ligada que tuviera los elementos: codop = ADCA, operando = SI y para los 5 elementos restantes pense que podria hacerlos con arreglos, que direccionamiento fuera algo como: direc[0] = IMM direc[1] = DIR direc[2] = EXT direc[3] = IDX direc[4] = IDX1 y codigo maquina fuera: maq[0] = 89ii maq[1] = 99dd maq[2] = B9hhl .... .... esto seria un array de cadenas un char **direc y para los campos que tienen numeros seria un simple array, el codigo que tengo hecho es el siguiente pero me aparecen warnings que dicen assignment makes integer from pointer without a cast, y no entiendo por que,¿¿¿como corregirlo??? #include <stdio.h> #include <stdlib.h> #include <string.h> typedef struct nodo { char *codigo; char *Operando; char **modo_direccionamiento; char **codigo_maquina; char *bytes_calculados; char *bytes_x_calcular; char *total_bytes; struct nodo *sig; }COD; void buscarFinLinea(FILE *hc12); void ignorarEspacios(FILE *hc12); char *Tabla_Operandos(FILE *hc12); void insertarFinal(char *ins,char *op,char **dir,char **maq,char *calculado,char *calcular,char *total,COD *ultimo,int i); COD *ultimoElemento(COD *cabeza); COD *crearNodo(char *ins,char *op,char **dir,char **maq,char *calculado,char *calcular,char *total,int i); void quitarSaltosLinea(char *cadena); int main() { COD *cabeza = NULL,*ultimo; FILE *hc12; int p,i,car; char *ins,*op,**dir,**maq,*calculado,*calcular,*total; if((hc12 = fopen("archivo.txt","r"))!= NULL ) { i = 0; while((car = fgetc(hc12 ))!= EOF ) { if(car != '\t') { ins = Tabla_Operandos(hc12); ignorarEspacios(hc12); op = Tabla_Operandos(hc12); ignorarEspacios(hc12); buscarFinLinea(hc12); if(car == '\t') { dir = (char**)malloc(8*sizeof(char)); dir[i] = Tabla_Operandos(hc12); ignorarEspacios(hc12); maq = (char**)malloc(8*sizeof(char)); maq[i] = Tabla_Operandos(hc12); ignorarEspacios(hc12); calculado = (char*)malloc(8*sizeof(char)); calculado[i] = Tabla_Operandos(hc12); ignorarEspacios(hc12); calcular = (char*)malloc(8*sizeof(char)); calcular[i] = Tabla_Operandos(hc12); ignorarEspacios(hc12); total = (char*)malloc(8*sizeof(char)); total[i] = Tabla_Operandos(hc12); buscarFinLinea(hc12); if(cabeza == NULL) //cabeza = crearNodo(ins,op,dir,maq,calculado,calcular,total,i); else { //ultimo = ultimoElemento(cabeza); //insertarFinal(ins,op,dir,maq,calculado,calcular,total,ultimo); } i++; } } } } else printf("No se pudo abrir archivo\n"); return 0; } void buscarFinLinea(FILE *fd) { int car; while((car = fgetc(fd ))!= '\n') ; } void ignorarEspacios(FILE *fd) { int car; do { }while(car == '\t' || car == ' '); } char *Tabla_Operandos(FILE *hc12) { int car,lon = 0,pos; char *cadena; do { lon++; }while(car != '\t'); fseek(hc12 ,pos ,SEEK_SET ); cadena = (char*)calloc((lon +1),sizeof(char)); fgets(cadena ,lon +1,hc12 ); quitarSaltosLinea(cadena); return cadena; } void quitarSaltosLinea(char *cadena) { char *ptr; if(((ptr =strchr(cadena ,'\n'))!=NULL )||((ptr =strchr(cadena ,'\t'))!=NULL )||((ptr =strchr(cadena ,' '))!=NULL )) *ptr = '\0'; }
de antemano gracias
|
|
|
138
|
Programación / Programación C/C++ / pasar por referencia un puntero
|
en: 12 Enero 2014, 03:15 am
|
Saludos, tengo unas dudas con respecto a por que en algunas ocasiones se tienen que pasar los punteros por referencias?? como cuando estas haciendo una lista enlazada y quieres insertar por la cabeza, por que tienes que pasar el puntero por referencia, que no se supone que el puntero ya almacena una direccion de memoria y que por lo tanto no es necesario pasarlo asi funcion(&cabeza).
gracias
|
|
|
140
|
Programación / Programación C/C++ / Re: problema con lista indexada
|
en: 8 Enero 2014, 00:08 am
|
gracias por sus respuestas, una ultima duda, si tengo por ejemplo el archivo *****ORG***$AB Et1**SWI******* *****ADCA**1,X *****BRA***ET1 los codops son (ORG,SWI,ADCA,BRA) y cada uno de esos los tengo que buscar en una lista, en este ejemplo el unico codop que no se debe de encontrar es el ORG, pero en el codigo siempre me aparece NO SE ENCONTRO EL CODOP DE OPERACION, ya cheque que la funcion busqueda este bien implementada pero aun asi no puedo encontrar cual es el fallo #include <stdio.h> #include <stdlib.h> #include <string.h> #define LONG_ETIQUETA 8 #define LONG_CODOP 5 #define COMENTARIO ';' #define TABULADOR '\t' #define ESPACIOS_ ' ' typedef enum {FALSO,VERDADERO} booleano; typedef enum {ETIQUETA,CODOP,OPERANDO} linea; typedef enum {INS,OPE} tabla; typedef struct nodo { char *codigo; char *Operando; struct nodo *sig; }COD; COD *crearNodo(char *instruccion,char *op); void insertarFinal(char *instruccion,char *op,COD *ultimo); COD *ultimoElemento(COD *cabeza); void quitarSaltosLinea(char *cadena); int verificarCombinacion(FILE *fd); booleano esComentario(FILE *fd); char *Etiqueta_Codop_Operando(FILE *fd,int linea); char *_Codop_Operando(FILE *fd,int linea); void ultimaLinea(char *codop); void erroresEtiqueta(char *etiqueta); void erroresCodop(char *codop); void buscarFinLinea(FILE *fd); void ignorarEspacios(FILE *fd); booleano esNumero(char caracter); booleano esLetra(char caracter); void listaCodops(COD *cabeza); char *Tabla_Operandos(FILE *hc12,int tabla); COD *buscarCodop(COD *cabeza,char *codop); void imprimirLista(COD *cabeza); int main() { FILE *fd; int car,combinacion; COD *cabeza = NULL,*encontrado; char *etiqueta,*codop,*operando; //listaCodops(cabeza); if((fd = fopen("P2ASM.txt","r"))!= NULL ) { while((car = fgetc(fd ))!= EOF ) { switch(car) { case COMENTARIO: if(esComentario(fd)) else buscarFinLinea(fd); break; case ESPACIOS_: case TABULADOR: etiqueta = "null"; printf("ETIQUETA = %s\n",etiqueta ); ignorarEspacios(fd); codop = Etiqueta_Codop_Operando(fd,CODOP); erroresCodop(codop); if((encontrado = buscarCodop(cabeza,codop)) == NULL) printf("\tNO SE ENCONTRO EL CODOP DE OPERACION\n"); combinacion = verificarCombinacion(fd); if(combinacion == 2) { operando = "null"; printf("OPERANDO = %s\n\n",operando ); } else { ignorarEspacios(fd); operando = Etiqueta_Codop_Operando(fd,OPERANDO); printf("OPERANDO = %s\n\n",operando ); } break; default: etiqueta = Etiqueta_Codop_Operando(fd,ETIQUETA); printf("ETIQUETA = %s\n",etiqueta ); erroresEtiqueta(etiqueta); combinacion = verificarCombinacion(fd); if(combinacion == 2) { codop = "null"; erroresCodop(codop); if((encontrado = buscarCodop(cabeza,codop)) == NULL) printf("\tNO SE ENCONTRO EL CODOP DE OPERACION\n"); operando = "null"; printf("OPERANDO = %s\n\n",operando ); } else { ignorarEspacios(fd); codop = Etiqueta_Codop_Operando(fd,CODOP); erroresCodop(codop); if((encontrado = buscarCodop(cabeza,codop)) == NULL) printf("\tNO SE ENCONTRO EL CODOP DE OPERACION\n"); combinacion = verificarCombinacion(fd); if(combinacion == 2) { operando = "null"; printf("OPERANDO = %s\n\n",operando ); } else { ignorarEspacios(fd); operando = Etiqueta_Codop_Operando(fd,OPERANDO); printf("OPERANDO = %s\n\n",operando ); } } break; } } ultimaLinea(codop); } else printf("No se pudo abrir el archivo"); return 0; } booleano esComentario(FILE *fd) { int car; while((car = fgetc(fd ))!= '\n') { if(car == ';') return 0; } return 1; } void buscarFinLinea(FILE *fd) { int car; while((car = fgetc(fd ))!= '\n') ; } void ignorarEspacios(FILE *fd) { int car; do { }while(car == '\t' || car == ' '); } int verificarCombinacion(FILE *fd) { int car,combinacion; if((car = fgetc(fd ))== '\n') combinacion = 2; else combinacion = 1; return combinacion; } booleano esLetra(char caracter) { if((caracter >= 'A' && caracter <= 'Z')||(caracter >= 'a' && caracter <= 'z')) return 1; else return 0; } booleano esNumero(char caracter) { if(caracter >= '0' && caracter <= '9') return 1; else return 0; } char *Etiqueta_Codop_Operando(FILE *fd,int linea) { int car,lon = 0,pos; char *cadena; if((linea == ETIQUETA)||(linea == CODOP)) { do { lon++; }while(car != '\t' && car != ' ' && car != '\n'); } else { do { lon++; }while(car != '\n'); } quitarSaltosLinea(cadena); return cadena; } void quitarSaltosLinea(char *cadena) { char *ptr; if(((ptr =strchr(cadena ,'\n'))!=NULL )||((ptr =strchr(cadena ,'\t'))!=NULL )||((ptr =strchr(cadena ,' '))!=NULL )) *ptr = '\0'; } void erroresEtiqueta(char *etiqueta) { int tam,i = 0,esEtiqueta = 1; if(tam-1 > LONG_ETIQUETA) printf("\tError:la longitud maxima de una etiqueta es de 8 caracteres\n"); if(!esLetra(etiqueta[i])) printf("\tError:la etiqueta debe iniciar con letra\n"); else { for(i = 0;(i < tam)&&(esEtiqueta);i++) { if((!esLetra(etiqueta[i]))&&(!esNumero(etiqueta[i]))&&(etiqueta[i] != '_')) esEtiqueta = 0; } if(!esEtiqueta) printf("\tError:los caracteres validos en las etiquetas son letras, digitos(0..9) y el guion bajo\n"); } } void erroresCodop(char *codop) { int tam,i = 0,esCodop = 1,punto = 0; if(tam > LONG_CODOP) printf("\tError:la longitud maxima de un codigo de operacion es de 5 caracteres\n"); if((strcmp(codop ,"null"))== 0) printf("\tError:siempre debe de haber un codigo de operacion\n"); else { if(!esLetra(codop[i])) printf("\tError:los codigos de operacion deben iniciar con letra\n"); else { for(i = 1;(i < tam)&&(esCodop)&&(punto>=0&&punto<=1);i++) { if((!esLetra(codop[i]))&&(codop[i] != '.')) esCodop = 0; else if(codop[i] == '.') punto++; } if(!esCodop) printf("\tError:los caracteres validos en un codigo de operacion son letras y el caracter punto\n"); if(punto > 1) printf("\tError:los codigos de operacion no pueden tener mas de un punto\n"); } } } void ultimaLinea(char *codop) { if((strcmp(codop ,"END")) != 0) printf("Error:No se encontro el END.\n"); } void listaCodops(COD *cabeza) { int car; FILE *hc12; char *instruccion,*op; COD *ultimo; if((hc12 = fopen("TABOP.txt","r"))!= NULL ) { while((car = fgetc(hc12 ))!= EOF ) { if(car != '\t') { instruccion = Tabla_Operandos(hc12,INS); op = Tabla_Operandos(hc12,OPE); if(cabeza == NULL) cabeza = crearNodo(instruccion,op); else { ultimo = ultimoElemento(cabeza); insertarFinal(instruccion,op,ultimo); } } else buscarFinLinea(hc12); } imprimirLista(cabeza); } else printf("No se pudo abrir el archivo\n"); } char *Tabla_Operandos(FILE *hc12,int tabla) { int car,lon = 0,pos; char *cadena; do { lon++; }while(car != '\t'); fseek(hc12 ,pos ,SEEK_SET ); fgets(cadena ,lon +1,hc12 ); quitarSaltosLinea(cadena); if(tabla == INS) ignorarEspacios(hc12); else buscarFinLinea(hc12); return cadena; } void insertarFinal(char *instruccion,char *op,COD *ultimo) { ultimo->sig = crearNodo(instruccion,op); ultimo->sig->sig = NULL; ultimo = ultimo->sig; } COD *ultimoElemento(COD *cabeza) { COD *ptr; ptr = cabeza; while(ptr->sig != NULL) ptr = ptr->sig; return ptr; } COD *crearNodo(char *instruccion,char *op) { COD *x; int tam,tam2; x ->Operando = malloc((tam2 +1)); strcpy(x ->codigo ,instruccion ); x->sig = NULL; return x; } COD *buscarCodop(COD *cabeza,char *codop) { COD *ptr; for(ptr = cabeza;ptr != NULL;ptr = ptr->sig) { if((strcmp(ptr ->codigo ,codop )) == 0) return ptr; } return NULL; } void imprimirLista(COD *cabeza) { COD *ptr; for(ptr = cabeza;ptr != NULL;ptr = ptr->sig) { } }
gracias
|
|
|
|
|
|
|