File: codegroup.man

package info (click to toggle)
codegroup 20080907%2Bds1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 368 kB
  • sloc: ansic: 520; makefile: 88; sh: 9
file content (157 lines) | stat: -rw-r--r-- 7,268 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157

CODEGROUP(1)                                         CODEGROUP(1)

NAME
       codegroup  -  encode  /  decode binary file as five letter
       codegroups

SYNOPSIS
       codegroup -d|-e [ -u ] [ infile [ outfile ] ]

DESCRIPTION
       For decades, spies have written their encoded messages  in
       groups of five letters.

       codegroup encodes any binary file into this form, allowing
       it to be transmitted through any medium, and decodes files
       containing  codegroups  into  the original input.  Encoded
       files contain a 16-bit cyclical redundancy check (CRC) and
       file  size  to  verify,  when decoded, that the message is
       complete and correct.  Files  being  decoded  may  contain
       other  information before and after the codegroups, allow-
       ing in-the-clear annotations to be included.

       codegroup makes no attempt, on its own,  to  prevent  your
       message from being read.  Cryptographic security should be
       delegated to a package intended for that purpose, such  as
       pgp.   codegroup  can  then  be  applied  to the encrypted
       binary output, transforming  it  into  easily  transmitted
       text.   Text  created  by  codegroup  uses only upper case
       ASCII letters and spaces.  Unlike files encoded with uuen-
       code  or  pgp's  ``ASCII  armour'' facility, the output of
       codegroup can be easily (albeit tediously) read  over  the
       telephone,  broadcast  on shortwave radio to agents in the
       field, or sent by telegram, telex, or Morse code.

       To illustrate the difference, here are the first few lines
       of a binary file encoded by:

       base64:
            H4sICFJ9MzYAA2EudGFyAOxba3faSNKer+lf0SezO3YmgLnY2I6TyQIGgwOGBTtOYjuJEMJo
            DJJGF1+ys//9rarulpqLHRi/mdk9G84JIKGuqq579eNkNn745q9sNru9tcXhs5gtFPAzm83l
            xad88WyxmNssbhe3sps8m8ttZ/M/8K1vL9oPP0RBaPggypU1vrad+59zosj0HqAj9xF//pe8
            WsaVNbTH1rfkAfoobm7ea//cZn4rtv/mNtq/kM9t/cCz31Io9foftz9nnW77oMdfcdMdWJe+

       uuencode:
            begin 644 data.bin
            M'XL("&7._R\  VUO;V\ /9U+FN2XSF3G6H5OA1(?HOB<=/<7__X7TN<PJ[L&
            M=?-&1;I+) B8 0;P?_Z'?WY_-=7Q"T_JSZ_6)X9?&"$\OU9[N'\A[A%^L^6=
            M?^M[OOV+:9=UM9J^] MAS_ ;X0O]U];(Z?<WWE9_\^[/]ZMM\OO[CG'^2M\M
            M_G(+,US/LWKZE1#C^YO?D_;O#G[7][2R^+0>XJ^&PI/\[?7-7U]KU=]SSWQ?

       pgp:
            -----BEGIN PGP MESSAGE-----
            Version: 2.6.2i

            hIwCCb8iTku3pBUBA/9oSDlfk/On9bwjmTnB98Eejr6agkPSi3n6hd8JkAtJd33f
            kzFq18Jo0xzRUWZ7Di6Jq/FXpeI1yztVDqispbcYOP0aDv4JZOSF1kRsmJ9xK9Bo
            Cv4a967IXPkkRsjIAkx0B39dYxCzf8kHUn4THmyV/b2qLUZ0cc+mr8hxFfFpuYSM

       codegroup:
            ZZZZZ YBPIL AIAIG FMOPP CPAAA DGNGP GPGPA ADNJN ELJKO ELIMO
            GEOHF KIFGP IFBCB PKCPI YJMHE PHBHP PPOBH NCOHD AKLLL AGHFP
            DEGEF LKELC EAIJI ABAGP AHPPO IHHPH OHPDF YNFPB ALEPO KMPKP
            NGCHI GFPBI CBDML PFGHL LIHPC BOOBB HOLDO FJNHP OLHLL OPNIL

       Only  codegroup  conforms to the telegraphic convention of
       all upper case letters, and passes the ``telephone  test''
       of  being  readable  without any modifiers such as ``capi-
       tal'' and ``lower-case''.  Avoiding punctuation marks  and
       lower case letters makes the output of codegroup much eas-
       ier to transmit over a voice  or  traditional  telegraphic
       link.

OPTIONS
       -decode     Decodes the input, previously created by code-
                   group, to recover the original input file, and
                   verifies it to detect truncation or corruption
                   of the contents.

       -encode     Encodes the input into  an  output  text  file
                   containing  five letter code groups (default).

       -usage      Print how-to-call information.

       All options may be abbreviated to a single letter.

APPLICATION NOTES
       Encoding a binary  file  as  ASCII  characters  inevitably
       increases  its size.  When used in conjunction with exist-
       ing compression and encryption tools, the resulting growth
       in file size is usually acceptable.  For example, a random
       extract of electronic mail 32768 bytes in length was  cho-
       sen as a test sample.  Compression with gzip compacted the
       file to 15062 bytes.  It was then encrypted for  transmis-
       sion  to  a single recipient with pgp, which resulted in a
       15233 byte file.  (Even though pgp has  its  own  compres-
       sion,  smaller  files usually result from initial compres-
       sion with gzip.  In this case, pgp alone would  have  pro-
       duced a file of 15420 bytes.)

       codegroup  transforms the encrypted file into a 37296 byte
       text file.  Thus, due to compression, the code groups  for
       the encrypted file are only a little larger than the orig-
       inal cleartext.

       Restricting the character set and including spaces between
       groups  results  in substantially larger output files than
       those produced by uuencode and pgp.   Files  encoded  with
       codegroup  are about 2.5 times the size of the input file,
       while uuencode and pgp expand the  file  only  about  35%.
       codegroup  is  thus preferable only for applications where
       its limited character set is an advantage.

FILES
       If no infile is specified or infile  is  a  single  ``-'',
       codegroup  reads  from  standard  input;  if no outfile is
       given, or outfile is a single ``-'',  output  is  sent  to
       standard  output.   The  input  and  output  are processed
       strictly serially; consequently codegroup may be  used  in
       pipelines.

BUGS
       When  a  CRC  error is detected, no indication is given of
       the location in the  file  where  the  error(s)  occurred.
       When  sending large files, you may want to break them into
       pieces with the splits utility  (available  from  the  Web
       page cited below) so, in case of error, only the erroneous
       pieces have to be re-sent.

       It might be nice to embed the original file name and modes
       in  the  encoded  output,  but  this opens the door to all
       kinds  of  system-dependent  problems.   You  can   always
       include  this  information  as text before the first code-
       group, or send an archive created with tar or zip.

SEE ALSO
       base64(1),  gzip(1),  pgp(1),  splits(1),  tar(1),   uuen-
       code(1), zip(1)

EXIT STATUS
       codegroup  returns  status  0  if processing was completed
       without errors, 1 if errors were detected  in  decoding  a
       file which indicate the output is incorrect or incomplete,
       and 2 if processing could not be performed at all due, for
       example,  to  a  nonexistent  input  file or no codegroups
       found in the input.

AUTHOR
            John Walker
            http://www.fourmilab.ch/

       This software is in the public domain.  Permission to use,
       copy,  modify,  and distribute this software and its docu-
       mentation for  any  purpose  and  without  fee  is  hereby
       granted,  without  any  conditions  or restrictions.  This
       software is provided ``as is'' without express or  implied
       warranty.