O erro que você está encontrando:
* missing separator (did you mean TAB instead of 8 spaces?). Stop.
Significa que makefile
contém espaços em vez de Tab's. O utilitário make
é notoriamente exigente quanto ao uso de Espaço ao invés de Tab . Portanto, é provável que o makefile
contenha Espaço no início das sub-rotinas de regras no arquivo.
Exemplo
Digamos que eu tenha os seguintes 3% de arquivos.c
:
char *
hello()
{
return "Hello";
}
world.c
char *
world()
{
return "world";
}
main.c :
#include <stdio.h>
/* Prototypes. */
char *hello();
char *world();
int
main(int argc, char *argv[])
{
printf("%s, %s!\n", hello(), world());
return 0;
}
Digamos que eu tenha o seguinte Makefile
:
# The executable 'helloworld' depends on all 3 object files
helloworld: main.o hello.o world.o
cc -o helloworld main.o hello.o world.o # Line starts with TAB!
# Build main.o (only requires main.c to exist)
main.o: main.c
cc -c main.c # Line starts with TAB!
# Build hello.o (only requires hello.c to exist)
hello.o: hello.c
cc -c hello.c # Line starts with TAB!
# Build world.o (only requires world.c to exist)
world.o: world.c
cc -c world.c # Line starts with TAB!
# Remove object files, executables (UNIX/Windows), Emacs backup files,
#+ and core files
clean:
rm -rf *.o helloworld *~ *.core core # Line starts with TAB!
Agora tentamos criar um alvo
Quando eu executo o alvo helloworld
:
$ make helloworld
makefile:3: *** missing separator (did you mean TAB instead of 8 spaces?). Stop.
Parece familiar?
Corrigindo o problema
Você pode consertar isso alterando os Espaços para os caracteres reais do Tab . Eu usei vim
para reparar meu arquivo. Basta abri-lo:
$ vim makefile
E, em seguida, execute este comando dentro de:
:%s/^[ ]\+/^I/
Isto irá substituir todas as linhas que começam com 1 ou mais Espaços com uma Aba real .
Agora, quando eu executar novamente meu helloworld
target:
$ make helloworld
cc -c main.c # Line starts with TAB!
cc -c hello.c # Line starts with TAB!
cc -c world.c # Line starts with TAB!
cc -o helloworld main.o hello.o world.o # Line starts with TAB!