user3739406
user3739406

Reputation: 364

Reading in file leads to seg fault

So I've got a text file:

5f6
2f8
2f2

And I'm reading in the values : 5,6,2,8,2,2 where the first two numbers are always rows x columns, then I'm trying to draw rectangles in retrospect to the files values (This works, but after running the program and when it prints them, it seg faults).

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

int main(int argc, char * argv[])
{

    initscr();
    cbreak();
    noecho();

    char str[100];
    static char * row;
    static char * col;
    static int i;
    static int j;
    static int k;
    static int x; 
    static int y;
    int count = 0;

    FILE* file;
    file = fopen(argv[1],"r");

    if(file == NULL)
    {
        mvprintw(0,0,"File returns null pointer");
        exit(1);
    }

    while(!feof(file))
    {
        fgets(str,100,file);
        row = strtok(str,"x");
        col = strtok(NULL," \n");

        x = atol(row);
        y = atol(col);

        for(j=0;j<x;j++)
        {
            for(k=0;k<y;k++)
            {
                mvprintw(k+5,j+5+count,".");
                refresh(); //Space out drawing each rectangle? so they don't overlap
            }
        }
        count+=5;
    }

    fclose(file);
    getch();
    endwin();
    return (0);
}

I'm not really sure on how to proceed here, how would I go about eliminating this seg fault, and possibly spacing out the resultant drawing (The count variable doesn't seem to do it).

Upvotes: 0

Views: 46

Answers (1)

Iharob Al Asimi
Iharob Al Asimi

Reputation: 53016

Your segmentation fault is because you are not checking whether strtok() returned NULL and you still dereference the pointer with atol(), this is an example of how to do it correctly

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

int main(int argc, char * argv[])
{
    char  str[100];
    int   j;
    int   k;
    int   count;
    FILE *file;

    file = fopen(argv[1],"r");
    if (file == NULL)
     {
        mvprintw(0, 0, "File returns null pointer");
        return 1;
     }

    initscr();
    cbreak();
    noecho();

    count = 0;
    while(fgets(str, sizeof(str), file) != NULL)
     {
        char *endptr;
        char *row;
        char *col;
        int   x;
        int   y;

        row = strtok(str, "f");
        if (row == NULL)
         {
            fprintf(stderr, "`%s' does not contain `f'\n", str);
            continue;
         }
        col = strtok(NULL, " \n");
        if (col == NULL)
         {
            fprintf(stderr, "`%s' caused an unexpected error\n", str);
            continue;
         }
        x = strtol(row, &endptr, 10);
        if (*endptr != '\0')
         {
            fprintf(stderr, "Cannot convert `%s' to integer\n", row);
            continue;
         }
        y = strtol(col, &endptr, 10);
        if (*endptr != '\0')
         {
            fprintf(stderr, "Cannot convert `%s' to integer\n", col);
            continue;
         }
        for (j = 0 ; j  < x ; j++)
         {
            for (k = 0 ; k < y ; k++)
             {
                mvprintw(k + 5, j + 5 + count, ".");
                refresh();
             }
         }
        count+=5;
     }

    fclose(file);
    getch();
    endwin();

    return 0;
}

Upvotes: 2

Related Questions