v0.2.0
A wrapper around Fanuc Robotics' command-line Karel translator (ktrans.exe
)
that makes it work a little more like a modern compiler by adding some missing
functionality (like support for multiple include paths and dependency file
generation).
ktransw
is written in Python 2, so naturally it needs a Python 2 install.
The script itself doesn't do any translation, so a copy of ktrans.exe
(and
related libraries) is also needed.
Finally, pre-processing is handled by a patched version of Tristan Miller's GPP (the "Generic PreProcessor").
Clone this repository to your machine (or download any of the releases)
and add the directory containing ktransw.py
and ktransw.cmd
to your PATH
.
Command sessions opened after setting up the PATH
should be able to
successfully run ktransw
from anywhere.
Alternatively, don't change your PATH
, but start ktransw
by specifying
the full path on the command line.
For maximum convenience, make sure that ktrans.exe
is also on the PATH
.
ktransw
does not try to locate ktrans.exe
on its own, so if it is not
on the PATH
, its location must be provided by using the --ktrans
command
line option with each invocation.
Download the latest binary release from gpp releases, and place it on
the PATH
. If gpp.exe
cannot be placed on the path, the --gpp
command
line option may be used to tell ktransw
where it is.
usage: ktransw [-h] [-v] [-q] [-d] [-E] [-M] [-MM] [-MT target] [-MF file]
[-MG] [-MP] [--ktrans PATH] [--gpp PATH] [-I PATH]
[ARG [ARG ...]]
Version 0.2.0
A wrapper around Fanuc Robotics' command-line Karel translator (ktrans.exe)
that adds a C-like preprocessor, support for multiple include directories,
conditional compilation, include guards, macros and more.
positional arguments:
ARG Arguments to pass on to ktrans. Use normal (forward-
slash) notation here
optional arguments:
-h, --help show this help message and exit
-v, --verbose Print (lots of) debug information
-q, --quiet Print nothing, except when ktrans encounters an error
-d, --dry-run Do nothing, except checking parameters
-E Preprocess only; do not translate
-M Output GCC compatible dependency file
-MM Like '-M', but don't include system headers
-MT target Change the target of the rule emitted by dependency
generation (default: base name of source, with object
extension (.pc))
-MF file When used with -M or -MM, specifies a file to write the
dependencies to.
-MG Assume missing header files are generated files and add them
to the dependency list without raising an error
-MP Add a phony target for each dependency to support renaming
dependencies without having to update the Makefile to match
-k, --keep-build-dir Don't delete the temporary build directory on exit
--ktrans PATH Location of ktrans (by default ktransw assumes it's on the
Windows PATH)
--gpp PATH Location of gpp (by default ktransw assumes it's on the
Windows PATH)
-I PATH Include paths (multiple allowed)
Example invocation:
ktransw /IC:\foo\bar\include /IC:\baz\include C:\my_prog.kl /config robot.ini
All arguments using forward-slash notation (except '/I') are passed on
to ktrans.
ktransw
is supposed to be a transparent wrapper around ktrans.exe
. Refer
for more information on the use of ktrans.exe
to the relevant Fanuc Robotics
manuals.
See also rossum.
See the gpp documentation for more information.
Yes, it only runs on Windows, actually.
If you know of a way to run ktrans.exe
under Linux, I'd be interested.
ktransw
only wraps ktrans.exe
, it does not replace it or Roboguide, so
depending on your project's requirements (is it Karel only? Do you need to
translate TP programs, etc), yes, you still need Roboguide.
Backwards compatibility is currently not guaranteed, as the functionality
provided by the pre-processor cannot be duplicated by plain ktrans
. With
care, avoiding multiple inclusions of the same file would be possible, but
that would seriously hamper the development of stand-alone, re-usable
libraries (as the including entity would be made responsible for tracking
includes and making sure that all required definitions are available at
translation time).
In cases where plain ktrans
must be used, it should be possible to use
ktransw
s -E
command line option: this will make ktransw
only pre-process
the input file, without doing any translation. The resulting output is a
completely flattened file, without any pre-processor directives. ktrans
and
Roboguide should be able to translate this.
Make sure to include the appropriate include guards, to avoid problems with
multiple inclusion of headers. The pre-processor supports the typical %IFNDEF
,
%DEFINE
, %ENDIF
pattern as is common in C/C++ headers. Either wrap
%INCLUDE
directives in such conditionals, or add them to the respective
headers.
For headers that cannot be changed (or are not supposed to be changed),
wrapping %INCLUDE
directives is recommended.
(for the headers distributed by Fanuc in the support directories (kliotyps.kl and friends), see the fr_hdrs convenience package)
This tool might be migrated to a C/C++ implementation to avoid the overhead of starting the Python interpreter.
Backward compatibility with plain ktrans
would be nice to restore. A
carefully chosen notation for the new pre-processor directives might allow
for this.
WinOLPC, OlpcPRO and Roboguide are products of Fanuc America Corporation. The
author of ktransw
is not affiliated with Fanuc in any way.