Saturday, January 29, 2011

Problems with Windows and the Scripting Editor

Hello All,

The Scripting Component for Open Wonderland (OWL) is one of the implementations for scripting that have been created by the OWL community. This implementation of scripting utilizes a scripting interface defined in JSR-223, Scripting for the Java Platform. This interface allows for the use of any scripting language that has a scripting engine that conforms to the JSR-223 specification, and there are a number of compliant scripting languages. For instance, usable languages include javascript, jython, jruby, sleep, php and java. This post will deal a bit with the problems involved with using java as a scripting language through the Scripting Component on Windows systems.

Ordinarily, java is not considered to be a scripting language but some helpful soul at Sun decided to create a JSR-223 compliant scripting engine to allow its usage. This was quite attractive to me when I was creating the UI for creating and managing scripts in OWL since I could use Netbeans to create a nice java program that I could then run as a script within the component. So, I happily sauntered along using my Mac to create and test the UI program while being completely oblivious to any difficulties with running a java script on Windows. Then people actually started trying to use the UI and I very rapidly was made aware of the fact that it wouldn't work on Windows. So, I cranked up my trusty old XP system and after a bit of poking I discovered that the problem was that javaws.exe, the program that implements the Web Start capability, was using the path to the JRE to run instead of the PATH to the JDK and when the scripting component was instructed to bring up the editor which is a java script, the javac.exe was nowhere to be found. The solution was to tell the javaws to use the JDK path but my fix turned out to be temporary since I was reconfiguring javaws itself. Then Nina (nnjones in the P2PU class) found that a reconfiguration of the browser would do a 'permanent' fix. Unfortunately, each person that wants to run the scripting editor on Windows has to resolve the problem on their system and also since the resolution has to do with the version of Windows and the browser used, there are lots of variations.

Here is the essence of the 'fix' that I just posted to a thread on the OWL forum about this problem:

thread -> http://groups.google.com/group/openwonderland/browse_thread/thread/3998957b6be51184

--------------------------------------------------------------------------------------------------


I have been working to try to resolve this problem with windows and the
scripting editor. I am using Vista so your results may vary. 

I have got it working with Firefox and Internet Explorer. 
1) Make sure that you have the JDK installed.
2) Make sure that your PATH environment variable does not have an entry for
the JRE and that it does have an entry for the JDK/bin directory.
3) In Firefox, go to Tools->Options->Applications tab. In the list of
Content Types, find the entry for JNLP File. Set the action for this item to
the javaws.exe that is in the JDK/bin directory. Save and exit. It should
now work.
4) In Internet Explorer, go to Tools->Internet Options->Programs->Set
Programs. Go to 'Associate a file type or protocol ...'. Find the line for
.jnlp file type and set the Current Default to the javaws.exe in the JDK/bin
directory. Save and exit. It should now work. 

-------------------------------------------------------------------------------------------------------------------------
In addition, I wanted to say a few more things about the scripting editor and other possible ideas about its use:

1) It is not mandatory to use the editor for creation or maintenance of scripts. Everything that is done with the editor can be done manually. All the scripts are stored on the OWL server using the 'webdav' api. The files are all stored in the .wonderland-server/[version]/run/content directory area and can be accessed by anyone with sufficient permissions to edit files at the server.

2) The editor is a script that is run through the JSR-223 interface and as such could be replaced by another script written in any of the supported languages.

I think a discussion of all this during the P2PU would be in order.

Morris

2 comments:

  1. I also think that a discussion on this has to happen. This module is very powerful and could enable non-Java developers to create content for the world, so I think we need to push it as much as we can!

    ReplyDelete
  2. I have added a new troubleshooting tip for this problem. So far it's worked for everybody: http://faithhold.dyndns.org:8080/JSPWiki/Wiki.jsp?page=Bots%20101#section-Bots+101-ProblemsInWindows7

    Cheers,
    José

    ReplyDelete