который из некого источника выгребает данные вида "задача"/"параметры" и должен их процессить. Изначально хотелось все разбить на паттерн-матчинг функций вида process/2, распихать по внутренним процессорам и оттуда уже их тянуть. Через import как я понимаю это сделать не получится, ибо будут конфликты, через макросы и apply - это какое-то извращение. Может уже мозги сплавились у меня?
некоторый источник? сторонее АПИ?
А просто написать эту функцию диспетчеризации не подходит? Типа def handle(“foo”, args), do: Foo.process(args) def handle(“bar”, args), do: Bar.process(args) Предельно простой подход, который легко прочитать и переделать если появится необходимость. Или она уже появилась?
В данном случае получается некая "двойная" работа, у нас есть основной модуль, который вытягивает "задачки", и модули, которые делают некие "типы" задач, один модуль может делать и 3 и 4 задачи, просто они группированы по одному типу. В итоге вариант который вы описали предельно прост, да, но при этом придется в двух местах следить, что верхний уровень "пробрасывает" задачи процесору.
А что не так с apply ?
Ну может есть более элегантное решение, решение с apply все-равно придется "мини" роутер писать, просто через макросы по факту
Более элегантного решения нет Твоя задача сводится к "в зависимости от данных, хочу вызывать разный код" В императивных языках ты бы писал огромный вложенный if-else или огромный case Тут у тебя хотя бы есть pattern-matching и apply
Обсуждают сегодня