Предотвращение конфликтов имен
Время выполнения Objective C обеспечивает только единственное плоское, глобальное пространство имен для каждого процесса для всех экспортируемых символов. Это включает все глобальные переменные, нестатические функции, имена классов и категории, объявленные для отдельных классов; протоколы имеют отдельное собственное глобальное пространство имен.
Поскольку предпочтительные плагины области от различных поставщиков должны сосуществовать в том же процессе, необходимо следовать соглашениям избежать коллизий имени символа. Каждый экспортируемый символ в предпочтительном плагине области должен быть снабжен префиксом идентификатор, уникальный для плагина. Это требование не обходится путем разгрузки каждого плагина прежде, чем загрузить следующий. Как только символ Objective C (имена классов, протоколы и категории) загружается, он не может быть разгружен.
Алгоритм уникальности
Ваш предпочтительный плагин области должен получить свой уникальный префикс из его идентификатора пакета с помощью следующего алгоритма:
Запустите с идентификатора пакета (
com.mycompany.preference.sound
)Капитализируйте первую букву каждого разделенного от периода компонента (
Com.Mycompany.Preference.Sound
)Удалите периоды (
ComMycompanyPreferenceSound
)
Обратите внимание на то, что это соглашение зависит от уникальности каждого идентификатора пакета. Для гарантии уникальности идентификатора пакета каждая организация должна снабдить префиксом свои идентификаторы ее упорядоченное реверсом доменное имя ICANN (например, “com.mycompany
”).
Каждая организация должна установить свои собственные процессы и соглашения избежать коллизий идентификатора пакета среди пакетов, разработанных в организации.
Чтобы избежать иметь необходимость использовать полные, снабженные префиксом имена символа в исходном коде, можно создать краткие макросы препроцессора. Они макросы могут быть определены в единственном заголовочном файле, импортирующемся в каждый исходный файл. Например:
#define SoundPref ComMycompanyPreferenceSoundPref |
#define AlertController ComMycompanyPreferenceSoundAlertController |
#define MicrophoneController ComMycompanyPreferenceSoundMicrophoneController |
Очевидно, эти ярлыки только допустимы в исходных файлах Objective C, включающих заголовочный файл. Ссылки на имена классов за пределами таких исходных файлов (например, в списке свойств пакета и в основном файле пера) должны указать полное, настоящее имя.
Категории
Плагины области Preference должны избегать использования категорий Objective C к переопределенным методам классов в общедоступных платформах. Если многократные панели пытаются переопределить тот же метод того же класса, только одно переопределение вступает в силу, приводя к непредсказуемому поведению.