RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 1 | .TH XXD 1 "May 2024" "Справочник по программе xxd" |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 2 | .\" |
| 3 | .\" 21st May 1996 |
| 4 | .\" Man page author: |
| 5 | .\" Tony Nugent <tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> |
| 6 | .\" Changes by Bram Moolenaar <Bram@vim.org> |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 7 | .SH НАЗНАЧЕНИЕ |
| 8 | Программа |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 9 | .I xxd |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 10 | \[em] выполняет преобразование данных или в шестнадцатеричный вид, или выполняет |
| 11 | обратное преобразование из шестнадцатеричного кода в исходный формат |
| 12 | .SH КРАТКИЙ ОБЗОР |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 13 | .B xxd |
| 14 | \-h[elp] |
| 15 | .br |
| 16 | .B xxd |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 17 | [аргументы] [входной_файл [выходной_файл]] |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 18 | .br |
| 19 | .B xxd |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 20 | \-r[evert] [аргументы] [входной_файл [выходной_файл]] |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 21 | .SH ОПИСАНИЕ |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 22 | Программа |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 23 | .I xxd |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 24 | создаёт представление указанного файла или данных, прочитанных из стандартного |
| 25 | потока ввода, в виде шестнадцатеричных кодов. Эта программа также может |
| 26 | выполнять обратное преобразование заданных шестнадцатеричными кодами данных |
| 27 | в исходный двоичных формат. |
| 28 | Подобно программам |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 29 | .BR uuencode(1) |
| 30 | и |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 31 | .BR uudecode(1) |
| 32 | , она позволяет выполнять преобразование двоичных данных в символы кодировки |
| 33 | ASCII, которые можно передавать по электронной почте, однако, помимо этого, |
| 34 | программа xxd позволяет выполнять декодирование в поток стандартного вывода, |
| 35 | а также может применяться для создания исправлений для двоичных файлов. |
| 36 | .SH АРГУМЕНТЫ КОМАНДНОЙ СТРОКИ |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 37 | Если |
| 38 | .I входной_файл |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 39 | не задан, то требуемые данные считываются из стандартного потока ввода. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 40 | В случае, если в качестве |
| 41 | .I входного_файла |
| 42 | используется символ |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 43 | .RB ' \- ', |
| 44 | источником данных также выступает стандартный поток ввода. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 45 | В том случае, если не указан |
| 46 | .I выходной_файл |
| 47 | (или вместо него используется символ |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 48 | .RB ' \- ' |
| 49 | ), результат преобразования направляется в стандартный поток вывода. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 50 | .PP |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 51 | Обратите внимание, что применяется "ленивый" алгоритм разбора аргументов, |
| 52 | который проверяет только первую букву аргумента, если, конечно, для этого |
| 53 | аргумента не указано какое-то значение. |
| 54 | Пробелы между односимвольным аргументом и его значением не являются |
| 55 | обязательными. Значения аргументов могут быть заданы в десятичном, |
| 56 | шестнадцатеричном или восьмеричном формате. |
| 57 | Таким образом, аргументы |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 58 | .BR \-c8 , |
| 59 | .BR "\-c 8" , |
| 60 | .B \-c 010 |
| 61 | и |
| 62 | .B \-cols 8 |
| 63 | являются равнозначными. |
| 64 | .PP |
| 65 | .TP |
| 66 | .IR \-a " | " \-autoskip |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 67 | Включить автоматический пропуск, т. е., вместо нескольких идущих подряд строк |
| 68 | с нулевым значением, используется одиночный символ '*'. |
| 69 | По умолчанию не применяется. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 70 | .TP |
| 71 | .IR \-b " | " \-bits |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 72 | Использовать биты (двоичный код), а не шестнадцатеричные цифры. |
| 73 | При указании этого аргумента, вместо обычного шестнадцатеричного представления |
| 74 | октетов, будет отображается набор из восьми цифр "1" и "0". Каждая строка |
| 75 | предваряется её номером в шестнадцатеричном виде, а завершается в виде символов |
| 76 | в кодировке ASCII (или в кодировке EBCDIC). Аргументы командной строки |
| 77 | \-p, \-i в этом режиме не применяются. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 78 | .TP |
| 79 | .IR "\-c кол " | " \-cols кол" |
| 80 | Задаёт количество октетов |
| 81 | .RI < кол >, |
| 82 | которое выводится на каждой строке. По умолчанию используется значение 16 |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 83 | (для аргумента \-i используется 12, для \-ps \[em] 30, для \-b \[em] 6). |
| 84 | Максимально допустимое значение \[em] 256. |
| 85 | Максимальное значение не применяется с аргументом \-ps. Если с аргументом \-ps, |
| 86 | указано значение 0, то будет выведена просто одна длинная строка. |
| 87 | .TP |
| 88 | .IR \-C " | " \-capitalize |
| 89 | Преобразовать наименования переменных в верхний регистр при использовании стиля |
| 90 | отображения в виде подключаемых файлов языка Си, |
| 91 | который включается через аргумент командной строки \-i. |
| 92 | .TP |
| 93 | .I \-d |
| 94 | Отображать смещение не в шестнадцатеричном, а в десятичном формате. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 95 | .TP |
| 96 | .IR \-E " | " \-EBCDIC |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 97 | Отображать символы в крайне правой колонке не в кодировке ASCII, |
| 98 | а в кодировке EBCDIC. Этот аргумент не влияет на шестнадцатеричное |
| 99 | представление данных. Данный аргумент не имеет смысла, если используются |
| 100 | аргументы командной строки \-r, \-p или \-i. |
| 101 | .TP |
| 102 | .IR \-e |
| 103 | Использовать обратный порядок байт при отображение шестнадцатеричного |
| 104 | представления данных. |
| 105 | Группа байт будет показана как двоичное слово от младших разрядов к старшим. |
| 106 | Используемое по умолчанию группирование по четыре байта может быть изменено |
| 107 | через аргумент командной строки |
| 108 | .RI "" \-g . |
| 109 | Действие этого аргумента распространяется только на шестнадцатеричное |
| 110 | представление данных и не оказывает влияние на символьное представление |
| 111 | в кодировке ASCII (или EBCDIC). |
| 112 | Аргументы командной строки |
| 113 | \-r, \-p, \-i не применяются в этом режиме. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 114 | .TP |
| 115 | .IR "\-g байт " | " \-groupsize байт" |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 116 | Выполнить группирование указанного количества |
| 117 | .RI < байт > |
| 118 | (две шестнадцатеричные цифры или восемь двоичных цифр), отделяя группы |
| 119 | друг от друга пробелами. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 120 | Значение |
| 121 | .I \-g 0 |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 122 | применяется для отказа от использования группирования. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 123 | По умолчанию используется значение |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 124 | .RI < байт ">, равное " 2 |
| 125 | при отображении в прямом порядке байт, \fI4\fP при отображении в обратном |
| 126 | порядке байт и \fI1\fP в двоичном режиме. Группировка не применяется |
| 127 | в режиме PostScript или include. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 128 | .TP |
| 129 | .IR \-h " | " \-help |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 130 | Показать краткую информацию об аргументах командной строки и завершить работу |
| 131 | программы. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 132 | Создание шестнадцатеричного представления не выполняется. |
| 133 | .TP |
| 134 | .IR \-i " | " \-include |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 135 | Создавать вывод в стиле подключаемых заголовочных файлов языка Си. |
| 136 | Вывод содержит полноценное определение статического массива данных, название |
| 137 | которого соответствует наименованию входного файла, если программа xxd |
| 138 | не считывает данные из стандартного потока ввода. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 139 | .TP |
| 140 | .IR "\-l длина " | " \-len длина" |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 141 | Указывает, что после записи заданного в параметре |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 142 | .RI < длина > |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 143 | количества октетов, работа программы будет завершена. |
| 144 | .TP |
| 145 | .I "\-n название " | " \-name название" |
| 146 | Изменить возвращаемое наименование переменной при использовании аргумента \-i. |
| 147 | Применяется к массиву байт, который будет именоваться как \fIназвание\fP и длина |
| 148 | файла как \fIназвание\fP_len. |
| 149 | .TP |
| 150 | .I \-o смещение |
| 151 | Указывает добавить |
| 152 | .RI < смещение > |
| 153 | в отображаемую позицию файла. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 154 | .TP |
| 155 | .IR \-p " | " \-ps " | " \-postscript " | " \-plain |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 156 | Использовать непрерывный формата вывода шестнадцатеричного кода, |
| 157 | известного как "простой" стиль или стиль "PostScript". |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 158 | .TP |
| 159 | .IR \-r " | " \-revert |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 160 | Выполнить операцию обратного преобразования, т. е. преобразование |
| 161 | шестнадцатеричного представления в двоичный код (или применить результат |
| 162 | в качестве исправления). |
| 163 | Если вывод происходит не в стандартного поток вывода, то программа xxd выполняет |
| 164 | добавление кода к выходному файлу. При использовании комбинации аргументов |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 165 | .I \-r \-p |
| 166 | происходит чтение "простого" шестнадцатеричного представления без использования |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 167 | информации о номерах строк и какого-либо специального распределения колонок. |
| 168 | Пробелы и символы новой строки могут встречаться в любом месте исходных данных. |
| 169 | При использовании комбинации аргументов |
| 170 | .I \-r \-b |
| 171 | будет происходить считывание двоичного представления вместо шестнадцатеричного. |
| 172 | .TP |
| 173 | .IR \-R " " когда |
| 174 | В выходных данных одни и те же шестнадцатеричные значения и строковые значения |
| 175 | будут подсвечиваться одним и тем же цветом. В основном это помогает различать |
| 176 | печатаемые и непечатаемые символы. |
| 177 | Где |
| 178 | .I \fIкогда\fP |
| 179 | может принимать значение |
| 180 | .BR never " (никогда), " always " (всегда), или " auto " (автовыбор, по умолчанию). |
| 181 | Если установлена переменная окружения |
| 182 | .BR $NO_COLOR |
| 183 | , то цветовая подсветка будет отключена. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 184 | .TP |
| 185 | .I \-seek смещение |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 186 | При указании после аргумента |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 187 | .I \-r |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 188 | , будет добавляться указанное |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 189 | .RI < смещение > |
| 190 | к файловым позициям, обнаруженным в исходных данных. |
| 191 | .TP |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 192 | .I \-s [+][\-]seek |
| 193 | Начинать обработку с указанного абсолютного (или относительного) |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 194 | .RI < смещения > |
| 195 | в байтах во входном_файле. |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 196 | Где \fI+ \fRуказывает, что смещение является относительным по отношению |
| 197 | к текущей позиции данных в стандартном потоке ввода (бессмысленно, если чтение |
| 198 | происходит не из стандартного потока ввода). А параметр \fI\- \fRуказывает, |
| 199 | что должно быть прочитано указанное количество символов от конца ввода (либо, |
| 200 | если одновременно с параметром \fI+\fR, то перед текущей позицией данных |
| 201 | в стандартном потоке ввода). |
| 202 | Если аргумент \-s не используется, то программа xxd начинает обработку |
| 203 | от текущей позиции в файле. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 204 | .TP |
| 205 | .I \-u |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 206 | Указывает, что в выводе отображать шестнадцатеричные цифры в верхнем регистре. |
| 207 | По умолчанию используются символы в нижнем регистре символов. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 208 | .TP |
| 209 | .IR \-v " | " \-version |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 210 | Показать информацию о версии программы и завершить работу. |
| 211 | .SH НЕКОТОРЫЕ РАЗЪЯСНЕНИЯ |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 212 | .PP |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 213 | При указании команды |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 214 | .I xxd \-r |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 215 | при запуске программы, будет применяться некий встроенный алгоритм |
| 216 | для распознавания информации о номерах строк. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 217 | Если возможен поиск по входному файлу, то номера строк в начале каждой строки |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 218 | шестнадцатеричного представления могут быть неупорядоченными, некоторые строки |
| 219 | могут быть пропущены или пересекаться друг с другом. В этих случаях программа |
| 220 | xxd использует функцию lseek(2) для перехода к следующей позиции. Если поиск по |
| 221 | входному файлу невозможен, то допустимы только пропуски строк, которые |
| 222 | заполняются нулевыми байтами. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 223 | .PP |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 224 | Использование команды |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 225 | .I xxd \-r |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 226 | приводит к тому, что сообщения об ошибках не будут отображаться. |
| 227 | Посторонние данные просто молча пропускаются. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 228 | .PP |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 229 | При редактировании шестнадцатеричного представления двоичных файлов, обращайте |
| 230 | внимание, что по команде |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 231 | .I xxd \-r |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 232 | , после считывания достаточного количества колонок шестнадцатеричных данных |
| 233 | (см. аргумент \-c), в строке ввода не будут обрабатываться остальные данные. |
| 234 | Это означает, что изменения, внесённые в колонке с текстом в кодировке |
| 235 | ASCII (или EBCDIC), всегда игнорируются. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 236 | При обратном преобразовании шестнадцатеричного представления в стиле |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 237 | PostScript с помощью команды xxd \-r \-p количество колонок не учитывается. |
| 238 | В этом случае распознаются все символы, которые похожи на пары шестнадцатеричных |
| 239 | цифр. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 240 | .PP |
| 241 | Обратите внимание на различие между командами |
| 242 | .PP |
| 243 | \fI% xxd \-i файл\fR |
| 244 | .PP |
| 245 | и |
| 246 | .PP |
| 247 | \fI% xxd \-i \< файл\fR |
| 248 | .PP |
| 249 | Команда |
| 250 | .I xxd \-s \+seek |
| 251 | может отличаться от |
| 252 | .I xxd \-s seek, |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 253 | поскольку для того, чтобы "отмотать" данные на входе назад, используется вызов |
| 254 | функции lseek(2). |
| 255 | При указании параметра '+' поведение будет отличаться, если входные данные |
| 256 | поступают со стандартного потока ввода, а позиция в файле стандартного ввода |
| 257 | не находится в начале файла к тому моменту, когда программа xxd запущена |
| 258 | и приступает к чтению ввода. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 259 | Нижеследующие примеры помогут прояснить (или ещё больше запутать!) ситуацию... |
| 260 | .PP |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 261 | Отмотка потока стандартного ввода назад необходима, поскольку программа 'cat' |
| 262 | уже выполнила чтение данных до конца из стандартного потока ввода: |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 263 | .PP |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 264 | \fI% sh \-c "cat > plain_copy; xxd \-s 0 > hex_copy" < file\fR |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 265 | .PP |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 266 | Вывод шестнадцатеричного представления от позиции в файле 0x480 (=1024+128). |
| 267 | Параметр '+' означает "относительно текущей позиции", таким образом '128' |
| 268 | добавляется к первому килобайту, где завершает работу программа dd: |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 269 | .PP |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 270 | \fI% sh \-c "dd of=plain_snippet bs=1k count=1; xxd \-s +128 \> hex_snippet" < file\fR |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 271 | .PP |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 272 | Вывод шестнадцатеричного представления от позиции в файле 0x100 (=1024\[mi]768): |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 273 | .PP |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 274 | \fI% sh \-c "dd of=plain_snippet bs=1k count=1; xxd \-s +\-768 \> hex_snippet" < file\fR |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 275 | .PP |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 276 | В то же время, следует заметить, что подобные ситуации встречаются довольно |
| 277 | редко, так что параметр '+' обычно не используется. Автор предпочитает наблюдать |
| 278 | за работой программы xxd с помощью инструментов strace(1) или truss(1) в тех |
| 279 | случаях, когда применяется аргумент |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 280 | \-s. |
| 281 | .SH ПРИМЕРЫ |
| 282 | .PP |
| 283 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 284 | Вывести всё, кроме первых трёх строк (0x30 байт) |
| 285 | .BR файла |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 286 | : |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 287 | .br |
| 288 | \fI% xxd \-s 0x30 file\fR |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 289 | .PP |
| 290 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 291 | Вывести три строки (0x30 байт) от конца |
| 292 | .BR файла |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 293 | : |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 294 | .br |
| 295 | \fI% xxd \-s \-0x30 file\fR |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 296 | .PP |
| 297 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 298 | Вывести 120 байт в виде непрерывного шестнадцатеричного представления |
| 299 | по 20 октетов в строке |
| 300 | .br |
| 301 | (этот пример для справочника xxd.1 на английском языке, для русского языка будет |
| 302 | немного другой результат): |
| 303 | .br |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 304 | \fI% xxd \-l 120 \-ps \-c 20 xxd.1\fR |
| 305 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 306 | 2e544820585844203120224d6179203230323422 |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 307 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 308 | 20224d616e75616c207061676520666f72207878 |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 309 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 310 | 64220a2e5c220a2e5c222032317374204d617920 |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 311 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 312 | 313939360a2e5c22204d616e2070616765206175 |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 313 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 314 | 74686f723a0a2e5c2220202020546f6e79204e75 |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 315 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 316 | 67656e74203c746f6e79407363746e7567656e2e |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 317 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 318 | |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 319 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 320 | Вывести первые 120 байт этого справочника по 12 октетов в строке |
| 321 | .br |
| 322 | (этот пример для справочника xxd.1 на английском языке, для русского языка будет |
| 323 | немного другой результат): |
| 324 | .br |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 325 | \fI% xxd \-l 120 \-c 12 xxd.1\fR |
| 326 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 327 | 00000000: 2e54 4820 5858 4420 3120 224d .TH XXD 1 "M |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 328 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 329 | 0000000c: 6179 2032 3032 3422 2022 4d61 ay 2024" "Ma |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 330 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 331 | 00000018: 6e75 616c 2070 6167 6520 666f nual page fo |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 332 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 333 | 00000024: 7220 7878 6422 0a2e 5c22 0a2e r xxd"..\\".. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 334 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 335 | 00000030: 5c22 2032 3173 7420 4d61 7920 \\" 21st May |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 336 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 337 | 0000003c: 3139 3936 0a2e 5c22 204d 616e 1996..\\" Man |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 338 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 339 | 00000048: 2070 6167 6520 6175 7468 6f72 page author |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 340 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 341 | 00000054: 3a0a 2e5c 2220 2020 2054 6f6e :..\\" Ton |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 342 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 343 | 00000060: 7920 4e75 6765 6e74 203c 746f y Nugent <to |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 344 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 345 | 0000006c: 6e79 4073 6374 6e75 6765 6e2e ny@sctnugen. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 346 | .PP |
| 347 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 348 | Показать дату из файла |
| 349 | .B xxd.1 |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 350 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 351 | (этот пример для справочника xxd.1 на английском языке, для русского языка будет |
| 352 | немного другая команда, например, для UTF-8 \[em] \flxxd \-s 0x50 \-l 13 \-c 13 xxd.1\fR): |
| 353 | .PP |
| 354 | \fI% xxd \-s 0x33 \-l 13 \-c 13 xxd.1\fR |
| 355 | .br |
| 356 | 00000033: 3231 7374 204d 6179 2031 3939 36 21st May 1996 |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 357 | .PP |
| 358 | .br |
| 359 | Скопировать |
| 360 | .B входной_файл |
| 361 | в |
| 362 | .B выходной_файл |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 363 | с добавлением 100 байт со значением 0x00 в начало файла: |
| 364 | .br |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 365 | \fI% xxd входной_файл | xxd \-r \-s 100 \> выходной_файл\fR |
| 366 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 367 | |
| 368 | .br |
| 369 | Заменить дату в файле |
| 370 | .B xxd.1 |
| 371 | .br |
| 372 | (этот пример для справочника xxd.1 на английском языке, для русского языка будут |
| 373 | немного другие команды): |
| 374 | .PP |
| 375 | \fI% echo "0000034: 3574 68" | xxd \-r \- xxd.1\fR |
| 376 | .br |
| 377 | \fI% xxd \-s 0x33 \-l 13 \-c 13 xxd.1\fR |
| 378 | .br |
| 379 | 00000033: 3235 7468 204d 6179 2031 3939 36 25th May 1996 |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 380 | .PP |
| 381 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 382 | Создать 65537-байтный файл, все байты которого имеют значение 0x00, |
| 383 | кроме последнего байта, который должен иметь значение 'A' (0x41): |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 384 | .PP |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 385 | \fI% echo "010000: 41" | xxd \-r > file\fR |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 386 | .PP |
| 387 | .br |
| 388 | Создать шестнадцатеричное представление этого файла с |
| 389 | использованием автоматического пропуска: |
| 390 | .PP |
| 391 | \fI% xxd \-a \-c 12 file\fR |
| 392 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 393 | 00000000: 0000 0000 0000 0000 0000 0000 ............ |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 394 | .br |
| 395 | * |
| 396 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 397 | 0000fffc: 0000 0000 41 ....A |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 398 | .PP |
| 399 | Создать 1-байтный файл, содержащий символ 'A'. |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 400 | Число после аргументов '\-r \-s' добавляется к номерам строк, найденным в файле, |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 401 | иначе говоря, предшествующие байты пропускаются: |
| 402 | .PP |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 403 | \fI% echo '010000: 41' | xxd \-r \-s \-0x10000 > file\fR |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 404 | .PP |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 405 | Программу xxd можно использовать в качестве фильтра в редакторе, например в |
| 406 | .B vim(1) |
| 407 | , чтобы создать шестнадцатеричное представление области между |
| 408 | закладками 'a' и 'z': |
| 409 | .br |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 410 | \fI:'a,'z!xxd\fR |
| 411 | .PP |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 412 | Можно использовать программу xxd в качестве фильтра в редакторе, например в |
| 413 | .B vim(1) |
| 414 | , для восстановления данных из шестнадцатеричного представления |
| 415 | между закладками 'a' и 'z': |
| 416 | .br |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 417 | \fI:'a,'z!xxd \-r\fR |
| 418 | .PP |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 419 | Можно использовать программу xxd в качестве фильтра в редакторе, например в |
| 420 | .B vim(1) |
| 421 | , для восстановления данных из единственной строки |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 422 | шестнадцатеричного представления. Поместите курсор в соответствующую строку |
| 423 | и наберите |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 424 | .br |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 425 | \fI!!xxd \-r\fR |
| 426 | .PP |
| 427 | Чтобы прочитать единственный символ из канала связи: |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 428 | .br |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 429 | \fI% xxd \-c1 < /dev/term/b &\fR |
| 430 | .br |
| 431 | \fI% stty < /dev/term/b \-echo \-opost \-isig \-icanon min 1\fR |
| 432 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 433 | \fI% echo \-n foo \> /dev/term/b\fR |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 434 | .PP |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 435 | .SH КОДЫ ЗАВЕРШЕНИЯ |
| 436 | При завершении работы, программа xxd возвращает следующие значения: |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 437 | .TP |
| 438 | 0 |
| 439 | Ошибки не обнаружены. |
| 440 | .TP |
| 441 | \-1 |
| 442 | Операция не поддерживается (выполнение |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 443 | .I \%xxd \-r \-i |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 444 | пока невозможно). |
| 445 | .TP |
| 446 | 1 |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 447 | Ошибка при разборе аргументов командной строки. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 448 | .TP |
| 449 | 2 |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 450 | Ошибки во входном файле. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 451 | .TP |
| 452 | 3 |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 453 | Ошибки в выходном файле. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 454 | .TP |
| 455 | 4,5 |
| 456 | Желательная позиция поиска недостижима. |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 457 | .SH СМОТРИТЕ ТАКЖЕ |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 458 | uuencode(1), uudecode(1), patch(1) |
| 459 | .br |
| 460 | .SH ПРЕДУПРЕЖДЕНИЕ |
| 461 | Странность этой программы соответствует особенностям мозга её создателя. |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 462 | Используйте её на свой страх и риск. Копируйте файлы, отслеживайте вызовы, |
| 463 | становитесь волшебником. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 464 | .br |
| 465 | .SH ВЕРСИЯ |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 466 | Этот справочник документирует программу xxd версии 1.7 от 2024-05. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 467 | .SH АВТОР |
| 468 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 469 | (c) Юрген Вайгерт (Juergen Weigert), 1990-1997 |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 470 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 471 | <jnweiger@informatik.uni\-erlangen.de> |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 472 | .LP |
| 473 | Вы можете свободно распространять программу со ссылкой на меня. |
| 474 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 475 | Если использование этой программы принесло вам какой-то доход, поделитесь со |
| 476 | мной. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 477 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 478 | Если вы потеряли деньги, то я тут ни при чём. |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 479 | .PP |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 480 | Первый вариант справочника написан Тони Наджентом (Tony Nugent) |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 481 | .br |
| 482 | <tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> |
| 483 | .br |
RestorerZ | 12333ba | 2024-08-20 19:57:00 +0200 | [diff] [blame] | 484 | Небольшие изменения внесены Брамом Моленаром (Bram Moolenaar). |
| 485 | Справочник отредактирован Юргеном Вайгертом (Juergen Weigert). |
Bram Moolenaar | 217ad92 | 2005-03-20 22:37:15 +0000 | [diff] [blame] | 486 | .PP |