Также в ней присутствует один выходной файл — hello.exe или hello, в зависимости от операционной системы. Однако в этом случае способ передачи имени файла компилятору зависит от инструментария. Большая часть инструментов для указания выходного файла использует -о <file>, но Visual C++ и Intel для Windows используют -Fe<file>, a Borland использует -e<file>. Заметьте, что указывать расширение исполняемого файла не обязательно.
Единственная информация в табл. 1.7, относящаяся к третьей категории — путям поиска файлов, — имеется в строке для Digital Mars. Так как библиотека STLPort не является встроенной стандартной библиотекой Digital Mars, компилятору с помощью опции -I требуется сообщить, где искать заголовочные файлы STLPort. Заголовочные файлы STLPort расположены в поддиректории /stlport/stlport установки Digital Mars. В табл. 1.7 я указал эту директорию с помощью опции <dmcroot>/stlport/stlport. За дополнительной информацией об опции -I обратитесь к рецепту 1.5.
Большая часть опций командной строки в табл. 1.7 относится к четвертой категории: общей конфигурационной информации. Эти опции не относятся к какому-либо отдельному файлу, а включают или отключают определенные функции компилятора.
• Опции -nologo (Visual C++ и Intel для Windows) и -q (Borland) говорят компилятору не печатать в консоли свои название и версию. Это делает вывод компилятора более простым для чтения.
• Опции -EHsc (Visual C++ и Intel для Windows) и -Ае (Digital Mars) говорят компилятору включить обработку исключений С++.
• Опции -GR (Visual C++ и Intel для Windows) и -Ar (Digital Mars) говорят компилятору включить информацию времени исполнения (RTTI).
• Опции -Zc:wchar_t (Visual C++ и Intel для Windows) и -wchar_t (Metrowerks) говорят компилятору распознавать wchar_t как встроенный тип.
• Опция -Zc:forScope (Visual C++ и Intel для Windows) говорит компилятору задействовать современные правила для областей видимости циклов for.
• Опция -cwd include (Metrowerks) говорит компилятору начинать поиск включенного заголовка с директории исходного файла, содержащего директиву include. Это поведение по умолчанию для всех инструментов, кроме Metrowerks.
Далее давайте рассмотрим второе решение нашей проблемы. Вместо того чтобы компилировать и компоновать с помощью одной команды, второй шаг можно разбить на две части.
2a. Введите команду, говорящую компилятору скомпилировать программу в объектный файл без компоновки.
2b. Введите команду, говорящую компоновщику создать исполняемый файл из объектных файлов, созданных на шаге 2a.
В нашем простом случае нет причин для раздельной компиляции и компоновки. Однако раздельная компиляция и компоновка требуются достаточно часто, так что важно, чтобы вы знали, как это делается. Например, при создании статической библиотеки вы должны скомпилировать файлы без компоновки, а затем передать готовые объектные файлы в архиватор.
Команды для компиляции и компоновки в два этапа представлены в табл. 1.8 и 1.9. В некоторых случаях я устанавливаю для объектного файла расширение o[bj], указывающее, что одна и та же командная строка годится и для Windows, и для Unix, за исключением расширения объектного файла.
Табл. 1.8. Команды для компиляции hello.cpp без компоновки
Инструментарий Командная строка GCC
g++ --c -o hello.o hello.cpp Visual C++
cl -с -nologo -EHsc -GR -Zc:forScope -Zc:wchar_t -Fohello hello.cpp Intel (Windows)
icl -с -nologo -EHsc -GR -Zc:forScope Zc:wchar_t -Fohello hello.cpp Intel (Linux)
icpc -с о hello.о hello.cpp Metrowerks
mwcc -c -wchar_t on -cwd include -o hello.o[bj] hello.cpp Comeau
como -с -o hello.o[bj] hello.cpp Borland
bcc32 -c -q -o hello.obj hello.cpp Digital Mars
dmc -c -Ae -Ar -l<dmcroot>/stlport/stlport -o hello.obj hello.cppТабл. 1.9. Команды для компоновки hello.exe или hello
Инструментарий Командная строка GCC
g++ -о hello hello.o Visual C++
link -nologo -out:hello.exe hello.obj Intel (Windows)
xilink -nologo -out:hello.exe hello.obj Intel (Linux)
icpc -o hello hello.o Metrowerks
mwld -o hello hello.o[bj] Comeau
como --no_prelink_verbose -о hello hello.o[bj] Borland
bcc32 -q -ehello hello.cpp Digital Mars
link -noi hello.obj, hello.exe,NUL,user32.lib kernel32.libНапример, чтобы собрать исполняемый файл hello с помощью инструментария GCC, перейдите в директорию, содержащую hello.cpp, и введите следующие команды.
$ g++ -с -о hello.о hello.cpp
$ g++ -о hello hello.о
Теперь программу можно запустить вот так.
$ ./hello Hello, World!
Таблица 1.9 почти идентична табл. 1.6. Имеется только два различия. Во-первых, используется опция -с, говорящая компилятору скомпилировать без компоновки. Во-вторых, указанный выходной файл является объектным файлом hello.obj или hello.o, а не исполняемым. Большая часть компиляторов для указания выходного файла использует опцию -о <file>, но Visual C++ и Intel для Windows используют опцию -Fo<file>. Кроме того, все компиляторы, за исключением Visual C++ и Intel для Windows, требуют, чтобы было указано расширение объектного файла.
Теперь все командные строки в табл. 1.9 должны быть просты и понятны, так что я сделаю только два замечания.
• Компоновщик Digital Mars имеет необычный синтаксис, содержащий шесть полей, разделенных запятыми, которые используются для указания различных типов входных файлов. Сейчас вам требуется знать только то, что первое поле предназначено для объектных файлов, а второе — для выходного файла. Опция -noi говорит компоновщику выполнить компоновку с учетом регистра, что необходимо для программ на C++.
• Компоновщик Borland ilink32.exe использует синтаксис, похожий на Digital Mars. Чтобы упростить командную строку, я использовал для выполнения этапа компоновки компилятор bcc32.exe. Внутри себя bcc32.exe вызывает ilink32.exe.
Смотри также
Рецепты 1.7 и 1.15.
1.3. Сборка статической библиотеки из командной строки
Проблема
Вы хотите использовать свои инструменты командной строки для сборки статической библиотеки из набора исходных файлов С++, таких как перечисленные в примере 1.1.
Решение
Во-первых, используйте компилятор для компиляции исходных файлов в объектные файлы. Если ваши исходные файлы включают заголовочные файлы, расположенные в других директориях, то для указания компилятору, где искать эти заголовочные файлы, вам может потребоваться использовать опцию -I. За дополнительной информацией обратитесь к рецепту 1.5. Во-вторых, для объединения объектных файлов в статическую библиотеку используйте архиватор.
Чтобы скомпилировать каждый из трех исходных файлов из примера 1.1, используйте командные строки из табл. 1.8, изменив соответственно имена входного и выходного файлов. Чтобы объединить результирующие объектные файлы в статическую библиотеку, используйте команды, приведенные в табл. 1.10.
Табл. 1.10. Команды для создания архива libjohnpaul.lib или libjohnpaul.а
Инструментарий Командная строка GCC (Unix) Intel (Linux) Comeau (Unix)
ar ru libjohnpaul.a john.c paul.о johnpaul.o ranlib libjohnpaul.a GCC (Windows)
ar ru libjohnpaul.a john.o paul.o johnpaul.о Visual C++
lib -nologo -out:libjohnpaul.lib john.obj paul.obj johnpaul.obj Comeau (with Visual С++) Intel (Windows)
xilib -nologo/out:libjohnpaul.lib john.obj paul.obj johnpaul.obj Metrowerks (Windows)
mwld -library -o libjohnpaul.lib john.obj paul.obj johnpaul.obj Metrowerks (Mac OS X)
mwld -library -o libjohnpaul.a john.о paul.o johnpaul.о Borland
tlib libjohnpaul lib /u /a /C +john +paul +johnpaul Digital Mars
lib -c -n libjohnpaul.lib john.obj paul.obj johnpaul.objНапример, чтобы скомпилировать john.cpp, paul.cpp и johnpaul.cpp в объектные файлы с помощью GCC, перейдите в директорию johnpaul и введите следующие команды, создающие объектные файлы john.о, paul.о и johnpaul.о: