реклама на сайте
подробности

 
 
> Make
Злодей
сообщение Sep 15 2009, 07:46
Сообщение #1


Частый гость
**

Группа: Участник
Сообщений: 149
Регистрация: 29-04-08
Из: Петербург
Пользователь №: 37 142



Makefile
Код
#    Здравствуйте! Хочу что бы файл $(FILENAME) создавался по следующему закону:
#  - При вызове цели create только если файл не существует.
#  - При вызове цели force_create даже если файл уже существует.

FILENAME = test.txt

create: $(FILENAME)

$(FILENAME): force_create

force_create:
    echo "file contents..." > $(FILENAME)

.PHONY : create force_create

# В этом маке я неправильно выразил своё желание.
# При вызове create всегда выполняется force_create,
# а я имел в виду выполнять её только если нет файла.
# Спасибо.


Сообщение отредактировал Злодей - Sep 15 2009, 07:47
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
boldgambler
сообщение Dec 9 2009, 12:06
Сообщение #2





Группа: Участник
Сообщений: 6
Регистрация: 26-04-09
Пользователь №: 48 288



решил не создавать отдельную тему, тут спрошу

имеем makefile для сборки под avr
Код
...
CFLAGS          = -mmcu=${CPU} -g -O0 -Wall
...
SOURCE            = $(wildcard $(addsuffix /*.c, $(SOURCE_DIRS)))
OBJECTS_DIRS  = $(notdir $(SOURCE))
OBJECTS           = $(OBJECTS_DIRS:.c=.o)
...
${NAME}.elf: ${OBJECTS}
    ${CC} -mmcu=${CPU} -o $@ ${OBJECTS} ${LDFLAGS}
...


так вот, ответом на это служит
Цитата
avr-gcc -mmcu=atmega32 -g -O0 -Wall -c -o main.o ../src/main.c
avr-gcc -mmcu=atmega32 -o test.elf main.o


вопрос: откуда берется первая строка?
и каким образом в нее попадает CFLAGS (если его менять, то это видно) ?
ну и "-c -o" тоже нигде в makefile не встречается.
Go to the top of the page
 
+Quote Post
mdmitry
сообщение Dec 9 2009, 13:59
Сообщение #3


Начинающий профессионал
*****

Группа: Свой
Сообщений: 1 215
Регистрация: 25-10-06
Из: СПб
Пользователь №: 21 648



Цитата(boldgambler @ Dec 9 2009, 15:06) *
решил не создавать отдельную тему, тут спрошу

имеем makefile для сборки под avr
Код
...
CFLAGS          = -mmcu=${CPU} -g -O0 -Wall
...
SOURCE            = $(wildcard $(addsuffix /*.c, $(SOURCE_DIRS)))
OBJECTS_DIRS  = $(notdir $(SOURCE))
OBJECTS           = $(OBJECTS_DIRS:.c=.o)
...
${NAME}.elf: ${OBJECTS}
    ${CC} -mmcu=${CPU} -o $@ ${OBJECTS} ${LDFLAGS}
...



вопрос: откуда берется первая строка?
и каким образом в нее попадает CFLAGS (если его менять, то это видно) ?
ну и "-c -o" тоже нигде в makefile не встречается.

Как попросили вызвать avr-gcc, так make и сделал. Вы привели не весь makefile, в нем обычно определяется тим контроллера, его частота и флаги запуска gcc. Имеет смысл ознакомится с документацией на make, есть на русском языке перевод.
У Вас определены файлы для сборки (SOURCE), ключи компилятора (CFLAGS) и другие макро для make. Есть правило для сборки цели (${NAME}.elf: ${OBJECTS}). Все это подробно описано в документации.
Поищите по форуму, вопросы о makefile встречаются нередко.


--------------------
Наука изощряет ум; ученье вострит память. Козьма Прутков
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 23rd July 2025 - 12:22
Рейтинг@Mail.ru


Страница сгенерированна за 0.01386 секунд с 7
ELECTRONIX ©2004-2016