Liblouisutdml is an open-source library providing complete braille
transcription services for xml, html and text documents. It translates
into appropriate braille codes and formats according to its style
sheet and the specifications in the document. A command-line program,
file2brl which uses this library is also included. The latest
version of liblouis is required. Java bindings are built in to the
The library is licensed under the GNU Lesser General Public License (LGPL) version 3 or later. See the file COPYING.LIB.
The command line tools, are licensed under the GNU General Public License version 3.0 or later. See the file COPYING.
For documentation, see
These are in the docs directory. For an example of a configuration
preferences.cfg. For examples of
semantics-action files, see
nemeth.sem. These files
are in the
lbu_files subdirectory. For examples of translation
nemeth.ctb and whatever other files they may include. These are all
tables directory of
First obtain the latest version of liblouis and compile it. Before compiling, you should chose between 16- and 32-bit Unicode, as described in the README file and the documentation. liblouisutdml inherits this choice from liblouis.
After unpacking the distribution tarball for liblouisutdml go to the
directory it creates. After running
make install. You will need root privileges for the installation step.
This will produce the liblouisutdml library and the program
file2brl. To compile the Java bindings go to the java subdirectory
Note that that the library and programs will not work properly unless you have first installed the latest version of liblouis.
$ docker run -it liblouis/liblouisutdml /bin/bash root@74a8b1ad5e03:/usr/src/liblouisutdml# file2brl --help Usage: file2brl [OPTION] [inputFile] [outputFile] Translate an xml or a text file into an embosser-ready braille file. This includes translation into grade two, if desired, mathematical codes, etc. It also includes formatting according to a built-in style sheet which can be modified by the user. If inputFile is not specified or '-' input is taken from stdin. If outputFile is not specified the output is sent to stdout. -h, --help display this help and exit -v, --version display version information and exit -f, --config-file name a configuration file that specifies how to do the translation -b, --backward backward translation -r, --reformat reformat a braille file -T, --text Treat as text even if xml -t, --html html document, not xhtml -p, --poorly-formatted translate a poorly formatted file -P, --paragraph-line treat each block of text ending in a newline as a paragraph. If there are two newline characters a blank line will be inserted before the next paragraph -C, --config-setting specify particular configuration settings They override any settings that are specified in a config file -w --writeable-path path for temp files and log file -l, --log-file write errors to file2brl.log instead of stderr Report bugs to <firstname.lastname@example.org>. root@74a8b1ad5e03:/usr/src/liblouisutdml#
Docker for cross-compiling
You can use a Dockerfile to cross-compile liblouisutdml using mingw either for 32 or for 64 bit architecture:
# for 32 bit architecture docker build -f Dockerfile.win32 . # for 64 bit architecture docker build -f Dockerfile.win64 .
Then grab the artifact from the docker container.
Or instead let the Makefile do it all for you: