Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/config/sys/Darwin-clang.gmk

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

Diff markup

Differences between /config/sys/Darwin-clang.gmk (Version 11.3.0) and /config/sys/Darwin-clang.gmk (Version 10.3.p1)


  1 #                                                   1 #
  2 # ------ macOS ------                          <<   2 # ------ MacOS-X ------
  3 #                                 macOS, Apple <<   3 #                                 MacOS 10.8/9/10/11, clang-3.6 and higher
  4 #                                                   4 #
  5 # Original author: Gabriele Cosmo - CERN            5 # Original author: Gabriele Cosmo - CERN
  6 #                                                   6 #
  7 ifeq ($(G4SYSTEM),Darwin-clang)                     7 ifeq ($(G4SYSTEM),Darwin-clang)
  8   CXX       := clang++                              8   CXX       := clang++
  9   CXXFLAGS  := -Wall -Wno-non-virtual-dtor -Wn      9   CXXFLAGS  := -Wall -Wno-non-virtual-dtor -Wno-long-long
 10   CXXFLAGS  += -Wwrite-strings -Wpointer-arith     10   CXXFLAGS  += -Wwrite-strings -Wpointer-arith -Woverloaded-virtual
 11   CXXFLAGS  += -Wno-variadic-macros -Wshadow -     11   CXXFLAGS  += -Wno-variadic-macros -Wshadow -pipe
 12   CXXFLAGS  += -fno-trapping-math -ftree-vecto     12   CXXFLAGS  += -fno-trapping-math -ftree-vectorize -fno-math-errno
 13   CPPFLAGS  += -DGL_SILENCE_DEPRECATION        <<  13   G4USE_STD11 := 1
 14   CPPFLAGS  += -std=c++17                      <<  14   ifdef G4USE_STD14
 15   CXXFLAGS  += -std=c++17                      <<  15     CPPFLAGS  += -std=c++14
 16   G4USE_STD17 := 1                             <<  16     CXXFLAGS  += -std=c++14
                                                   >>  17   else
                                                   >>  18     ifdef G4USE_STD17
                                                   >>  19       CPPFLAGS  += -std=c++17
                                                   >>  20       CXXFLAGS  += -std=c++17
                                                   >>  21     else
                                                   >>  22       CXXFLAGS  += -std=c++11
                                                   >>  23       CPPFLAGS  += -std=c++11
                                                   >>  24     endif
                                                   >>  25   endif
 17   ifdef G4MULTITHREADED                            26   ifdef G4MULTITHREADED
 18     CXXFLAGS += -ftls-model=initial-exec -pthr     27     CXXFLAGS += -ftls-model=initial-exec -pthread
 19   endif                                            28   endif
 20   ifdef G4OPTIMISE                                 29   ifdef G4OPTIMISE
 21     CXXFLAGS  += -O3                               30     CXXFLAGS  += -O3
 22     FCFLAGS   := -O3                               31     FCFLAGS   := -O3
 23     CCFLAGS   := -O3                               32     CCFLAGS   := -O3
 24   else                                             33   else
 25     ifdef G4DEBUG                                  34     ifdef G4DEBUG
 26       CXXFLAGS  += -g                              35       CXXFLAGS  += -g
 27       FCFLAGS   := -g                              36       FCFLAGS   := -g
 28       CCFLAGS   := -g                              37       CCFLAGS   := -g
 29     endif                                          38     endif
 30   endif                                            39   endif
 31   ifdef G4PROFILE                                  40   ifdef G4PROFILE
 32     CXXFLAGS  += -pg                               41     CXXFLAGS  += -pg
 33     FCFLAGS   += -pg                               42     FCFLAGS   += -pg
 34     CCFLAGS   += -pg                               43     CCFLAGS   += -pg
 35   endif                                            44   endif
 36   ifdef G4OPTDEBUG                                 45   ifdef G4OPTDEBUG
 37     CXXFLAGS  += -O2 -g                            46     CXXFLAGS  += -O2 -g
 38     FCFLAGS   += -O2 -g                            47     FCFLAGS   += -O2 -g
 39     CCFLAGS   += -O2 -g                            48     CCFLAGS   += -O2 -g
 40   endif                                            49   endif
 41   G4RUNPATHOPTION := -Wl,-rpath,               <<  50   ifdef G4LIB_BUILD_SHARED
 42 #  G4STATIC_MODE += -Wl,-force_load            <<  51     CXXFLAGS  += -fPIC
                                                   >>  52     FCFLAGS   += -fPIC
                                                   >>  53     CCFLAGS   += -fPIC
                                                   >>  54   endif
                                                   >>  55   G4RUNPATHOPTION := -Wl,-rpath 
                                                   >>  56   G4STATIC_MODE += -Wl,-force_load
 43   FC := gfortran                                   57   FC := gfortran
 44   FCFLAGS += -fno-automatic -fno-backslash -fn     58   FCFLAGS += -fno-automatic -fno-backslash -fno-second-underscore
 45   LDFLAGS += -bind_at_load                         59   LDFLAGS += -bind_at_load
 46   FCLIBS := -lg2c -lnsl                            60   FCLIBS := -lg2c -lnsl
 47   SHEXT   := dylib                                 61   SHEXT   := dylib
 48   LOADLIBS += -lm                                  62   LOADLIBS += -lm
 49   ifndef X11FLAGS                                  63   ifndef X11FLAGS
 50     X11FLAGS  := -I/usr/X11/include                64     X11FLAGS  := -I/usr/X11/include
 51   endif                                            65   endif
 52   ifndef X11LIBS                                   66   ifndef X11LIBS
 53     X11LIBS   := -L/usr/X11/lib  -lXmu -lXt -l <<  67     X11LIBS   := -L/usr/X11/lib  -lXmu -lXt -lXext -lX11 -lXi -lSM -lICE
 54   endif                                            68   endif
 55   ifndef XMFLAGS                                   69   ifndef XMFLAGS
 56     XMFLAGS   := -I/usr/local/include          <<  70     XMFLAGS   := -I/sw/include
 57 #   XMFLAGS   := -I/usr/X11/include          #     71 #   XMFLAGS   := -I/usr/X11/include          ##### some installations.
 58   endif                                            72   endif
 59   ifndef XMLIBS                                    73   ifndef XMLIBS
 60     XMLIBS    := -L/usr/local/lib -lXm -lXpm   <<  74     XMLIBS    := -L/sw/lib -lXm -lXpm
 61 #   XMLIBS    := -L/usr/X11/lib -lXm -lXpm   #     75 #   XMLIBS    := -L/usr/X11/lib -lXm -lXpm   ##### some installations.
 62   endif                                            76   endif
 63   ifndef XAWFLAGS                                  77   ifndef XAWFLAGS
 64     XAWFLAGS   := -I/usr/local/include         <<  78     XAWFLAGS   := -I/sw/include
 65 #   XAWFLAGS   := -I/usr/X11/include         #     79 #   XAWFLAGS   := -I/usr/X11/include         ##### some installations.
 66   endif                                            80   endif
 67   ifndef XAWLIBS                                   81   ifndef XAWLIBS
 68     XAWLIBS    := -lXaw                            82     XAWLIBS    := -lXaw
 69   endif                                            83   endif
 70   DLDLIBS   := -ldl                                84   DLDLIBS   := -ldl
 71   ifndef OGLHOME                                   85   ifndef OGLHOME
 72     OGLHOME  := /usr/X11                           86     OGLHOME  := /usr/X11
 73   endif                                            87   endif
 74   ifndef OGLFLAGS                                  88   ifndef OGLFLAGS
 75     OGLFLAGS  := -I$(OGLHOME)/include              89     OGLFLAGS  := -I$(OGLHOME)/include 
 76   endif                                            90   endif
 77   ifndef OGLLIBS                                   91   ifndef OGLLIBS
 78     OGLPATH  := $(shell test -f /Library/Frame <<  92     QTGLPATH  := $(shell test -f /System/Library/Frameworks/OpenGL.framework/OpenGL && echo "/System/Library/Frameworks/OpenGL.framework")
 79     ifneq ($(OGLPATH),/Library/Frameworks/Open <<  93     ifeq ($(QTGLPATH),/System/Library/Frameworks/OpenGL.framework)
 80       OGLPATH  := $(shell test -f /System/Libr <<  94       OGLLIBS := -F/System/Library/Frameworks -framework OpenGL -framework AGL 
 81     endif                                      <<  95       ifeq ($(G4VIS_USE_OPENGLX),1)
 82     ifneq ($(OGLPATH),)                        <<  96         OGLLIBS += -L$(OGLHOME)/lib -lGLU -lGL
 83       OGLLIBS := -F$(OGLPATH)/.. -framework Op <<  97       endif
 84     else                                           98     else
 85       OGLLIBS := -L$(OGLHOME)/lib -lGL         <<  99       OGLLIBS := -L$(OGLHOME)/lib -lGLU -lGL
 86     endif                                         100     endif
 87   endif                                           101   endif
 88                                                   102 
 89 # ---- Qt Setup block ------------------------    103 # ---- Qt Setup block -------------------------------------------------------
 90                                                   104 
 91   ifndef QTHOME                                   105   ifndef QTHOME
 92     QTHOME := /Library/Frameworks                 106     QTHOME := /Library/Frameworks
 93   endif                                           107   endif
 94   ifndef QT_VERSION                            << 
 95     QT_VERSION := 5                            << 
 96   endif                                        << 
 97   ifeq ($(QTHOME),/Library/Frameworks)            108   ifeq ($(QTHOME),/Library/Frameworks)
 98     ifndef QTMOC                                  109     ifndef QTMOC
 99       QTMOC      := /usr/bin/moc                  110       QTMOC      := /usr/bin/moc
100     endif                                         111     endif
101     ifndef QTFLAGS                                112     ifndef QTFLAGS
102       QTFLAGS   := -I $(QTHOME)/QtCore.framewo << 113       QTFLAGS   := -I $(QTHOME)/QtCore.framework/Headers 
103       QTFLAGS   += -I $(QTHOME)/QtGui.framewor << 114       QTFLAGS   += -I $(QTHOME)/QtGui.framework/Headers 
104       QTFLAGS   += -I $(QTHOME)/QtWidgets.fram << 
105       QTFLAGS   += -I $(QTHOME)/QtOpenGL.frame    115       QTFLAGS   += -I $(QTHOME)/QtOpenGL.framework/Headers
106       QTFLAGS   += -I $(QTHOME)/Qt3DCore.frame << 
107       QTFLAGS   += -I $(QTHOME)/Qt3DExtras.fra << 
108       QTFLAGS   += -I $(QTHOME)/Qt3DRender.fra << 
109       ifeq ($(QT_VERSION),6)                   << 
110         QTFLAGS   += -I $(QTHOME)/QtOpenGLWidg << 
111       endif                                    << 
112       QTFLAGS   += -I $(QTHOME)/include/Qt -I$    116       QTFLAGS   += -I $(QTHOME)/include/Qt -I$(QTHOME)/include
113     endif                                         117     endif
114     ifndef QTLIBPATH                              118     ifndef QTLIBPATH
115       QTLPATH  := $(QTHOME)                       119       QTLPATH  := $(QTHOME)
116     endif                                         120     endif
117     QTLIBPATH  := -F$(QTLPATH)                    121     QTLIBPATH  := -F$(QTLPATH)
118     QT_AS_FRAMEWORK := $(shell test -d $(QTLPA    122     QT_AS_FRAMEWORK := $(shell test -d $(QTLPATH)/QtCore.framework && echo yes)
119     ifndef QTLIBS                                 123     ifndef QTLIBS
120       ifdef QT_AS_FRAMEWORK                       124       ifdef QT_AS_FRAMEWORK
121         QTLIBS    := $(QTLIBPATH) -framework Q    125         QTLIBS    := $(QTLIBPATH) -framework QtCore -framework QtGui
122       else                                        126       else
123         QTLIBS    := -L$(QTLPATH) -lQtCore -lQ    127         QTLIBS    := -L$(QTLPATH) -lQtCore -lQtGui
124       endif                                       128       endif   
125     endif                                         129     endif
126     ifndef QT3DLIBS                            << 
127       ifdef QT_AS_FRAMEWORK                    << 
128         QT3DLIBS  := $(QTLIBPATH) -framework Q << 
129         QT3DLIBS  += -framework QtWidgets -fra << 
130       else                                     << 
131         QT3DLIBS  := -L$(QTLPATH) -lQtCore -lQ << 
132         QT3DLIBS  += -lQtWidgets -lQt3DCore -l << 
133       endif                                    << 
134     endif                                      << 
135     ifndef GLQTLIBS                               130     ifndef GLQTLIBS  
136       ifdef QT_AS_FRAMEWORK                       131       ifdef QT_AS_FRAMEWORK
137         GLQTLIBS  := $(QTLIBPATH) -framework Q << 132         GLQTLIBS    := $(QTLIBPATH) -framework QtCore -framework QtGui
138         ifeq ($(QT_VERSION),6)                 << 133         GLQTLIBS    += -framework QtOpenGL
139           GLQTLIBS += -framework QtOpenGLWidge << 
140         endif                                  << 
141       else                                        134       else
142         GLQTLIBS  := -L$(QTLPATH) -lQtCore -lQ << 135         GLQTLIBS    := -L$(QTLPATH) -lQtCore -lQtGui -lQtOpenGL
143         ifeq ($(QT_VERSION),6)                 << 
144           GLQTLIBS += -lQtOpenGLWidgets        << 
145         endif                                  << 
146       endif                                       136       endif   
147     endif                                         137     endif
148   else                                            138   else
149     ifndef QTMOC                                  139     ifndef QTMOC
150       QTMOC      := $(QTHOME)/bin/moc             140       QTMOC      := $(QTHOME)/bin/moc
151     endif                                         141     endif
152     QTLPATH  := $(QTHOME)/lib                     142     QTLPATH  := $(QTHOME)/lib
153     ifndef QTFLAGS                             << 143     ifndef QTFLAGS                          # Qt5
154       QTFLAGS   := -I $(QTLPATH)/QtCore.framew    144       QTFLAGS   := -I $(QTLPATH)/QtCore.framework/Headers 
155       QTFLAGS   += -I $(QTLPATH)/QtGui.framewo    145       QTFLAGS   += -I $(QTLPATH)/QtGui.framework/Headers 
156       QTFLAGS   += -I $(QTLPATH)/QtWidgets.fra    146       QTFLAGS   += -I $(QTLPATH)/QtWidgets.framework/Headers
157       QTFLAGS   += -I $(QTLPATH)/QtOpenGL.fram    147       QTFLAGS   += -I $(QTLPATH)/QtOpenGL.framework/Headers
158       QTFLAGS   += -I $(QTLPATH)/Qt3DCore.fram << 148       QTFLAGS   += -I $(QTLPATH)/QtPrintSupport.framework/Headers
159       QTFLAGS   += -I $(QTLPATH)/Qt3DExtras.fr << 
160       QTFLAGS   += -I $(QTLPATH)/Qt3DRender.fr << 
161       QTFLAGS   += -I $(QTHOME)/include/Qt -I$    149       QTFLAGS   += -I $(QTHOME)/include/Qt -I$(QTHOME)/include
162       ifeq ($(QT_VERSION),6)                   << 
163         QTFLAGS   += -I $(QTHOME)/QtOpenGLWidg << 
164       endif                                    << 
165     endif                                         150     endif
166     ifndef QTLIBS                                 151     ifndef QTLIBS
167        QTLIBS    := -F$(QTLPATH) -framework Qt    152        QTLIBS    := -F$(QTLPATH) -framework QtCore -framework QtGui
168        QTLIBS    += -framework QtWidgets       << 153        QTLIBS    += -framework QtWidgets -framework QtPrintSupport
169     endif                                      << 
170     ifndef QT3DLIBS                            << 
171        QT3DLIBS    := -F$(QTLPATH) -framework  << 
172        QT3DLIBS    += -framework QtWidgets     << 
173        QT3DLIBS    += -framework Qt3DCore -fra << 
174     endif                                         154     endif   
175     ifndef GLQTLIBS                               155     ifndef GLQTLIBS  
176       GLQTLIBS    := -F$(QTLPATH) -framework Q    156       GLQTLIBS    := -F$(QTLPATH) -framework QtCore -framework QtGui
177       GLQTLIBS    += -framework QtWidgets         157       GLQTLIBS    += -framework QtWidgets
178       GLQTLIBS    += -framework QtOpenGL       << 158       GLQTLIBS    += -framework QtOpenGL -framework QtPrintSupport
179       ifeq ($(QT_VERSION),6)                   << 
180         GLQTLIBS  += -framework QtOpenGLWidget << 
181       endif                                    << 
182     endif                                         159     endif   
183   endif                                           160   endif
184                                                   161 
185 #------ Wt Setup block -----------------------    162 #------ Wt Setup block ------------------------------------------------------
186                                                   163 
187   ifndef WTHOME                                   164   ifndef WTHOME
188     WTHOME := /usr                                165     WTHOME := /usr
189   endif                                           166   endif
190   WTFLAGS := -I$(WTHOME)/include/boost -I$(WTH    167   WTFLAGS := -I$(WTHOME)/include/boost -I$(WTHOME)/include -DQT_NO_KEYWORDS 
191   WTLIBS  := -L$(WTHOME)/lib -lwt -lwtext -lwt    168   WTLIBS  := -L$(WTHOME)/lib -lwt -lwtext -lwthttp  -lboost_signals  -L/usr/lib -lz -lssl -lcrypto
192                                                   169 
193 #---------------------------------------------    170 #----------------------------------------------------------------------------
194                                                   171 
195   define build-granular-shared-lib                172   define build-granular-shared-lib
196     @libdir=`(cd $(@D);/bin/pwd)`; \              173     @libdir=`(cd $(@D);/bin/pwd)`; \
197      cd $(G4TMPDIR); \                            174      cd $(G4TMPDIR); \
198      $(CXX) -Wl,-w -dynamiclib -single_module  << 175      $(CXX) -dynamiclib -single_module -undefined dynamic_lookup \
199          -o $$libdir/$(@F) $(INTYLIBS) *.o        176          -o $$libdir/$(@F) $(INTYLIBS) *.o
200   endef                                           177   endef
201   define build-global-shared-lib                  178   define build-global-shared-lib
202     @libdir=`(cd $(@D);/bin/pwd)`; \              179     @libdir=`(cd $(@D);/bin/pwd)`; \
203      cd $(G4TMP)/$(G4SYSTEM); \                   180      cd $(G4TMP)/$(G4SYSTEM); \
204      $(CXX) -Wl,-w -dynamiclib -single_module  << 181      $(CXX) -dynamiclib -single_module -undefined dynamic_lookup \
205          -o $$libdir/$(@F) $(INTYLIBS) $(forea    182          -o $$libdir/$(@F) $(INTYLIBS) $(foreach dir,$(SUBLIBS),$(dir)/*.o);
206   endef                                           183   endef
207                                                   184 
208 endif                                             185 endif