Почему Xcode 7 показывает * .tbd вместо * .dylib?

138

Xcode 7 In Target> BuildPhases> Связать двоичные файлы с библиотеками> нажмите + кнопку

Выбирая рамки для добавления, вы не можете найти * .dylib, вместо этого вы увидите * .tbd.

Что является причиной этого?

** Для людей, которым нужен dylib, следуйте из этого поста

  1. Выберите «Добавить другое»
  2. В окне выбора файла выполните «CMD» + Shift + G (Перейти в папку) и введите / usr / lib /
  3. Из / user / lib вы можете найти файлы * .dylib
Тед
источник
11
Это все часть яблок «секретного план» ...
l'L'л
добавление * .dylib из / usr / lib / Это работает только для меня при запуске моего приложения на симуляторе, оно не работает с устройством.
Кешав Вишвкарма

Ответы:

153

Я искал Google, но пока могу найти только одну цитату из форумов разработчиков Apple :

Для тех, кому интересно, файлы .tbd - это новые «текстовые библиотеки-заглушки», которые предоставляют гораздо более компактную версию библиотек-заглушек для использования в SDK и помогают значительно уменьшить размер загружаемого файла.

Надеюсь, больше документации будет в ближайшее время.

Обновить

В качестве примера приведено все содержимое libsqlite3.tbd . Это просто текстовый файл. Обратите внимание, что имя для установки - libsqlite3.dylib .

---
archs:           [ armv7, armv7s, arm64 ]
platform:        ios
install-name:    /usr/lib/libsqlite3.dylib
current-version: 216.4
compatibility-version: 9.0
exports:         
  - archs:           [ armv7, armv7s, arm64 ]
    symbols:         [ __sqlite3_lockstate, __sqlite3_purgeEligiblePagerCacheMemory, 
                       __sqlite3_system_busy_handler, __sqlite_auto_profile, 
                       __sqlite_auto_profile_syslog, __sqlite_auto_trace, 
                       __sqlite_auto_trace_syslog, _sqlite3OsShmHasMultipleLinks, 
                       _sqlite3OsShmRenamedWhileOpen, _sqlite3OsShmWasTruncated, 
                       _sqlite3OsShmWasUnlinkedWhileOpen, _sqlite3VersionNumber, 
                       _sqlite3VersionString, _sqlite3_aggregate_context, 
                       _sqlite3_aggregate_count, _sqlite3_auto_extension, 
                       _sqlite3_backup_finish, _sqlite3_backup_init, _sqlite3_backup_pagecount, 
                       _sqlite3_backup_remaining, _sqlite3_backup_step, 
                       _sqlite3_bind_blob, _sqlite3_bind_blob64, _sqlite3_bind_double, 
                       _sqlite3_bind_int, _sqlite3_bind_int64, _sqlite3_bind_null, 
                       _sqlite3_bind_parameter_count, _sqlite3_bind_parameter_index, 
                       _sqlite3_bind_parameter_name, _sqlite3_bind_text, 
                       _sqlite3_bind_text16, _sqlite3_bind_text64, _sqlite3_bind_value, 
                       _sqlite3_bind_zeroblob, _sqlite3_blob_bytes, _sqlite3_blob_close, 
                       _sqlite3_blob_open, _sqlite3_blob_read, _sqlite3_blob_reopen, 
                       _sqlite3_blob_write, _sqlite3_busy_handler, _sqlite3_busy_timeout, 
                       _sqlite3_cancel_auto_extension, _sqlite3_changes, 
                       _sqlite3_clear_bindings, _sqlite3_close, _sqlite3_close_v2, 
                       _sqlite3_collation_needed, _sqlite3_collation_needed16, 
                       _sqlite3_column_blob, _sqlite3_column_bytes, _sqlite3_column_bytes16, 
                       _sqlite3_column_count, _sqlite3_column_decltype, 
                       _sqlite3_column_decltype16, _sqlite3_column_double, 
                       _sqlite3_column_int, _sqlite3_column_int64, _sqlite3_column_name, 
                       _sqlite3_column_name16, _sqlite3_column_text, _sqlite3_column_text16, 
                       _sqlite3_column_type, _sqlite3_column_value, _sqlite3_commit_hook, 
                       _sqlite3_compileoption_get, _sqlite3_compileoption_used, 
                       _sqlite3_complete, _sqlite3_complete16, _sqlite3_config, 
                       _sqlite3_context_db_handle, _sqlite3_create_collation, 
                       _sqlite3_create_collation16, _sqlite3_create_collation_v2, 
                       _sqlite3_create_function, _sqlite3_create_function16, 
                       _sqlite3_create_function_v2, _sqlite3_create_module, 
                       _sqlite3_create_module_v2, _sqlite3_data_count, 
                       _sqlite3_data_directory, _sqlite3_db_config, _sqlite3_db_filename, 
                       _sqlite3_db_handle, _sqlite3_db_mutex, _sqlite3_db_readonly, 
                       _sqlite3_db_release_memory, _sqlite3_db_status, 
                       _sqlite3_declare_vtab, _sqlite3_enable_shared_cache, 
                       _sqlite3_errcode, _sqlite3_errmsg, _sqlite3_errmsg16, 
                       _sqlite3_errstr, _sqlite3_exec, _sqlite3_expired, 
                       _sqlite3_extended_errcode, _sqlite3_extended_result_codes, 
                       _sqlite3_file_control, _sqlite3_finalize, _sqlite3_free, 
                       _sqlite3_free_table, _sqlite3_get_autocommit, _sqlite3_get_auxdata, 
                       _sqlite3_get_table, _sqlite3_global_recover, _sqlite3_initialize, 
                       _sqlite3_intarray_bind, _sqlite3_intarray_create, 
                       _sqlite3_interrupt, _sqlite3_last_insert_rowid, 
                       _sqlite3_libversion, _sqlite3_libversion_number, 
                       _sqlite3_limit, _sqlite3_log, _sqlite3_malloc, _sqlite3_malloc64, 
                       _sqlite3_memory_alarm, _sqlite3_memory_highwater, 
                       _sqlite3_memory_used, _sqlite3_mprintf, _sqlite3_msize, 
                       _sqlite3_mutex_alloc, _sqlite3_mutex_enter, _sqlite3_mutex_free, 
                       _sqlite3_mutex_leave, _sqlite3_mutex_try, _sqlite3_next_stmt, 
                       _sqlite3_open, _sqlite3_open16, _sqlite3_open_v2, 
                       _sqlite3_os_end, _sqlite3_os_init, _sqlite3_overload_function, 
                       _sqlite3_prepare, _sqlite3_prepare16, _sqlite3_prepare16_v2, 
                       _sqlite3_prepare_v2, _sqlite3_profile, _sqlite3_progress_handler, 
                       _sqlite3_randomness, _sqlite3_realloc, _sqlite3_realloc64, 
                       _sqlite3_release_memory, _sqlite3_reset, _sqlite3_reset_auto_extension, 
                       _sqlite3_result_blob, _sqlite3_result_blob64, _sqlite3_result_double, 
                       _sqlite3_result_error, _sqlite3_result_error16, 
                       _sqlite3_result_error_code, _sqlite3_result_error_nomem, 
                       _sqlite3_result_error_toobig, _sqlite3_result_int, 
                       _sqlite3_result_int64, _sqlite3_result_null, _sqlite3_result_text, 
                       _sqlite3_result_text16, _sqlite3_result_text16be, 
                       _sqlite3_result_text16le, _sqlite3_result_text64, 
                       _sqlite3_result_value, _sqlite3_result_zeroblob, 
                       _sqlite3_rollback_hook, _sqlite3_rtree_geometry_callback, 
                       _sqlite3_rtree_query_callback, _sqlite3_set_authorizer, 
                       _sqlite3_set_auxdata, _sqlite3_shutdown, _sqlite3_sleep, 
                       _sqlite3_snprintf, _sqlite3_soft_heap_limit, _sqlite3_soft_heap_limit64, 
                       _sqlite3_sourceid, _sqlite3_sql, _sqlite3_status, 
                       _sqlite3_status64, _sqlite3_step, _sqlite3_stmt_busy, 
                       _sqlite3_stmt_readonly, _sqlite3_stmt_status, _sqlite3_strglob, 
                       _sqlite3_stricmp, _sqlite3_strnicmp, _sqlite3_table_column_metadata, 
                       _sqlite3_temp_directory, _sqlite3_test_control, 
                       _sqlite3_thread_cleanup, _sqlite3_threadsafe, _sqlite3_total_changes, 
                       _sqlite3_trace, _sqlite3_transfer_bindings, _sqlite3_update_hook, 
                       _sqlite3_uri_boolean, _sqlite3_uri_int64, _sqlite3_uri_parameter, 
                       _sqlite3_user_data, _sqlite3_value_blob, _sqlite3_value_bytes, 
                       _sqlite3_value_bytes16, _sqlite3_value_double, _sqlite3_value_int, 
                       _sqlite3_value_int64, _sqlite3_value_numeric_type, 
                       _sqlite3_value_text, _sqlite3_value_text16, _sqlite3_value_text16be, 
                       _sqlite3_value_text16le, _sqlite3_value_type, _sqlite3_version, 
                       _sqlite3_vfs_find, _sqlite3_vfs_register, _sqlite3_vfs_unregister, 
                       _sqlite3_vmprintf, _sqlite3_vsnprintf, _sqlite3_vtab_config, 
                       _sqlite3_vtab_on_conflict, _sqlite3_wal_autocheckpoint, 
                       _sqlite3_wal_checkpoint, _sqlite3_wal_checkpoint_v2, 
                       _sqlite3_wal_hook ]
...

Я нашел этот и другие файлы .tbd в

Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/usr/lib/

Вы также можете увидеть файл .tbd, если перейдете на вкладку «Общие» своего проекта XCode, а затем добавите библиотеку в разделе «Связанные фреймворки и библиотеки». Файл .tbd будет скопирован в ваш проект.

Таким образом, похоже, что файл .dylib - это фактическая библиотека двоичного кода, которую использует ваш проект, и он находится в каталоге / usr / lib / на устройстве пользователя. Файл .tbd, с другой стороны, является просто текстовым файлом, который включен в ваш проект и служит ссылкой на требуемый двоичный файл .dylib. Поскольку этот текстовый файл намного меньше, чем двоичная библиотека, он уменьшает размер загружаемого пакета SDK.

На данный момент я только догадываюсь на основании предоставленной информации, поэтому, пожалуйста, поправьте меня, если я ошибаюсь.

Suragch
источник
3
Формат файла TBD на самом деле является просто файлом YAML. Компоновщик просто ищет определенные теги.
C0deH4cker
5
Почему размер приложения уменьшается? Разве это не просто ссылка на настоящий dylib в любом случае во время компиляции / компоновки? Не говорю, что ты не прав, просто пытаешься понять
stonedauwg
3
Это уменьшает размер SDK, который вы загружаете с Xcode, а не размер создаваемого вами приложения.
Joky
Спасибо, @Joky. Я исправил ошибку в своем ответе. Знаете ли вы, в какой момент двоичные файлы добавляются в приложение, если их нет в SDK? И откуда они берутся? Они загружаются по мере необходимости в зависимости от того, какие файлы .tbd используются?
Сурагч
5
Дилибы в SDK присутствуют на устройстве, когда установлена ​​ОС. Таким образом, они были бесполезны в SDK, но позволяли компоновщику выполнять свою работу, когда вы связываете приложение (динамические библиотеки не копируются в приложение и остаются разделенными). Таким образом, изменение в файлах tbd заключается в удалении dylib с сохранением только минимального объема информации, использованного компоновщиком, и обновлении компоновщика для понимания этого нового формата.
Joky
22

.dylib - это скомпилированный двоичный файл, содержащий машинный код. .tbd - это меньший текстовый файл, похожий на карту кроссплатформенного модуля.

Питер Лапису
источник
8
Где ты это узнал? Есть ли у вас какие-либо ссылки, которые я мог бы изучить больше об этом?
Сурагч
2
просто посмотрите на содержание .tds
Питер Лапису
6
Является ли файл .tds таким же, как файл .tdb? Где мне найти такой файл, чтобы посмотреть его содержимое?
Сурагч
7
Это TBD, а не TDS или TDB. Это расшифровывается как текстовое определение dylib.
craig65535
4

.tbd- Text Based dylib stubs. Это своего рода оптимизация, которая означает, что вам не нужно копировать.dylib файл (который существует на цели) в ваш пакет (например, приложение). Этот файл не содержит двоичного кода, который оказывает существенное влияние на размер файла.

Это применимо только для:

  1. Dynamic libraries потому что они связаны во время выполнения
  2. Файл должен иметь соответствующий путь к цели. В результате это лучшее место для standard system libraries.

Для разработки iOS вы можете найти .tbd файлы, которые вы можете использовать здесь

/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/usr/lib

Например libiconv.tbdвыглядит так

введите описание изображения здесь

Этот файл содержит мета-информацию, например:

  • .dylib расположение
  • символы (свойства класса, методы)
  • архитектура
  • Платформа
yoAlex5
источник
1
он не содержит объявлений метода. Только имена классов и имена свободных функций экспортируются из библиотеки.
Антон Кукоба