Не могу понять ошибку сегмента

Почему я продолжаю получать заданную ошибку, когда пытаюсь передать -H в командной строке как флаг? -h (справка) работает отлично, но -H(заголовок) портится каждый раз.

У меня также есть основная функция, которая вызывает parse_command_line, передавая argc & argc.

bool определяется как bool header = false;

файл char** file = NULL;

и причина у меня есть файл +=1; в коде так, что он компилируется, потому что я использую make-файл, который превращает все предупреждения в ошибки.

#include "parse.h"              /* prototypes for exported functions */
#include "../main/unused.h"
#include <stdlib.h>
#include <getopt.h>
#include <stdio.h>
#include <stdint.h>

int
parse_command_line (int argc, char **argv, bool *header, char **file)
{
int oc = 0;
file += 1;
bool help = false;
struct option long_options[] = 
{
    {"header", no_argument, NULL, 'H'},
    {"help", no_argument, NULL, 'h'},
    {0, 0, 0, 0}
};

while ((oc = getopt_long(argc, argv, "+Hh", long_options, NULL)) != -1)
{
    printf("The value of oc = %d\n", oc);

    switch(oc)
    {
        case 'h':
            help = true;
            break;
        case 'H':
            printf("inside case H");
            *header = true;
            break;
        case '?':
            fprintf(stderr, "Unknown flag = -%c, type -h or --help for help!\n", optopt);
            exit(EXIT_FAILURE);
            break;
        default:
            break;
    }
}

printf("Out of loop");    if (optind+1 != argc)
{
    fprintf(stderr, "Uh oh, invalid input! Try again with -h or --help for help!\n");
    exit(EXIT_FAILURE);
}

if (help)
{
    printf("\nHaving some trouble? Let me show you the ropes!\n\n");
    printf("Format: ydi <option(s)> mini-elf-file\n\n");
    printf("Here's your options:\n");
    printf("-h --help       Display usage\n");
    printf("-H --header     Show the Mini-Elf header\n");
    exit(1);
}

if (header)
{
    printf("Inside HEader");
    FILE *file;
    uint16_t nums[6];
    file = fopen(argv[optind], "r");

    #define STRUCT_ITEMS 7
    fread(nums, 16, 6, file);
    int cur_print;
    for (cur_print = 0; cur_print < STRUCT_ITEMS; cur_print++)
    {
        printf("%d ", nums[cur_print]);
    }
}
return 0;
} 

Мой файл parse.h выглядит следующим образом:

#ifndef __PARSE_COMMAND_LINE__
#define __PARSE_COMMAND_LINE__
#include <stdbool.h>

int parse_command_line (int argc, char **argv, bool *header, char **file);

#endif

Существуют и другие файлы, такие как elf.h и elf.c, которые я не реализовал и на данный момент не вызываю вообще, поэтому я полагаю, что они не будут проблемой и не нужно публиковать небольшие файлы. 2 строчных файла. Моя основная функция заключается в следующем:

#include <stdio.h>              /* standard I/O */
#include <stdlib.h>
#include "unused.h"             /* UNUSED macro */
#include "../cmdline/parse.h"   /* command line parser */
#include "../y86/elf.h"         /* Mini-ELF format */

int
main (int argc UNUSED, char **argv UNUSED)
{
  printf ("Congratulations, you have compiled your source code!\n");
  bool header = false;
  char **file = NULL;
  parse_command_line (argc, argv, &header, file);
  return 0;
}

И файл unused.h (потому что компилятор сделает предупреждение о неиспользуемых переменных вместо предупреждения) выглядит следующим образом:

#ifndef __UNUSED__
#define __UNUSED__
#define UNUSED __attribute__ ((unused))
#endif

1 ответ

Код не проверяет возвращаемое значение fopen, которое будет NULL в случае ошибки. Разыменование NULL в вызове fread вызывает ошибку по умолчанию.

Другие вопросы по тегам