вход функцию, которая имеет сигнатуру либо F(K) -> V, либо F(K) -> Result<V, E>, где V — никогда не Result (соответственно, эти случаи можно отличить однозначно). Обрабатывать мне их нужно по-разному.
Это было бы просто, если бы оба этих случая имплементировали какой-то один трейт, примерно так: https://play.rust-lang.org/?version=stable&mode=debug&edition=2018&gist=9199c15041dc3b99877b2373810c7bfd.
Компилятор, естественно, помечает это как конфликтующие реализации. Один из вариантов решения проблемы — если бы у меня был способ сначала имплементировать трейт для всех V являющихся Result, а потом для всех V не являющихся Result, но я не нашёл способа сделать второе. Это легко возможно, если есть negative trait bounds, но с ними всё, кажется, совсем плохо. Кроме того, помог бы оператор != в where, но он вообще ещё в pre-RFC.
Specialization решает это элементарно, но она не в stable.
Вопрос: есть ли какой-то способ это сделать, который я не вижу?
Тип враппер. Fn(K) -> MyWrapper<V>
Без негативных трейтов такое вроде не сделать
Обсуждают сегодня