Совместное использование классов между iOS и watchOS

В настоящее время у меня есть приложение для iOS. В зависимости от местоположения пользователя он использует тот или иной класс. Как я это делаю для своего приложения для iOS? У меня protocol:

protocol ParseProtocol {

    var urlToParse: URL? { get }
    var parsedXMLData: [MyData] { get }

    func parseFeed()

    init()
}

А затем на ViewController, когда я определяю город, в котором находится пользователь, вызывается функция parser и генерирует класс в зависимости от String, в котором находится пользователь:

func parser(for city: String) -> ParseProtocol? {

        let bundlePath     = Bundle.main.bundlePath
        let bundleFullName = bundlePath.components(separatedBy: "/").last
        let bundleName     = bundleFullName?.components(separatedBy: ".").first
        let combinedName   = bundleName! + "." + cityIn + "Parser"
        let Class          = NSClassFromString(combinedName) as? ParseProtocol.Type

        print("CITY: \(city)  \(combinedName)")

        return Class?.init()
    }

Сейчас я разрабатываю усложнение для watchOS и хотел бы использовать те же классы, что и раньше, для watchOS и iOS, поскольку они одинаковы. Моя проблема возникает здесь, так как это разные комплекты, которые отличаются от combinedName:

  • watchOS combinedName - это MyApp-watchOS Extension.LondonParser
  • iOS combinedName - это MyApp.LondonParser

Я застрял здесь и не знаю, как этого добиться.

как насчет добавления LondonParser и других подобных классов к цели расширения WatchKit? Один класс может быть в нескольких целях

staticVoidMan 09.03.2018 19:42
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
1
1
192
1

Ответы 1

Если вам нужно использовать NSClassFromString на основе текущего пакета, вы можете сделать это так:

let targetName = Bundle.main.infoDictionary![kCFBundleNameKey as String] as! String
let Class = NSClassFromString("\(targetName).\(className)") as? ParseProtocol.Type

Конечно, имя цели будет отличаться для каждой цели, но это не проблема, если вы добавили желаемый класс в цель. Из целевого объекта расширения вы не можете получить доступ к классам, добавленным только к целевому приложению хоста.

Для пояснения: ваше приложение состоит из одного или нескольких продуктов (целей). У каждой цели есть три имени:

  1. Отображаемое имя: имя, отображаемое под значком приложения на главном экране.
  2. Идентификатор пакета: (глобальный) уникальный идентификатор цели.
  3. Имя цели: имя, используемое для идентификации цели во время компиляции.

Третье имя используется для создания классов с помощью NSClassFromString. Также обратите внимание, что имя цели НЕ ДОЛЖНО содержать пробелов, как в "MyApp-watchOS Extension". Тогда компилятор не может найти класс.

Мой вопрос в том, можно ли получить доступ к классу, который есть в проекте. В настоящее время он добавлен к обеим целям (расширение iOS + watchOS), но я не могу этого сделать. Я бы хотел, чтобы классы не повторялись для моего приложения iOS, а затем и для моего приложения watchOS.

javierdemartin 09.03.2018 20:54

В чем проблема с добавлением одного и того же класса к нескольким целям? Во всяком случае, «классов проекта» нет. Проект - всего лишь контейнер для целей. Возможно, вы сможете импортировать целевое приложение хоста в расширение для часов с помощью import MyApp. Но я почти уверен, что это вызовет больше проблем, чем решит.

sundance 09.03.2018 21:40

Другие вопросы по теме