Changeset 3258 in kBuild
- Timestamp:
- Jan 3, 2019 5:34:09 AM (6 years ago)
- Location:
- trunk/kBuild/tools
- Files:
-
- 7 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/kBuild/tools/GXX32.kmk
r3121 r3258 38 38 TOOL_GXX32_CC ?= gcc$(HOSTSUFF_EXE) -m32 39 39 TOOL_GXX32_CXX ?= g++$(HOSTSUFF_EXE) -m32 40 TOOL_GXX32_PCH ?= $(TOOL_GXX32_CXX) 40 41 TOOL_GXX32_AS ?= gcc$(HOSTSUFF_EXE) -m32 41 42 TOOL_GXX32_AR ?= ar$(HOSTSUFF_EXE) … … 80 81 81 82 TOOL_GXX32_CXXOBJSUFF ?= .o 82 TOOL_GXX32_CXXOBJSUFF ?= .o83 83 TOOL_GXX32_CXXFLAGS ?= 84 84 TOOL_GXX32_CXXFLAGS.debug ?= -g … … 88 88 TOOL_GXX32_CXXDEFS ?= 89 89 90 TOOL_GXX32_PCHOBJSUFF ?= .h.gch 91 TOOL_GXX32_PCHFLAGS ?= $(TOOL_GXX32_CXXFLAGS) 92 TOOL_GXX32_PCHFLAGS.debug ?= $(TOOL_GXX32_CXXFLAGS.debug) 93 TOOL_GXX32_PCHFLAGS.profile ?= $(TOOL_GXX32_CXXFLAGS.profile) 94 TOOL_GXX32_PCHFLAGS.release ?= $(TOOL_GXX32_CXXFLAGS.release) 95 TOOL_GXX32_PCHINCS ?= $(TOOL_GXX32_CXXINCS) 96 TOOL_GXX32_PCHDEFS ?= $(TOOL_GXX32_CXXDEFS) 97 90 98 TOOL_GXX32_ASFLAGS ?= -x assembler-with-cpp 91 99 TOOL_GXX32_ASFLAGS.debug ?= -g … … 116 124 TOOL_GXX32_COMPILE_C_DEPEND = 117 125 TOOL_GXX32_COMPILE_C_DEPORD = 118 ifdef KBUILD_USE_KOBJCACHE 119 TOOL_GXX32_COMPILE_C_USES_KOBJCACHE = 1 120 TOOL_GXX32_COMPILE_C_OUTPUT = $(outbase).i 126 TOOL_GXX32_COMPILE_C_OUTPUT = $(if-expr "$(use_objcache)" != "",$(outbase).i,) 127 TOOL_GXX32_COMPILE_C_USES_KOBJCACHE = $(if-expr "$(use_objcache)" != "",1,) 121 128 define TOOL_GXX32_COMPILE_C_CMDS 129 if "$(use_objcache)" != "" 122 130 $(QUIET)$(KOBJCACHE) -f $(outbase).koc -d $(PATH_OBJCACHE) -t $(bld_trg).$(bld_trg_arch) -p\ 123 131 --kObjCache-cpp $(outbase).i\ … … 131 139 -o $(obj)\ 132 140 - 133 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 134 endef 135 else # !KBUILD_USE_KOBJCACHE 136 TOOL_GXX32_COMPILE_C_OUTPUT = 137 define TOOL_GXX32_COMPILE_C_CMDS 141 else 138 142 $(QUIET)$(TOOL_GXX32_CC) -c\ 139 143 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ … … 141 145 -o $(obj)\ 142 146 $(abspath $(source)) 147 endif 143 148 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 144 149 endef 145 endif # !KBUILD_USE_KOBJCACHE146 150 147 151 148 152 ## Compile C++ source. 153 # @param $(target) Normalized main target name. 154 # @param $(source) Source filename (relative). 155 # @param $(obj) Object file name. This shall be (re)created by the compilation. 156 # @param $(dep) Dependcy file. This shall be (re)created by the compilation. 157 # @param $(flags) Flags. 158 # @param $(defs) Definitions. No -D or something. 159 # @param $(incs) Includes. No -I or something. 160 # @param $(dirdep) Directory creation dependency. 161 # @param $(deps) Other dependencies. 162 # @param $(outbase) Output basename (full). Use this for list files and such. 163 # @param $(objsuff) Object suffix. 164 TOOL_GXX32_COMPILE_CXX_OUTPUT = $(if-expr "$(use_objcache)" != "",$(outbase).ii,) 165 TOOL_GXX32_COMPILE_CXX_DEPEND = $($(target)_1_GCC_PCH_FILE) 166 TOOL_GXX32_COMPILE_CXX_DEPORD = 167 TOOL_GXX32_COMPILE_CXX_USES_KOBJCACHE = $(if-expr "$(use_objcache)" != "",1,) 168 define TOOL_GXX32_COMPILE_CXX_CMDS 169 if "$(use_objcache)" != "" 170 $(QUIET)$(KOBJCACHE) -f $(outbase).koc -d $(PATH_OBJCACHE) -t $(bld_trg).$(bld_trg_arch) -p\ 171 --kObjCache-cpp $(outbase).ii\ 172 $(TOOL_GXX32_CXX) -E -o - $(if-expr defined($(target)_PCH_HDR)\ 173 ,-fpch-preprocess -Winvalid-pch -I$($(target)_1_GCC_PCH_DIR) -include $(basename $($(target)_1_GCC_PCH_FILE)),)\ 174 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ 175 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 176 $(abspath $(source))\ 177 --kObjCache-cc $(obj)\ 178 $(TOOL_GXX32_CXX) -c\ 179 $(flags) -fpreprocessed $(if-expr defined($(target)_PCH_HDR),-fpch-preprocess,) -x c++\ 180 -o $(obj)\ 181 - 182 else 183 $(QUIET)$(TOOL_GXX32_CXX) -c\ 184 $(flags) $(addprefix -I, $($(target)_1_GCC_PCH_DIR) $(incs)) $(addprefix -D, $(defs))\ 185 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 186 -o $(obj) $(if-expr defined($(target)_PCH_HDR) \ 187 ,-Winvalid-pch -include $(basename $($(target)_1_GCC_PCH_FILE)),) \ 188 $(abspath $(source)) 189 endif 190 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 191 endef 192 193 194 ## Precompile C++ header. 149 195 # @param $(target) Normalized main target name. 150 196 # @param $(source) Source filename (relative). … … 158 204 # @param $(outbase) Output basename (full). Use this for list files and such. 159 205 # @param $(objsuff) Object suffix. 160 TOOL_GXX32_COMPILE_CXX_DEPEND = 161 TOOL_GXX32_COMPILE_CXX_DEPORD = 162 ifdef KBUILD_USE_KOBJCACHE 163 TOOL_GXX32_COMPILE_CXX_USES_KOBJCACHE = 1 164 TOOL_GXX32_COMPILE_CXX_OUTPUT = $(outbase).ii 165 define TOOL_GXX32_COMPILE_CXX_CMDS 166 $(QUIET)$(KOBJCACHE) -f $(outbase).koc -d $(PATH_OBJCACHE) -t $(bld_trg).$(bld_trg_arch) -p\ 167 --kObjCache-cpp $(outbase).ii\ 168 $(TOOL_GXX32_CXX) -E -o -\ 169 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ 170 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 171 $(abspath $(source))\ 172 --kObjCache-cc $(obj)\ 173 $(TOOL_GXX32_CXX) -c\ 174 $(flags) -fpreprocessed -x c++\ 175 -o $(obj)\ 176 - 206 TOOL_GXX32_COMPILE_PCH_OUTPUT = $($(target)_1_GCC_PCH_FILE) 207 TOOL_GXX32_COMPILE_PCH_DEPEND = 208 TOOL_GXX32_COMPILE_PCH_DEPORD = $($(target)_1_GCC_PCH_DIR) 209 define TOOL_GXX32_COMPILE_PCH_CMDS 210 $(QUIET)$(TOOL_GXX32_PCH) -c\ 211 $(flags) $(addprefix -I, $($(target)_1_GCC_PCH_DIR) $(incs)) $(addprefix -D, $(defs))\ 212 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 213 -o $(obj)\ 214 $(abspath $(source)) 215 $(INSTALL) --hard-link-files-when-possible -m 0644 -- "$(obj)" "$($(target)_1_GCC_PCH_FILE)" 177 216 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 178 217 endef 179 else # !KBUILD_USE_KOBJCACHE180 TOOL_GXX32_COMPILE_CXX_OUTPUT =181 define TOOL_GXX32_COMPILE_CXX_CMDS182 $(QUIET)$(TOOL_GXX32_CXX) -c\183 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\184 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\185 -o $(obj)\186 $(abspath $(source))187 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" ""188 endef189 endif # !KBUILD_USE_KOBJCACHE190 218 191 219 … … 231 259 $(QUIET)$(APPEND) $(out).ar-script 'CREATE $(out)' 232 260 $(QUIET)$(APPEND) -n $(out).ar-script \ 233 $(foreach o,$( objs), 'ADDMOD $(o)') \261 $(foreach o,$(filter-out %.h.gch,$(objs)), 'ADDMOD $(o)') \ 234 262 $(foreach o,$(filter-out %.def %.imp %.dll,$(othersrc)), 'ADDLIB $(o)') 235 263 $(if $(filter %.def %.imp %.dll,$(othersrc))\ 236 ,$(TOOL_GXX3 _AR_IMP) -o $(outbase).imp.a $(filter %.def %.imp %.dll,$(othersrc))\264 ,$(TOOL_GXX32_AR_IMP) -o $(outbase).imp.a $(filter %.def %.imp %.dll,$(othersrc))\ 237 265 $(NL)$(TAB)$(QUIET)$(APPEND) $(out).ar-script 'ADDLIB $(outbase).imp.a') 238 266 $(QUIET)$(APPEND) $(out).ar-script 'SAVE' … … 263 291 TOOL_GXX32_LINK_PROGRAM_DEPORD = 264 292 define TOOL_GXX32_LINK_PROGRAM_CMDS 265 $(QUIET)$(TOOL_GXX32_LD) $(flags) -o $(out) $( objs)\293 $(QUIET)$(TOOL_GXX32_LD) $(flags) -o $(out) $(filter-out %.h.gch,$(objs))\ 266 294 $(foreach p,$(libpath), -L$(p))\ 267 295 $(foreach lib,$(libs), $(if $(findstring $(lib),$(subst /,x,$(lib))), -l$(patsubst lib%,%,$(lib)), $(lib)))\ … … 298 326 $(QUIET)$(TOOL_GXX32_LD) $(TOOL_GXX32_LDFLAGS.dll) $(flags) -o $(out)\ 299 327 $(if $(filter-out win os2, $(KBUILD_TARGET)),$(call TOOL_GXX32_LD_SONAME,$(target),$(out)))\ 300 $( objs)\328 $(filter-out %.h.gch,$(objs))\ 301 329 $(foreach p,$(libpath), -L$(p))\ 302 330 $(foreach lib,$(libs), $(if $(findstring $(lib),$(subst /,x,$(lib))), -l$(patsubst lib%,%,$(lib)), $(lib)))\ … … 331 359 TOOL_GXX32_LINK_SYSMOD_DEPORD = 332 360 define TOOL_GXX32_LINK_SYSMOD_CMDS 333 $(QUIET)$(TOOL_GXX32_LD_SYSMOD) $(TOOL_GXX32_LDFLAGS.sysmod) $(flags) -o $(out) $( objs)\361 $(QUIET)$(TOOL_GXX32_LD_SYSMOD) $(TOOL_GXX32_LDFLAGS.sysmod) $(flags) -o $(out) $(filter-out %.h.gch,$(objs))\ 334 362 $(filter %.def, $(othersrc))\ 335 363 $(foreach p,$(libpath), -L$(p))\ -
trunk/kBuild/tools/GXX3OMF.kmk
r3121 r3258 37 37 TOOL_GXX3OMF_CC ?= gcc$(HOSTSUFF_EXE) 38 38 TOOL_GXX3OMF_CXX ?= g++$(HOSTSUFF_EXE) 39 TOOL_GXX3OMF_PCH ?= $(TOOL_GXX3OMF_CXX) 39 40 TOOL_GXX3OMF_AS ?= gcc$(HOSTSUFF_EXE) 40 41 TOOL_GXX3OMF_AR ?= emxomfar$(HOSTSUFF_EXE) … … 67 68 68 69 TOOL_GXX3OMF_CXXOBJSUFF ?= .o 69 TOOL_GXX3OMF_CXXOBJSUFF ?= .o70 70 TOOL_GXX3OMF_CXXFLAGS ?= -Zomf 71 71 TOOL_GXX3OMF_CXXFLAGS.debug ?= -g … … 75 75 TOOL_GXX3OMF_CXXDEFS ?= 76 76 77 TOOL_GXX3OMF_PCHOBJSUFF ?= .h.gch 78 TOOL_GXX3OMF_PCHFLAGS ?= $(TOOL_GXX3OMF_CXXFLAGS) 79 TOOL_GXX3OMF_PCHFLAGS.debug ?= $(TOOL_GXX3OMF_CXXFLAGS.debug) 80 TOOL_GXX3OMF_PCHFLAGS.profile ?= $(TOOL_GXX3OMF_CXXFLAGS.profile) 81 TOOL_GXX3OMF_PCHFLAGS.release ?= $(TOOL_GXX3OMF_CXXFLAGS.release) 82 TOOL_GXX3OMF_PCHINCS ?= $(TOOL_GXX3OMF_CXXINCS) 83 TOOL_GXX3OMF_PCHDEFS ?= $(TOOL_GXX3OMF_CXXDEFS) 84 77 85 TOOL_GXX3OMF_ASFLAGS ?= -x assembler-with-cpp -Zomf 78 86 TOOL_GXX3OMF_ASFLAGS.debug ?= -g … … 108 116 TOOL_GXX3OMF_COMPILE_C_DEPEND = 109 117 TOOL_GXX3OMF_COMPILE_C_DEPORD = 110 ifdef KBUILD_USE_KOBJCACHE 111 TOOL_GXX3OMF_COMPILE_C_USES_KOBJCACHE = 1 112 TOOL_GXX3OMF_COMPILE_C_OUTPUT = $(outbase).i 118 TOOL_GXX3OMF_COMPILE_C_OUTPUT = $(if-expr "$(use_objcache)" != "",$(outbase).i,) 119 TOOL_GXX3OMF_COMPILE_C_USES_KOBJCACHE = $(if-expr "$(use_objcache)" != "",1,) 113 120 define TOOL_GXX3OMF_COMPILE_C_CMDS 121 if "$(use_objcache)" != "" 114 122 $(QUIET)$(KOBJCACHE) -f $(outbase).koc -d $(PATH_OBJCACHE) -t $(bld_trg).$(bld_trg_arch) -p\ 115 123 --kObjCache-cpp $(outbase).i\ … … 123 131 -o $(obj)\ 124 132 - 125 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 126 endef 127 else # !KBUILD_USE_KOBJCACHE 128 TOOL_GXX3OMF_COMPILE_C_OUTPUT = 129 define TOOL_GXX3OMF_COMPILE_C_CMDS 133 else 130 134 $(QUIET)$(TOOL_GXX3OMF_CC) -c\ 131 135 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ 132 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP 136 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 133 137 -o $(obj)\ 134 138 $(abspath $(source)) 139 endif 135 140 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 136 141 endef 137 endif # !KBUILD_USE_KOBJCACHE138 142 139 143 … … 142 146 # @param $(source) Source filename (relative). 143 147 # @param $(obj) Object file name. This shall be (re)created by the compilation. 144 # @param $(dep) Dependcy file. This shall be (re)created by the compilation. 145 # @param $(flags) Flags. 146 # @param $(defs) Definitions. No -D or something. 147 # @param $(incs) Includes. No -I or something. 148 # @param $(dirdep) Directory creation dependency. 149 # @param $(deps) Other dependencies. 150 # 151 # @param $(outbase) Output basename (full). Use this for list files and such. 152 # @param $(objsuff) Object suffix. 153 TOOL_GXX3OMF_COMPILE_CXX_DEPEND = 154 TOOL_GXX3OMF_COMPILE_CXX_DEPORD = 155 ifdef KBUILD_USE_KOBJCACHE 156 TOOL_GXX3OMF_COMPILE_CXX_USES_KOBJCACHE = 1 157 TOOL_GXX3OMF_COMPILE_CXX_OUTPUT = $(outbase).ii 148 # @param $(dep) Dependcy file. This shall be (re)created by the compilation. 149 # @param $(flags) Flags. 150 # @param $(defs) Definitions. No -D or something. 151 # @param $(incs) Includes. No -I or something. 152 # @param $(dirdep) Directory creation dependency. 153 # @param $(deps) Other dependencies. 154 # @param $(outbase) Output basename (full). Use this for list files and such. 155 # @param $(objsuff) Object suffix. 156 TOOL_GXX3OMF_COMPILE_CXX_OUTPUT = $(if-expr "$(use_objcache)" != "",$(outbase).ii,) 157 TOOL_GXX3OMF_COMPILE_CXX_DEPEND = $($(target)_1_GCC_PCH_FILE) 158 TOOL_GXX3OMF_COMPILE_CXX_DEPORD = 159 TOOL_GXX3OMF_COMPILE_CXX_USES_KOBJCACHE = $(if-expr "$(use_objcache)" != "",1,) 158 160 define TOOL_GXX3OMF_COMPILE_CXX_CMDS 161 if "$(use_objcache)" != "" 159 162 $(QUIET)$(KOBJCACHE) -f $(outbase).koc -d $(PATH_OBJCACHE) -t $(bld_trg).$(bld_trg_arch) -p\ 160 163 --kObjCache-cpp $(outbase).ii\ 161 $(TOOL_GXX3OMF_CXX) -E -o -\ 164 $(TOOL_GXX3OMF_CXX) -E -o - $(if-expr defined($(target)_PCH_HDR)\ 165 ,-fpch-preprocess -Winvalid-pch -I$($(target)_1_GCC_PCH_DIR) -include $(basename $($(target)_1_GCC_PCH_FILE)),)\ 162 166 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ 163 167 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ … … 165 169 --kObjCache-cc $(obj)\ 166 170 $(TOOL_GXX3OMF_CXX) -c\ 167 $(flags) -fpreprocessed -x c++\171 $(flags) -fpreprocessed $(if-expr defined($(target)_PCH_HDR),-fpch-preprocess,) -x c++\ 168 172 -o $(obj)\ 169 173 - 174 else 175 $(QUIET)$(TOOL_GXX3OMF_CXX) -c\ 176 $(flags) $(addprefix -I, $($(target)_1_GCC_PCH_DIR) $(incs)) $(addprefix -D, $(defs))\ 177 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 178 -o $(obj) $(if-expr defined($(target)_PCH_HDR) \ 179 ,-Winvalid-pch -include $(basename $($(target)_1_GCC_PCH_FILE)),) \ 180 $(abspath $(source)) 181 endif 170 182 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 171 183 endef 172 else # !KBUILD_USE_KOBJCACHE 173 TOOL_GXX3OMF_COMPILE_CXX_OUTPUT = 174 define TOOL_GXX3OMF_COMPILE_CXX_CMDS 175 $(QUIET)$(TOOL_GXX3OMF_CXX) -c\ 176 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ 177 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP \ 184 185 186 ## Precompile C++ header. 187 # @param $(target) Normalized main target name. 188 # @param $(source) Source filename (relative). 189 # @param $(obj) Object file name. This shall be (re)created by the compilation. 190 # @param $(dep) Dependcy file. This shall be (re)created by the compilation. 191 # @param $(flags) Flags. 192 # @param $(defs) Definitions. No -D or something. 193 # @param $(incs) Includes. No -I or something. 194 # @param $(dirdep) Directory creation dependency. 195 # @param $(deps) Other dependencies. 196 # @param $(outbase) Output basename (full). Use this for list files and such. 197 # @param $(objsuff) Object suffix. 198 TOOL_GXX3OMF_COMPILE_PCH_OUTPUT = $($(target)_1_GCC_PCH_FILE) 199 TOOL_GXX3OMF_COMPILE_PCH_DEPEND = 200 TOOL_GXX3OMF_COMPILE_PCH_DEPORD = $($(target)_1_GCC_PCH_DIR) 201 define TOOL_GXX3OMF_COMPILE_PCH_CMDS 202 $(QUIET)$(TOOL_GXX3OMF_PCH) -c\ 203 $(flags) $(addprefix -I, $($(target)_1_GCC_PCH_DIR) $(incs)) $(addprefix -D, $(defs))\ 204 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 178 205 -o $(obj)\ 179 206 $(abspath $(source)) 207 $(INSTALL) --hard-link-files-when-possible -m 0644 -- "$(obj)" "$($(target)_1_GCC_PCH_FILE)" 180 208 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 181 209 endef 182 endif # !KBUILD_USE_KOBJCACHE183 210 184 211 … … 251 278 $(NL)$(TAB)$(QUIET)$(QUIET)$(TOOL_GXX3OMF_AR_IMP) -o $(out) @$(outbase).rsp\ 252 279 $(NL)$(TAB)$(QUIET)$(RM) -f $(outbase).rsp) 253 $(QUIET)$(APPEND) -n $(outbase).rsp $(flags) $(out) $( objs) $(filter-out %.def %.imp %.dll,$(othersrc))280 $(QUIET)$(APPEND) -n $(outbase).rsp $(flags) $(out) $(filter-out %.h.gch,$(objs)) $(filter-out %.def %.imp %.dll,$(othersrc)) 254 281 $(QUIET)$(TOOL_GXX3OMF_AR) @$(outbase).rsp 255 282 endef … … 277 304 $(flags)\ 278 305 -o $(out)\ 279 $( objs)\306 $(filter-out %.h.gch,$(objs))\ 280 307 $(foreach p,$(libpath), -L$(p))\ 281 308 $(othersrc)\ … … 308 335 $(flags)\ 309 336 -o $(out)\ 310 $( objs)\337 $(filter-out %.h.gch,$(objs))\ 311 338 $(foreach p,$(libpath), -L$(p))\ 312 339 $(othersrc)\ … … 339 366 $(flags)\ 340 367 -o $(out)\ 341 $( objs)\368 $(filter-out %.h.gch,$(objs))\ 342 369 $(foreach p,$(libpath), -L$(p))\ 343 370 $(othersrc)\ -
trunk/kBuild/tools/GXX3PLAIN.kmk
r3121 r3258 37 37 TOOL_GXX3PLAIN_CC ?= gcc$(HOSTSUFF_EXE) 38 38 TOOL_GXX3PLAIN_CXX ?= g++$(HOSTSUFF_EXE) 39 TOOL_GXX3PLAIN_PCH ?= $(TOOL_GXX3PLAIN_CXX) 39 40 TOOL_GXX3PLAIN_AS ?= gcc$(HOSTSUFF_EXE) 40 41 TOOL_GXX3PLAIN_AR ?= ar$(HOSTSUFF_EXE) … … 74 75 75 76 TOOL_GXX3PLAIN_CXXOBJSUFF ?= .o 76 TOOL_GXX3PLAIN_CXXOBJSUFF ?= .o77 77 TOOL_GXX3PLAIN_CXXFLAGS ?= 78 78 TOOL_GXX3PLAIN_CXXFLAGS.debug ?= -g … … 82 82 TOOL_GXX3PLAIN_CXXDEFS ?= 83 83 84 TOOL_GXX3PLAIN_PCHOBJSUFF ?= .h.gch 85 TOOL_GXX3PLAIN_PCHFLAGS ?= $(TOOL_GXX3PLAIN_CXXFLAGS) 86 TOOL_GXX3PLAIN_PCHFLAGS.debug ?= $(TOOL_GXX3PLAIN_CXXFLAGS.debug) 87 TOOL_GXX3PLAIN_PCHFLAGS.profile ?= $(TOOL_GXX3PLAIN_CXXFLAGS.profile) 88 TOOL_GXX3PLAIN_PCHFLAGS.release ?= $(TOOL_GXX3PLAIN_CXXFLAGS.release) 89 TOOL_GXX3PLAIN_PCHINCS ?= $(TOOL_GXX3PLAIN_CXXINCS) 90 TOOL_GXX3PLAIN_PCHDEFS ?= $(TOOL_GXX3PLAIN_CXXDEFS) 91 84 92 TOOL_GXX3PLAIN_ASFLAGS ?= -x assembler-with-cpp 85 93 TOOL_GXX3PLAIN_ASFLAGS.debug ?= -g … … 108 116 TOOL_GXX3PLAIN_COMPILE_C_DEPEND = 109 117 TOOL_GXX3PLAIN_COMPILE_C_DEPORD = 110 ifdef KBUILD_USE_KOBJCACHE 111 TOOL_GXX3PLAIN_COMPILE_C_USES_KOBJCACHE = 1 112 TOOL_GXX3PLAIN_COMPILE_C_OUTPUT = $(outbase).i 118 TOOL_GXX3PLAIN_COMPILE_C_OUTPUT = $(if-expr "$(use_objcache)" != "",$(outbase).i,) 119 TOOL_GXX3PLAIN_COMPILE_C_USES_KOBJCACHE = $(if-expr "$(use_objcache)" != "",1,) 113 120 define TOOL_GXX3PLAIN_COMPILE_C_CMDS 121 if "$(use_objcache)" != "" 114 122 $(QUIET)$(KOBJCACHE) -f $(outbase).koc -d $(PATH_OBJCACHE) -t $(bld_trg).$(bld_trg_arch) -p\ 115 123 --kObjCache-cpp $(outbase).i\ … … 123 131 -o $(obj)\ 124 132 - 125 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 126 endef 127 else # !KBUILD_USE_KOBJCACHE 128 TOOL_GXX3PLAIN_COMPILE_C_OUTPUT = 129 define TOOL_GXX3PLAIN_COMPILE_C_CMDS 133 else 130 134 $(QUIET)$(TOOL_GXX3PLAIN_CC) -c\ 131 135 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ … … 133 137 -o $(obj)\ 134 138 $(abspath $(source)) 139 endif 135 140 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 136 141 endef 137 endif # !KBUILD_USE_KOBJCACHE138 142 139 143 140 144 ## Compile C++ source. 145 # @param $(target) Normalized main target name. 146 # @param $(source) Source filename (relative). 147 # @param $(obj) Object file name. This shall be (re)created by the compilation. 148 # @param $(dep) Dependcy file. This shall be (re)created by the compilation. 149 # @param $(flags) Flags. 150 # @param $(defs) Definitions. No -D or something. 151 # @param $(incs) Includes. No -I or something. 152 # @param $(dirdep) Directory creation dependency. 153 # @param $(deps) Other dependencies. 154 # @param $(outbase) Output basename (full). Use this for list files and such. 155 # @param $(objsuff) Object suffix. 156 TOOL_GXX3PLAIN_COMPILE_CXX_OUTPUT = $(if-expr "$(use_objcache)" != "",$(outbase).ii,) 157 TOOL_GXX3PLAIN_COMPILE_CXX_DEPEND = $($(target)_1_GCC_PCH_FILE) 158 TOOL_GXX3PLAIN_COMPILE_CXX_DEPORD = 159 TOOL_GXX3PLAIN_COMPILE_CXX_USES_KOBJCACHE = $(if-expr "$(use_objcache)" != "",1,) 160 define TOOL_GXX3PLAIN_COMPILE_CXX_CMDS 161 if "$(use_objcache)" != "" 162 $(QUIET)$(KOBJCACHE) -f $(outbase).koc -d $(PATH_OBJCACHE) -t $(bld_trg).$(bld_trg_arch) -p\ 163 --kObjCache-cpp $(outbase).ii\ 164 $(TOOL_GXX3PLAIN_CXX) -E -o - $(if-expr defined($(target)_PCH_HDR)\ 165 ,-fpch-preprocess -Winvalid-pch -I$($(target)_1_GCC_PCH_DIR) -include $(basename $($(target)_1_GCC_PCH_FILE)),)\ 166 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ 167 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 168 $(abspath $(source))\ 169 --kObjCache-cc $(obj)\ 170 $(TOOL_GXX3PLAIN_CXX) -c\ 171 $(flags) -fpreprocessed $(if-expr defined($(target)_PCH_HDR),-fpch-preprocess,) -x c++\ 172 -o $(obj)\ 173 - 174 else 175 $(QUIET)$(TOOL_GXX3PLAIN_CXX) -c\ 176 $(flags) $(addprefix -I, $($(target)_1_GCC_PCH_DIR) $(incs)) $(addprefix -D, $(defs))\ 177 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 178 -o $(obj) $(if-expr defined($(target)_PCH_HDR) \ 179 ,-Winvalid-pch -include $(basename $($(target)_1_GCC_PCH_FILE)),) \ 180 $(abspath $(source)) 181 endif 182 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 183 endef 184 185 186 ## Precompile C++ header. 141 187 # @param $(target) Normalized main target name. 142 188 # @param $(source) Source filename (relative). … … 150 196 # @param $(outbase) Output basename (full). Use this for list files and such. 151 197 # @param $(objsuff) Object suffix. 152 TOOL_GXX3PLAIN_COMPILE_CXX_DEPEND = 153 TOOL_GXX3PLAIN_COMPILE_CXX_DEPORD = 154 ifdef KBUILD_USE_KOBJCACHE 155 TOOL_GXX3PLAIN_COMPILE_CXX_USES_KOBJCACHE = 1 156 TOOL_GXX3PLAIN_COMPILE_CXX_OUTPUT = $(outbase).ii 157 define TOOL_GXX3PLAIN_COMPILE_CXX_CMDS 158 $(QUIET)$(KOBJCACHE) -f $(outbase).koc -d $(PATH_OBJCACHE) -t $(bld_trg).$(bld_trg_arch) -p\ 159 --kObjCache-cpp $(outbase).ii\ 160 $(TOOL_GXX3PLAIN_CXX) -E -o -\ 161 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ 162 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 163 $(abspath $(source))\ 164 --kObjCache-cc $(obj)\ 165 $(TOOL_GXX3PLAIN_CXX) -c\ 166 $(flags) -fpreprocessed -x c++\ 167 -o $(obj)\ 168 - 198 TOOL_GXX3PLAIN_COMPILE_PCH_OUTPUT = $($(target)_1_GCC_PCH_FILE) 199 TOOL_GXX3PLAIN_COMPILE_PCH_DEPEND = 200 TOOL_GXX3PLAIN_COMPILE_PCH_DEPORD = $($(target)_1_GCC_PCH_DIR) 201 define TOOL_GXX3PLAIN_COMPILE_PCH_CMDS 202 $(QUIET)$(TOOL_GXX3PLAIN_PCH) -c\ 203 $(flags) $(addprefix -I, $($(target)_1_GCC_PCH_DIR) $(incs)) $(addprefix -D, $(defs))\ 204 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 205 -o $(obj)\ 206 $(abspath $(source)) 207 $(INSTALL) --hard-link-files-when-possible -m 0644 -- "$(obj)" "$($(target)_1_GCC_PCH_FILE)" 169 208 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 170 209 endef 171 else # !KBUILD_USE_KOBJCACHE172 TOOL_GXX3PLAIN_COMPILE_CXX_OUTPUT =173 define TOOL_GXX3PLAIN_COMPILE_CXX_CMDS174 $(QUIET)$(TOOL_GXX3PLAIN_CXX) -c\175 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\176 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\177 -o $(obj)\178 $(abspath $(source))179 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" ""180 endef181 endif # !KBUILD_USE_KOBJCACHE182 210 183 211 … … 221 249 TOOL_GXX3PLAIN_LINK_LIBRARY_DEPORD = 222 250 define TOOL_GXX3PLAIN_LINK_LIBRARY_CMDS 223 $(call xargs,$(QUIET)$(TOOL_GXX3PLAIN_AR) $(flags) $(out),$( objs))251 $(call xargs,$(QUIET)$(TOOL_GXX3PLAIN_AR) $(flags) $(out),$(filter-out %.h.gch,$(objs))) 224 252 $(foreach lib,$(othersrc)\ 225 253 ,$(NL)$(TAB)$(call MSG_AR_MERGE,$(target),$(out),$(lib)) \ … … 254 282 TOOL_GXX3PLAIN_LINK_PROGRAM_DEPORD = 255 283 define TOOL_GXX3PLAIN_LINK_PROGRAM_CMDS 256 $(QUIET)$(TOOL_GXX3PLAIN_LD) $(flags) -o $(out) $( objs)\284 $(QUIET)$(TOOL_GXX3PLAIN_LD) $(flags) -o $(out) $(filter-out %.h.gch,$(objs))\ 257 285 $(filter %.def, $(othersrc))\ 258 286 $(foreach p,$(libpath), -L$(p))\ … … 282 310 $(QUIET)$(TOOL_GXX3PLAIN_LD) $(TOOL_GXX3PLAIN_LDFLAGS.dll) $(flags) -o $(out)\ 283 311 $(if $(filter-out win32 os2, $(KBUILD_TARGET)),$(call TOOL_GXX3PLAIN_LD_SONAME,$(target),$(out)))\ 284 $( objs)\312 $(filter-out %.h.gch,$(objs))\ 285 313 $(filter %.def, $(othersrc))\ 286 314 $(foreach p,$(libpath), -L$(p))\ … … 313 341 $(QUIET)$(if $(TOOL_GXX3PLAIN_LD_SYSMOD.$(bld_trg)),$(TOOL_GXX3PLAIN_LD_SYSMOD.$(bld_trg)),$(TOOL_GXX3PLAIN_LD_SYSMOD))\ 314 342 $(TOOL_GXX3PLAIN_LDFLAGS_SYSMOD.$(bld_trg)) $(flags) -o $(out) \ 315 $( objs)\343 $(filter-out %.h.gch,$(objs))\ 316 344 $(filter %.def, $(othersrc))\ 317 345 $(foreach p,$(libpath), -L$(p))\ -
trunk/kBuild/tools/GXX42MACHO.kmk
r3121 r3258 39 39 TOOL_GXX42MACHO_CC ?= $(TOOL_GXX42MACHO_PREFIX)gcc$(TOOL_GXX42MACHO_SUFFIX) 40 40 TOOL_GXX42MACHO_CXX ?= $(TOOL_GXX42MACHO_PREFIX)g++$(TOOL_GXX42MACHO_SUFFIX) 41 TOOL_GXX42MACHO_PCH ?= $(TOOL_GXX42MACHO_CXX) 41 42 TOOL_GXX42MACHO_OBJC ?= $(TOOL_GXX42MACHO_PREFIX)gcc$(TOOL_GXX42MACHO_SUFFIX) 42 43 TOOL_GXX42MACHO_OBJCXX ?= $(TOOL_GXX42MACHO_PREFIX)gcc$(TOOL_GXX42MACHO_SUFFIX) … … 76 77 TOOL_GXX42MACHO_CXXINCS ?= 77 78 TOOL_GXX42MACHO_CXXDEFS ?= 79 80 TOOL_GXX42MACHO_PCHOBJSUFF ?= .h.gch 81 TOOL_GXX42MACHO_PCHFLAGS ?= $(TOOL_GXX42MACHO_CXXFLAGS) 82 TOOL_GXX42MACHO_PCHFLAGS.debug ?= $(TOOL_GXX42MACHO_CXXFLAGS.debug) 83 TOOL_GXX42MACHO_PCHFLAGS.profile ?= $(TOOL_GXX42MACHO_CXXFLAGS.profile) 84 TOOL_GXX42MACHO_PCHFLAGS.release ?= $(TOOL_GXX42MACHO_CXXFLAGS.release) 85 TOOL_GXX42MACHO_PCHINCS ?= $(TOOL_GXX42MACHO_CXXINCS) 86 TOOL_GXX42MACHO_PCHDEFS ?= $(TOOL_GXX42MACHO_CXXDEFS) 78 87 79 88 TOOL_GXX42MACHO_OBJCOBJSUFF ?= .o … … 155 164 TOOL_GXX42MACHO_COMPILE_C_DEPEND = 156 165 TOOL_GXX42MACHO_COMPILE_C_DEPORD = 157 ifdef KBUILD_USE_KOBJCACHE 158 TOOL_GXX42MACHO_COMPILE_C_USES_KOBJCACHE = 1 159 TOOL_GXX42MACHO_COMPILE_C_OUTPUT = $(outbase).i 166 TOOL_GXX42MACHO_COMPILE_C_OUTPUT = $(if-expr "$(use_objcache)" != "",$(outbase).i,) 167 TOOL_GXX42MACHO_COMPILE_C_USES_KOBJCACHE = $(if-expr "$(use_objcache)" != "",1,) 160 168 define TOOL_GXX42MACHO_COMPILE_C_CMDS 169 if "$(use_objcache)" != "" 161 170 $(QUIET)$(KOBJCACHE) -f $(outbase).koc -d $(PATH_OBJCACHE) -t $(bld_trg).$(bld_trg_arch) -p\ 162 171 --kObjCache-cpp $(outbase).i\ … … 170 179 -o $(obj)\ 171 180 - 172 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 173 endef 174 else # !KBUILD_USE_KOBJCACHE 175 TOOL_GXX42MACHO_COMPILE_C_OUTPUT = 176 define TOOL_GXX42MACHO_COMPILE_C_CMDS 181 else 177 182 $(QUIET)$(TOOL_GXX42MACHO_CC) -c\ 178 183 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ … … 180 185 -o $(obj)\ 181 186 $(abspath $(source)) 182 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 183 endef 184 end if # !KUSE_OBJCACHE187 endif 188 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 189 endef 185 190 186 191 … … 189 194 # @param $(source) Source filename (relative). 190 195 # @param $(obj) Object file name. This shall be (re)created by the compilation. 191 # @param $(dep) Dependcy file. This shall be (re)created by the compilation. 192 # @param $(flags) Flags. 193 # @param $(defs) Definitions. No -D or something. 194 # @param $(incs) Includes. No -I or something. 195 # @param $(dirdep) Directory creation dependency. 196 # @param $(deps) Other dependencies. 197 # @param $(outbase) Output basename (full). Use this for list files and such. 198 # @param $(objsuff) Object suffix. 199 TOOL_GXX42MACHO_COMPILE_CXX_DEPEND = 200 TOOL_GXX42MACHO_COMPILE_CXX_DEPORD = 201 ifdef KBUILD_USE_KOBJCACHE 202 TOOL_GXX42MACHO_COMPILE_CXX_USES_KOBJCACHE = 1 203 TOOL_GXX42MACHO_COMPILE_CXX_OUTPUT = $(outbase).ii 196 # @param $(dep) Dependcy file. This shall be (re)created by the compilation. 197 # @param $(flags) Flags. 198 # @param $(defs) Definitions. No -D or something. 199 # @param $(incs) Includes. No -I or something. 200 # @param $(dirdep) Directory creation dependency. 201 # @param $(deps) Other dependencies. 202 # @param $(outbase) Output basename (full). Use this for list files and such. 203 # @param $(objsuff) Object suffix. 204 TOOL_GXX42MACHO_COMPILE_CXX_OUTPUT = $(if-expr "$(use_objcache)" != "",$(outbase).ii,) 205 TOOL_GXX42MACHO_COMPILE_CXX_DEPEND = $($(target)_1_GCC_PCH_FILE) 206 TOOL_GXX42MACHO_COMPILE_CXX_DEPORD = 207 TOOL_GXX42MACHO_COMPILE_CXX_USES_KOBJCACHE = $(if-expr "$(use_objcache)" != "",1,) 204 208 define TOOL_GXX42MACHO_COMPILE_CXX_CMDS 209 if "$(use_objcache)" != "" 205 210 $(QUIET)$(KOBJCACHE) -f $(outbase).koc -d $(PATH_OBJCACHE) -t $(bld_trg).$(bld_trg_arch) -p\ 206 211 --kObjCache-cpp $(outbase).ii\ 207 $(TOOL_GXX42MACHO_CXX) -E -o -\ 212 $(TOOL_GXX42MACHO_CXX) -E -o - $(if-expr defined($(target)_PCH_HDR)\ 213 ,-fpch-preprocess -Winvalid-pch -I$($(target)_1_GCC_PCH_DIR) -include $(basename $($(target)_1_GCC_PCH_FILE)),)\ 208 214 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ 209 215 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ … … 211 217 --kObjCache-cc $(obj)\ 212 218 $(TOOL_GXX42MACHO_CXX) -c\ 213 $(flags) -fpreprocessed -x c++\219 $(flags) -fpreprocessed $(if-expr defined($(target)_PCH_HDR),-fpch-preprocess,) -x c++\ 214 220 -o $(obj)\ 215 221 - 216 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 217 endef 218 else # !KBUILD_USE_KOBJCACHE 219 TOOL_GXX42MACHO_COMPILE_CXX_OUTPUT = 220 define TOOL_GXX42MACHO_COMPILE_CXX_CMDS 222 else 221 223 $(QUIET)$(TOOL_GXX42MACHO_CXX) -c\ 222 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ 223 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 224 -o $(obj)\ 225 $(abspath $(source)) 226 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 227 endef 228 endif # !KBUILD_USE_KOBJCACHE 224 $(flags) $(addprefix -I, $($(target)_1_GCC_PCH_DIR) $(incs)) $(addprefix -D, $(defs))\ 225 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 226 -o $(obj) $(if-expr defined($(target)_PCH_HDR) \ 227 ,-Winvalid-pch -include $(basename $($(target)_1_GCC_PCH_FILE)),) \ 228 $(abspath $(source)) 229 endif 230 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 231 endef 232 233 234 ## Precompile C++ header. 235 # @param $(target) Normalized main target name. 236 # @param $(source) Source filename (relative). 237 # @param $(obj) Object file name. This shall be (re)created by the compilation. 238 # @param $(dep) Dependcy file. This shall be (re)created by the compilation. 239 # @param $(flags) Flags. 240 # @param $(defs) Definitions. No -D or something. 241 # @param $(incs) Includes. No -I or something. 242 # @param $(dirdep) Directory creation dependency. 243 # @param $(deps) Other dependencies. 244 # @param $(outbase) Output basename (full). Use this for list files and such. 245 # @param $(objsuff) Object suffix. 246 TOOL_GXX42MACHO_COMPILE_PCH_OUTPUT = $($(target)_1_GCC_PCH_FILE) 247 TOOL_GXX42MACHO_COMPILE_PCH_DEPEND = 248 TOOL_GXX42MACHO_COMPILE_PCH_DEPORD = $($(target)_1_GCC_PCH_DIR) 249 define TOOL_GXX42MACHO_COMPILE_PCH_CMDS 250 $(QUIET)$(TOOL_GXX42MACHO_PCH) -c\ 251 $(flags) $(addprefix -I, $($(target)_1_GCC_PCH_DIR) $(incs)) $(addprefix -D, $(defs))\ 252 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 253 -o $(obj)\ 254 $(abspath $(source)) 255 $(INSTALL) --hard-link-files-when-possible -m 0644 -- "$(obj)" "$($(target)_1_GCC_PCH_FILE)" 256 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 257 endef 229 258 230 259 … … 356 385 TOOL_GXX42MACHO_LINK_LIBRARY_DEPORD = 357 386 define TOOL_GXX42MACHO_LINK_LIBRARY_CMDS 358 $(if $(strip $( objs)),$(call xargs,$(QUIET)$(TOOL_GXX42MACHO_AR) $(flags) $(out),$(objs)))387 $(if $(strip $(filter-out %.h.gch,$(objs))),$(call xargs,$(QUIET)$(TOOL_GXX42MACHO_AR) $(flags) $(out),$(filter-out %.h.gch,$(objs)))) 359 388 $(foreach lib,$(othersrc)\ 360 389 ,$(NL)$(TAB)$(call MSG_AR_MERGE,$(target),$(out),$(lib)) \ … … 389 418 TOOL_GXX42MACHO_LINK_PROGRAM_DEPORD = 390 419 define TOOL_GXX42MACHO_LINK_PROGRAM_CMDS 391 $(QUIET)$(APPEND) -n $(outbase).rsp $( objs)420 $(QUIET)$(APPEND) -n $(outbase).rsp $(filter-out %.h.gch,$(objs)) 392 421 $(QUIET)$(TOOL_GXX42MACHO_LD) $(flags) -o $(out)\ 393 422 -filelist $(outbase).rsp\ … … 420 449 TOOL_GXX42MACHO_LINK_DLL_DEPORD = 421 450 define TOOL_GXX42MACHO_LINK_DLL_CMDS 422 $(QUIET)$(APPEND) -n $(outbase).rsp $( objs)451 $(QUIET)$(APPEND) -n $(outbase).rsp $(filter-out %.h.gch,$(objs)) 423 452 $(QUIET)$(TOOL_GXX42MACHO_LD) $(TOOL_GXX42MACHO_LDFLAGS.dll) $(flags) -o $(out)\ 424 453 $(call TOOL_GXX42MACHO_LD_SONAME,$(target),$(out))\ … … 452 481 TOOL_GXX42MACHO_LINK_SYSMOD_DEPORD = 453 482 define TOOL_GXX42MACHO_LINK_SYSMOD_CMDS 454 $(QUIET)$(APPEND) -n $(outbase).rsp $( objs)483 $(QUIET)$(APPEND) -n $(outbase).rsp $(filter-out %.h.gch,$(objs)) 455 484 $(QUIET)$(TOOL_GXX42MACHO_LD_SYSMOD) $(TOOL_GXX42MACHO_LDFLAGS.sysmod) $(flags) -o $(out)\ 456 485 -filelist $(outbase).rsp\ -
trunk/kBuild/tools/GXX4MACHO.kmk
r3121 r3258 39 39 TOOL_GXX4MACHO_CC ?= $(TOOL_GXX4MACHO_PREFIX)gcc$(TOOL_GXX4MACHO_SUFFIX) 40 40 TOOL_GXX4MACHO_CXX ?= $(TOOL_GXX4MACHO_PREFIX)g++$(TOOL_GXX4MACHO_SUFFIX) 41 TOOL_GXX4MACHO_PCH ?= $(TOOL_GXX4MACHO_CXX) 41 42 TOOL_GXX4MACHO_OBJC ?= $(TOOL_GXX4MACHO_PREFIX)gcc$(TOOL_GXX4MACHO_SUFFIX) 42 43 TOOL_GXX4MACHO_OBJCXX ?= $(TOOL_GXX4MACHO_PREFIX)gcc$(TOOL_GXX4MACHO_SUFFIX) … … 76 77 TOOL_GXX4MACHO_CXXINCS ?= 77 78 TOOL_GXX4MACHO_CXXDEFS ?= 79 80 TOOL_GXX4MACHO_PCHOBJSUFF ?= .h.gch 81 TOOL_GXX4MACHO_PCHFLAGS ?= $(TOOL_GXX4MACHO_CXXFLAGS) 82 TOOL_GXX4MACHO_PCHFLAGS.debug ?= $(TOOL_GXX4MACHO_CXXFLAGS.debug) 83 TOOL_GXX4MACHO_PCHFLAGS.profile ?= $(TOOL_GXX4MACHO_CXXFLAGS.profile) 84 TOOL_GXX4MACHO_PCHFLAGS.release ?= $(TOOL_GXX4MACHO_CXXFLAGS.release) 85 TOOL_GXX4MACHO_PCHINCS ?= $(TOOL_GXX4MACHO_CXXINCS) 86 TOOL_GXX4MACHO_PCHDEFS ?= $(TOOL_GXX4MACHO_CXXDEFS) 78 87 79 88 TOOL_GXX4MACHO_OBJCOBJSUFF ?= .o … … 155 164 TOOL_GXX4MACHO_COMPILE_C_DEPEND = 156 165 TOOL_GXX4MACHO_COMPILE_C_DEPORD = 157 ifdef KBUILD_USE_KOBJCACHE 158 TOOL_GXX4MACHO_COMPILE_C_USES_KOBJCACHE = 1 159 TOOL_GXX4MACHO_COMPILE_C_OUTPUT = $(outbase).i 166 TOOL_GXX4MACHO_COMPILE_C_OUTPUT = $(if-expr "$(use_objcache)" != "",$(outbase).i,) 167 TOOL_GXX4MACHO_COMPILE_C_USES_KOBJCACHE = $(if-expr "$(use_objcache)" != "",1,) 160 168 define TOOL_GXX4MACHO_COMPILE_C_CMDS 169 if "$(use_objcache)" != "" 161 170 $(QUIET)$(KOBJCACHE) -f $(outbase).koc -d $(PATH_OBJCACHE) -t $(bld_trg).$(bld_trg_arch) -p\ 162 171 --kObjCache-cpp $(outbase).i\ … … 170 179 -o $(obj)\ 171 180 - 172 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 173 endef 174 else # !KBUILD_USE_KOBJCACHE 175 TOOL_GXX4MACHO_COMPILE_C_OUTPUT = 176 define TOOL_GXX4MACHO_COMPILE_C_CMDS 181 else 177 182 $(QUIET)$(TOOL_GXX4MACHO_CC) -c\ 178 183 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ … … 180 185 -o $(obj)\ 181 186 $(abspath $(source)) 182 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 183 endef 184 end if # !KUSE_OBJCACHE187 endif 188 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 189 endef 185 190 186 191 187 192 ## Compile C++ source. 193 # @param $(target) Normalized main target name. 194 # @param $(source) Source filename (relative). 195 # @param $(obj) Object file name. This shall be (re)created by the compilation. 196 # @param $(dep) Dependcy file. This shall be (re)created by the compilation. 197 # @param $(flags) Flags. 198 # @param $(defs) Definitions. No -D or something. 199 # @param $(incs) Includes. No -I or something. 200 # @param $(dirdep) Directory creation dependency. 201 # @param $(deps) Other dependencies. 202 # @param $(outbase) Output basename (full). Use this for list files and such. 203 # @param $(objsuff) Object suffix. 204 TOOL_GXX4MACHO_COMPILE_CXX_OUTPUT = $(if-expr "$(use_objcache)" != "",$(outbase).ii,) 205 TOOL_GXX4MACHO_COMPILE_CXX_DEPEND = $($(target)_1_GCC_PCH_FILE) 206 TOOL_GXX4MACHO_COMPILE_CXX_DEPORD = 207 TOOL_GXX4MACHO_COMPILE_CXX_USES_KOBJCACHE = $(if-expr "$(use_objcache)" != "",1,) 208 define TOOL_GXX4MACHO_COMPILE_CXX_CMDS 209 if "$(use_objcache)" != "" 210 $(QUIET)$(KOBJCACHE) -f $(outbase).koc -d $(PATH_OBJCACHE) -t $(bld_trg).$(bld_trg_arch) -p\ 211 --kObjCache-cpp $(outbase).ii\ 212 $(TOOL_GXX4MACHO_CXX) -E -o - $(if-expr defined($(target)_PCH_HDR)\ 213 ,-fpch-preprocess -Winvalid-pch -I$($(target)_1_GCC_PCH_DIR) -include $(basename $($(target)_1_GCC_PCH_FILE)),)\ 214 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ 215 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 216 $(abspath $(source))\ 217 --kObjCache-cc $(obj)\ 218 $(TOOL_GXX4MACHO_CXX) -c\ 219 $(flags) -fpreprocessed $(if-expr defined($(target)_PCH_HDR),-fpch-preprocess,) -x c++\ 220 -o $(obj)\ 221 - 222 else 223 $(QUIET)$(TOOL_GXX4MACHO_CXX) -c\ 224 $(flags) $(addprefix -I, $($(target)_1_GCC_PCH_DIR) $(incs)) $(addprefix -D, $(defs))\ 225 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 226 -o $(obj) $(if-expr defined($(target)_PCH_HDR) \ 227 ,-Winvalid-pch -include $(basename $($(target)_1_GCC_PCH_FILE)),) \ 228 $(abspath $(source)) 229 endif 230 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 231 endef 232 233 234 ## Precompile C++ header. 188 235 # @param $(target) Normalized main target name. 189 236 # @param $(source) Source filename (relative). … … 197 244 # @param $(outbase) Output basename (full). Use this for list files and such. 198 245 # @param $(objsuff) Object suffix. 199 TOOL_GXX4MACHO_COMPILE_CXX_DEPEND = 200 TOOL_GXX4MACHO_COMPILE_CXX_DEPORD = 201 ifdef KBUILD_USE_KOBJCACHE 202 TOOL_GXX4MACHO_COMPILE_CXX_USES_KOBJCACHE = 1 203 TOOL_GXX4MACHO_COMPILE_CXX_OUTPUT = $(outbase).ii 204 define TOOL_GXX4MACHO_COMPILE_CXX_CMDS 205 $(QUIET)$(KOBJCACHE) -f $(outbase).koc -d $(PATH_OBJCACHE) -t $(bld_trg).$(bld_trg_arch) -p\ 206 --kObjCache-cpp $(outbase).ii\ 207 $(TOOL_GXX4MACHO_CXX) -E -o -\ 208 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ 209 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 210 $(abspath $(source))\ 211 --kObjCache-cc $(obj)\ 212 $(TOOL_GXX4MACHO_CXX) -c\ 213 $(flags) -fpreprocessed -x c++\ 214 -o $(obj)\ 215 - 216 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 217 endef 218 else # !KBUILD_USE_KOBJCACHE 219 TOOL_GXX4MACHO_COMPILE_CXX_OUTPUT = 220 define TOOL_GXX4MACHO_COMPILE_CXX_CMDS 221 $(QUIET)$(TOOL_GXX4MACHO_CXX) -c\ 222 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ 246 TOOL_GXX4MACHO_COMPILE_PCH_OUTPUT = $($(target)_1_GCC_PCH_FILE) 247 TOOL_GXX4MACHO_COMPILE_PCH_DEPEND = 248 TOOL_GXX4MACHO_COMPILE_PCH_DEPORD = $($(target)_1_GCC_PCH_DIR) 249 define TOOL_GXX4MACHO_COMPILE_PCH_CMDS 250 $(QUIET)$(TOOL_GXX4MACHO_PCH) -c\ 251 $(flags) $(addprefix -I, $($(target)_1_GCC_PCH_DIR) $(incs)) $(addprefix -D, $(defs))\ 223 252 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 224 253 -o $(obj)\ 225 254 $(abspath $(source)) 226 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 227 endef 228 endif # !KBUILD_USE_KOBJCACHE 229 230 231 ## Compile Objective-C source. 232 # @param $(target) Normalized main target name. 233 # @param $(source) Source filename (relative). 234 # @param $(obj) Object file name. This shall be (re)created by the compilation. 235 # @param $(dep) Dependcy file. This shall be (re)created by the compilation. 236 # @param $(flags) Flags. 237 # @param $(defs) Definitions. No -D or something. 238 # @param $(incs) Includes. No -I or something. 239 # @param $(dirdep) Directory creation dependency. 240 # @param $(deps) Other dependencies. 241 # @param $(outbase) Output basename (full). Use this for list files and such. 242 # @param $(objsuff) Object suffix. 243 TOOL_GXX4MACHO_COMPILE_OBJC_DEPEND = 244 TOOL_GXX4MACHO_COMPILE_OBJC_DEPORD = 245 ifdef KBUILD_USE_KOBJCACHE 246 TOOL_GXX4MACHO_COMPILE_OBJC_USES_KOBJCACHE = 1 247 TOOL_GXX4MACHO_COMPILE_OBJC_OUTPUT = $(outbase).mi 248 define TOOL_GXX4MACHO_COMPILE_OBJC_CMDS 249 $(QUIET)$(KOBJCACHE) -f $(outbase).koc -d $(PATH_OBJCACHE) -t $(bld_trg).$(bld_trg_arch) -p\ 250 --kObjCache-cpp $(outbase).ii\ 251 $(TOOL_GXX4MACHO_OBJC) -E -o -\ 252 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ 253 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 254 $(abspath $(source))\ 255 --kObjCache-cc $(obj)\ 256 $(TOOL_GXX4MACHO_OBJC) -c\ 257 $(flags) -fpreprocessed -x objective-c \ 258 -o $(obj)\ 259 - 260 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 261 endef 262 else # !KBUILD_USE_KOBJCACHE 263 TOOL_GXX4MACHO_COMPILE_OBJC_OUTPUT = 264 define TOOL_GXX4MACHO_COMPILE_OBJC_CMDS 265 $(QUIET)$(TOOL_GXX4MACHO_OBJC) -c\ 266 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ 267 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 268 -o $(obj)\ 269 $(abspath $(source)) 270 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 271 endef 272 endif # !KBUILD_USE_KOBJCACHE 255 $(INSTALL) --hard-link-files-when-possible -m 0644 -- "$(obj)" "$($(target)_1_GCC_PCH_FILE)" 256 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 257 endef 273 258 274 259 … … 356 341 TOOL_GXX4MACHO_LINK_LIBRARY_DEPORD = 357 342 define TOOL_GXX4MACHO_LINK_LIBRARY_CMDS 358 $(if $(strip $( objs)),$(call xargs,$(QUIET)$(TOOL_GXX4MACHO_AR) $(flags) $(out),$(objs)))343 $(if $(strip $(filter-out %.h.gch,$(objs))),$(call xargs,$(QUIET)$(TOOL_GXX4MACHO_AR) $(flags) $(out),$(filter-out %.h.gch,$(objs)))) 359 344 $(foreach lib,$(othersrc)\ 360 345 ,$(NL)$(TAB)$(call MSG_AR_MERGE,$(target),$(out),$(lib)) \ … … 389 374 TOOL_GXX4MACHO_LINK_PROGRAM_DEPORD = 390 375 define TOOL_GXX4MACHO_LINK_PROGRAM_CMDS 391 $(QUIET)$(APPEND) -n $(outbase).rsp $( objs)376 $(QUIET)$(APPEND) -n $(outbase).rsp $(filter-out %.h.gch,$(objs)) 392 377 $(QUIET)$(TOOL_GXX4MACHO_LD) $(flags) -o $(out)\ 393 378 -filelist $(outbase).rsp\ … … 420 405 TOOL_GXX4MACHO_LINK_DLL_DEPORD = 421 406 define TOOL_GXX4MACHO_LINK_DLL_CMDS 422 $(QUIET)$(APPEND) -n $(outbase).rsp $( objs)407 $(QUIET)$(APPEND) -n $(outbase).rsp $(filter-out %.h.gch,$(objs)) 423 408 $(QUIET)$(TOOL_GXX4MACHO_LD) $(TOOL_GXX4MACHO_LDFLAGS.dll) $(flags) -o $(out)\ 424 409 $(call TOOL_GXX4MACHO_LD_SONAME,$(target),$(out))\ … … 452 437 TOOL_GXX4MACHO_LINK_SYSMOD_DEPORD = 453 438 define TOOL_GXX4MACHO_LINK_SYSMOD_CMDS 454 $(QUIET)$(APPEND) -n $(outbase).rsp $( objs)439 $(QUIET)$(APPEND) -n $(outbase).rsp $(filter-out %.h.gch,$(objs)) 455 440 $(QUIET)$(TOOL_GXX4MACHO_LD_SYSMOD) $(TOOL_GXX4MACHO_LDFLAGS.sysmod) $(flags) -o $(out)\ 456 441 -filelist $(outbase).rsp\ -
trunk/kBuild/tools/GXX64.kmk
r3121 r3258 38 38 TOOL_GXX64_CC ?= gcc$(HOSTSUFF_EXE) -m64 39 39 TOOL_GXX64_CXX ?= g++$(HOSTSUFF_EXE) -m64 40 TOOL_GXX64_PCH ?= $(TOOL_GXX64_CXX) 40 41 TOOL_GXX64_AS ?= gcc$(HOSTSUFF_EXE) -m64 41 42 TOOL_GXX64_AR ?= ar$(HOSTSUFF_EXE) … … 80 81 81 82 TOOL_GXX64_CXXOBJSUFF ?= .o 82 TOOL_GXX64_CXXOBJSUFF ?= .o83 83 TOOL_GXX64_CXXFLAGS ?= 84 84 TOOL_GXX64_CXXFLAGS.debug ?= -g … … 88 88 TOOL_GXX64_CXXDEFS ?= 89 89 90 TOOL_GXX64_PCHOBJSUFF ?= .h.gch 91 TOOL_GXX64_PCHFLAGS ?= $(TOOL_GXX64_CXXFLAGS) 92 TOOL_GXX64_PCHFLAGS.debug ?= $(TOOL_GXX64_CXXFLAGS.debug) 93 TOOL_GXX64_PCHFLAGS.profile ?= $(TOOL_GXX64_CXXFLAGS.profile) 94 TOOL_GXX64_PCHFLAGS.release ?= $(TOOL_GXX64_CXXFLAGS.release) 95 TOOL_GXX64_PCHINCS ?= $(TOOL_GXX64_CXXINCS) 96 TOOL_GXX64_PCHDEFS ?= $(TOOL_GXX64_CXXDEFS) 97 90 98 TOOL_GXX64_ASFLAGS ?= -x assembler-with-cpp 91 99 TOOL_GXX64_ASFLAGS.debug ?= -g … … 116 124 TOOL_GXX64_COMPILE_C_DEPEND = 117 125 TOOL_GXX64_COMPILE_C_DEPORD = 118 ifdef KBUILD_USE_KOBJCACHE 119 TOOL_GXX64_COMPILE_C_USES_KOBJCACHE = 1 120 TOOL_GXX64_COMPILE_C_OUTPUT = $(outbase).i 126 TOOL_GXX64_COMPILE_C_OUTPUT = $(if-expr "$(use_objcache)" != "",$(outbase).i,) 127 TOOL_GXX64_COMPILE_C_USES_KOBJCACHE = $(if-expr "$(use_objcache)" != "",1,) 121 128 define TOOL_GXX64_COMPILE_C_CMDS 129 if "$(use_objcache)" != "" 122 130 $(QUIET)$(KOBJCACHE) -f $(outbase).koc -d $(PATH_OBJCACHE) -t $(bld_trg).$(bld_trg_arch) -p\ 123 131 --kObjCache-cpp $(outbase).i\ … … 131 139 -o $(obj)\ 132 140 - 133 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 134 endef 135 else # !KBUILD_USE_KOBJCACHE 136 TOOL_GXX64_COMPILE_C_OUTPUT = 137 define TOOL_GXX64_COMPILE_C_CMDS 141 else 138 142 $(QUIET)$(TOOL_GXX64_CC) -c\ 139 143 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ … … 141 145 -o $(obj)\ 142 146 $(abspath $(source)) 147 endif 143 148 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 144 149 endef 145 endif # !KBUILD_USE_KOBJCACHE146 150 147 151 148 152 ## Compile C++ source. 153 # @param $(target) Normalized main target name. 154 # @param $(source) Source filename (relative). 155 # @param $(obj) Object file name. This shall be (re)created by the compilation. 156 # @param $(dep) Dependcy file. This shall be (re)created by the compilation. 157 # @param $(flags) Flags. 158 # @param $(defs) Definitions. No -D or something. 159 # @param $(incs) Includes. No -I or something. 160 # @param $(dirdep) Directory creation dependency. 161 # @param $(deps) Other dependencies. 162 # @param $(outbase) Output basename (full). Use this for list files and such. 163 # @param $(objsuff) Object suffix. 164 TOOL_GXX64_COMPILE_CXX_OUTPUT = $(if-expr "$(use_objcache)" != "",$(outbase).ii,) 165 TOOL_GXX64_COMPILE_CXX_DEPEND = $($(target)_1_GCC_PCH_FILE) 166 TOOL_GXX64_COMPILE_CXX_DEPORD = 167 TOOL_GXX64_COMPILE_CXX_USES_KOBJCACHE = $(if-expr "$(use_objcache)" != "",1,) 168 define TOOL_GXX64_COMPILE_CXX_CMDS 169 if "$(use_objcache)" != "" 170 $(QUIET)$(KOBJCACHE) -f $(outbase).koc -d $(PATH_OBJCACHE) -t $(bld_trg).$(bld_trg_arch) -p\ 171 --kObjCache-cpp $(outbase).ii\ 172 $(TOOL_GXX64_CXX) -E -o - $(if-expr defined($(target)_PCH_HDR)\ 173 ,-fpch-preprocess -Winvalid-pch -I$($(target)_1_GCC_PCH_DIR) -include $(basename $($(target)_1_GCC_PCH_FILE)),)\ 174 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ 175 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 176 $(abspath $(source))\ 177 --kObjCache-cc $(obj)\ 178 $(TOOL_GXX64_CXX) -c\ 179 $(flags) -fpreprocessed $(if-expr defined($(target)_PCH_HDR),-fpch-preprocess,) -x c++\ 180 -o $(obj)\ 181 - 182 else 183 $(QUIET)$(TOOL_GXX64_CXX) -c\ 184 $(flags) $(addprefix -I, $($(target)_1_GCC_PCH_DIR) $(incs)) $(addprefix -D, $(defs))\ 185 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 186 -o $(obj) $(if-expr defined($(target)_PCH_HDR) \ 187 ,-Winvalid-pch -include $(basename $($(target)_1_GCC_PCH_FILE)),) \ 188 $(abspath $(source)) 189 endif 190 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 191 endef 192 193 194 ## Precompile C++ header. 149 195 # @param $(target) Normalized main target name. 150 196 # @param $(source) Source filename (relative). … … 158 204 # @param $(outbase) Output basename (full). Use this for list files and such. 159 205 # @param $(objsuff) Object suffix. 160 TOOL_GXX64_COMPILE_CXX_DEPEND = 161 TOOL_GXX64_COMPILE_CXX_DEPORD = 162 ifdef KBUILD_USE_KOBJCACHE 163 TOOL_GXX64_COMPILE_CXX_USES_KOBJCACHE = 1 164 TOOL_GXX64_COMPILE_CXX_OUTPUT = $(outbase).ii 165 define TOOL_GXX64_COMPILE_CXX_CMDS 166 $(QUIET)$(KOBJCACHE) -f $(outbase).koc -d $(PATH_OBJCACHE) -t $(bld_trg).$(bld_trg_arch) -p\ 167 --kObjCache-cpp $(outbase).ii\ 168 $(TOOL_GXX64_CXX) -E -o -\ 169 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ 170 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 171 $(abspath $(source))\ 172 --kObjCache-cc $(obj)\ 173 $(TOOL_GXX64_CXX) -c\ 174 $(flags) -fpreprocessed -x c++\ 175 -o $(obj)\ 176 - 206 TOOL_GXX64_COMPILE_PCH_OUTPUT = $($(target)_1_GCC_PCH_FILE) 207 TOOL_GXX64_COMPILE_PCH_DEPEND = 208 TOOL_GXX64_COMPILE_PCH_DEPORD = $($(target)_1_GCC_PCH_DIR) 209 define TOOL_GXX64_COMPILE_PCH_CMDS 210 $(QUIET)$(TOOL_GXX64_PCH) -c\ 211 $(flags) $(addprefix -I, $($(target)_1_GCC_PCH_DIR) $(incs)) $(addprefix -D, $(defs))\ 212 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 213 -o $(obj)\ 214 $(abspath $(source)) 215 $(INSTALL) --hard-link-files-when-possible -m 0644 -- "$(obj)" "$($(target)_1_GCC_PCH_FILE)" 177 216 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 178 217 endef 179 else # !KBUILD_USE_KOBJCACHE180 TOOL_GXX64_COMPILE_CXX_OUTPUT =181 define TOOL_GXX64_COMPILE_CXX_CMDS182 $(QUIET)$(TOOL_GXX64_CXX) -c\183 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\184 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\185 -o $(obj)\186 $(abspath $(source))187 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" ""188 endef189 endif # !KBUILD_USE_KOBJCACHE190 218 191 219 … … 231 259 $(QUIET)$(APPEND) $(out).ar-script 'CREATE $(out)' 232 260 $(QUIET)$(APPEND) -n $(out).ar-script \ 233 $(foreach o,$( objs), 'ADDMOD $(o)') \261 $(foreach o,$(filter-out %.h.gch,$(objs)), 'ADDMOD $(o)') \ 234 262 $(foreach o,$(othersrc), 'ADDLIB $(o)') 235 263 $(QUIET)$(APPEND) $(out).ar-script 'SAVE' … … 259 287 TOOL_GXX64_LINK_PROGRAM_DEPORD = 260 288 define TOOL_GXX64_LINK_PROGRAM_CMDS 261 $(QUIET)$(TOOL_GXX64_LD) $(flags) -o $(out) $( objs)\289 $(QUIET)$(TOOL_GXX64_LD) $(flags) -o $(out) $(filter-out %.h.gch,$(objs))\ 262 290 $(foreach p,$(libpath), -L$(p))\ 263 291 $(foreach lib,$(libs), $(if $(findstring $(lib),$(subst /,x,$(lib))), -l$(patsubst lib%,%,$(lib)), $(lib)))\ … … 293 321 $(QUIET)$(TOOL_GXX64_LD) $(TOOL_GXX64_LDFLAGS.dll) $(flags) -o $(out)\ 294 322 $(if $(filter-out win os2, $(KBUILD_TARGET)),$(call TOOL_GXX64_LD_SONAME,$(target),$(out)))\ 295 $( objs)\323 $(filter-out %.h.gch,$(objs))\ 296 324 $(foreach p,$(libpath), -L$(p))\ 297 325 $(foreach lib,$(libs), $(if $(findstring $(lib),$(subst /,x,$(lib))), -l$(patsubst lib%,%,$(lib)), $(lib)))\ … … 325 353 TOOL_GXX64_LINK_SYSMOD_DEPORD = 326 354 define TOOL_GXX64_LINK_SYSMOD_CMDS 327 $(QUIET)$(TOOL_GXX64_LD_SYSMOD) $(TOOL_GXX64_LDFLAGS.sysmod) $(flags) -o $(out) $( objs)\355 $(QUIET)$(TOOL_GXX64_LD_SYSMOD) $(TOOL_GXX64_LDFLAGS.sysmod) $(flags) -o $(out) $(filter-out %.h.gch,$(objs))\ 328 356 $(foreach p,$(libpath), -L$(p))\ 329 357 $(foreach lib,$(libs), $(if $(findstring $(lib),$(subst /,x,$(lib))), -l$(patsubst lib%,%,$(lib)), $(lib)))\ -
trunk/kBuild/tools/LLVMGXX42MACHO.kmk
r3121 r3258 39 39 TOOL_LLVMGXX42MACHO_CC ?= $(TOOL_LLVMGXX42MACHO_PREFIX)gcc$(TOOL_LLVMGXX42MACHO_SUFFIX) 40 40 TOOL_LLVMGXX42MACHO_CXX ?= $(TOOL_LLVMGXX42MACHO_PREFIX)g++$(TOOL_LLVMGXX42MACHO_SUFFIX) 41 TOOL_LLVMGXX42MACHO_PCH ?= $(TOOL_LLVMGXX42MACHO_CXX) 41 42 TOOL_LLVMGXX42MACHO_OBJC ?= $(TOOL_LLVMGXX42MACHO_PREFIX)gcc$(TOOL_LLVMGXX42MACHO_SUFFIX) 42 43 TOOL_LLVMGXX42MACHO_OBJCXX ?= $(TOOL_LLVMGXX42MACHO_PREFIX)gcc$(TOOL_LLVMGXX42MACHO_SUFFIX) … … 76 77 TOOL_LLVMGXX42MACHO_CXXINCS ?= 77 78 TOOL_LLVMGXX42MACHO_CXXDEFS ?= 79 80 TOOL_LLVMGXX42MACHO_PCHOBJSUFF ?= .h.gch 81 TOOL_LLVMGXX42MACHO_PCHFLAGS ?= $(TOOL_LLVMGXX42MACHO_CXXFLAGS) 82 TOOL_LLVMGXX42MACHO_PCHFLAGS.debug ?= $(TOOL_LLVMGXX42MACHO_CXXFLAGS.debug) 83 TOOL_LLVMGXX42MACHO_PCHFLAGS.profile ?= $(TOOL_LLVMGXX42MACHO_CXXFLAGS.profile) 84 TOOL_LLVMGXX42MACHO_PCHFLAGS.release ?= $(TOOL_LLVMGXX42MACHO_CXXFLAGS.release) 85 TOOL_LLVMGXX42MACHO_PCHINCS ?= $(TOOL_LLVMGXX42MACHO_CXXINCS) 86 TOOL_LLVMGXX42MACHO_PCHDEFS ?= $(TOOL_LLVMGXX42MACHO_CXXDEFS) 78 87 79 88 TOOL_LLVMGXX42MACHO_OBJCOBJSUFF ?= .o … … 155 164 TOOL_LLVMGXX42MACHO_COMPILE_C_DEPEND = 156 165 TOOL_LLVMGXX42MACHO_COMPILE_C_DEPORD = 157 ifdef KBUILD_USE_KOBJCACHE 158 TOOL_LLVMGXX42MACHO_COMPILE_C_USES_KOBJCACHE = 1 159 TOOL_LLVMGXX42MACHO_COMPILE_C_OUTPUT = $(outbase).i 166 TOOL_LLVMGXX42MACHO_COMPILE_C_OUTPUT = $(if-expr "$(use_objcache)" != "",$(outbase).i,) 167 TOOL_LLVMGXX42MACHO_COMPILE_C_USES_KOBJCACHE = $(if-expr "$(use_objcache)" != "",1,) 160 168 define TOOL_LLVMGXX42MACHO_COMPILE_C_CMDS 169 if "$(use_objcache)" != "" 161 170 $(QUIET)$(KOBJCACHE) -f $(outbase).koc -d $(PATH_OBJCACHE) -t $(bld_trg).$(bld_trg_arch) -p\ 162 171 --kObjCache-cpp $(outbase).i\ … … 170 179 -o $(obj)\ 171 180 - 172 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 173 endef 174 else # !KBUILD_USE_KOBJCACHE 175 TOOL_LLVMGXX42MACHO_COMPILE_C_OUTPUT = 176 define TOOL_LLVMGXX42MACHO_COMPILE_C_CMDS 181 else 177 182 $(QUIET)$(TOOL_LLVMGXX42MACHO_CC) -c\ 178 183 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ … … 180 185 -o $(obj)\ 181 186 $(abspath $(source)) 182 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 183 endef 184 end if # !KUSE_OBJCACHE187 endif 188 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 189 endef 185 190 186 191 … … 189 194 # @param $(source) Source filename (relative). 190 195 # @param $(obj) Object file name. This shall be (re)created by the compilation. 191 # @param $(dep) Dependcy file. This shall be (re)created by the compilation. 192 # @param $(flags) Flags. 193 # @param $(defs) Definitions. No -D or something. 194 # @param $(incs) Includes. No -I or something. 195 # @param $(dirdep) Directory creation dependency. 196 # @param $(deps) Other dependencies. 197 # @param $(outbase) Output basename (full). Use this for list files and such. 198 # @param $(objsuff) Object suffix. 199 TOOL_LLVMGXX42MACHO_COMPILE_CXX_DEPEND = 200 TOOL_LLVMGXX42MACHO_COMPILE_CXX_DEPORD = 201 ifdef KBUILD_USE_KOBJCACHE 202 TOOL_LLVMGXX42MACHO_COMPILE_CXX_USES_KOBJCACHE = 1 203 TOOL_LLVMGXX42MACHO_COMPILE_CXX_OUTPUT = $(outbase).ii 196 # @param $(dep) Dependcy file. This shall be (re)created by the compilation. 197 # @param $(flags) Flags. 198 # @param $(defs) Definitions. No -D or something. 199 # @param $(incs) Includes. No -I or something. 200 # @param $(dirdep) Directory creation dependency. 201 # @param $(deps) Other dependencies. 202 # @param $(outbase) Output basename (full). Use this for list files and such. 203 # @param $(objsuff) Object suffix. 204 TOOL_LLVMGXX42MACHO_COMPILE_CXX_OUTPUT = $(if-expr "$(use_objcache)" != "",$(outbase).ii,) 205 TOOL_LLVMGXX42MACHO_COMPILE_CXX_DEPEND = $($(target)_1_GCC_PCH_FILE) 206 TOOL_LLVMGXX42MACHO_COMPILE_CXX_DEPORD = 207 TOOL_LLVMGXX42MACHO_COMPILE_CXX_USES_KOBJCACHE = $(if-expr "$(use_objcache)" != "",1,) 204 208 define TOOL_LLVMGXX42MACHO_COMPILE_CXX_CMDS 209 if "$(use_objcache)" != "" 205 210 $(QUIET)$(KOBJCACHE) -f $(outbase).koc -d $(PATH_OBJCACHE) -t $(bld_trg).$(bld_trg_arch) -p\ 206 211 --kObjCache-cpp $(outbase).ii\ 207 $(TOOL_LLVMGXX42MACHO_CXX) -E -o -\ 212 $(TOOL_LLVMGXX42MACHO_CXX) -E -o - $(if-expr defined($(target)_PCH_HDR)\ 213 ,-fpch-preprocess -Winvalid-pch -I$($(target)_1_GCC_PCH_DIR) -include $(basename $($(target)_1_GCC_PCH_FILE)),)\ 208 214 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ 209 215 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ … … 211 217 --kObjCache-cc $(obj)\ 212 218 $(TOOL_LLVMGXX42MACHO_CXX) -c\ 213 $(flags) -fpreprocessed -x c++\219 $(flags) -fpreprocessed $(if-expr defined($(target)_PCH_HDR),-fpch-preprocess,) -x c++\ 214 220 -o $(obj)\ 215 221 - 216 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 217 endef 218 else # !KBUILD_USE_KOBJCACHE 219 TOOL_LLVMGXX42MACHO_COMPILE_CXX_OUTPUT = 220 define TOOL_LLVMGXX42MACHO_COMPILE_CXX_CMDS 222 else 221 223 $(QUIET)$(TOOL_LLVMGXX42MACHO_CXX) -c\ 222 $(flags) $(addprefix -I, $(incs)) $(addprefix -D, $(defs))\ 223 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 224 -o $(obj)\ 225 $(abspath $(source)) 226 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 227 endef 228 endif # !KBUILD_USE_KOBJCACHE 224 $(flags) $(addprefix -I, $($(target)_1_GCC_PCH_DIR) $(incs)) $(addprefix -D, $(defs))\ 225 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 226 -o $(obj) $(if-expr defined($(target)_PCH_HDR) \ 227 ,-Winvalid-pch -include $(basename $($(target)_1_GCC_PCH_FILE)),) \ 228 $(abspath $(source)) 229 endif 230 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 231 endef 232 233 234 ## Precompile C++ header. 235 # @param $(target) Normalized main target name. 236 # @param $(source) Source filename (relative). 237 # @param $(obj) Object file name. This shall be (re)created by the compilation. 238 # @param $(dep) Dependcy file. This shall be (re)created by the compilation. 239 # @param $(flags) Flags. 240 # @param $(defs) Definitions. No -D or something. 241 # @param $(incs) Includes. No -I or something. 242 # @param $(dirdep) Directory creation dependency. 243 # @param $(deps) Other dependencies. 244 # @param $(outbase) Output basename (full). Use this for list files and such. 245 # @param $(objsuff) Object suffix. 246 TOOL_LLVMGXX42MACHO_COMPILE_PCH_OUTPUT = $($(target)_1_GCC_PCH_FILE) 247 TOOL_LLVMGXX42MACHO_COMPILE_PCH_DEPEND = 248 TOOL_LLVMGXX42MACHO_COMPILE_PCH_DEPORD = $($(target)_1_GCC_PCH_DIR) 249 define TOOL_LLVMGXX42MACHO_COMPILE_PCH_CMDS 250 $(QUIET)$(TOOL_LLVMGXX42MACHO_PCH) -c\ 251 $(flags) $(addprefix -I, $($(target)_1_GCC_PCH_DIR) $(incs)) $(addprefix -D, $(defs))\ 252 -Wp,-MD,$(dep) -Wp,-MT,$(obj) -Wp,-MP\ 253 -o $(obj)\ 254 $(abspath $(source)) 255 $(INSTALL) --hard-link-files-when-possible -m 0644 -- "$(obj)" "$($(target)_1_GCC_PCH_FILE)" 256 $(QUIET)$(APPEND) -n "$(dep)" "" "$(source):" "" 257 endef 229 258 230 259 … … 356 385 TOOL_LLVMGXX42MACHO_LINK_LIBRARY_DEPORD = 357 386 define TOOL_LLVMGXX42MACHO_LINK_LIBRARY_CMDS 358 $(if $(strip $( objs)),$(call xargs,$(QUIET)$(TOOL_LLVMGXX42MACHO_AR) $(flags) $(out),$(objs)))387 $(if $(strip $(filter-out %.h.gch,$(objs))),$(call xargs,$(QUIET)$(TOOL_LLVMGXX42MACHO_AR) $(flags) $(out),$(filter-out %.h.gch,$(objs)))) 359 388 $(foreach lib,$(othersrc)\ 360 389 ,$(NL)$(TAB)$(call MSG_AR_MERGE,$(target),$(out),$(lib)) \ … … 389 418 TOOL_LLVMGXX42MACHO_LINK_PROGRAM_DEPORD = 390 419 define TOOL_LLVMGXX42MACHO_LINK_PROGRAM_CMDS 391 $(QUIET)$(APPEND) -n $(outbase).rsp $( objs)420 $(QUIET)$(APPEND) -n $(outbase).rsp $(filter-out %.h.gch,$(objs)) 392 421 $(QUIET)$(TOOL_LLVMGXX42MACHO_LD) $(flags) -o $(out)\ 393 422 -filelist $(outbase).rsp\ … … 420 449 TOOL_LLVMGXX42MACHO_LINK_DLL_DEPORD = 421 450 define TOOL_LLVMGXX42MACHO_LINK_DLL_CMDS 422 $(QUIET)$(APPEND) -n $(outbase).rsp $( objs)451 $(QUIET)$(APPEND) -n $(outbase).rsp $(filter-out %.h.gch,$(objs)) 423 452 $(QUIET)$(TOOL_LLVMGXX42MACHO_LD) $(TOOL_LLVMGXX42MACHO_LDFLAGS.dll) $(flags) -o $(out)\ 424 453 $(call TOOL_LLVMGXX42MACHO_LD_SONAME,$(target),$(out))\ … … 452 481 TOOL_LLVMGXX42MACHO_LINK_SYSMOD_DEPORD = 453 482 define TOOL_LLVMGXX42MACHO_LINK_SYSMOD_CMDS 454 $(QUIET)$(APPEND) -n $(outbase).rsp $( objs)483 $(QUIET)$(APPEND) -n $(outbase).rsp $(filter-out %.h.gch,$(objs)) 455 484 $(QUIET)$(TOOL_LLVMGXX42MACHO_LD_SYSMOD) $(TOOL_LLVMGXX42MACHO_LDFLAGS.sysmod) $(flags) -o $(out)\ 456 485 -filelist $(outbase).rsp\
Note:
See TracChangeset
for help on using the changeset viewer.