Ayuda con interprete de mi propio lenguaje de script sencillo

Iniciado por harry_the_blogger, 28 Octubre 2014, 01:12 AM

0 Miembros y 1 Visitante están viendo este tema.

harry_the_blogger

Hola, amigos. Estoy desarrollando un programa que rellena las casillas de un array con una X según la posicion y las ordenes que se indiquen desde un fichero de texto que actúa como script.

En cuanto al programa, mi único problema está en la parte en donde interpreta los scripts.

Voy dividiendo linea por linea usando strtok(...), y hasta ahí todo bien. Copio el contenido del puntero que devuelve strtok hacia un buffer de 16 caracteres para no tener que preocuparme por cosas raras con punteros.

El problema viene cuando intento usar strcmp(...) para ver si la linea actual coincide con la instruccion "fill" o "inc_x". Cuando lo hace, el programa crashea.

¿Podría alguien ayudarme a solucionar mi problema, o darme una mejor idea de como hacerlo? Gracias de antemano

Código (cpp) [Seleccionar]

#include <stdio.h>
#include <stdlib.h>

#define NROWS 5//32
#define NCOLUMNS 5//32
int parse_script(char filename[]){
   unsigned int x = 0;
   unsigned int y = 0;
   char array[NROWS][NCOLUMNS];
   unsigned int file_size;
   unsigned int i = 0;

   FILE *script_file;
   char *script_content;
   char *current_line;
   char current_instruction[16];

   for(x = 0; x < NCOLUMNS; x++){
       for(y = 0; y < NROWS; y++){
           array[x][y] = 'O';
       }
   }

   ///First step, read all file content before preprocess it.
   script_file = fopen(filename, "r");

   ///If all is good, get the size of file
   fseek(script_file, 0, SEEK_END);
   file_size = (unsigned long ) ftell(script_file);
   rewind(script_file);

   ///Resize the array to the size of file
   script_content = (char *) calloc (1, (size_t) file_size);

   ///Read the data from the file and put it in the array
   fread((char *)script_content, file_size, 1, script_file);    ///Last step: Free resources

   ///Second step: Execute instruction by instruction
   ///The program must divide the content in lines using \n
   x = 0;
   y = 0;
   char delimiters[] = "\r\n";
   current_line = strtok((char *) script_content, delimiters);//argumentos: frase, caracter delimitador
   while(current_line != NULL)
   {

      strncpy(current_instruction, current_line, 16);
      printf("%s \n", current_line);

      ///Here, the program must analyze the instruction and take an action
      if(strcmp("fill", current_instruction) == 0){
           array[x][y] = 'X';
       
      }

      if(strcmp("inc_x", current_instruction) == 0){
           x++;
           
      }

      current_line = strtok(NULL, delimiters);
   }

   ///Third step: Show array.
   printf("\nThe content of the array is: \n");
   for(x = 0; x < NCOLUMNS; x++){
       for(y = 0; y < NROWS; y++){
           printf("%c", array[x][y]);
           printf(" ");
       }
       printf("\n");

   }
   printf("End of array. Thanks for use my program\n");

   free(script_content);
   fclose(script_file);
}

int main(int argc, char *argv[])
{
   if(argc < 2)
       return -1;

   

   if(strcmp(argv[1], "-w") == 0){
       parse_script(argv[2]);
       return 0;
   }

   printf("Invalid command!!\n");

   return 0;
}



Fichero de prueba usado (escribir su ruta en la linea de comandos como parametro despues del nombre del ejecutable):

Código (asm) [Seleccionar]

fill
inc_x
Vista mi blog es enriquemesa.blogspot.com

T. Collins

Te crashea o no compila? Porque para usar strcmp, strcpy etc tienes que incluir #include <string.h>, y has utilizado mal "strncpy" porque solo admite dos argumentos.

Cambiando eso he conseguido que me compile, pero no he probado si hace lo que quieres.

rir3760

Cita de: T. Collins en 28 Octubre 2014, 02:08 AMPorque para usar strcmp, strcpy etc tienes que incluir #include <string.h>
Cierto, falta ese encabezado.

Cita de: T. Collins en 28 Octubre 2014, 02:08 AMy has utilizado mal "strncpy" porque solo admite dos argumentos.
La función strncpy es parte de la biblioteca estándar de C.

Un problema con ella es que copia los caracteres del origen al destino, como máximo los indicados por su tercer argumento pero si copia ese máximo no agrega el terminador de cadena '\0', en su lugar se puede utilizar la función sprintf en la forma:
/* strncpy(current_instruction, current_line, 16); */
sprintf(current_instruction, "%.*s", 15, current_line);


Un saludo
C retains the basic philosophy that programmers know what they are doing; it only requires that they state their intentions explicitly.
--
Kernighan & Ritchie, The C programming language

T. Collins

#3
Cita de: rir3760 en 28 Octubre 2014, 02:28 AM
Cierto, falta ese encabezado.
La función strncpy es parte de la biblioteca estándar de C.

Un problema con ella es que copia los caracteres del origen al destino, como máximo los indicados por su tercer argumento pero si copia ese máximo no agrega el terminador de cadena '\0', en su lugar se puede utilizar la función sprintf en la forma:
/* strncpy(current_instruction, current_line, 16); */
sprintf(current_instruction, "%.*s", 15, current_line);


Un saludo

Tienes razón, no conocía strncpy y al cambiar todo a la vez  y ver que compilaba ni probé por qué lo había puesto él así. Gracias por la aclaración.

harry_the_blogger

Gracias por responder. No he podido solucionarlo!! He tratado de hacer lo que me dijo TCollins

Cita de: rir3760 en 28 Octubre 2014, 02:28 AM
Cierto, falta ese encabezado.
La función strncpy es parte de la biblioteca estándar de C.

Un problema con ella es que copia los caracteres del origen al destino, como máximo los indicados por su tercer argumento pero si copia ese máximo no agrega el terminador de cadena '\0', en su lugar se puede utilizar la función sprintf en la forma:
/* strncpy(current_instruction, current_line, 16); */
sprintf(current_instruction, "%.*s", 15, current_line);


Un saludo

Pero aún así falla. ¿Podría alguien decirme alguna otra forma de conseguir comparar la linea actual con una instruccion??? Gracias.
Vista mi blog es enriquemesa.blogspot.com