ID:               24204
 Comment by:       thesin at users dot sf dot net
 Reported By:      php_public at macfreek dot nl
 Status:           Analyzed
 Bug Type:         Java related
 Operating System: Mac OS X (10.2.6)
 PHP Version:      4.3.2
 Assigned To:      kalowsky
 New Comment:

java builds fine on OSX, this is the how to

config:
./configure --with-java=/System/Library/Frameworks/
JavaVM.framework/Versions/1.3.1/Home

I chose 1.3.1 for compat, if you have 1.4.1 it can be 
used.

Patch the source like so:
  perl -pi -e 's,DL_FETCH_SYMBOL\(dl_handle\, 
\"JNI_CreateJavaVM\"\),DL_FETCH_SYMBOL\(dl_handle\, 
\"_JNI_CreateJavaVM_Impl\"\),g' ext/java/java.c  perl 
-pi -e 's,DL_FETCH_SYMBOL\(dl_handle\, 
\"JNI_GetDefaultJavaVMInitArgs\"\),DL_FETCH_SYMBOL\(dl_
handle\, \"_JNI_GetDefaultJavaVMInitArgs_Impl\"\),g' 
ext/java/java.c

and finally the config (php.ini):
java.home = /System/Library/Frameworks/
JavaVM.framework/Versions/1.3.1/Home
java.library = /System/Library/Frameworks/
JavaVM.framework/Versions/1.3.1/Libraries/libjvm.dylib

of course the java.class.path should equal the full 
path to php_java.jar

and I haven't figured out the java.library.path yet 
from what I've read it should point to the path where 
java.so is created and you should make a libphp_java.so 
symlink to java.so (Shared version)

this will get you to this error when I use the java 
stuff in a php file:

file:
  $system = new Java("java.lang.System");
  printf("Java version = %s\n", $system-
>getProperty("java.version"));

Error:
Fatal error:  java.lang.UnsatisfiedLinkError: no 
php_java in java.library.path

from reading it seems that LD_LIBRARY_PATH needs to be 
set but that env var doesn't exist on OS X, in it's 
place there is DYLD_LIBRARY_PATH and LIBRARY_PATH but 
neither fixed it for me, if anyone can figure this out 
please email me.


Previous Comments:
------------------------------------------------------------------------

[2003-06-26 15:17:47] [EMAIL PROTECTED]

I should move this to analyzed :)

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

[2003-06-26 15:16:24] [EMAIL PROTECTED]

Oddly enough this only occurs while building the CLI, I can build the
CGI just fine.  It looks like the -framework JavaVM is being lost in
the CLI version of the build.


Is there someone more knowledgable with the build structure, more
specifically the CLI, that can shed a little light on this?


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

[2003-06-16 12:43:59] php_public at macfreek dot nl

Oh yes, this is not the proper fix! That's why I called 
it an *ugly* workaround. ;-)

By the way, the file in php-4.3.2/sapi/servlet/
servlet.c will most likely have the same problem.

I would have expected Apple to have made a symbolic 
link from /usr/include/JavaVM/jni.h to whereever the 
file may reside in the most current release. However, 
that is not the case, and Java seem to be installed, so 
we apparently have to deal with whatever is available. 
The correct solution is probably to add the appropriate 
-I option to the linker, by altering the configure 
file.

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

[2003-06-16 07:43:53] [EMAIL PROTECTED]

The short of it is, those files are needed, but I believe you're
misunderstanding how frameworks work.  By specifying the full path you
are (potentially) invalidating future release of the JavaVM framework. 


The proper answer is to figure out why the jni.h file is not being used
by JavaVM framework.  I'll try to reproduce it later today.

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

[2003-06-16 07:10:17] php_public at macfreek dot nl

Description:
------------
In short, Java does not compile on Mac OS X, because 
the Java headers are at an other location then java.c 
expects them. configure does work.

Reproduce code:
---------------
On Mac OS X (Darwin):
./configure --with-java=/usr (you can leave the =/usr out).
make

Actual result:
--------------
/Users/freek/Downloads/php-4.3.2/ext/java/java.c:39:24: 
JavaVM/jni.h: No such file or directory

This is due to this code:
#if HAVE_JAVAVM_JAVAVM_H
#include <JavaVM/JavaVM.h>
#include <JavaVM/jni.h>
#define JNI_12
#else
#include <jni.h>
#endif

In php_config.h, the precompiler directive 
HAVE_JAVAVM_JAVAVM_H was set, even though there is no 
file on my system called JavaVM/JavaVM.h

As an ugly workaround, specifying the full path did 
work:
#include </System/Library/Frameworks/JavaVM.framework/
Versions/A/Headers/JavaVM.h>
#include </System/Library/Frameworks/JavaVM.framework/
Versions/1.3.1/Headers/jni.h

Apparently, jni.h is not in Java VM 1.4.1, which is 
also installed on Mac OS X. But to be honest, I got 
crazy about all symbolic links in /System/Library/
Frameworks/JavaVM.framework/


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


-- 
Edit this bug report at http://bugs.php.net/?id=24204&edit=1

Reply via email to