[devel] xplc-0.3.12-alt1.1: rebuild failed [6]
Dmitry V. Levin
=?iso-8859-1?q?ldv_=CE=C1_altlinux=2Eorg?=
Пн Апр 17 02:47:27 MSD 2006
On Mon, Apr 17, 2006 at 02:37:50AM +0400, Alexey Tourbin wrote:
> On Mon, Apr 17, 2006 at 01:50:27AM +0400, Dmitry V. Levin wrote:
> > > Теперь я переставляю -ldl с первого места на последнее:
> > >
> > > $ g++ -shared -Wl,-hlibxplc-0.3.so -Wl,--version-script=config/exports.map xplc/category.o xplc/catiter.o xplc/catmgr.o xplc/loader.o xplc/moduleloader.o xplc/modulemgr.o xplc/monikers.o xplc/new.o xplc/servmgr.o xplc/statichandler.o libxplc-cxx.so -o libxplc.so -Wl,-z,defs -ldl
> > > $
> > >
> > > Получилось!
> >
> > Лёш, это не глюк, это --as-needed, видимо, ты пропустил эту историю, см.
> > напр. http://wiki.sisyphus.ru/devel/UpStream/AsNeeded
>
> Кажется я догадываюсь, как это реализовано: компилятор (линкер в данном
> случае) сканирует аргументы командной строки слева направо. Он видит
> -ldl и проверяет, использует ли создаваемый ELF shared object какие-либо
> символы из -ldl. Поскольку создаваемый ELF в данном случае вообще
> пустой, компилятор выбрасывает -ldl и идёт дальше. Потом ему попадаются
> объектные файлы с dlopen(), но -ldl уже проехали. В конце
> активизируется -Wl,-z,defs и отваливает.
Именно так оно и происходит, это уже здесь обсуждалось, см.
http://lists.altlinux.org/pipermail/devel/2006-March/029704.html
и в целом архив этого списка за прошлый месяц с темой --as-needed.
> Если считать это такое поведение компилятора консистентным (особенно с
> точки зрения "Rule of Least Surprise"), тогда я наверное великий
> Корнхолио. Поэтому я и спрашиваю: документирован порядок обработки
> аргументов или нет.
Наверняка документирован.
--
ldv
----------- следующая часть -----------
Было удалено вложение не в текстовом формате...
Имя : =?iso-8859-1?q?=CF=D4=D3=D5=D4=D3=D4=D7=D5=C5=D4?=
Тип : application/pgp-signature
Размер : 191 байтов
Описание: =?iso-8859-1?q?=CF=D4=D3=D5=D4=D3=D4=D7=D5=C5=D4?=
Url : <http://lists.altlinux.org/pipermail/devel/attachments/20060417/6ca748c6/attachment-0001.bin>
Подробная информация о списке рассылки Devel