1 -- The getopt-functionality is loaded from pm3/getopt.lua
2 -- Have a look there for further details
3 getopt = require('getopt')
5 dumplib = require('html_dumplib')
7 example = "script run htmldump -o mifarecard_foo.html"
8 author = "Martin Holst Swende"
9 usage = "script run htmldump [-i <file>] [-o <file>]"
11 This script takes a dumpfile and produces a html based dump, which is a
12 bit more easily analyzed.
16 -i <file> Specifies the dump-file (input). If omitted, 'dumpdata.bin' is used
17 -o <filename> Speciies the output file. If omitted, <curtime>.html is used.
21 -------------------------------
23 -------------------------------
26 -- A debug printout-function
33 -- This is only meant to be used when errors occur
43 print("Example usage")
47 local function main(args)
49 local input = "dumpdata.bin"
50 local output = os.date("%Y-%m-%d_%H%M%S.html");
51 for o, a in getopt.getopt(args, 'i:o:h') do
52 if o == "h" then return help() end
53 if o == "i" then input = a end
54 if o == "o" then output = a end
56 local filename, err = dumplib.convert_bin_to_html(input,output,16)
57 if err then return oops(err) end
59 print(("Wrote a HTML dump to the file %s"):format(filename))
63 In the future, we may implement so that scripts are invoked directly
64 into a 'main' function, instead of being executed blindly. For future
65 compatibility, I have done so, but I invoke my main from here.