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.2)


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