Soname: различия между версиями
Нет описания правки |
|||
Строка 1: | Строка 1: | ||
[[Category:Devel]] | [[Category:Devel]] | ||
{{Stub}} | {{Stub}} | ||
=== Создание библиотеки с soname === | === Создание библиотеки с soname === | ||
Строка 30: | Строка 29: | ||
сохранить работоспособность старых приложений. | сохранить работоспособность старых приложений. | ||
Более подробно сказано здесь: | |||
[http://www.gnu.org/software/libtool/manual.html#Versioning http://www.gnu.org/software/libtool/manual.html#Versioning] | === Ссылки === | ||
* Более подробно сказано здесь: [http://www.gnu.org/software/libtool/manual.html#Versioning http://www.gnu.org/software/libtool/manual.html#Versioning] | |||
* [[API or ABI changing]] |
Версия от 14:42, 31 декабря 2009
Создание библиотеки с soname
Правильная библиотека имеет название типа libfoo.so.x.y.z, а на неё сделаны ссылки libfoo.so.x и libfoo.so. Причём сама библиотека и ссылка libfoo.so.x пакуется в пакет libfoo, а libfoo.so, нужная обычно только для линовки, вместе с заголовками для компиляции пакуется в в libfoo-devel.
Обычно версия библиотеки задаётся в LDFLAGS при линковке библиотеки примерно так: -Wl,-soname,libfoo.so.1
Где libfoo.so.1 - это т.н. soname библиотеки. Сам .so файл библиотеки при этом должен иметь имя типа libfoo.so.1.0.0 или даже libfoo.so.1.0 Обратите внимание, что первая цифра после .so совпадает с цифрой после soname.
Таким образом, библиотека libfoo.so.1.0 имеет soname libfoo.so.1 Также надо создать ссылки libfoo.so.1 -> libfoo.so.1.0 и libfoo.so -> libfoo.so.1.0
Теперь о дальнейшем развитии библиотеки.
Если в новом релизе добавилась в библиотеку какая-то функциональность, не меняя старой (обратная совместимость по API), то надо прибавлять вторую или третью цифру.
А если изменения в новой библиотеке затронули старые API/ABI, то надо менять soname и первую цифру. Это позволит в переходный период сохранить работоспособность старых приложений.
Ссылки
- Более подробно сказано здесь: http://www.gnu.org/software/libtool/manual.html#Versioning
- API or ABI changing