Ошибки Makefile - "*** отсутствует разделитель" и "*** рецепт начинается до первой цели"

Я пытаюсь построить userland для os161. Когда я набираю make в командной строке, я получаю следующую ошибку:

Makefile 24: *** отсутствует разделитель (вы имели в виду TAB вместо 8 пробелов?). Стоп.

Я проверил Makefile в строке 24 и попытался добавить TAB в начало строки, но это не сработало, так как я получил еще одну ошибку:

Makefile 24: *** рецепт начинается до первой цели. Стоп.

Вот полный make-файл для справки:

#
# Toplevel makefile for OS/161.
#
#
# Main rules:
#    all (default):  depend and compile system; install into staging area
#    rebuild:        likewise, but start with a clean slate.
#    fullrebuild:    likewise, but start with a very clean slate.
#
# What all does, in order:
#    tools:          depend and compile the tools used in build.
#    includes:       install header files.
#    build:          depend and compile the system.
#
# Other targets:
#    depend:         just update make dependency information.
#    tags:           generate/regenerate "tags" files.
#    install:        install into $(OSTREE).
#    clean:          remove generated files.
#    distclean:      remove all generated files.
#

TOP=.
.include "$(TOP)/mk/os161.config.mk"

all:;  # make this first

MKDIRS=$(OSTREE)

.include "$(TOP)/mk/os161.mkdirs.mk"

all: tools .WAIT includes .WAIT build

rebuild:
    $(MAKE) clean
    $(MAKE) all

fullrebuild:
    $(MAKE) distclean
    $(MAKE) all

# currently no tools required, hence no tools/ dir or work to do
tools:
    @true

build:
    (cd userland && $(MAKE) build)
    (cd man && $(MAKE) install-staging)
    (cd testscripts && $(MAKE) build)

includes tags depend:
    (cd kern && $(MAKE) $@)
    (cd userland && $(MAKE) $@)

clean:
    (cd kern && $(MAKE) $@)
    (cd userland && $(MAKE) $@)
    rm -rf $(INSTALLTOP)

distclean: clean
    rm -rf $(WORKDIR)

install: $(OSTREE)
    (cd $(INSTALLTOP) && tar -cf - .) | (cd $(OSTREE) && tar -xvf -)


.PHONY: all rebuild fullrebuild tools build includes tags depend
.PHONY: clean distclean

# old BSD name, same as distclean
cleandir: distclean
.PHONY: cleandir

Строка вопроса (24):

.include "$(TOP)/mk/os161.config.mk"

Любая помощь будет оценена. Я проверил подобные ошибки makefile, но я не могу найти, что не так.

2 ответа

Решение

Внимательно прочитайте документацию GNU make, особенно о директиве include.

Ваш

.include "$(TOP)/mk/os161.config.mk"

(неправильно) запрашивает включение файла, путь которого начинается с двойной кавычки (а у вас, вероятно, нет ни одного, поэтому include не удается...)

Ты хочешь

-include $(TOP)/mk/os161.config.mk

и эта строка начинается со знака минус или тире, а не с точки.

Обязательно используйте редактор, сохраняющий символы табуляции без изменений.

Кстати, FreeBSD make принимает .include директивы с начальной точкой и хочет путь в двойных кавычках.

Разделитель является <TAB>, Пожалуйста, не используйте пробелы в начале строки в Makefile, Makefile.in...

Snippet:

21  #
22  
23  
24  TOP=.
25  
26  all:;  # make this first
27  
28  MKDIRS=$(OSTREE)
29  
30  <TAB>include "$(TOP)/mk/os161.mkdirs.mk"
31  
32  all: tools .WAIT includes .WAIT build
33  
34  rebuild:
35  <TAB>$(MAKE) clean
36  <TAB>$(MAKE) all
37  
38  <TAB>fullrebuild:
39  <TAB>$(MAKE) distclean
40  <TAB>$(MAKE) all
Другие вопросы по тегам