2019-01-03 15:26:47 -05:00
|
|
|
! Copyright (C) 2019 John Benediktsson
|
|
|
|
|
! See http://factorcode.org/license.txt for BSD license
|
|
|
|
|
|
2019-04-02 20:26:50 -04:00
|
|
|
USING: ascii assocs byte-arrays kernel literals math sequences ;
|
2019-01-03 15:26:47 -05:00
|
|
|
|
|
|
|
|
IN: base32
|
|
|
|
|
|
|
|
|
|
<PRIVATE
|
|
|
|
|
|
|
|
|
|
<<
|
2019-04-02 20:26:50 -04:00
|
|
|
CONSTANT: ALPHABET $[ "0123456789ABCDEFGHJKMNPQRSTVWXYZ" >byte-array ]
|
2019-01-03 15:26:47 -05:00
|
|
|
>>
|
2019-04-02 20:26:50 -04:00
|
|
|
CONSTANT: INVERSE $[ 256 [ ALPHABET index 0xff or ] B{ } map-integers ]
|
2019-01-03 15:26:47 -05:00
|
|
|
CONSTANT: CHECKSUM $[ ALPHABET "*~$=U" append ]
|
|
|
|
|
|
|
|
|
|
: normalize-base32 ( seq -- seq' )
|
|
|
|
|
CHAR: - swap remove >upper H{
|
|
|
|
|
{ CHAR: I CHAR: 1 }
|
|
|
|
|
{ CHAR: L CHAR: 1 }
|
|
|
|
|
{ CHAR: O CHAR: 0 }
|
|
|
|
|
} substitute ;
|
|
|
|
|
|
|
|
|
|
: parse-base32 ( seq -- base32 )
|
2019-04-02 20:26:50 -04:00
|
|
|
0 swap [ [ 32 * ] [ INVERSE nth + ] bi* ] each ;
|
2019-01-03 15:26:47 -05:00
|
|
|
|
|
|
|
|
PRIVATE>
|
|
|
|
|
|
|
|
|
|
: >base32 ( seq -- base32 )
|
|
|
|
|
normalize-base32 parse-base32 ;
|
|
|
|
|
|
|
|
|
|
: base32> ( base32 -- seq )
|
|
|
|
|
dup 0 < [ non-negative-integer-expected ] when
|
|
|
|
|
[ dup 0 > ] [
|
|
|
|
|
32 /mod ALPHABET nth
|
|
|
|
|
] "" produce-as nip [ "0" ] when-empty reverse! ;
|
|
|
|
|
|
|
|
|
|
: >base32-checksum ( seq -- base32 )
|
|
|
|
|
normalize-base32 unclip-last [ parse-base32 ] dip
|
|
|
|
|
CHECKSUM index over 37 mod assert= ;
|
|
|
|
|
|
|
|
|
|
: base32-checksum> ( base32 -- seq )
|
|
|
|
|
[ base32> ] keep 37 mod CHECKSUM nth suffix ;
|