FullCombatBeard
FullCombatBeard

Reputation: 313

Parsing std input into a linked list using scanf

I want to take an std input separated by 3 semi colons (ex: test1:127:completed) and put it into a node of the linked list, which contains 3 attributes. When I run this it gives me a segfault, am I improperly using scanf in line 96?

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define BUFFERSIZE 1024

//for the linked list
struct node{
    char *fileName;
    int *lineNumber;
    char *filler;
    struct node *next;
};

int main (int argc, char *argv[])
{
    //Create the linked list of the file location and the line number
    char tmpstring[BUFFERSIZE];
    /* This won't change, or we would lose the list in memory */
    struct node *head = NULL;
    //tail
    struct node *tail = NULL;
    /* This will point to each node as it traverses the list */
    struct node *ptr;
    //new node pointer
    struct node *newnode;

    while (fgets(tmpstring, 128, stdin) == tmpstring)
    {
        newnode->next = NULL;
        // First insertion is a special case.
        if (tail == NULL)
            head = tail = newnode;
        else {
            tail->next = newnode;
            tail = newnode;
        }
    } // while

    for (ptr = head; ptr != NULL; ptr = ptr->next)
        //THIS IS THE PROBLEM                    scanf(" %s:%d:%s", ptr -> fileName, ptr -> lineNumber, ptr -> filler);
        printf("%s", ptr->fileName);

    //get how many nodes are in the linked list
    struct node *tmp = head;
    int count = 0;
    while(tmp!=NULL)
    {
        count++;
        tmp = tmp->next;
    }
    //end list creation

    //getGrepOutput();
    printf("%d\n", count);
}

//new code added
ptr -> fileName = (char*) malloc(50);
ptr -> lineNumber = (int*) malloc(50);
ptr -> filler = (char*) malloc(50);

Upvotes: 1

Views: 2524

Answers (1)

ouah
ouah

Reputation: 145899

scanf(" %s:%d:%s", ptr -> fileName, ptr -> lineNumber, ptr -> filler);

You need to allocate memory for ptr -> fileName which is just a dangling pointer in your program. Same for lineNumber and filler members.

Upvotes: 2

Related Questions