Makefile说变量是空的但不是

时间:2015-02-27 15:20:48

标签: c++ makefile

我正在尝试使用以下内容创建makefile:

$(CXX)=g++
$(SRC)=../src
$(INCL)=../include
all: cpu ram temperature swap statusshooter
    $(CXX) main.cpp cpu.o ram.o temperature.o swap.o statusshooter.o -o main.o -I$(INCL) -Ofast -Wall -lyaml-cpp -lglog -lpqxx -lpq
cpu:
    $(CXX) -c $(SRC)/CCpu.cpp -o cpu.o -Ofast -Wall 
ram:
    $(CXX) -c $(SRC)/CRam.cpp -o ram.o -Ofast -Wall 
temperature:
    $(CXX) -c $(SRC)/CTemperature.cpp -o temperature.o -Ofast -Wall
swap:
    $(CXX) -c $(SRC)/CSwap.cpp -o swap.o -Ofast -Wall  
statusshooter:
    $(CXX) -c $(SRC)/CStatusShooter.cpp -o statusshooter.o -Ofast -Wall  

使用以下命令执行该makefile: make CXX=g++-4.7会抛出以下错误:

makefile:2: *** empty variable name.  Stop.

如何解决这个问题?

2 个答案:

答案 0 :(得分:7)

语法$(CXX)用于评估make变量,而不是分配给它。你想要

CXX  = g++
SRC  = ../src
INCL = ../include

[...]

答案 1 :(得分:3)

要为变量写入var=...赋值,而不是$var=...,因此,在您的情况下, CXX=g++等。