如何在C中使用Make文件创建可执行文件

时间:2018-08-27 10:50:19

标签: makefile

我正在使用Makefile创建一个可执行文件,因此当我运行该可执行文件时,我只写了./ft_ls,但遇到此错误,下面是我的Makefile的代码。

  

“ ar:ft_ls:文件类型或格式不正确”

但是当我创建一个库并添加我的main.c文件和gcc时,它将运行file.so。如何从下面的Makefile创建可执行文件?

14 NAME = ft_ls
 15
 16 SRCS =  main.c\
 17         ft_perm.c\
 18         ft_group.c\
 19         count.c\
 20         ls_l.c\
 21         ls.c\
 22         ls_a.c\
 23         ls_rr.c\
 24         ls_r.c\
 25         ls_r_m.c\
 26         multi_args_l.c\
 27         ft_anigma.c\
 28         ls_g.c\
 29         ft_printf/ft_printf.c\
 30         ft_printf/precision.c ft_printf/mask_unicode.c ft_printf/width.c ft_printf/null_char.c ft_printf/wstr_precision.c\
 31         ft_printf/flags/flags.c ft_printf/flags/type_flags.c ft_printf/flags/checking_for.c ft_printf/n_func.c\
 32         ft_printf/conv/applying.c ft_printf/conv/conversion.c ft_printf/conv/zero_conv.c\
 33         ft_printf/alloc/ft_alloc.c ft_printf/alloc/to_str.c ft_printf/libft/ft_atoi.c ft_printf/alloc/ft_del_str.c\
 34         ft_printf/libft/ft_strncpy.c ft_printf/libft/ft_strcmp.c libft/ft_strncmp.c ft_printf/libft/ft_putstr.c ft_printf/color_part_two.c \
 35         ft_printf/libft/ft_strcpy.c ft_printf/libft/ft_strlen.c ft_printf/libft/ft_strdup.c \
 36         ft_printf/test/h_test.c ft_printf/test/jz_test.c ft_printf/test/l_test.c ft_printf/test/basic_test.c \
 37         ft_printf/itoa/ft_itoa_ll.c ft_printf/itoa/reverse.c ft_printf/libft/ft_strwdup.c ft_printf/color.c \
 38
 39 OB =    main.o \
 40         ft_perm.o\
 41         ft_group.o\
 42         count.o\
 43         ls_l.o\
 44         ls.o\
 45         ls_a.o\
 46         ls_rr.o\
 47         ls_r.o\
 48         ls_r_m.o\
 49         multi_args_l.o\
 50         ft_anigma.o\
 51         ls_g.o\
 52         ft_printf.o\
 53         type_flags.o applying.o basic_test.o checking_for.o conversion.o \
 54         flags.o ft_alloc.o ft_atoi.o mask_unicode.o n_func.o\
 55         ft_printf.o ft_strcmp.o ft_strcpy.o to_str.o wstr_precision.o\
 56         ft_strdup.o ft_strlen.o ft_strncpy.o h_test.o jz_test.o l_test.o precision.o \
 57         reverse.o width.o ft_itoa_ll.o null_char.o zero_conv.o ft_strwdup.o color.o \
 58         ft_putstr.o color_part_two.o ft_del_str.o ft_strncmp.o\
 59
 60 FLAGS = -Werror -Wall -Wextra
 61
 62 $(NAME):
 63     gcc  $(FLAGS) $(SRCS)  -o $(NAME)
 64
 65 all:    $(NAME)
 66
 67 clean:
 68     rm -f $(OB)
 69
 70 fclean: clean
 71     rm -f $(NAME)
 72
 73 re:     fclean all

1 个答案:

答案 0 :(得分:1)

 66 $(NAME):
 67     gcc -c $(FLAGS) -o ft_ls $(MAIN) $(OBJ)
 68     ar rc $(NAME) $(OB)

在上面的代码片段中,您有一个没有任何依赖关系的目标$(NAME)[= ft_ls]和两个命令,它们正在尝试创建一个可执行文件和一个库。另外,您定义了一个名为OB的变量,但引用了一个名为OBJ的变量。我怀疑您应该只创建一个可执行文件,像这样

$(NAME): $(MAIN) $(OB)
    gcc $(FLAGS) -o ft_ls $(MAIN) $(OB)

如果您使用的是GNU make,则可以使用$ @作为目标,使用$ ^作为依赖项(这使得Makefile易于维护),

$(NAME): $(MAIN) $(OB)
    gcc $(FLAGS) -o $@ $^

目前尚不清楚目标文件是如何编译的。如果您只有一堆.c文件并且需要一些.o文件,那么可能是使用了suffix rule(请参阅here),因此您将需要类似

.c.o:
        $(CC) -c $(FLAGS) -o $@ $<