Friday, October 17, 2008

Dabu!

This, I think, will be my last post in this blog.

We have "finished" - at least for this term. There is obviously plenty of work that still needs to be done, but for the most part, our job concluded on Wednesday when we gave our final presentation to the people at Sun Microsystems. Everyone who spoke with us following the presentation said that they were impressed and thought we did a great job, which is awesome. Now we just need to tell Heineman to give us an A. :)

So, for those of you who actually read this blog but missed the presentation, I'll fill you in a little bit. Our out-of-the-box experience is delivered in "stages." First, we wrap up the entire install process into a single double-click jar file. After everything is installed, we wanted to "wow" new users so we show them the Project Snowman game (which uses Project Darkstar) that has been developed in-house by Keith, Owen, Yi, and Jeff. The run process required that you have Ant installed, so we wrote a platform-independant launcher to run it in a single-click process. Once the user has gotten a chance to play around with an actual game, we teach them the API and let them start writing Project Darkstar code through the use of a set of basic tutorials. These tutorials cover every aspect of the API and when completed produce a very basic but functional server and client application that users can run and play around with. Finally, after they get a chance to learn the API, we have an optional "challenge" tutorial. This tutorial starts with a stipped-down version of the Project Snowman game and has users implement the different aspects of its server and client code. The idea behind this tutorial being to teach users what it takes to make a fully functional game using Project Darkstar.

I mentioned that there was more work to be done. Some of this will be accomplished in the beginning of B term. We want to give the tutorials to several of the Sun employees who work on Project Darkstar to get their feedback. Also, we would like to test our tutorials on several other students at WPI to see how the out-of-the-box experience pans out with them. We also need to write the paper for our MQP. The rest is out of our hands. Once we have these final pieces completed, everything will be released to the public and open-sourced to the community. There are also plans to use our tutorials at schools and universities across the country for Sun-sponsored game jams and events, which is exciting. So, yeah. The future is bright.

So, what did I learn from all this? One of the suprising things about my MQP is that even though I'm a CS major I wrote a very small amount of the actual code that was produced. This was NOT because I was incapable or didn't want to, I can assure you. Rather, I just got unlucky. Whenever code was necessary I was already working on some other task. So I didn't write that much code. I reprise: what did I learn, then?
Even though I didn't write that much code, I definately did a lot of reading. Early on, I looked at jMonkeyEngine. Even then, I didn't like it; however, comparing something like jME to Project Darkstar you can really see the difference between a massive pile of classes and an actual API. Seeing all the Darkstar code and hearing everyone at Sun comment on it has really given me a better understanding of what it takes to create a good API, and not just an API, but the underlying framework as well. I've gotten a chance to hear from some of the smartest people in the industry and see how they work in a lab setting, which I probably would not have done without this MQP. I've also learned a lot more about Java and JVM in general. Oh, and a few things about different operating systems just because everything we did had to be platform independant.

In the end, I think I've had a really good time working at Sun, and the experience has only improved the more time I spent working there. I hope that the work that my group and I have done will be beneficial to the future of Project Darkstar.


To top off my final post, I give you one last movie. It is .... how should I say it .... thrilling.

Adieu.

Wednesday, October 1, 2008

Me busy! Leave me alone!

So after a discussion with our advisor on Friday, a conclusion has been reached regarding the issue I spoke about in my last blog post. We're going to take the best of both worlds: Have a pre-defined project file (in NetBeans) included and then also specify a tutorial that will teach people how to create thier own project files. This tutorial will teach people about what is required to develop Darkstar applications from within multiple IDE's, namely NetBeans and Eclipse. Also, I added a section detailing what is required outside of IDE development as well. I was going to create pre-made projects for Eclipse as well, but the way Eclipse's project files are set up, you cannot have projects that are sharable without redefining required libraries. I was honestly suprised and slightly dissapointed at this, as it is a major downfall of what is normally a very solid IDE. However, we still always have the tutorial for creating Eclipse projects, so for now it will do.

Anyways. What have I been up to lately? Well, as the title suggests, I HAVE been pretty busy over the past several days (this is also one of the few times when the title actually made some sense). Basically I've been writing, writing, writing, and writing. Oh, and writing; can't forget about that one. And by writing I don't mean coding; I mean writing out project documents in text files. About a week ago when me and my project partners divied out tasks for the week, my friend and I were split between two tasks: writing the code for the tutorials and writing the actual text for them. He offered me the choice, and at the time I didn't care so we flipped a coin to determine who would do what.

Sometimes I really wish I had just chosen to write the code.

Writing each individual tutorial took much longer than expected. Even though there wasn't a lot of code I had to explain in detail every possible thing that was going on in order not to confuse the user. One of the things I keep in mind when I write them is that if I leave anything, anything at all, unexplained or amiguous then there is at least one user out there who is not going to get it, run in to problems, get confused /frustrated, and give up. And that means we've failed to provide an adequate out-of-the-box experience. Also, too much text can overwhelm the reader even if what is being explained is fairly trivial. So it's a tricky balance to get everything perfect.

Fortunately, I'm not the only person working on it. While I did all the text, my group members looked at it and made edits, suggestions, etc. I want to go over it one more time but so far I think it's really coming along. The tutorials are now in the process of being formatted into HTML documents, and I have to say, they look VERY nice. I'm truly impressed and pleased to see the results which so far have exceeded my expectations which usually doesn't happen that often, at least for me.

So thing have been coming along and I think we've made a lot of progress over a short time frame; however, there is still a lot that needs to get done. Mainly, I am slightly worried about the actual Snowman tutorials but as of right now I don't think I have enough information to comment on the status of those. We'll how it turns out, I guess.


Indeed.