в чем проблема? вы пытаетесь дергнуть функцию которая есть не всегда из функции которая есть всегда
Внутри foo() уже известно, что Self это ConcreteVC, а viewModel реализует Printable. Для такой конфигурации есть дефолтный метод. Я не вижу проблем. Вот ситуация не сильно изменилась, но уже все компилится
Его можно вынести в публичный интерфейс протокола, если нужно. Это ничего не изменит
ну так и было вот тут. в чем проблема то?
а ты все покрываешь протоколами и дженериками, чтоб не нарушать солид? почему решение убрать этот код из экстеншена и засунуть его во вьюконтроллер не подходит?
только стоит упомянуть, что юзая только один такой экстеншен при желании запихнуть в реализацию printingviewcontroller конкретную реализацию printable у тебя ничего не получится, что собственно и не получится и с ":" если ты пойдешь дальше и решишь наследовать протоколы. Если без протоколов и экстеншенов жить тяжело, нужно поддерживать все, что только можно и нужны сториборды, то можно сделать два экстеншена на конформс к протоколу и на сам протокол
А он пойдет дальше наследовать протоколы:)
Ну ты ниже сам себе ответил, почему == тут не к месту. Я, в принципе, уже все сделал тем способом, что обсудили. Одно доп вычисляемое свойство - небольшая цена. Зато теперь код лаконично пошарен по всему проекту как нужно
Обсуждают сегодня