History log of /trunk/main/bridges/ (Results 51 - 75 of 105)
Revision (<<< Hide revision tags) (Show revision tags >>>)Date Author Comments
(<<< Hide modified files)
(Show modified files >>>)
c25219e005-Aug-2015 Pedro Giffuni

FreeBSD build fixes.

This allows out the box builds with gcc and to
simplify the build with clang and also the FreeBSD port.

From Don Lewis (FreeBSD port maintainer):

B

FreeBSD build fixes.

This allows out the box builds with gcc and to
simplify the build with clang and also the FreeBSD port.

From Don Lewis (FreeBSD port maintainer):

Because we need to use different CFLAGS for gcc and clang, I had to add
some compiler detection logic. On most platforms, the value of $(COM)
is either set statically by set_soenv, or set_soenv parses the compiler
name to figure out which compiler is being used and then set $(COM)
appropriately. The latter doesn't work for FreeBSD because cc could
either be gcc or clang. For FreeBSD, I added the compiler detection
logic to configure, which then passes that to set_soenv, in a somewhat
hackish manner.

When building with ports gcc on FreeBSD, we need to pass the rpath for
the gcc runtime to the linker. The FreeBSD port attempts to to this by
adding this information to LDFLAGS, which the openoffice configure
script then steps on, and in any case, this does not help the out of the
box build. My solution is to add some logic to configure to generate
the necessary linker flags, which it then passes to set_soenv for
inclusion in FreeBSD*Env.Set.sh.

On FreeBSD, the out of the box build needs to pass $LIBINTL_PREFIX in
the environment to the build phase. I added some code to configure to
figure out the value of this variable and to pass it to set_soenv for
inclusion in FreeBSD*Env.Set.sh so that this does not need to be done as
a extra step in the build.

Changing $(COM) from GCC to CLANG for clang builds caused a number
regressions elsewhere in the build framework. These were mostly caused
by the framework checking for $(COM) == GCC and $(OS) == FREEBSD, with
$(COM) == CLANG case unhandled. The fix was generally to just ignore
the value of $(COM) and only test the value of $(OS). One special case
was the bridgetest regression test, which started dumping core on INTEL
32-bit when built with clang. It turns out that this entire test is was
skipped for $(COM) == gcc, $(OS) == FREEBSD, and $(CPU) == I. Rather
than also skipping this test when building with clang, I tracked down
the failure to a particular subtest involving polymorphic structures
that also fails on OS/2 and tweaked the code to also skip that subtest
on FREEBSD INTEL (32-bit). Now bridgetest is run and passes on FreeBSD
with both gcc and clang, on both i386 and amd64.

Submitted by: Don Lewis


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1694132 13f79535-47bb-0310-9956-ffa450edef68

show more ...

2e13fcb726-Mar-2015 Pedro Giffuni

Huge update to the FreeBSD port (amd64 part).

Starting with FreeBSD 10, the FreeBSD project has moved from using
gcc/libstdc++ to using a complete C++ stack based on clang/llvm
libc+

Huge update to the FreeBSD port (amd64 part).

Starting with FreeBSD 10, the FreeBSD project has moved from using
gcc/libstdc++ to using a complete C++ stack based on clang/llvm
libc++ and libcxxrt. This new stack has better standards compliance
and has huge similarities with MacOSX but it brought subtle low
level problems for our outdated bridges code.

Don Lewis has done a brave effort to update this code and
has done extensive testing within FreeBSD port. Support
for older versions of gcc has been dropped.

Code Review:
https://reviews.freebsd.org/D2108
https://reviews.freebsd.org/D2055

Author: Don Lewis (truckman at FreeBSD)


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1669459 13f79535-47bb-0310-9956-ffa450edef68

show more ...

baf6650d26-Mar-2015 Pedro Giffuni

Huge update to the FreeBSD port (i386 part).

Starting with FreeBSD 10, the FreeBSD project has moved from using
gcc/libstdc++ to using a complete C++ stack based on clang/llvm
libc++

Huge update to the FreeBSD port (i386 part).

Starting with FreeBSD 10, the FreeBSD project has moved from using
gcc/libstdc++ to using a complete C++ stack based on clang/llvm
libc++ and libcxxrt. This new stack has better standards compliance
and has huge similarities with MacOSX but it brought subtle low
level problems for our outdated bridges code.

Don Lewis has done a brave effort to update this code and
has done extensive testing within FreeBSD port. Support
for older versions of gcc has been dropped.

Code Review:
https://reviews.freebsd.org/D2108
https://reviews.freebsd.org/D2055

Author: Don Lewis (truckman at FreeBSD)


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1669457 13f79535-47bb-0310-9956-ffa450edef68

show more ...

76cf606906-Jul-2014 Pedro Giffuni

Add initial support for FreeBSD PPC using gcc.

This is just the skeleton and required bridge support based
on linux-ppc. Currently untested.


git-svn-id: https://svn.apache.

Add initial support for FreeBSD PPC using gcc.

This is just the skeleton and required bridge support based
on linux-ppc. Currently untested.


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1608245 13f79535-47bb-0310-9956-ffa450edef68

show more ...

ae90bea216-Jun-2014 Pedro Giffuni

Fix mismatch from a mismatched patch.

git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1602791 13f79535-47bb-0310-9956-ffa450edef68

892b8f2030-Apr-2014 Pedro Giffuni

Fix build with gcc on FreeBSD-i386.

There is an issue building the bridges module with newer versions
of gcc. Merge a local workaround for gcc used in amd64 (r1424178)
to fix the bui

Fix build with gcc on FreeBSD-i386.

There is an issue building the bridges module with newer versions
of gcc. Merge a local workaround for gcc used in amd64 (r1424178)
to fix the build.

Reference:
http://www.freebsd.org/cgi/query-pr.cgi?pr=ports/187218


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1591501 13f79535-47bb-0310-9956-ffa450edef68

show more ...

07a3d7f129-Apr-2014 Pedro Giffuni

Many spelling fixes: directories a* - g*.

Attempt to clean up most but certainly not all the spelling
mistakes that found home in OpenOffice through decades. We
could probably blame

Many spelling fixes: directories a* - g*.

Attempt to clean up most but certainly not all the spelling
mistakes that found home in OpenOffice through decades. We
could probably blame the international nature of the code but
it is somewhat shameful that this wasn't done before.


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1591058 13f79535-47bb-0310-9956-ffa450edef68

show more ...


inc/bridges/cpp_uno/bridge.hxx
inc/bridges/cpp_uno/shared/vtablefactory.hxx
source/cpp_uno/cc50_solaris_intel/cpp2uno.cxx
source/cpp_uno/cc50_solaris_intel/except.cxx
source/cpp_uno/cc50_solaris_intel/uno2cpp.cxx
source/cpp_uno/cc50_solaris_sparc/cpp2uno.cxx
source/cpp_uno/cc50_solaris_sparc/except.cxx
source/cpp_uno/cc50_solaris_sparc/uno2cpp.cxx
source/cpp_uno/gcc3_freebsd_intel/cpp2uno.cxx
source/cpp_uno/gcc3_freebsd_intel/except.cxx
source/cpp_uno/gcc3_freebsd_intel/uno2cpp.cxx
source/cpp_uno/gcc3_freebsd_x86-64/cpp2uno.cxx
source/cpp_uno/gcc3_freebsd_x86-64/except.cxx
source/cpp_uno/gcc3_freebsd_x86-64/uno2cpp.cxx
source/cpp_uno/gcc3_linux_alpha/cpp2uno.cxx
source/cpp_uno/gcc3_linux_alpha/uno2cpp.cxx
source/cpp_uno/gcc3_linux_arm/cpp2uno.cxx
source/cpp_uno/gcc3_linux_arm/except.cxx
source/cpp_uno/gcc3_linux_arm/uno2cpp.cxx
source/cpp_uno/gcc3_linux_hppa/cpp2uno.cxx
source/cpp_uno/gcc3_linux_hppa/except.cxx
source/cpp_uno/gcc3_linux_hppa/uno2cpp.cxx
source/cpp_uno/gcc3_linux_ia64/cpp2uno.cxx
source/cpp_uno/gcc3_linux_ia64/uno2cpp.cxx
source/cpp_uno/gcc3_linux_intel/cpp2uno.cxx
source/cpp_uno/gcc3_linux_intel/except.cxx
source/cpp_uno/gcc3_linux_intel/uno2cpp.cxx
source/cpp_uno/gcc3_linux_m68k/cpp2uno.cxx
source/cpp_uno/gcc3_linux_m68k/except.cxx
source/cpp_uno/gcc3_linux_m68k/uno2cpp.cxx
source/cpp_uno/gcc3_linux_mips/cpp2uno.cxx
source/cpp_uno/gcc3_linux_mips/except.cxx
source/cpp_uno/gcc3_linux_mips/uno2cpp.cxx
source/cpp_uno/gcc3_linux_powerpc/cpp2uno.cxx
source/cpp_uno/gcc3_linux_powerpc/uno2cpp.cxx
source/cpp_uno/gcc3_linux_powerpc64/cpp2uno.cxx
source/cpp_uno/gcc3_linux_powerpc64/uno2cpp.cxx
source/cpp_uno/gcc3_linux_s390/cpp2uno.cxx
source/cpp_uno/gcc3_linux_s390/uno2cpp.cxx
source/cpp_uno/gcc3_linux_s390x/cpp2uno.cxx
source/cpp_uno/gcc3_linux_s390x/uno2cpp.cxx
source/cpp_uno/gcc3_linux_sparc/cpp2uno.cxx
source/cpp_uno/gcc3_linux_sparc/except.cxx
source/cpp_uno/gcc3_linux_sparc/uno2cpp.cxx
source/cpp_uno/gcc3_linux_x86-64/cpp2uno.cxx
source/cpp_uno/gcc3_linux_x86-64/except.cxx
source/cpp_uno/gcc3_linux_x86-64/uno2cpp.cxx
source/cpp_uno/gcc3_macosx_intel/cpp2uno.cxx
source/cpp_uno/gcc3_macosx_intel/except.cxx
source/cpp_uno/gcc3_macosx_intel/uno2cpp.cxx
source/cpp_uno/gcc3_macosx_powerpc/cpp2uno.cxx
source/cpp_uno/gcc3_macosx_powerpc/uno2cpp.cxx
source/cpp_uno/gcc3_netbsd_intel/cpp2uno.cxx
source/cpp_uno/gcc3_netbsd_intel/except.cxx
source/cpp_uno/gcc3_netbsd_intel/uno2cpp.cxx
source/cpp_uno/gcc3_os2_intel/cpp2uno.cxx
source/cpp_uno/gcc3_os2_intel/except.cxx
source/cpp_uno/gcc3_os2_intel/uno2cpp.cxx
source/cpp_uno/gcc3_solaris_intel/cpp2uno.cxx
source/cpp_uno/gcc3_solaris_intel/except.cxx
source/cpp_uno/gcc3_solaris_intel/uno2cpp.cxx
source/cpp_uno/gcc3_solaris_sparc/cpp2uno.cxx
source/cpp_uno/gcc3_solaris_sparc/except.cxx
source/cpp_uno/gcc3_solaris_sparc/uno2cpp.cxx
source/cpp_uno/mingw_intel/cpp2uno.cxx
source/cpp_uno/mingw_intel/except.cxx
source/cpp_uno/mingw_intel/uno2cpp.cxx
source/cpp_uno/msvc_win32_intel/cpp2uno.cxx
source/cpp_uno/msvc_win32_intel/except.cxx
source/cpp_uno/msvc_win32_intel/uno2cpp.cxx
source/cpp_uno/s5abi_macosx_x86-64/cpp2uno.cxx
source/cpp_uno/s5abi_macosx_x86-64/except.cxx
source/cpp_uno/s5abi_macosx_x86-64/uno2cpp.cxx
source/cpp_uno/shared/component.cxx
source/jni_uno/jni_base.h
source/jni_uno/jni_bridge.cxx
source/jni_uno/jni_java2uno.cxx
source/jni_uno/jni_uno2java.cxx
Revision tags: AOO410
03c0a2df28-Mar-2014 Herbert Dürr

#i124421# use OSL_ debug helpers instead of tools DBG_ stuff

git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1582709 13f79535-47bb-0310-9956-ffa450edef68

53858dc427-Mar-2014 Herbert Dürr

#i124421# disable generated type_info for the OSX64 uno bridge

When the dynamic loading of the type_info symbols failed the UNO bridge
synthesized type_info objects itself. The synthesiz

#i124421# disable generated type_info for the OSX64 uno bridge

When the dynamic loading of the type_info symbols failed the UNO bridge
synthesized type_info objects itself. The synthesized ones trigger the
crash observed so we disable their generation and handle the result
gracefully.


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1582359 13f79535-47bb-0310-9956-ffa450edef68

show more ...

Revision tags: AOO410_Beta
dc9e41dd13-Feb-2014 Herbert Dürr

#i124086# preserve 16byte stack alignment in gcc3-solaris-intel's uno2cpp bridge

Patch-by: Apostolos Syropoulos <asyropoulos123@hotmail.com>
Review-by: Herbert Dürr <hdu@apache.org>

#i124086# preserve 16byte stack alignment in gcc3-solaris-intel's uno2cpp bridge

Patch-by: Apostolos Syropoulos <asyropoulos123@hotmail.com>
Review-by: Herbert Dürr <hdu@apache.org>


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1567914 13f79535-47bb-0310-9956-ffa450edef68

show more ...

0848378b04-Feb-2014 Herbert Dürr

#i123862# use O*String's isEmpty() method to check for emptiness in modules starting with 'b'

Patch-by: j.nitschke@ok.de
Review-by: hdu@apache.org


git-svn-id: https://svn.a

#i123862# use O*String's isEmpty() method to check for emptiness in modules starting with 'b'

Patch-by: j.nitschke@ok.de
Review-by: hdu@apache.org


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1564230 13f79535-47bb-0310-9956-ffa450edef68

show more ...

9310f8ce12-Dec-2013 Herbert Dürr

#i122195# fix leak when handling exceptions in the UNO bridge for OSX 64bit


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1550381 13f79535-47bb-0310-9956-ffa450edef68

d62fe53b11-Dec-2013 Herbert Dürr

#i122195# adapt bridges build.lst to renamed bridge

git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1550058 13f79535-47bb-0310-9956-ffa450edef68

51a1e52e10-Dec-2013 Herbert Dürr

#i122195# provide proper type_info for UNO exceptions on OSX 64bit

on OSX 64bit the class_type_info classes are specified
in http://refspecs.linuxbase.org/cxxabi-1.86.html#rtti but
t

#i122195# provide proper type_info for UNO exceptions on OSX 64bit

on OSX 64bit the class_type_info classes are specified
in http://refspecs.linuxbase.org/cxxabi-1.86.html#rtti but
these details are not generally available in a public header
of most development environments. So we define them locally.


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1549940 13f79535-47bb-0310-9956-ffa450edef68

show more ...

6d1ed1dd10-Dec-2013 Herbert Dürr

#122195# change cppu env, comid from generic cxx to s5abi (System 5 AMD64 ABI)

Patch by: Juergen Schmidt <jsc@apache.org>

Merged from r1534063 in the rejuvenate01 branch


#122195# change cppu env, comid from generic cxx to s5abi (System 5 AMD64 ABI)

Patch by: Juergen Schmidt <jsc@apache.org>

Merged from r1534063 in the rejuvenate01 branch


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1549925 13f79535-47bb-0310-9956-ffa450edef68

show more ...

Revision tags: AOO401, AOO400
6bb33f8606-May-2013 Herbert Dürr

allow non-gcc to build the mac-i386 UNO bridge

git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1479516 13f79535-47bb-0310-9956-ffa450edef68

fea2173f30-Apr-2013 Herbert Dürr

adapt the optimization fix to UNO bridge's callVirtualMethod() for FreeBSD and Linux

adapted from the the fix to OSX 64bit's UNO bridge (in r1477588):
if the pCallStack variable is optim

adapt the optimization fix to UNO bridge's callVirtualMethod() for FreeBSD and Linux

adapted from the the fix to OSX 64bit's UNO bridge (in r1477588):
if the pCallStack variable is optimized out then any assumptions of the
method's inlined assembler about stack layout collapse. Adding a pseudo
dependency to the pCallStack variable solves that problem.


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1477604 13f79535-47bb-0310-9956-ffa450edef68

show more ...

484ad1f230-Apr-2013 Herbert Dürr

#i122195# fix build problems in the OSX64 UNO bridge


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1477591 13f79535-47bb-0310-9956-ffa450edef68

d6bfa59d30-Apr-2013 Herbert Dürr

#i122195# fix OSX64 UNO bridge's privateSnippetExecutor() for high optimization levels

the inline assembler clobbers r10 too


git-svn-id: https://svn.apache.org/repos/asf/openof

#i122195# fix OSX64 UNO bridge's privateSnippetExecutor() for high optimization levels

the inline assembler clobbers r10 too


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1477590 13f79535-47bb-0310-9956-ffa450edef68

show more ...

3f6fbc8330-Apr-2013 Herbert Dürr

#i122195# fix OSX64 UNO bridge's callVirtualMethod() for high optimization levels

if the pCallStack variable is optimized out then any assumptions of the
method's inlined assembler about

#i122195# fix OSX64 UNO bridge's callVirtualMethod() for high optimization levels

if the pCallStack variable is optimized out then any assumptions of the
method's inlined assembler about stack layout collapse. Adding a pseudo
dependency to the pCallStack variable solves that problem.


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1477588 13f79535-47bb-0310-9956-ffa450edef68

show more ...

1466499a29-Apr-2013 Herbert Dürr

#i121715# let the C++ compiler do the C++ exception handling

the manually created exception handling tables are not supported for MACH-objects
used on MacOSX. Rather than porting them ma

#i121715# let the C++ compiler do the C++ exception handling

the manually created exception handling tables are not supported for MACH-objects
used on MacOSX. Rather than porting them manually or half-manually e.g. using
LLVM-intrinsics the compiler is happy to do the work for us for C++ methods
even if they only contain inline assembler (wrapped by the compiler generated
frame setup code, of course).


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1476937 13f79535-47bb-0310-9956-ffa450edef68

show more ...

2755751f29-Apr-2013 Herbert Dürr

#i121715# add a CxxAbi compatible UNO bridge for 64bit MacOSX

the calling conventions on 64bit Mac follow the sysv-abi for AMD64 like
the FreeBSD and the Linux ports, so basing this brid

#i121715# add a CxxAbi compatible UNO bridge for 64bit MacOSX

the calling conventions on 64bit Mac follow the sysv-abi for AMD64 like
the FreeBSD and the Linux ports, so basing this bridge on the one from
FreeBSD saved some time. Thanks to Pedro Giffuni for this suggestion!

Some modififications were needed regarding symbol names, the layout of
unwind and exception structures, the missing derivatives of type_info
and vtable-offsets. The eh_frame specific stuff is not converted yet.


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1476927 13f79535-47bb-0310-9956-ffa450edef68

show more ...

d65a224223-Apr-2013 Herbert Dürr

add some documentation links to the assembler needed for the infamous UNO bridges

ceterum censeo: good old C-linkage interoperability would be much more robust,
reliable and easier to ma

add some documentation links to the assembler needed for the infamous UNO bridges

ceterum censeo: good old C-linkage interoperability would be much more robust,
reliable and easier to maintain compared to the current UNO-bridges approach
of emulating the behaviour of the individual compiler, linker, dylib, unwind, etc.
environments and thus being extremely platform specific. What an incredible waste
of energy for little (if any) gain. SCNR.


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1470937 13f79535-47bb-0310-9956-ffa450edef68

show more ...

bfa8fc8717-Apr-2013 Herbert Dürr

search for own abi.hxx header which is not in the system headers


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1468863 13f79535-47bb-0310-9956-ffa450edef68

476b544117-Apr-2013 Herbert Dürr

avoid terminate being called because of missing unwind tables in the Linux AMD64 bridge

The interesting discussion in http://gcc.gnu.org/ml/gcc/2012-03/threads.html#00455
pointed to the

avoid terminate being called because of missing unwind tables in the Linux AMD64 bridge

The interesting discussion in http://gcc.gnu.org/ml/gcc/2012-03/threads.html#00455
pointed to the fnon-call-exception option to solve this problem. Thanks to Stephan
for starting this fruitful mailing list thread.


git-svn-id: https://svn.apache.org/repos/asf/openoffice/trunk@1468857 13f79535-47bb-0310-9956-ffa450edef68

show more ...

12345