Hello there,
We are having an issue with compilation differences between GCC 3.3
and 4.0, OS 10.4.10, on PowerPC using 10.3.9 SDK, on Intel using
10.4u SDK.
We are working with the JRex library to embed Gecko framework in a
Universal Java application. When we compile using GCC 3.3, the
appropriate dynamic libraries are created without problem and
packaged into a Java application bundle, which launches correctly.
But when we compile the same code with GCC 4.0, the dynamic libraries
are created, but fail to load into our Java application correctly. We
see some strange behaviours when using GDB, that occur every time the
program is run, and only in very specific places in the large codebase:
On PPC, a C++ function is called
nsIXPConnect *xpc = nsContentUtils::XPConnect();
but returns null. nsContentUtils::XPConnect is defined as:
static nsIXPConnect *XPConnect()
{
return sXPConnect;
}
When we follow the call with GDB we notice that there are two
sXPConnect symbols...
On Intel, another C++ function is called:
nsresult rv = CallGetService(NS_SCRIPTSECURITYMANAGER_CONTRACTID,
&sSecurityManager);
but the call results in sSecurityManager null. We follow the call
with GDB and see correct values and code flow until this function
return, where it mysteriously "drops" the value to be assigned to
sSecurityManager.
Even more mysteriously, if we move the program counter back with GDB
and repeat the function a second time, it returns the value for
sSecurityManager correctly!
Have any of you guys encountered such behaviour before?
Thanks for any help,
Zoltan Foley-Fisher
Atimi Software Inc.