Monday, March 30, 2009

Switching between different Java versions, Java 5 instead of Java 6

Since like many of you I am developing multiple projects simultaneously and have a very heterogeneous environment on my Windows machine, I always looked for a simple way to switch between the latest Java version and the previous one, which I still needed for some older projects.
Once installed, the latest JRE/JDK (currently, Java 6) become the JVM of choice for any app in Windows OS and it was quite tricky for me to force an app to be executed under Java 5.

I saw many posts on the Internet claiming they solved the issue by manually
editing Windows registry and/or replacing soem files in Windows/system32 directory - never wanted to do that.

This post is probably the closest to what I wanted to do, however the code from this post did not work 'as is' in my batch files.

Looking at java.exe command options in Java 6 I found an amazing feature:
-version:

This is what the command line java says about it:
-version:
require the specified version to run

Sounds just what I needed! So I run it like this:
>java -version:1.5.0_17 -version

And voila! - here is what says my Java 6 now:
java version "1.5.0_17"
Java(TM) 2 Runtime Environment, Standard Edition (build 1.5.0_17-b04)
Java HotSpot(TM) Client VM (build 1.5.0_17-b04, mixed mode)


Of course if I run it with just -version (no ":" and no alternative JRE/JDK), it keeps saying:
> java -version
java version "1.6.0_12"
Java(TM) SE Runtime Environment (build 1.6.0_12-b04)
Java HotSpot(TM) Client VM (build 11.2-b01, mixed mode, sharing)

Sunday, March 01, 2009

NetBeans debugger does not stop on breakpoints

If NetBeans shows you that a debugger is running, however you can not stop it on breakpoint and the "Set In/Step Out /etc" menu is grayed out, it quite sure means that your debugger is not properly configured. Follow this post to configure your debugger to work with NetBeans properly.

Configuring Xdebug with XAMPP for NetBeans and Eclipse, Windows 7 and Win XP

UPDATE: Since XAMPP 1.7.2 + PHP 5.3 the things get much easier. Here is the quote from NetBeans web site, and it works! With this XAMPP version the only php.ini is located in \php

Xdebug on XAMPP 1.7.2 (PHP 5.3)

  1. Locate and open XAMPP_HOME\php\php.ini for editing. This is the only php.ini file in XAMPP 1.7.2.
  2. Find and uncomment the line zend_extension = "XAMPP_HOME\php\ext\php_xdebug.dll".
  3. Find and uncomment the line xdebug.remote_host=localhost. Change the value of the setting from localhost to 127.0.0.1.
  4. Find and uncomment the line xdebug.remote_enable = 0. Change 0 to 1.
  5. Find and uncomment the line xdebug.remote_handler = "dbgp".
  6. Find and uncomment the line xdebug.remote_port = 9000.
  7. Save php.ini.
  8. Restart the Apache server.

============ For old XAMP 1.7.0 ==================================
Installing NetBeans was easy. The more difficult part was configuring and making the PHP debugger work.
I have XAMPP installation on my Win XP and NetBeans uses Xdebug (http://www.xdebug.org), so I assumed it will be quite easy to configure all the stuff. Well, it was not that easy just because there is a missing link in NetBeans docs speaking about Xdebug config with XAMPP.

For XAMPP you should work with [xamp-dir]/php/php.ini. In fact there is another php.ini in /apache/bin - do not worry aboput it, it is just a shortcut to the first one.

First, make sure that anything in Zend section in your php.ini is commented out:

[Zend]
;zend_extension_ts = "C:\xampp\php\zendOptimizer\lib\ZendExtensionManager.dll"
;zend_extension_manager.optimizer_ts = "C:\xampp\php\zendOptimizer\lib\Optimizer"
;zend_optimizer.enable_loader = 0
;zend_optimizer.optimization_level=15
;zend_optimizer.license_path =
; Local Variables:
; tab-width: 4
; End:


Next, (IMPORTANT!) find the line
extension=php_xdebug.dll

and comment it out, so it becomes to be
;extension=php_xdebug.dll

That's seems strange and illogical, but trust me you must do it to get the things work. This is missed from most posts / threads RE Xdebug / Xampp, only few of them mention it.

Next, edit Xdebug section of your php.ini to look like:

XDebug]
;; Only Zend OR (!) XDebug
zend_extension_ts="C:\xampp\php\ext\php_xdebug.dll"

xdebug.remote_enable=1
xdebug.remote_host=127.0.0.1
xdebug.remote_portjavascript:void(0)=9000
xdebug.remote_mode=req
xdebug.remote_handler=dbgp
xdebug.profiler_enable=1
xdebug.profiler_output_dir="C:\xampp\tmp"

Now, restart Apache and point your browser to a PHP file with phpinfo().
You should see that xdebug appears twice in your phpinfo():
- once near the Zend Engine 2 logo, with text similar to

This program makes use of the Zend Scripting Language Engine:
Zend Engine v2.2.0, Copyright (c) 1998-2007 Zend Technologies
with Xdebug v2.0.4, Copyright (c) 2002-2008, by Derick Rethans

- and the second time much lower at that page, with the tables showing something like:

xdebug
xdebug support enabled
Version 2.0.4

Supported protocols Revision
DBGp - Common DeBuGger Protocol $Revision: 1.125.2.6 $
GDB - GNU Debugger protocol $Revision: 1.87 $
PHP3 - PHP 3 Debugger protocol $Revision: 1.22 $


If you do not see either of this appearances your configuration is incorrect!
Also, if you see the table with "Xdebug support" text, but there is a text saying "XDEBUG IS NOT INSTALLED AS ZEND EXTENSION" your configuration should be fixed.

Now, if you are done with that, go to Xdebug web and pick one of the latest Xdebug dlls. Put it in your [xampp-dir]/php/ext folder and change in php.ini the line

zend_extension_ts="C:\xampp\php\ext\php_xdebug.dll"
to point to the new dll, i.e.
zend_extension_ts="C:\xampp\php\ext\php_xdebug-2.0.4-5.2.8.dll"

"_ts" means thread safe, so you need a thread-safe dll version from Xdebug web.
Note that NOT all thread safe version found there will work with XAMPP. I am not sure why, but from the latest release only php_xdebug-2.0.4-5.2.8.dll works as it is expected, others e.g. php_xdebug-2.0.3-5.3.0.dll or php_xdebug-2.0.4-5.3.0-vc9.dll just does not worked for me, showing "XDEBUG IS NOT INSTALLED AS ZEND EXTENSION" or just disappearing from the phpinfo() at all.

Now save php.ini, restart Apache and verify that you see Xdebug info in two locations in phpinfo(), like it is explained above. If you got it working, both NetBeans and Eclipse PDT will be able to work with Xdebug now