Ошибка компоновщика: “компоновщик ввел файл, неиспользованный потому что, связавшись не сделанный”, неопределенная ссылка на функцию в том файле

Я испытываю затруднения из-за соединения моих файлов.

В основном моя программа состоит из:

  • Основная программа, gen1.
  • gen1 - получает вход, отправляет к str2value для обработки, выходных результатов str2value, вход повреждений в маркеры с помощью "токенизатора" определяет, к какой обработке, чтобы сделать к каждому маркеру, и выдает их str2num, или str2cmd. Это затем возвращает массив результатов.
  • str2num - делает некоторую обработку
  • str2cmd - так же
  • author.py - сценарий Python, который генерирует str2cmd.c и str2cmd.h от заголовка cmdTable.h.

Я вполне уверен, я имею, мой включает право, я проверил пару раз. Я также проверил, что нет никаких условий #ifndef неправильно в заголовках.

Вот мой Make-файл:

#CPP = g++ -lserial
CPP = g++ -DTESTMODE
C= gcc
DEFINES = LURC
CFLAGS = -Wall -fshort-enums -D$(DEFINES)
PROJECTFILES = gen1.cpp str2value.o

STR2VALUEFILES = str2value.cpp str2cmd.o str2num.o tokenizer.o str2value.h

gen1 : $(PROJECTFILES)
        $(CPP) $(CFLAGS) -o gen1 $(PROJECTFILES)



str2value.o : $(STR2VALUEFILES)
#       echo "str2value"
        $(CPP) $(CFLAGS) -c $(STR2VALUEFILES)

str2num.o: str2num.cpp  str2value.h str2num.hpp
         $(C) $(CFLAGS) -c $^


tokenizer.o: tokenizer.cpp tokenizer.hpp
        $(CPP) $(CFLAGS) -c $^

str2cmd.o : authorCMDs.py cmdTable.h
        python authorCMDs.py cmdTable.h str2cmd #this uses the gcc -E cmdTable.h -DLURC
        $(C) $(CFLAGS) -c str2cmd.c str2cmd.h

#TODO: add a thing that checks str2cmd.h/.c has not been modified by hand



.PHONEY: clean
clean:
        rm *.o

.PHONEY: all
all:
        clear
        make clean
        make

Вот вывод, из которого я получаю, делают все:

make clean
make[1]: Entering directory `/home/frames/LURC/gen1/gen1Source'
rm *.o
make[1]: Leaving directory `/home/frames/LURC/gen1/gen1Source'
make
make[1]: Entering directory `/home/frames/LURC/gen1/gen1Source'
python authorCMDs.py cmdTable.h str2cmd #this uses the gcc -E cmdTable.h -DLURC
str2cmd.c and str2cmd.h, generated from cmdTable.h

gcc  -Wall -fshort-enums -DLURC -c str2cmd.c str2cmd.h
gcc  -Wall -fshort-enums -DLURC -c str2num.cpp str2value.h str2num.hpp
g++ -DTESTMODE -Wall -fshort-enums -DLURC -c tokenizer.cpp tokenizer.hpp
g++ -DTESTMODE -Wall -fshort-enums -DLURC -c str2value.cpp str2cmd.o str2num.o tokenizer.o str2value.h
g++: str2cmd.o: linker input file unused because linking not done
g++: str2num.o: linker input file unused because linking not done
g++: tokenizer.o: linker input file unused because linking not done
g++ -DTESTMODE -Wall -fshort-enums -DLURC -o gen1 gen1.cpp str2value.o
str2value.o: In function `getValue(char*)':
str2value.cpp:(.text+0xbd): undefined reference to `str2cmd(char*)'
str2value.cpp:(.text+0x102): undefined reference to `str2num(char*)'
str2value.o: In function `getAllValues(char*)':
str2value.cpp:(.text+0x164): undefined reference to `tokenizer::tokenizer(char*)'
str2value.cpp:(.text+0x177): undefined reference to `tokenizer::getNumTokens(char const*)'
str2value.cpp:(.text+0x1a9): undefined reference to `tokenizer::getNextToken(char const*)'
str2value.cpp:(.text+0x1e9): undefined reference to `tokenizer::getNumTokens(char const*)'
str2value.cpp:(.text+0x201): undefined reference to `tokenizer::~tokenizer()'
str2value.cpp:(.text+0x25b): undefined reference to `tokenizer::~tokenizer()'
collect2: ld returned 1 exit status
make[1]: *** [gen1] Error 1
make[1]: Leaving directory `/home/frames/LURC/gen1/gen1Source'
make: *** [all] Error 2

Какие-либо предложения о том, о чем это? STR2VALUESFILES имеет все объектные файлы, в которых я нуждаюсь, для определения недостающих функций.

38
задан Lyndon White 28 September 2016 в 01:39
поделиться

1 ответ

Я думаю, вы не понимаете, как компилятор собирает все вместе. Когда вы используете флаг -c , т. Е. Связывание не выполняется, входными данными является код C ++, а выходными данными - объектный код. Таким образом, файлы .o не смешиваются с -c , и компилятор предупреждает вас об этом. Символы из объектного файла не перемещаются в другие подобные объектные файлы.

Все объектные файлы должны находиться при последнем вызове компоновщика, что здесь не так, поэтому компоновщик (вызываемый через интерфейс g ++ ) жалуется на пропущенные символы.

Вот небольшой пример (вызов g ++ явно для ясности):

PROG ?= myprog
OBJS = worker.o main.o

all: $(PROG)

.cpp.o:
        g++ -Wall -pedantic -ggdb -O2 -c -o $@ $<

$(PROG): $(OBJS)
        g++ -Wall -pedantic -ggdb -O2 -o $@ $(OBJS)

Также имеется утилита makedepend , которая поставляется с X11 - очень помогает с зависимостями исходного кода. Вы также можете посмотреть параметр -M gcc для построения правил make .

51
ответ дан 27 November 2019 в 03:48
поделиться