Open st7105 opened 3 years ago
Да, интересно получается. Можно попробовать находить общий префикс у файлов и не добавлять его, если он уже есть.
А что это за известная проблема, на неё есть задача в каком-нибудь трекере?
Хранить путь загрузки в TorrentData, а не использовать параметр из api.
Боюсь, что тут могут возникнуть проблемы с обратной совместимостью. Сейчас источником данных является торрент-клиент, а торрт всего лишь помогает ему. То есть, пользователь может прямо в клиенте задать нужный путь и торрт будет это учитывать.
В предлагаемом решении мы пытаемся обойти странность поведения одного из клиентов, размазав ответственность ещё и на торрт. Утрируя: пытаемся превратить торрт в ещё один интерфейс для клиента.
Предложите решение, с меня реализация.
Пока только такие варианты, один исследовательский, два радикальных:
sub_path
(считаем, что если торрент был когда-то добавлен, то директория уже создана).
После нескольких фиксов возникла концептуальная проблема. А именно, в api utorrent в методе добавления торрента используется относительный путь (в принципе неподдерживается абсолютный путь, только относительный), а в возвращаемом списке всех торрентов уже абсолютный (известная проблема в utorrent).
В функции
update_torrents
происходит передача абсолютного пути при добавлении нового торрента:Это приводит к постоянному дублированию:
/home/download/home/download/home/...
Варианты решения:
TorrentData
, а не использовать параметр из api.