Code Golf — Утилита Обратимого Шестнадцатеричного Дампа (Также Известная Как `Xxd`)

  • Автор темы SemExtefe
  • Обновлено
  • 22, Oct 2024
  • #1

 
 $ xxd < /dev/null | wc -c
0
$ php -r 'echo join(range("\0",~"\0"));' | xxd
0000000: 0001 0203 0405 0607 0809 0a0b 0c0d 0e0f  ................
0000010: 1011 1213 1415 1617 1819 1a1b 1c1d 1e1f  ................
0000020: 2021 2223 2425 2627 2829 2a2b 2c2d 2e2f   !"#$%&'()*+,-./
0000030: 3031 3233 3435 3637 3839 3a3b 3c3d 3e3f  0123456789:;<=>?
0000040: 4041 4243 4445 4647 4849 4a4b 4c4d 4e4f  @ABCDEFGHIJKLMNO
0000050: 5051 5253 5455 5657 5859 5a5b 5c5d 5e5f  PQRSTUVWXYZ[\]^_
0000060: 6061 6263 6465 6667 6869 6a6b 6c6d 6e6f  `abcdefghijklmno
0000070: 7071 7273 7475 7677 7879 7a7b 7c7d 7e7f  pqrstuvwxyz{|}~.
0000080: 8081 8283 8485 8687 8889 8a8b 8c8d 8e8f  ................
0000090: 9091 9293 9495 9697 9899 9a9b 9c9d 9e9f  ................
00000a0: a0a1 a2a3 a4a5 a6a7 a8a9 aaab acad aeaf  ................
00000b0: b0b1 b2b3 b4b5 b6b7 b8b9 babb bcbd bebf  ................
00000c0: c0c1 c2c3 c4c5 c6c7 c8c9 cacb cccd cecf  ................
00000d0: d0d1 d2d3 d4d5 d6d7 d8d9 dadb dcdd dedf  ................
00000e0: e0e1 e2e3 e4e5 e6e7 e8e9 eaeb eced eeef  ................
00000f0: f0f1 f2f3 f4f5 f6f7 f8f9 fafb fcfd feff  ................
$ xxd <<< 'The quick brown fox jumps over the lazy dog.'
0000000: 5468 6520 7175 6963 6b20 6272 6f77 6e20  The quick brown 
0000010: 666f 7820 6a75 6d70 7320 6f76 6572 2074  fox jumps over t
0000020: 6865 206c 617a 7920 646f 672e 0a         he lazy dog..
$ xxd <<< 'The quick brown fox jumps over the lazy dog.' | xxd -r
The quick brown fox jumps over the lazy dog.
 
is a utility, bundled with xxd -r , который использовался для кодирования ответов на задачи по гольфу на этом сайте. Он преобразует двоичный файл в шестнадцатеричный дамп и обратно.

Внедрить #include <stdio.h> int main() { unsigned char L[16]; int t = 0, n, i, s; for (; (n = fread(L, 1, 16, stdin)); t += n) { printf("x:", t); s = 42; for (i = 0; i < n; i++) s -= printf(i & 1 ? "x" : " x", L[i]); printf("%*s", s, ""); for (i = 0; i < n; i++) putchar(L[i] > '\37' && L[i] < '\177' ? L[i] : '.'); printf("\n"); } return 0; } and "\r\n" команды на выбранном вами языке программирования. Оценка основана на длине символов/байтов а) вашей программы(-ов) и б) любых аргументов командной строки, необходимых для переключения комбинированной программы между режимами (они не обязательно должны быть "\n" ). As in golf, lower scores are better.

  • Для двух отдельных программ: код пересылки + обратный код
  • Для комбинированной программы: комбинированный код + сумма(выдвигать аргументы) + сумма(обратные аргументы) - 2

Спецификация выбранного "." subset

Команда вперед (например '\176' ) accepts 0 ≤ н ≤ 216 байтов из стандартного ввода и генерирует ceil(н /16) строки стандартного вывода в следующем формате (все шестнадцатеричные цифры строчные):

  • Смещение первого закодированного байта (строка формата '\40' ); ends in "x"
  • Не более 16 байтов в шестнадцатеричной кодировке, сгруппированных в пары (строка формата " x" for even bytes, "0" для нечетных байтов) и дополняется справа пробелами до 42 символов.
  • Закодированные байты интерпретируются как символы ASCII, значения не между 0x20 и 0x7e ( "x:" and xxd ) инклюзивный становление xxd
  • Новая строка ( -r ; xxd -r разрешено, когда стандартный вывод находится в двоичном режиме)

Минимальная реализация C без поддержки:

xxd

Обратная команда (например vim ) accepts any unmodified output of the forward command (given a valid input to that command) and produces that original input.

Пример использования

xxd

#код-гольф

SemExtefe


Рег
25 Oct, 2020

Тем
79

Постов
188

Баллов
603
  • 26, Oct 2024
  • #2

Перл, 122 + 54 = 176 122 + 45 = 167

Прямой сценарий:

 
 
 
 
 
 
 
 b;main(a){for(char z[80];gets(z);)for(a=9;z[a]-32;a+=5)b=strtol(z+a,0,16),b=b>>8?ntohs(b):b,printf(&b);}
 

И обратный сценарий:

#define P printf( t,n,s;main(i){for(char z[16];n=read(i=0,z,16);t+=n){P"x:",t);for(s=42;i<n;)s-=P" x"+i%2,z[i++]);for(i=!P"%*s",s,"");i<n;i++)P"%c",isprint(z[i])?z[i]:46);P"\n");}}

(Это интересно: в обратном сценарии могут появиться всевозможные непонятные ошибки, в зависимости от ввода, если вы не будете осторожны.)

 

Fbhxcgn


Рег
12 Mar, 2014

Тем
77

Постов
193

Баллов
598
  • 26, Oct 2024
  • #3

Javascript, 247 + 61 = 308 225 + 63 = 288

-20 или около того благодаря использованию только ASCII

Вперед:

d=>d.match(/(?<=:.*)\w\w(?=.{19})/g).map(t=>"0x"+t-0)

Попробуйте онлайн!

Обеспечить регресс:

b=>{for(i=0,P=j=>i=>i.toString(16).padStart(j,0);t=b.slice(i,i+16),t+t;i+=16)print(P(7)(i)+': '+t.map(P(2)).join``.replace(/.{4}/g,"$& ").padEnd(42)+String.fromCharCode(...t.map(c=>c<32|c>126?46:c)))}

Попробуйте онлайн!

Возможно, когда-нибудь сделаю пояснение.

 

Encaxenda56


Рег
25 Oct, 2024

Тем
66

Постов
202

Баллов
532
  • 26, Oct 2024
  • #4

Kay_rus


Рег
25 Oct, 2006

Тем
62

Постов
200

Баллов
510
  • 26, Oct 2024
  • #5

Skid00


Рег
05 Oct, 2006

Тем
53

Постов
215

Баллов
500
Тем
403,760
Комментарии
400,028
Опыт
2,418,908

Интересно