руководство пользователя для gnu awk
приложение b. установка gawk
это приложение содержит инструкции для установки gawk на различных платформах, которые поддерживаются разработчиками. первые разработчики поддерживали unix (и одновременно gnu), потом были реализованы и другие переносы. файл `acknowledgment' в поставке gawk перечисляет электронные адреса лиц, осуществивших такие переносы. они также указаны в разделе b.7 [обнаруженные нестыковки и ошибки], стр. 292. b.1 распространение gawkв этом разделе сначала описывается, как получить поставку gawk, как извлечь, и что содержится в различных файлах и подкаталогах. b.1.1 получение поставки gawk
имеются три пути получения программного обеспечения gnu. 2. можно заказать gawk непосредственно в free software foundation. поставки программного обеспечения возможны для unix, ms-dos и vms, на ленте и cd-rom. адрес такой: free software foundation 59 temple place--suite 330 boston, ma 02111-1307 usa phone: +1-617-542-5942 fax (including japan): +1-617-542-2652 e-mail: gnu@gnu.org средства от fsf непосредственно направляются на поддержку foundation и производство свободного программного обеспечения. 3. можно получить gawk , используя анонимное ftp к internet host gnudist.gnu.org, в каталоге `/gnu/gawk'. вот список других сайтов ftp, откуда можно получать программное обеспечение gnu. если сайт числится как "site:directory" , то каталог указывает, где размещается обеспечение gnu. нужно использовать сайты, которые географически близки к вам. азия:cair-archive.kaist.ac.kr:/pub/gnu ftp.cs.titech.ac.jp ftp.nectec.or.th: /pub/mirrors/gnu utsun.s.u-tokyo.ac.jp:/ftpsync/prep австралия:archie.au:/gnu (archie.oz or archie.oz.au for acsnet) африка:ftp.sun.ac.za:/pub/gnu middle east: ftp.technion.ac.il:/pub/unsupported/gnu europe: archive.eu.net ftp.denet.dk ftp.eunet.ch ftp.funet.fi:/pub/gnu ftp.ieunet.ie:pub/gnu ftp.informatik.rwth-aachen.de:/pub/gnu ftp.informatik.tu-muenchen.de ftp.luth.se:/pub/unix/gnu ftp.mcc.ac.uk ftp.stacken.kth.se ftp.sunet.se:/pub/gnu ftp.univ-lyon1.fr:pub/gnu ftp.win.tue.nl:/pub/gnu irisa.irisa.fr:/pub/gnu isy.liu.se nic.switch.ch:/mirror/gnu src.doc.ic.ac.uk:/gnu unix.hensa.ac.uk:/pub/uunet/systems/gnu южная америка:ftp.inf.utfsm.cl:/pub/gnu ftp.unicamp.br:/pub/gnu западная канада:ftp.cs.ubc.ca:/mirror2/gnu usa: col.hp.com:/mirrors/gnu f.ms.uky.edu:/pub3/gnu ftp.cc.gatech.edu:/pub/gnu ftp.cs.columbia.edu:/archives/gnu/prep ftp.digex.net:/pub/gnu ftp.hawaii.edu:/mirrors/gnu ftp.kpc.com:/pub/mirror/gnu usa (продолжение):ftp.uu.net:/systems/gnu gatekeeper.dec.com:/pub/gnu jaguar.utah.edu:/gnustuff labrea.stanford.edu mrcnext.cso.uiuc.edu:/pub/gnu vixen.cso.uiuc.edu:/gnu wuarchive.wustl.edu:/systems/gnu b.1.2 извлечение поставкиgawk поставляется в tar file, запакованном по gnu zip программе, gzip. если вы имеете поставку (например. `gawk-3.0.4.tar.gz'), сначала распакуйте файл по gzip и затем используйте tar для извлечения поставки. вы можете для получения поставки gawk использовать следующий конвейер: # в системе v, добавьте 'o' к флажкам tar gzip -d -c gawk-3.0.4.tar.gz -- tar -xvpf это создаст каталог с именем `gawk-3.0.4' в текущем каталоге. имя файла с поставкой имеет форму `gawk-v.r.n.tar.gz'. v представляет главную версию gawk, r означает текущий выпуск версии v, и n означает уровень корректировки, в том смысле, что часть ошибок в выпуске исправлена. текущий уровень корректировки есть 4, но в следующих поставках вы получите версию, выпуск и корректировку более высоких уровней. (заметим, что уровни выпуска, большие или равные 90, означают "beta," или non-production software; вам не следует пользоваться такими версиями, если только вы не хотите поэкспериментировать.) если работаете не на системе unix, вам необходимы дополнительные действия для получения и извлечения поставки gawk. вы должны проконсультироваться по этому поводу у локального эксперта. b.1.3 содержимое поставки gawkпоставка gawk имеет ряд исходных си-файлов, файлов с документацией, подкаталоги и файлы, относящиеся к процессам конфигурации (см. раздел b.2 [компиляция и установка на платформе unix], стр. 284), и несколько подкаталогов, относящихся к различным, не-unix, операционным системам. в частности, в нее входят: различные `.c', `.y' и `.h' файлы эти файлы фактически содержат исходные коды gawk.
`readme' `readme.d/readme.*' `install' файл с обзором процесса конфигурации и установки. `ports' список систем, на которые gawk перенесен и на которых успешно прошла система тестов. `acknowledgment' список лиц, сделавших существенный вклад в коды или документацию. `changelog' подробный список изменений, сделанных в исходном коде при исправлении ошибок или при усовершенствованиях. `news' список изменений в gawk со времени последнего выпуска или исправления. `copying' общая публичная лицензия gnu. `futures' короткий перечень свойств и/или изменений, предполагаемых в будущих выпусках, с указаниями временных рамок изменений, связанных с их сложностью. `limitations' список факторов, которые ограничивают производительность gawk. большинство их зависит от аппаратуры и программ операционной системы, а не от самой gawk. `posix.std' описание областей, в которых стандарт posix для awk неточен, и то, как gawk решает эти проблемы. `problems' файл, описывающий обнаруженные коллизии в текущем выпуске. `doc/awkforai.txt' короткая статья, поясняющая, почему gawk есть хороший язык для программирования ai (искусственного интеллекта). `doc/readme.card' `doc/ad.block' `doc/awkcard.in' `doc/cardfonts' `doc/colors' `doc/macros' `doc/no.colors' `doc/setter.outline' исходный код troff для пяти-цветной справочной карты. новая версия troff, такая как gnu troff (groff), необходима для получения цветной версии. см. файл `readme.card' с инструкциями, если у вас старая версия troff. `doc/gawk.1' исходный код troff для manual page с описанием gawk. поставляется для удобства пользователей unix. `doc/gawk.texi' исходный файл texinfo для настоящей книги. он должен быть обработан с tex для получения печатного документа, и с makeinfo для получения информационного файла info. `doc/gawk.info' сгенерированный файл info для этой книги. `doc/igawk.1' источник troff для manual page, описывающего программу igawk, представленную в разделе 16.2.9 [простой способ использовать библиотечные функции], стр. 244. `doc/makefile.in' входной файл, используемый в конфигурационном процессе для генерации фактического `makefile' для создания документации. `makefile.in' `acconfig.h' `aclocal.m4' `configh.in' `configure.in' `configure' `custom.h' `missing/*' эти файлы и подкаталог используются при конфигурации gawk для различных систем unix. они описаны детально в разделе b.2 [компиляция и установка gawk в unix], стр. 284. `awklib/extract.awk' `awklib/makefile.in' каталог `awklib' содержит копию `extract.awk' (см. раздел 16.2.7 [извлечение программ из texinfo source files], стр. 238), которая может использоваться для извлечения примеров программ из texinfo source file для настоящей книги, и файла `makefile.in' file, который сценарий конфигурирования использует для генерации `makefile'. как часть процесса построения gawk, библиотечные функции из главы 15 [библиотека функций awk], стр. 169, и программы igawk из раздела 16.2.9 [простой способ использования библиотеки функций], стр. 244, извлечены в готовом виде для использования. они установлены как часть процесса установки. `atari/*' файлы, необходимые для построения gawk на atari st. см. детали в разделе b.5 [установка gawk на atari st], стр. 289. `pc/*' эти файлы необходимы для построения gawk под ms-dos и os/2. см. детали в разделе b.4 [ms-dos и os/2, установка и компиляция], стр. 288. `vms/*' файлы, нужные для построения gawk под vms. см. подробности в разделе b.3 [как компилировать и устанавливать gawk на vms], стр. 285. `test/*' набор тестов для gawk. можно использовать `make check' из верхнего уровня каталога gawk для запуска вашей версии gawk на наборе тестов. если gawk успешно передаст `make check', то вы можете быть уверены в успешности его переноса. b.2 компиляция и установка gawk на unixобычно для компиляции и установки gawk достаточно выдать две команды. однако, если используется необычная система, может оказаться необходимым вам самим сконфигурировать gawk для вашей системы. b.2.1 компиляция gawk для unixпосле извлечения поставки gawk, смените каталог на `gawk-3.0.4'. подобно большинству программ gnu, gawk конфигурируется автоматически для системы unix запуск программы конфигурации. эта программа представляет сценарий оболочки bourne, который был сгенерирован посредством gnu autoconf. (программное обеспечение autoconf полностью описано в autoconf--generating automatic configuration scripts, который доступен в free software foundation.) чтобы конфигурировать gawk, просто запустите sh ./configure. это даст `makefile' и `config.h', подогнанный к вашей системе. файл `config.h' описывает различные факты о вашей системе. вы можете захотеть отредактировать `makefile' для изменения переменной cflags, которая управляет параметрами командной строки, передаваемыми компилятору cи (такими как уровни оптимизации или компиляцией для отладки). вы также можете добавить ваши собственные значения для большинства make-переменных, таких как cc и cflags, в командной строке при исполнении конфигурации:
cc=cc cflags=-g sh ./configure после завершения конфигурации и возможного редактирования `makefile', выдайте команду make, и вскоре после этого вы получите рабочую версию gawk. вот и все! (если эти шаги не удадутся, пошлите пожалуйста сообщение об неполадках; см. раздел b.7 [сообщения о конфликтах и ошибках], стр. 292.) b.2.2 процесс конфигурации(этот раздел представляет интерес только если вы знаете что-то об употреблении языка cи и операционной системе unix.) исходный код для gawk вообще старается придерживаться формальных стандартов там, где это возможно. это значит, что gawk использует библиотечные подпрограммы, соответствующие стандарту ansi c и стандарту posix для интерфейса c операционной системой. при использовании компилятора ansi c, прототипы функций используются для помощи в улучшении проверки во время компиляции. многие системы unix не поддерживают всех стандартов ни ansi ни posix. `пропавшие' подкаталоги в поставке gawk содержат замещающие версии тех подпрограмм, которые наиболее вероятно будут опущены. файл `config.h', который создается программой конфигурации, содержит определения, описывающие свойства конкретной операционной системы, в которой вы пытаетесь скомпилировать gawk. в этом файле описаны три факта: что головные файлы доступны и могут быть правильно включены, что (предположительно) стандартные функции фактически доступны в ваших библиотеках cи, а также другие различные факты о вашем варианте unix. например, может не оказаться элемента st.blksize в статической структуре. в этом случае `have.st.blksize' будет неопределенным. возможно, что ваш cи-компилятор войдет в конфигурацию. это может оказаться так из-за невыхода по ошибке при не обнаружении библиотечной функции. чтобы обойти это, нужно отредактировать файл `custom.h'. используйте `#ifdef', который подходит для вашей системы, и либо #define все константы, которые должна определить конфигурация, но не сделала этого, или #undef все константы, которые конфигурация определила, хотя и не должна была это делать. `custom.h' автоматически включается посредством `config.h'. также возможно, что программа конфигурации, порожденная посредством autoconf, не будет работать на вашей системе в какой-то иной форме. если у вас какие-то неприятности, файл `configure.in' есть ввод для autoconf. вы можете изменить этот файл и сгенерировать новую версию конфигурации, которая будет работать на вашей системе. см. раздел b.7 [сообщения о конфликтах и ошибках], стр. 292, о том как сообщать о неудачах при конфигурировании gawk. тот же самый механизм можно использовать для посылки исправлений в `configure.in' и/или `custom.h'. b.3 как компилировать и устанавливать gawk на vmsв этом разделе описывается компиляция и установка gawk под vms. b.3.1 компиляция gawk на vmsдля компиляции gawk под vms, имеется командная процедура dcl, которая выдаст все необходимые команды cc и link, и также имеется `makefile'для использования с утилитой mms. из исходного каталога возьмите или $ @[.vms]vmsbuild.com или $ mms/description=[.vms]descrip.mms gawk в зависимости от того, какой cи-компилятор используется, следуйте одному из наборов инструкций в таблице:
vax c v3.x
vax c v2.x
gnu c
dec c gawk тестировался под vax/vms 5.5-1 с использованием vax c v3.2, gnu c 1.40 и 2.3. это должно работать без изменений для vms v4.6 и следующих версий. b.3.2 установка gawk на vmsдля установки gawk нужна только "иностранная" команда, которая есть символ dcl и начинается с знака доллара. например: $ gawk :== $disk1:[gnubin]gawk (подставьте фактическое расположение gawk.exe вместо `$disk1:[gnubin]'.) символ должен быть помещен в `login.com' любого пользователя, кто хочет выполнять gawk, так что он будет определен каждый раз, когда пользователь входит в систему. как альтернатива, символ может быть помещен в системную процедуру `sylogin.com', которая будет позволять всем пользователям выполнять gawk. при желании вход в help может быть загружен в vms help-библиотеку: $ library/help sys$help:helplib [.vms]gawk.hlp (можно, если хотите, подставить ориентированную на сайт библиотеку help вместо стандартной библиотеки vms `helplib'.) после загрузки текста help $ help gawk выдаст информацию и о реализации gawk и о программном языке awk. логическое имя `awk.library' может обозначать используемое по умолчанию место для программных файлов awk. при параметре `-f' , если указанное имя файла не содержит информации об устройстве или пути в каталог, gawk будет сначала искать его в текущем каталоге, затем в каталоге, указанном трансляцией `awk.library', если файл не найден. если после поиска в обоих каталогах файл все еще не будет найден, то gawk припишет окончание `.awk' к имени файла и повторит его поиск. если `awk.library' не определена, эта часть поиска окажется бесполезной. b.3.3 выполнение gawk на vmsпоиск в командной строке и соглашения о кавычках значительно отличаются на vms, так что примеры из настоящей книги или из других источников должны быть немного изменены и тогда они будут исполняться правильно. вот несколько тривиальных тестов: $ gawk -- "begin {print \"hello, world!\"}" $ gawk -"w" version ! could also be -"w version" or "-w version" заметим, что верхне-регистровые и смешанные тексты должны быть в кавычках. vms-вариант gawk включает интерфейс в стиле dcl в дополнение к оригинальному интерфейсу в стиле shell (см. подробности в help). один побочный эффект от двойного анализа командной строки есть то, что если имеется только один параметр (как в закавыченной строке в приведенной выше программе), то команда становится двусмысленной. чтобы обойти это, требуется обычно необязательный флажок `--' , чтобы вызвать стиль unix вместо анализа по dcl. если присутствуют какие-нибудь другие параметры типа dash (или кратные параметры, такие как файлы с данными для обработки), то двусмысленности нет и `--' можно опустить. по умолчанию путь поиска программных файлов, указанных параметром `-f', есть "sys$disk:[],awk.library:". логическое имя `awkpath' можно использовать для его изменения. формат `awkpath' есть разделенный запятыми список каталогов. при составлении его значения надо брать в кавычки, чтобы сохранялся единственный перевод, а не много переводный список поиска rms. b.3.4 построение и использование gawk на vms posixигнорируйте приведенные выше инструкции, хотя `vms/gawk.hlp' должен оставаться доступным в библиотеке help. исходное дерево должно быть распаковано в файловую систему container вместо обычной файловой системы vms. убедитесь, что сценарии `configure' и `vms/posix-cc.sh' выполнимы; используйте `chmod +x' на них, если нужно. затем выполните две следующих команды: psx? cc=vms/posix-cc.sh configure psx? make cc=c89 gawkпервая команда построит файлы `config.h' и `makefile' из трафаретов, используя сценарий для подгонки cи-компилятора к требованиям конфигурации. вторая команда компилирует и редактирует gawk, используя непосредственно компилятор си; игнорируйте все предостережения от make о том, что он не может переопределить cc. конфигурация потребует очень много времени для исполнения, но она обеспечивает увеличивающуюся обратную связь в процессе исполнения. это было проверено с vax/vms v6.2, vms posix v2.0 и dec c v5.2. если построена, gawk будет работать подобно всем другим утилитам оболочки. в отличие от обычно перенесенной на vms gawk, здесь не нужны специальные манипуляции в командной строке в окружении vms posix. |
<<< | оглавление | >>> |