Makefile не может понять комментарии - PullRequest
3 голосов
/ 25 августа 2009

Если я добавлю комментарии (# ...) в мой Makefile, make выдаст мне ошибку и выйдет. Если я удаляю комментарии, make-файл работает нормально.

Makefile:1: *** missing separator. Stop.
  • Make-версия: 3.81
  • Linux: Ubuntu 9.04

Makefile:

# Backup Makefile
#
# Create backups from various services and the system itself. This
# script is used to perform single backup tasks or a whole backup
# from the system. For more information about this file and how to
# use it, read the README file in the same directory.

BACKUP_ROOT = /srv/backup
ETC_PATH = /srv/config
SVN_PATH = /srv/svn/
TRAC_PATH = /srv/trac/sysinventory
PR10_PATH = /swsd/project/vmimages/...
PR10_MOUNT_PATH = /tmp/temp_sshfs_pr10

MYSQL_USER = "xxx"
MYSQL_PASSWORD = "xxx"


DATE = `date +%F`

help :
        cat README

init-environment :
        mkdir -p $(BACKUP_ROOT)
        mkdir $(BACKUP_ROOT)/tmp
        mkdir -p $(PR10_MOUNT_PATH)

backup : backup-mysql backup-configuration backup-svn backup-trac

upload-to-pr10 : mount-pr10
        tar cf $(DATE)-backup-blizzard.tar -C $(BACKUP_ROOT) *.-backup.tar.gz
        mv $(BACKUP_ROOT)/*-backup-blizzard.tar $(PR10_MOUNT_PATH)/
        umount $(PR10_MOUNT_PATH)

mount-pr10 :
        su xxx -d "sshfs -o allow_root xxx@xxx:$(PR10_PATH) $(PR10_MOUNT_PATH)"
        fusermount -u $(PR10_MOUNT_PATH)

backup-mysql :
        mysqldump --comments --user=$(MYSQL_USER) --password=$(MYSQL_PASSWORD) --all-databases --result-file=$(BACKUP_ROOT)/tmp/mysql_dump.sql
        tar czf $(BACKUP_ROOT)/$(DATE)-mysql-backup.tar.gz -C 
        $(BACKUP_ROOT)/tmp/mysql_dump.sql

backup-configuration :
        tar czf $(BACKUP_ROOT)/$(DATE)-configuration-backup.tar.gz $(ETC_PATH)/

backup-svn :
        svnadmin dump $(SVN_PATH)/repository > $(BACKUP_ROOT)/tmp/svn_repository.dump
        tar czf $(BACKUP_ROOT)/$(DATE)-subversion-backup.tar.gz -C $(BACKUP_ROOT)/tmp/svn_repository.dump

backup-trac :
        tar czf $(BACKUP_ROOT)/$(DATE)-trac-backup.tar.gz $(TRAC_PATH)/

clean :
        rm -f $(BACKUP_ROOT)/tmp/mysql_dump.sql
        rm -f $(BACKUP_ROOT)/tmp/svn_repository.dump
        rm -f $(BACKUP_ROOT)/*-backup.tar.gz
        rm -f $(BACKUP_ROOT)/*-backup-blizzard.tar

Ответы [ 2 ]

9 голосов
/ 25 августа 2009

Ваш Makefile работает для меня (с пробелами, замененными табуляциями), так что, похоже, у вас есть случайные непечатные символы.

Попробуйте проверить вывод "cat -vet Makefile". Это покажет, где находятся EOL, TAB и другие невидимые символы.

Вы захотите увидеть что-то вроде этого:

# Backup Makefile$
#$
# Create backups from various services and the system itself. This$
# script is used to perform single backup tasks or a whole backup$
# from the system. For more information about this file and how to$
# use it, read the README file in the same directory.$
$
BACKUP_ROOT = /srv/backup$
ETC_PATH = /srv/config$
SVN_PATH = /srv/svn/$
TRAC_PATH = /srv/trac/sysinventory$
PR10_PATH = /swsd/project/vmimages/...$
PR10_MOUNT_PATH = /tmp/temp_sshfs_pr10$
$
MYSQL_USER = "xxx"$
MYSQL_PASSWORD = "xxx"$
$
$
DATE = `date +%F`$
$
help :$
^Icat README$
$
$
init-environment :$
^Imkdir -p $(BACKUP_ROOT)$
^Imkdir $(BACKUP_ROOT)/tmp$
^Imkdir -p $(PR10_MOUNT_PATH)$
$

Убедитесь, что перед всеми командами стоит "^I".

Вы также можете попытаться найти случайные символы, используя что-то вроде:

cat -vet Makefile | grep "\^[^I]" --colour=auto
1 голос
/ 25 августа 2009

Возможно, вы использовали пробелы вместо вкладок для вашего комментария. Пожалуйста, опубликуйте make-файл, чтобы нам не приходилось угадывать.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...