> I think there is some kind of misunderstanding. I'm still not understanding. > ... but still requires auxilliary stuff ... What is the difference between "auxiliary stuff" of Java (such as the native executables produced by gcj), different from the "auxiliary stuff" of other executables (such as native executables produced by Fortran, Pascal and C), such that the former "auxiliary stuff" you don't like, but the later is "auxiliary stuff" that does not raise any consternation? If the context is just JBC running on JVM, then I'm right there with you. I'm not a big fan of JVM -- it's one layer removed from the metal too much for my comfort. But gcj makes native executables (I think; I haven't used gcj; my understanding is that it's just another front-end for GCC), so the JBC on JVM is not relevant. (And there's nothing wrong with byte code in certain contexts / problem domains. I have no problems with Lua bytecode, for example. And as I understand it, Perl scripts get compiled into Perl bytecode and then executed (interpreted?) by the Perl bytecode engine. And JBC on JVM for J2EE is clearly a big win, and much more palatable / tractable in the enterprise context.) Sincerely, --Eljay