File: README.adoc

package info (click to toggle)
lua-basexx 0.3-2.1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, forky, trixie
  • size: 132 kB
  • sloc: makefile: 6
file content (114 lines) | stat: -rw-r--r-- 3,320 bytes parent folder | download | duplicates (2)
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
= basexx

image::https://api.travis-ci.org/aiq/basexx.png[travis]

A Lua library for base2, base16, base32, base64, base85 decoding and encoding of data strings.

== API

For every supported format has basexx a *_from_* and *_to_* function.

The *_from_* functions have two parameters:

* *str* which represent the encoded string that should be decoded
* *ignore* is an optional set of characters that should be ignored in the string, see the *_from_bit_* and *_from_hex_* examples

The *_from_* functions return a string if the string can be decoded, otherwise *_nil_* and information which character caused the error.

The *_to_* functions have just one parameter:

* *str* the data string that should be encoded

=== from_bit / to_bit

Converts a byte string to a bitfield string.

* 0, O and o maps to the same value
* 1, I, i, L and l maps to the same value

[source,lua]
----
basexx.to_bit( "ACDC" ) --> 01000001010000110100010001000011
basexx.from_bit( "01000001010000110100010001000011" ) --> ACDC
basexx.from_bit( "o1ooooo1o1oooo11" ) --> AC
basexx.from_bit( "Oioooooi Oiooooii\n", " \n" ) --> AC
----

=== from_hex / to_hex

Converts a byte string to a uppercase http://tools.ietf.org/html/rfc3548#section-6[hex] data string.

[source,lua]
----
basexx.to_hex( "Hello world!" ) --> 48656C6C6F20776F726C6421
basexx.from_hex( "4865-6C6C 6F20-776F 726C-6421", "- " ) --> Hello world!
basexx.from_hex( "48656c6c6f20776f726c6421" ) --> Hello world!
----

=== from_base32 / to_base32

Converts a byte string to a http://tools.ietf.org/html/rfc3548#section-5[base32(_rfc3548)] uppercase data string.

* It's case insensitive

[source,lua]
----
basexx.to_base32( "chunky bacon!" ) --> MNUHK3TLPEQGEYLDN5XCC===
basexx.from_base32( "MNUHK3TLPEQGEYLDN5XCC===" ) --> chunky bacon!
----

=== from_crockford / to_crockford

Converts a byte string to a http://www.crockford.com/wrmg/base32.html[base32(_crockford_)] uppercase data string. The optional check value is not implemented. 

* It's case insensitive
* 1, I, i, L and l maps to the same value
* 0, O and o maps to the same value

[source,lua]
----
string.lower( basexx.to_crockford( "Hello World" ) ) --> 91jprv3f41bpywkccg
basexx.from_crockford( "axqqeb10d5t20wk5c5p6ry90exqq4tvk44" ) --> Wow, it really works!
----

=== from_base64 / to_base64

Converts a byte string to a https://tools.ietf.org/html/rfc4648#section-4[base64] data string.

[source,lua]
----
basexx.to_base64( "Man") --> TWFu
basexx.from_base64( "TWFu" ) --> Man
----

=== from_url64 / to_url64

Same as above, but uses a https://tools.ietf.org/html/rfc4648#section-5[URL Safe base64] alphabet and no padding.

=== from_z85 / to_z85

Converts a byte string to a http://rfc.zeromq.org/spec:32[base85(ZeroMQ)] data string.
to_z85 expects only a binary string that length is divisible by 4 with no remainder, and from_z85 expects only printable a string that length is divisible by 5 with no remainder.

[source,lua]
----
basexx.to_z85( "1234" ) --> f!$Kw
basexx.from_z85( "f!$Kw" ) --> 1234
----

== Installation

To install the version 0.3.0 of basexx use LuaRocks with the following line.

----
luarocks install basexx
----


If you want to use the current development version, clone this repository and use
LuaRocks with the following command.

----
luarocks make dist/basexx-scm-0.rockspec
----