spin2cpp next generation
ersmith
Posts: 6,089
I'm slowly working on spin2cpp 2.0. Spin2cpp is a tool to convert Spin code to C++ (or C) code. The 2.0 release will provide much better translation (the output C++ code will be more "natural" and readable) and will work better with more compilers. I'm not there yet, but there's a "preview" release 1.91 available now at:
https://github.com/totalspectrum/spin2cpp/releases/tag/v1.91
The main change is that comments are now copied from the Spin code to the C++ code, but there are also lots of other smaller bug fixes and output tweaks.
Note that since Google Code no longer allows binary downloads, I'm moving development of spin2cpp over there. The main web page for spin2cpp will henceforth be:
https://github.com/totalspectrum/spin2cpp
Please let me know of any problems you find with this release!
Thanks,
Eric
https://github.com/totalspectrum/spin2cpp/releases/tag/v1.91
The main change is that comments are now copied from the Spin code to the C++ code, but there are also lots of other smaller bug fixes and output tweaks.
Note that since Google Code no longer allows binary downloads, I'm moving development of spin2cpp over there. The main web page for spin2cpp will henceforth be:
https://github.com/totalspectrum/spin2cpp
Please let me know of any problems you find with this release!
Thanks,
Eric
Comments
It's great that you can start out with Spin code when developing assembly routines and then run Spin2Cpp on it and have C++ code that you can give to people for further development.
Like I said, it's been a while so maybe these aren't issues anymore. And I agree with Rayman: spin2cpp is a great tool.
I hate to bring it up, but it seems to me at least that this is the wrong use of the tool.
Don't get me wrong. I applaud Eric's efforts, but the usage model needs to be better defined.
In my mind the usage should be:
Spin as the source with binary as the end result, and the intermediate C++ code is just a temporary step to a binary that should be ignored.
The generated code (in the past at least) is not maintainable as source code. The output in many cases created array indexed variables that are difficult to understand much less change by hand from one revision to the next.
Does this make any sense?
Then why don't you just use a spin compiler?
-Phil
Fair point. My perspective is that spin2cpp should be used to convert spin objects to C++ in order to build a library of C++ code. That's what I've used it for, and I like that usage. But they are two considerably different use cases.
Is there a strong case against doing both? It seems to me that the main difference between both is that for the binary case spin2cpp will have to generate a bit of boiler plate to get things started.
And, anyone who did would probably be just fine with the Spin version of that assembly code...
SRLM:
Improving the PASM support is something I'm still working on; I agree it's a priority for readable code. The --gas option converts the PASM to inline assembly, but local symbols and the like still aren't really working.
Jazzed:
I agree that spin2cpp 1.x is really best used as a compiler from Spin to machine code (with the .spin file as the primary source code). My goal with spin2cpp 2.x is to make the output C++ code more useful in itself. It may never be quite as natural as hand written C++, but it can certainly be better than it is now (as you've noted!)
I'll second this opinion. I plan to add Spin support to PropWare via spin2cpp. If any Spin files are added to the project, they'll be translated via spin2cpp to C++ source and then compiled (and linked with) PropGCC. I haven't looked into the details of this yet, but it should make mixed Spin and C/C++ projects pretty easy.