41faa44b02
2009-09-22 21:19:24 +0200 cmc r276365 : #i100000# that's the most plausible explanation, -D$(CVER) is needed by scp2 under windows 2009-09-19 16:10:36 +0200 cmc r276303 : #i100000# revert this for no partically good reason 2009-09-18 14:16:47 +0200 cmc r276279 : remove extra build depend 2009-09-18 08:56:15 +0200 cmc r276265 : #i100000# rerun autoconf 2009-09-17 14:59:38 +0200 cmc r276245 : CWS-TOOLING: rebase CWS cmcfixes62 to trunk@276192 (milestone: DEV300:m59) 2009-09-10 16:40:49 +0200 pl r276041 : fix warning 2009-09-10 11:34:55 +0200 pl r276026 : disable warning from system header 2009-09-09 19:30:45 +0200 pl r276013 : use osl_getAsciiFunctionSymbol instead of strange cast 2009-09-09 19:25:32 +0200 pl r276012 : add some casting hacks to make compile on solaris cc 2009-09-09 19:10:48 +0200 pl r276009 : add missing Configure option for solaris sparce 32bit 2009-09-09 18:37:05 +0200 pl r276008 : merge fix for #i104525# into moved code 2009-09-07 13:28:08 +0200 cmc r275894 : CWS-TOOLING: rebase CWS cmcfixes62 to trunk@275801 (milestone: DEV300:m57) 2009-08-28 12:36:27 +0200 cmc r275523 : CWS-TOOLING: rebase CWS cmcfixes62 to trunk@275331 (milestone: DEV300:m56) 2009-08-26 12:56:18 +0200 cmc r275413 : #i104088# use the right headers in the right place 2009-08-25 17:07:50 +0200 cmc r275372 : #i104500# make openssl build on linux that isn't x86 or x86_64 2009-08-25 13:08:48 +0200 cmc r275347 : #i89237# pretty picswitch up 2009-08-25 10:58:09 +0200 cmc r275342 : #i104489# remove last unused code in starmath 2009-08-25 10:23:33 +0200 cmc r275338 : #i104088# clean up the define post-move 2009-08-24 13:46:57 +0200 cmc r275310 : #i104088# 64bit odbc api changes 2009-08-24 13:42:52 +0200 cmc r275309 : #i89237# unify linux platform mks under a generic parent 2009-08-24 13:19:52 +0200 cmc r275307 : #i104455# remove unused code 2009-08-24 13:10:56 +0200 cmc r275306 : #i104088# 64bit odbc api changes 2009-08-24 10:07:50 +0200 cmc r275293 : #i104306# move recent-used to vcl 2009-08-24 09:32:08 +0200 cmc r275291 : #i104306# move recent-used to vcl 2009-08-23 22:01:07 +0200 cmc r275286 : #i104306# move recently-used to vcl 2009-08-22 15:25:25 +0200 cmc r275285 : #i104088# 64bit odbc api changes 2009-08-21 17:52:40 +0200 cmc r275268 : #i104306# move recently-used to vcl 2009-08-21 14:38:26 +0200 cmc r275257 : #i104408 make these headers ready for c++0x 2009-08-21 14:20:19 +0200 cmc r275251 : #i104406# avoid overlapping strcpy to avoid bustage on recent toolchains 2009-08-21 14:14:25 +0200 cmc r275250 : #i104385# silence 64bit warnings
259 lines
7.9 KiB
Makefile
259 lines
7.9 KiB
Makefile
#*************************************************************************
|
|
#
|
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
#
|
|
# Copyright 2008 by Sun Microsystems, Inc.
|
|
#
|
|
# OpenOffice.org - a multi-platform office productivity suite
|
|
#
|
|
# $RCSfile: unxlngi6.mk,v $
|
|
#
|
|
# $Revision: 1.48 $
|
|
#
|
|
# This file is part of OpenOffice.org.
|
|
#
|
|
# OpenOffice.org is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU Lesser General Public License version 3
|
|
# only, as published by the Free Software Foundation.
|
|
#
|
|
# OpenOffice.org is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU Lesser General Public License version 3 for more details
|
|
# (a copy is included in the LICENSE file that accompanied this code).
|
|
#
|
|
# You should have received a copy of the GNU Lesser General Public License
|
|
# version 3 along with OpenOffice.org. If not, see
|
|
# <http://www.openoffice.org/license.html>
|
|
# for a copy of the LGPLv3 License.
|
|
#
|
|
#*************************************************************************
|
|
|
|
# generic mk file for unxlng (unix linux glibc)
|
|
ASM*=
|
|
AFLAGS*=
|
|
SOLAR_JAVA*=
|
|
# default optimization level for product code
|
|
CDEFAULTOPT*=-O2
|
|
# architecture dependent flags for the C and C++ compiler that can be changed by
|
|
# exporting the variable ARCH_FLAGS="..." in the shell, which is used to start build
|
|
ARCH_FLAGS*=
|
|
# position independent code switch
|
|
PICSWITCH*:=-fpic
|
|
JAVAFLAGSDEBUG=-g
|
|
|
|
# filter for supressing verbose messages from linker
|
|
#not needed at the moment
|
|
#LINKOUTPUT_FILTER=" |& $(SOLARENV)/bin/msg_filter"
|
|
|
|
# _PTHREADS is needed for the stl
|
|
CDEFS+=$(PTHREAD_CFLAGS) -DGLIBC=2 -D_PTHREADS -D_REENTRANT -DNEW_SOLAR -D_USE_NAMESPACE=1 -DSTLPORT_VERSION=$(STLPORT_VER)
|
|
|
|
# enable visibility define in "sal/types.h"
|
|
.IF "$(HAVE_GCC_VISIBILITY_FEATURE)" == "TRUE"
|
|
CDEFS += -DHAVE_GCC_VISIBILITY_FEATURE
|
|
.ENDIF # "$(HAVE_GCC_VISIBILITY_FEATURE)" == "TRUE"
|
|
|
|
# this is a platform with JAVA support
|
|
.IF "$(SOLAR_JAVA)"!=""
|
|
JAVADEF=-DSOLAR_JAVA
|
|
.IF "$(debug)"==""
|
|
JAVA_RUNTIME=-ljava
|
|
.ELSE
|
|
JAVA_RUNTIME=-ljava_g
|
|
.ENDIF
|
|
.ENDIF
|
|
|
|
# name of C++ Compiler
|
|
CXX*=g++
|
|
# name of C Compiler
|
|
CC*=gcc
|
|
.IF "$(SYSBASE)"!=""
|
|
CFLAGS_SYSBASE:=-isystem $(SYSBASE)$/usr$/include
|
|
CXX+:=$(CFLAGS_SYSBASE)
|
|
CC+:=$(CFLAGS_SYSBASE)
|
|
.ENDIF # "$(SYSBASE)"!=""
|
|
CFLAGS+=-fmessage-length=0 -c
|
|
|
|
# flags to enable build with symbols; required for crashdump feature
|
|
.IF "$(ENABLE_SYMBOLS)"=="SMALL"
|
|
CFLAGSENABLESYMBOLS=-g1
|
|
.ELSE
|
|
CFLAGSENABLESYMBOLS=-g # was temporarily commented out, reenabled before Beta
|
|
|
|
.ENDIF
|
|
|
|
# flags for the C++ Compiler
|
|
CFLAGSCC= -pipe $(ARCH_FLAGS)
|
|
# Flags for enabling exception handling
|
|
CFLAGSEXCEPTIONS=-fexceptions -fno-enforce-eh-specs
|
|
# Flags for disabling exception handling
|
|
CFLAGS_NO_EXCEPTIONS=-fno-exceptions
|
|
|
|
# -fpermissive should be removed as soon as possible
|
|
CFLAGSCXX= -pipe $(ARCH_FLAGS)
|
|
.IF "$(HAVE_GCC_VISIBILITY_FEATURE)" == "TRUE"
|
|
CFLAGSCXX += -fvisibility-inlines-hidden
|
|
.ENDIF # "$(HAVE_GCC_VISIBILITY_FEATURE)" == "TRUE"
|
|
|
|
CFLAGS_CREATE_PCH=-x c++-header -I$(INCPCH) -DPRECOMPILED_HEADERS
|
|
CFLAGS_USE_PCH=-I$(SLO)$/pch -DPRECOMPILED_HEADERS -Winvalid-pch
|
|
CFLAGS_USE_EXCEPTIONS_PCH=-I$(SLO)$/pch_ex -DPRECOMPILED_HEADERS -Winvalid-pch
|
|
|
|
# Compiler flags for compiling static object in multi threaded environment with graphical user interface
|
|
CFLAGSOBJGUIMT=
|
|
# Compiler flags for compiling static object in multi threaded environment with character user interface
|
|
CFLAGSOBJCUIMT=
|
|
# Compiler flags for compiling shared object in multi threaded environment with graphical user interface
|
|
CFLAGSSLOGUIMT=$(PICSWITCH)
|
|
# Compiler flags for compiling shared object in multi threaded environment with character user interface
|
|
CFLAGSSLOCUIMT=$(PICSWITCH)
|
|
# Compiler flags for profiling
|
|
CFLAGSPROF=
|
|
# Compiler flags for debugging
|
|
CFLAGSDEBUG=-g
|
|
CFLAGSDBGUTIL=
|
|
# Compiler flags for enabling optimizations
|
|
.IF "$(PRODUCT)"!=""
|
|
CFLAGSOPT=$(CDEFAULTOPT) -fno-strict-aliasing # optimizing for products
|
|
.ELSE # "$(PRODUCT)"!=""
|
|
CFLAGSOPT= # no optimizing for non products
|
|
.ENDIF # "$(PRODUCT)"!=""
|
|
# Compiler flags for disabling optimizations
|
|
CFLAGSNOOPT=-O0
|
|
# Compiler flags for describing the output path
|
|
CFLAGSOUTOBJ=-o
|
|
|
|
# -Wshadow does not work for C with nested uses of pthread_cleanup_push:
|
|
CFLAGSWARNCC=-Wall -Wextra -Wendif-labels
|
|
CFLAGSWARNCXX=$(CFLAGSWARNCC) -Wshadow -Wno-ctor-dtor-privacy \
|
|
-Wno-non-virtual-dtor
|
|
CFLAGSWALLCC=$(CFLAGSWARNCC)
|
|
CFLAGSWALLCXX=$(CFLAGSWARNCXX)
|
|
CFLAGSWERRCC=-Werror
|
|
|
|
# Once all modules on this platform compile without warnings, set
|
|
# COMPILER_WARN_ERRORS=TRUE here instead of setting MODULES_WITH_WARNINGS (see
|
|
# settings.mk):
|
|
MODULES_WITH_WARNINGS := \
|
|
soldep
|
|
|
|
# switches for dynamic and static linking
|
|
STATIC = -Wl,-Bstatic
|
|
DYNAMIC = -Wl,-Bdynamic
|
|
|
|
# name of linker
|
|
LINK*=$(CXX)
|
|
LINKC*=$(CC)
|
|
|
|
# default linker flags
|
|
LINKFLAGSDEFS*=-Wl,-z,defs
|
|
LINKFLAGSRUNPATH_URELIB=-Wl,-rpath,\''$$ORIGIN'\'
|
|
LINKFLAGSRUNPATH_UREBIN=-Wl,-rpath,\''$$ORIGIN/../lib:$$ORIGIN'\'
|
|
#TODO: drop $ORIGIN once no URE executable is also shipped in OOo
|
|
LINKFLAGSRUNPATH_OOO=-Wl,-rpath,\''$$ORIGIN:$$ORIGIN/../ure-link/lib'\'
|
|
LINKFLAGSRUNPATH_SDK=-Wl,-rpath,\''$$ORIGIN/../../ure-link/lib'\'
|
|
LINKFLAGSRUNPATH_BRAND=-Wl,-rpath,\''$$ORIGIN:$$ORIGIN/../basis-link/program:$$ORIGIN/../basis-link/ure-link/lib'\'
|
|
LINKFLAGSRUNPATH_OXT=
|
|
LINKFLAGSRUNPATH_NONE=
|
|
# flag -Wl,-z,noexecstack sets the NX bit on the stack
|
|
LINKFLAGS=-Wl,-z,noexecstack -Wl,-z,combreloc $(LINKFLAGSDEFS)
|
|
.IF "$(HAVE_LD_BSYMBOLIC_FUNCTIONS)" == "TRUE"
|
|
LINKFLAGS += -Wl,-Bsymbolic-functions -Wl,--dynamic-list-cpp-new -Wl,--dynamic-list-cpp-typeinfo
|
|
.ENDIF
|
|
|
|
# linker flags for linking applications
|
|
LINKFLAGSAPPGUI= -Wl,-export-dynamic -Wl,--noinhibit-exec \
|
|
-Wl,-rpath-link,$(LB):$(SOLARLIBDIR)
|
|
LINKFLAGSAPPCUI= -Wl,-export-dynamic -Wl,--noinhibit-exec \
|
|
-Wl,-rpath-link,$(LB):$(SOLARLIBDIR)
|
|
|
|
# linker flags for linking shared libraries
|
|
LINKFLAGSSHLGUI= -shared
|
|
LINKFLAGSSHLCUI= -shared
|
|
|
|
LINKFLAGSTACK=
|
|
LINKFLAGSPROF=
|
|
LINKFLAGSDEBUG=-g
|
|
LINKFLAGSOPT=
|
|
|
|
# linker flags for optimization (symbol hashtable)
|
|
# for now, applied to symbol scoped libraries, only
|
|
LINKFLAGSOPTIMIZE*=-Wl,-O1
|
|
LINKVERSIONMAPFLAG=$(LINKFLAGSOPTIMIZE) -Wl,--version-script
|
|
|
|
SONAME_SWITCH=-Wl,-h
|
|
|
|
# Sequence of libs does matter !
|
|
|
|
STDLIBCPP=-lstdc++
|
|
|
|
# default objectfilenames to link
|
|
STDOBJVCL=$(L)$/salmain.o
|
|
STDOBJGUI=
|
|
STDSLOGUI=
|
|
STDOBJCUI=
|
|
STDSLOCUI=
|
|
|
|
.IF "$(ALLOC)" == "TCMALLOC"
|
|
STDLIBGUIMT+=-ltcmalloc
|
|
STDLIBCUIMT+=-ltcmalloc
|
|
STDSHLGUIMT+=-ltcmalloc
|
|
STDSHLCUIMT+=-ltcmalloc
|
|
.ENDIF
|
|
.IF "$(HAVE_LD_HASH_STYLE)" == "TRUE"
|
|
LINKFLAGS += -Wl,--hash-style=both
|
|
.ELSE
|
|
LINKFLAGS += -Wl,-zdynsort
|
|
.ENDIF
|
|
|
|
# libraries for linking applications
|
|
STDLIBGUIMT+=-Wl,--as-needed -lX11 -ldl -lpthread -lm -Wl,--no-as-needed
|
|
STDLIBCUIMT+=-Wl,--as-needed -ldl -lpthread -lm -Wl,--no-as-needed
|
|
# libraries for linking shared libraries
|
|
STDSHLGUIMT+=-Wl,--as-needed -lX11 -lXext -ldl -lpthread -lm -Wl,--no-as-needed
|
|
STDSHLCUIMT+=-Wl,--as-needed -ldl -lpthread -lm -Wl,--no-as-needed
|
|
|
|
LIBSALCPPRT*=-Wl,--whole-archive -lsalcpprt -Wl,--no-whole-archive
|
|
|
|
.IF "$(USE_STLP_DEBUG)" != ""
|
|
.IF "$(STLPORT_VER)" >= "500"
|
|
LIBSTLPORT=$(DYNAMIC) -lstlportstlg
|
|
LIBSTLPORTST=$(STATIC) -lstlportstlg $(DYNAMIC)
|
|
.ELSE
|
|
LIBSTLPORT=$(DYNAMIC) -lstlport_gcc_stldebug
|
|
LIBSTLPORTST=$(STATIC) -lstlport_gcc_stldebug $(DYNAMIC)
|
|
.ENDIF
|
|
.ELSE # "$(USE_STLP_DEBUG)" != ""
|
|
.IF "$(STLPORT_VER)" >= "500"
|
|
LIBSTLPORT=$(DYNAMIC) -lstlport
|
|
LIBSTLPORTST=$(STATIC) -lstlport $(DYNAMIC)
|
|
.ELSE
|
|
LIBSTLPORT=$(DYNAMIC) -lstlport_gcc
|
|
LIBSTLPORTST=$(STATIC) -lstlport_gcc $(DYNAMIC)
|
|
.ENDIF
|
|
.ENDIF # "$(USE_STLP_DEBUG)" != ""
|
|
|
|
#FILLUPARC=$(STATIC) -lsupc++ $(DYNAMIC)
|
|
|
|
# name of library manager
|
|
LIBMGR*=ar
|
|
LIBFLAGS=-r
|
|
|
|
# tool for generating import libraries
|
|
IMPLIB=
|
|
IMPLIBFLAGS=
|
|
|
|
MAPSYM=
|
|
MAPSYMFLAGS=
|
|
|
|
RC=irc
|
|
RCFLAGS=-fo$@ $(RCFILES)
|
|
RCLINK=
|
|
RCLINKFLAGS=
|
|
RCSETVERSION=
|
|
|
|
# platform specific identifier for shared libs
|
|
DLLPRE=lib
|
|
DLLPOST=.so
|
|
PCHPOST=.gch
|