Octave-Lint (3)A few more additional features that could be copied from existing tools in a similar areas. Immediately we can think of all the warnings that GCC would spit out, when you compile C/C++ code using '
gcc -Wall code.cc'. Specifically, flagging unused variables, data type conversions in known stdlibrary of Octave functions and such. Its time, I could show the code, instead of waxing eloquent about it. Just that I dont have anything to show.
Octave -> Matlab -> OctaveNext in a similar spirit of the AST walker static-checker we could also have a program transformation tool for converting Octave -> Matlab code. I could '
ask' for type inference whenever it is '
confused' by '
ambiguous' nature of the code. This is exciting, in terms of the possibilities it opens up for us. It is going to be a long project, but defnitely rewarding one.
The Octave parser is widely acknowledged on our
mailing lists as a
superset of Matlablanguage. Using the Octave parser, you could in theory convert Matlab code the other-way
round too. Now this is double bonanza, a kind of buy-1 and you get-1 free. Am I excited?
The starting point of the program transformation tool would be from
Paul Kienzle's work on
Oct2Mat conversion script. A few things are simple to understand, and require plain substituion. Paul's code does it using an
AWK script, and clearly mentions not wanting to Octave's parse tree for doing the conversion. Paul attempts to do it using filters in AWK, and aims for an independent program for doing the conversion. Since our aims are to take advantage of whatever we have (
GPL, Octave, Parser) then we can stand on the shoulders of giants instead of '
lets start at the very beginning, Do Re Mi'. Paul's code helps us easily identify the transformation rules to be applied.
The Octave->Matlab transformation rules, applied in Paul's code include
- gsub("#" , "%"); convert # to %
- gsub("[(][)]",""); convert () to ' ' as Matlab 4.0 and Octave-2.1.50 dont support empty arguments. This is not a problem anymore.
- gsub("gset[^;%]*;",""); a graphics command conversion.
- gsub("gset[^;]*%","%"); a graphics command conversion.
- gsub("gset[^;]*$",""); a graphics command conversion.
- gsub("endfunction",""); Octave has endif, endfor, endfunction etc, so those get converted to end, or in Matlab nothing at all. Infact Matlab complains if you have the end keyword at the end of a function file.
- gsub("endif","end"); Same as 6.
- gsub("endwhile","end"); Same as 6.
- gsub("endfor","end"); Same as 6.
- gsub("end_try_catch","end"); Same as 6.
- gsub(/&&/,"\\&"); Matlab didnot have the short circuit logical operators initially, so we had to use the logical &.
- gsub("SEEK_CUR",0); They also seemingly lacked options for STDIO processing.
- gsub("SEEK_END",1); Same as 12.
- gsub("SEEK_SET",-1); Same as 12.
- gsub("usage","error"); Our usage() and print_usage() are replaced by error() function.
- gsub("__error_text__","lasterr"); Some Octave specific code
- gsub("unwind_protect_cleanup",""); Again Octave was first here, w.r.t try/catch ...
- gsub("end_unwind_protect",""); ... doing it the LISP way.
- gsub("unwind_protect",""); Same as [17, 18].
- gsub(/\|\|/,"|"); Logical short-circuit OR operator was NOT there in Matlab first. We got here earlier.
- gsub("!","~"); They dont know whats Not !
- gsub("[\\]$","..."); Line continuations are OK for us. Not them!
These rules are easily loaded as actions for a AST walker, for operators in Octave. We just generate the do_convert_oct_to_mat() on each node. As an example, the node for the operator short-circuit && will have the conversion rule embedded in this routine as follows,
string short_ckt_and::do_convert_oct_to_mat() { l_str=left_node.do_convert_oct_to_mat(); r_str=right_node.do_convert_oct_to_mat(); str=l_str + " & " + r_str; return str;}So basically it would be a really syntactically correct way of doing things for bulilding transformation tools from the existing code base. As explained earlied since Octave being a superset of Matlab we could also turn the world the other-way round.
Ofcourse the validity of the converter can be verified by doing the rountripping, O-2-M-2-O and running the code to see if we have the regression tests validated. John Eaton (JWE), has a set of regression cases for parser, which is again something we can re-use.
It would be fun to see this happen, and I suspect this is much lower hanging fruit than writing an evaluating AST-walker for building the profiler or a debugger.
Cheers,
Muthu