Double Commander

2.7. Внешние архиваторы

Содержание

1. Работа со сжатыми файлами
2. Средства для работы со сжатыми файлами
3. Работа с плагинами
4. Работа с внешними архиваторами
5. Настройка интеграции внешних архиваторов
5.1. Добавление нового внешнего архиватора
5.2. Переменные для команд внешнего архиватора
5.3. Модификаторы переменных
5.4. Настройка действия "Список"
5.5. Получение списка содержимого
5.5.1. Разграничение области для анализа
5.5.2. Разбор списка содержимого
5.5.3. Стандартный синтаксис разбора вывода
5.5.4. Пример со стандартным синтаксисом
5.5.5. Расширенный синтаксис разбора вывода
5.5.6. Пример с расширенным синтаксисом
5.6. Настройка действия "Извлечь"
5.7. Настройка действия "Добавить"
5.8. Настройка действия "Удалить"
5.9. Настройка действия "Проверить"
5.10. Настройка действия "Распаковать не учитывая пути"
5.11. Настройка действия "Создать самораспаковывающийся архив"
5.12. Использование ID

1. Работа со сжатыми файлами

После должной настройки Double Commander сможет работать со сжатыми файлами, как если бы это были простые папки.

Например, если у нас в панели есть ZIP-файл, мы можем просто выделить его, нажать Enter и в панели будет показано содержимое этого файла так же, как если бы мы перешли в каталог.

"Внутри" сжатого файла мы можем выполнять некоторые минимальные базовые функции, такие как просмотр файла, копирование его в другую панель и некоторые другие.

На изображении ниже показан пример открытия сжатого файла "help.rar":

Обзор

2. Средства для работы со сжатыми файлами

Double Commander достаточно универсален, чтобы через собственный интерфейс использовать внешние программы для работы со сжатыми файлами.

Он использует два разных принципа:

3. Работа с плагинами

Мы можем настроить Double Commander на использование "архиваторных плагинов", которые помогут справиться со сжатым файлом.

Дистрибутив Double Commander уже включает в себя некоторые из подобных WCX-плагинов.

На момент написания этих строк имеем следующий список (перечислены типы архивов, которые уже добавлены в настройки):

Архиваторные (WCX) плагины в дистрибутиве
Имя плагинаПоддерживаемые архивы
deb.wcx
*.deb
rpm.wcx
*.rpm
sevenzip.wcx
*.7z, *.arj, *.cab, *.cpio, *.cramfs, *.dmg, *.fat, *.hfs, *.iso, *.lha, *.lzh, *.ntfs, *.squashfs, *.taz, *.vhd, *.wim, *.xar и *.z
unrar.wcx
*.rar
zip.wcx
*.bz2, *.gz, *.jar, *.lzma, *.tar, *.tbz, *.tgz, *.tlz, *.txz, *.xz, *.zip и *.zipx

Пожалуйста, имейте в виду, что для ряда форматов поддерживается только чтение, то есть доступны только просмотр содержимого, распаковка и тестирование.


Кроме того, в Интернете мы можем найти ряд других WCX-плагинов.

Также помните, что плагины, написанные для работы с Total Commander, должны работать и с Double Commander.


Чтобы установить, включить или настроить их, нам нужно зайти в Настройки > Параметры... > Плагины > Плагины WCX:

Обзор

4. Работа с внешними архиваторами

Иногда нужного плагина просто не существует.

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

Double Commander использует механизм работы с внешними архиваторами аналогичный плагину MultiArc для Total Commander.

Чтобы было понятнее, использование внешнего архиватора можно описать следующим образом: это способ запустить архиватор, но заставить Double Commander управлять им, передавая исполняемому файлу архиватора различные параметры, которые нам понадобятся для интеграции с приложением.

Оставшаяся часть этой страницы будет посвящена вопросу настройки Double Commander для использования внешнего архиватора.

Предположим, мы хотим использовать "rar.exe" для работы с архивами RAR.

Как можно догадаться, необходимо настроить вызов внешнего архиватора для того, чтобы мы могли...


Все эти действия будут сконфигурированы в окне настроек DC в разделе "Архиваторы":

Обзор

Давайте рассмотрим универсальные возможности, предлагаемые нам Double Commander для использования внешнего упаковщика.

5. Настройка интеграции внешних архиваторов

Мы не будем описывать здесь, в начале, каждое поле, вместо этого подробно, шаг за шагом, разберём пример интеграции внешнего архиватора "rar.exe".

5.1. Добавление нового внешнего архиватора

Нажимаем кнопку "Добавить", указываем имя архиватора и теперь мы готовы его настроить.

Обзор


Далее нам нужно добавить описание архиватора, путь к исполняемому файлу, а затем расширение файла, без точки.

Если у нас более одного возможного расширения, просто перечисляем их через запятую, без пробела.

Обзор

5.2. Переменные для команд внешнего архиватора

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

Чтобы помочь в этом, Double Commander предлагает нам ряд переменных, ниже представлена таблица доступных:

Определение команды
ПеременнаяЧто означает
%P
Длинное имя архиватора (как в поле "Архиватор")
%p
Короткое имя архиватора (как в поле "Архиватор")
%A
Длинное имя файла архива
%a
Короткое имя файла архива
%L
Список файлов.
Это файл, содержащий имена файлов, которые будут обрабатываться внешним архиватором.
Имена файлов длинные.
%l
Список файлов с короткими именами файлов
%F
Имя одного файла для обработки.
Архиватор будет вызван несколько раз, до тех пор, пока не будут обработаны все файлы.
Эта переменная должна использоваться только в том случае, если архиватор не поддерживает работу со списком файлов в командной строке.
%V
Размер тома (для многотомного архива)
%W
Пароль
%E<errorlevel>
Максимальный допустимый код завершения (errorlevel, код выхода).
Например, %E2 означает, что принимаются коды завершения 0, 1 и 2.
Эта переменная может быть указана в любом месте команды.
Если она не используется, то только код завершения 0 считается успешным.
%O<модификатор>
По умолчанию MultiArc конвертирует вывод архиватора из кодировки OEM (DOS) в UTF-8.
Используйте её для переопределения кодировки, возможные модификаторы смотрите ниже.
Может использоваться только с командой "Список".
%R
Целевая поддиректория В архиве
{}
Если какая-то переменная заключена в фигурные скобки, то она будет добавлена только если эта переменная содержит что-либо, т.е. не пустая
%S
Зависит от режима, устанавливается в диалоге настройки, MultiArc будет запрашивать у пользователя дополнительные параметры командной строки, которые должны быть размещены на месте %S

Не беспокойтесь, ниже мы покажем пример для лучшего понимания.

5.3. Модификаторы переменных

Эти модификаторы могут быть указаны сразу же после переменных, без пробелов.

Модификаторы переменных
Буква модификатораЧто означает
F
включить в список только файлы (применимо к переменным %L и %l)
Q
брать в кавычки имена с пробелами
q
брать в кавычки все имена
W
использовать только имя, без пути
P
использовать только путь, без имени
A
использовать кодировку ANSI (может использоваться с переменными %L и %O)
U
использовать кодировку UTF-8 (может использоваться с переменными %L и %O)

И снова не волнуйтесь, пример будет ниже.

5.4. Настройка действия "Список"

Если мы хотим, чтобы Double Commander работал с архивами, как если бы это был каталог с файлами, у нас должна быть возможность получить список файлов в архиве.

На данный момент нам не нужно его распаковывать! Нет, это лишь вопрос получения списка его содержимого, чтобы Double Commander нам его показал.

В нашем примере "rar.exe", смотрим его документацию и видим команду "v", которая позволит нам использовать консольное приложение "rar.exe" для получения списка файлов внутри архива:

Обзор


Значит, для получения списка нам необходимо вызвать "rar.exe" с командой "v" и именем архива.

Сначала проверим это вручную, с файлом E:\Temp\just.rar

Обзор


Итак, теперь нам нужно настроить действие "Список", чтобы сообщить Double Commander, как вызвать "rar.exe" для получения содержимого сжатого файла.

Чтобы сделать это, запишем то же, но уже используя описанные выше переменные и модификаторы.

Вот как это будет выглядеть:

Обзор

У нас получилось %P v %AQA:

Таким образом, всё это для того, чтобы вызвать внешний архиватор с подходящими параметрами.

Будет использовано при вызове внутренней команды cm_OpenArchive.

5.5. Получение списка содержимого

Теперь архиватор будет выводить список файлов внутри архивов.

Но это еще не всё! Далее нам нужно разобрать вывод архиватора, приведя его к виду, необходимому для показа в файловой панели.

5.5.1. Разграничение области для анализа

Как мы видели на изображении выше, "rar.exe" выводит не просто голые данные.

Есть некоторая информация, которую мы должны убрать, чтобы сохранить только необходимое.

К счастью, мы можем указать Double Commander магическую строку, с которой DC начнёт анализ последующих строк.

Кроме того, мы можем указать магическую строку, останавливающую разбор данных.

Поскольку у нас есть пунктирная линия до и после, довольно просто установить эти два параметра:

Обзор

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

Символ карет "^" указывает, что магическая строка располагается в самом начале строки и никак иначе.

Если магическая строка, останавливающая разбор данных, может быть спутана с именем файла, то DC может прекратить анализ слишком рано, поэтому, когда возможно, полезно уточнить, что эта строка должна начинаться с самого начала строки.

Есть смысл установить "Конец списка" как можно дальше, но сохраняя его функцию: лучше и безопаснее убедиться, что в будущем не будет путаницы.

5.5.2. Разбор списка содержимого

Теперь DC точно знает, какие данные анализировать для получения списка файлов внутри архива.

Было бы проще жёстко задать в приложении порядок анализа вывода "rar.exe", но Double Commander этого не делает.

Вместо этого он чрезвычайно универсален, предоставляя нам возможность полностью настроить анализ!

Это может быть немного сложнее, но, с другой стороны, это даёт нам максимальную гибкость, поскольку так мы можем использовать внешние архиваторы, о которых разработчики Double Commander даже не знали!

Для извлечения информации из каждой строки списка файлов мы будем использовать шаблоны.

5.5.3. Стандартный синтаксис разбора вывода

Таблица ниже содержит выражения стандартного синтаксиса разбора вывода и, как мы увидим в примере, стандартный синтаксис преимущественно основана на прямой подстановке.

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

Стандартный синтаксис разбора вывода
ВыражениеЧто означает
n
имя файла
z
размер несжатого файла
c
описание файла
p
размер сжатого файла
d
день
t
месяц
TTT
трёхбуквенное имя месяца (Jan, Feb, Mar, ...)
y
год
h
часы
H
буква-модификатор часов: a - время до полудня (a.m.), p - время после полудня (p.m.)
m
минуты
s
секунды
a
атрибуты
e
расширение файла
?
пропустить один символ
*
пропустить до первого пробела или конца строки
+
для имён файлов, расположенных в конце строки: использовать все символы до конца строки

5.5.4. Пример со стандартным синтаксисом

Таким образом, вся суть заключается в том, чтобы использовать доступные выражения из предыдущей таблицы для создания шаблона "Формат списка", который в свою очередь укажет Double Commander, как этим архиватором получить содержимое архива: каталоги и имена файлов, размеры файлов, атрибуты, даты и т.д.

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

Вот что у нас получится:

Обзор

Итак, мы написали шаблон:

Теперь выделим наш архив "just.rar" в панели, нажмём Enter, чтобы войти в него как в каталог, и видим, что показ содержимое файла работает (за исключением последнего файла...):

Обзор

5.5.5. Расширенный синтаксис разбора вывода

Следующая таблица представляет нам расширенный синтаксис разбора вывода внешнего архиватора.

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

Пример его использования будет приведён в следующем разделе.

Расширенный синтаксис разбора
ВыражениеЧто означает
+
после имени не в конце строки: использовать все символы до следующего пробела
+
после любого числового поля: использовать все цифры до первого нецифрового символа
n+
имя файла: использовать все символы до конца строки
z+
размер несжатого файла: использовать все цифры до первого нецифрового символа
p+
размер сжатого файла: использовать все цифры до первого нецифрового символа
$
пропустить все пробелы/табуляции до следующего символа или до конца строки
\
данные продолжаются на следующей строке (поддерживается максимум 2 строки)
x
в точности один пробел, если на этом месте находится другой символ, то вся строка игнорируется
z=1024
размер несжатого файла, умноженный на указанное значение (в данном случае: 1024)
p=1024
размер сжатого файла, умноженный на указанное значение (в данном случае: 1024)

5.5.6. Пример с расширенным синтаксисом

Пример со стандартным синтаксисом оказался хорош, но не идеален.

В некоторых случаях он будет работать неправильно.

С огромными файлами размер будет намного шире, чем ожидалось, поэтому наша первая попытка не удалась.

Посмотрите на наш файл 007 Skyfall.TS.

Мы видим, что отображается неверная информация. Давайте сравним:

Обзор

Видим ошибки в имени файла, размере, дате и т.д.

Давайте для разрешения этой проблемной ситуации воспользуемся элементами расширенного синтаксиса.

Вот что можно использовать, даже если выводимое поле не всегда *точно* одной и той же ширины:

Обзор

Немного сложнее, но очень легко описать, и в конце мы увидим, что всё это не так уж сложно.

Раскрашенное описание поможет нам визуализировать каждый маленький блок разбора:

Обзор

Итак, используя эту строку формата списка, мы можем проверить снова и теперь у нас есть правильный результат даже для огромного файла:

Обзор

5.6. Настройка действия "Извлечь"

Это строка вызова внешнего архиватора для извлечения файла или всех файлов из выбранного архива, будем использовать те же переменные и их модификаторы.

Продолжаем работу с "rar.exe", из документации мы знаем, что для извлечения файла или группы файлов используется команда "x".

С "rar.exe" мы также можем указать в параметре список файлов для извлечения.

Воспользуемся предлагаемой Double Commander переменной %L, которая создаст текстовый файл с выделенными для извлечения файлами, и передадим его как параметр.

Ниже представлена строка для извлечения на примере "rar.exe":

Обзор

Описание этого примера:

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

Когда мы "входим" в архив как в каталог и нажимаем F3, чтобы просмотреть содержимое файла внутри архива, действие "Извлечь" происходит в фоне, выбранный файл извлекается с использованием этого шаблона во временный каталог, а уже оттуда передаётся просмотрщику.

Будет использовано при вызове внутренней команды cm_ExtractFiles.

5.7. Настройка действия "Добавить"

Это строка вызова внешнего архиватора для "упаковки" файла или всех выделенных файлов в архив, будем использовать те же переменные и их модификаторы.

Продолжаем работу с "rar.exe", из документации мы знаем, что для создания архива или добавления файла или группы файлов в существующий архив используется команда "a".

С "rar.exe" мы также можем указать в параметре список файлов для добавления.

Воспользуемся предлагаемой Double Commander переменной %L, которая создаст текстовый файл с выделенными в активной панели файлами, и передадим его как параметр.

Ниже представлена строка для создания или добавления в архив на примере "rar.exe":

Обзор

Описание этого примера:

Итак, эта команда будет вызвана, когда мы выберем файл или группу файлов и пожелаем упаковать с помощью внешнего архиватора "rar".

Будет использовано при вызове внутренней команды cm_PackFiles.

5.8. Настройка действия "Удалить"

Некоторые форматы сжатых файлов поддерживают возможность удаления файла внутри архива.

Если эта возможность поддерживается, мы можем в Double Commander настроить для этого вызов внешнего архиватора.

То есть, когда эта команда будет использоваться: входим в архив, выбираем внутри него файл и удаляем его.

Обратите внимание, что это действие находится на второй вкладке настроек внешнего архиватора.

Продолжая наш пример с "rar.exe", вот как мы можем настроить это действие:

Обзор

Описание этого примера:

5.9. Настройка действия "Проверить"

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

Если эта возможность поддерживается, мы можем в Double Commander настроить для этого вызов внешнего архиватора.

Продолжая наш пример с "rar.exe", вот как мы можем настроить это действие:

Обзор

Описание этого примера:

Будет использовано при вызове внутренней команды cm_TestArchive.

Если ошибок нет, окно тестирования будет закрыто, в противном случае появится следующее сообщение:

Обзор

5.10. Настройка действия "Распаковать не учитывая пути"

Если архив содержит каталоги, то при вызове внутренней команды cm_ExtractFiles для распаковки по умолчанию архиватор будет воссоздавать структуру каталогов.

Но иногда бывает необходимо извлечь все файлы без сохранения структуры каталогов и некоторые архиваторы поддерживают такую возможность.

Для этого используется действие "Распаковать не учитывая пути".

Продолжая наш пример с "rar.exe", вот как мы можем настроить это действие:

Обзор

Описание этого примера:

Такой способ можно выбрать в диалоговом окне распаковки архива:

Обзор

5.11. Настройка действия "Создать самораспаковывающийся архив"

Некоторые архиваторы могут создавать "самораспаковывающиеся" сжатые файлы (SFX-архивы).

Это означает, что в результате мы получим исполняемый файл, при запуске которого будет извлечено его содержимое.

Это полезно, когда хотим быть уверены, что у пользователей не будет проблем с распаковкой архива: ничего не нужно устанавливать, просто запустить и получить распакованные файлы!

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

Так обстоит дело, например, с "rar.exe". Вот как мы можем настроить это действие:

Обзор

Описание этого примера:

Самораспаковывающийся архив создаётся, как и обычный архив, с помощью внутренней команды cm_PackFiles, но в появившемся окне нужно отметить опцию "Самораспаковывающийся архив".

Обзор


5.12. Использование ID

Мы можем настроить Double Commander таким образом, чтобы он игнорировал расширение файла и пытался определить сжатый файл по его внутреннему содержимому, а затем вызывал описанные выше соответствующие команды получения списка и распаковки.

Для этого мы будем использовать внутреннюю команду cm_OpenArchive.

Примером использования может быть открытие самораспаковывающегося EXE-файла и получение содержимого, не запуская его.

Другим примером может быть просмотр содержимого архива, который сохраняется с иным, чем обычный архив, расширением файла, примером таких файлов могут быть, например, DOCX-файлы Microsoft Word, которые на самом деле представляют собой сжатые ZIP-файлы.

Мы можем настроить DC для обнаружения сигнатуры выбранного файла (шаблона данных в определённом месте файла), чтобы он был распознан и передан соответствующему архиватору.

Мы будем называть эти шаблоны "ID" и этот раздел посвящён их настройке.

Для этого у нас есть три опции: ID, Смещение ID и Диапазон поиска ID.

Мы укажем Double Commander, где нужно искать определённый ID для распознавания типа архива, а затем настроим команды, специфичные для этого типа архива.

Начнем с простого примера. На следующем изображении показано начало архива 7-Zip в шестнадцатеричном виде:

Пример архива 7-Zip

Посмотрев другие архивы 7-Zip, мы видим, что первые четыре байта — это всегда последовательность 0x37 0x7A 0xBC 0xAF.

Итак, извлечём из этого пользу: столкнувшись с файлом, который начинается с этой последовательности, Double Commander предположит, что этот файл является архивом 7-Zip.

Настраиваем:

ID 7-Zip архива

Мы должны записать ID группами по два шестнадцатеричных числа, разделяя их пробелами.

Смещение ID (необязательный) — это позиция ID в архиве. Если не указано, поиск ID будет идти с начала файла. Мы можем задать смещение со знаком "-" (минус): в этом случае поиск будет идти с конца файла. Специальное значение <SeekID> ограничивает поиск ID, если не найдено числовое значение смещения ID. Диапазоны поиска "0 .. размер файла" или "0 .. Диапазон поиска ID" (в зависимости от того, какое будет меньше). Значения могут быть указаны в десятеричной (12345) или шестнадцатеричной (0x3039) системе счисления. Отрицательные значения в шестнадцатеричном виде обозначаются как 0xFFFFFFFF (-1 в десятичном).

Диапазон поиска ID (необязательный) — это число байт, в которых Double Commander будет искать ID, если задано <SeekID>. По умолчанию 1 МБ.

Примечание: Все вышеуказанные параметры могут иметь несколько значений, в таком случае можно перечислить их через запятую.

В нашем примере с архивом 7-Zip будет достаточно указать ID и смещение ID (0, потому что в начале файла).

Теперь, когда мы вызовем команду cm_OpenArchive, Double Commander просканирует содержимое файла, найдёт последовательность "0x37 0x7A 0xBC 0xAF" по смещению 0, и будет обрабатывать его как тип 7Z, с соответствующими командами и параметрами для получения списка, распаковки и т.д.


Valid HTML 4.0 Transitional CSS Valid!