What can be done with an open source Java?
Since before JavaOne I’ve both asked and heard the question, “What can be done with an Open Source Java that cannot be done today?” Now, it seems that this question has been publicly asked, as Onno Kluyt, chairman of Sun’s JCP has just done in a recent article at MacWorld UK. To be very honest, I think this question is now a bit outdated. Now that the JCP rules allow for an open source implementation of Java, it is clear that we will have an open source implementation, no matter what Sun thinks about it. So we should start asking the next question: “What will Sun (and all the rest of us) do to have a complete and compatible open source implementation?” If we don't start now guaranteeing the compatibility of this open source implementation, then we, as a community, will face a huge problem. Since the question has been asked, let me start the discussion by listing the things we're looking for in Brazil, and the reason why we, as a country, are investing in the development of an open source implementation of Java. Although I did talk with Onno and others from Sun at JavaOne, and gave them basically these arguments, it is always good to make them clear: Distribution
We need the ability to distribute the JVM and the JRE. Sun's distribution policy is too restrictive. We want to distribute the JVM in any Linux distribution, repackage it so it can be updated remotely when the systems need update, and it can be integrated with whatever software system the OS uses. Why can MacOS users have their JVM updated "magically", and Windows users install theirs with one click, but Linux users cannot? As a developer, I need to ensure that my users will have very easy installation process, not the crappy do it yourself process that Linux has today. We want to distribute it even if there's a no value added application that needs it. And for systems for developers, we want to distribute the complete set of tools. In addition, I want to be able to distribute the VM, even if I'm including in the distribution components made to replace it, like a competing compatible VM. As a Government, I want the ability to distribute Java to all my citizens, no matter their OS preference. Sun's current policy essentially forbids all that. A Truly Free JVM
We want a complete JVM on free systems like Debian. We want Java to be really everywhere. The Free Linux distributions will not distribute a non-free VM, and as such, software developed for these distributions will not be done in Java. We need Java to be part of the core, so we can have all kinds of desktop applications written in Java. Keeping Java at the core
We want Java to be an important language for developing desktop and server applications in all systems, including the Free Linux distributions. We want to have interesting projects like Looking Glass, Eclipse, NetBeans, JBoss, Open4Biz, and so many other unbelievably cool open source Java projects to become core parts of the Linux distributions for every system. Write Once
We want to expand Open Office and other projects with Java! Open Office is the main office for free systems today. Open Office cannot really have Java as a core component because we don't have an open source implementation. This lack of an open source implementation precludes the inclusion of Java in this, and many other projects. This is an example of Sun’s restrictive licensing agreements that is hindering the fulfillment of the promise of Java. Run Everywhere
We want to port Java to other systems. As an example, I would love for Java to run on the Brazilian Electronic Voting Machine. It has a specific OS and a specific Hardware. This and many other systems could have a complete and compatible implementation if there was an open source implementation available. What does the future hold?
We want to guarantee that we have the rights to use it in the future. The Brazilian Government is using Java for many of its systems. How can we guarantee that we'll have a compatible implementation of Java if (for example) a resolution from the US Administration forbids Sun to do business with Brazil? How can we base our development in a technology with such possibility? The only way to guarantee the longevity we require is if we have an international community that can secure our long term use of an open source implementation. This is too problematic with a proprietary one. A true community process
We want it to be compatible! We don't want to just "do our own,” like so many open source projects that do most, but not all that is required to be compatible. We want to join the world wide community, and help create a full compatible implementation of Java. We want to be part of the JCP. Since an open source Java will be a reality, compatibility and cooperation are core issues. Support existing projects
And by the way, I don't really care if Sun open sources their VM or not. That's their decision. I think we in the Java community should rally together around the existing open source projects, AND help finish them. Go try out Kaffe, GCJ, or Classpath. Help by testing, developing, discussing. Help even by telling everybody that they exist. Go to open source events and tell everybody: you can do more today with the Classpath implementation (even though it’s incomplete) than you can do with many of the traditional open source languages. There's no reason not to use it! Sun, if you want to help…
If Sun wants to help, there are a few things it can do that have nothing to do with open sourcing their implementation: Change SCSL!
Please Onno, Jonathan, Scott: SCSL is terrible. It is slowing down the discussion on Java and Open Source. It forbids good people to work on guaranteeing compatibility of the open source VMs. And no, the recent Research License did not improve much, OK? It still has the same SCSL problems... |
<< Home