X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=mcs%2Fbuild%2Fexecutable.make;h=7ac941ca83996de7f98bc0f36cedb5ebf3568e46;hb=b2a11ac756f940c30b05aa0a8baf733572df4ce5;hp=7ac3b33846239297cc064116a273e3035c542d00;hpb=b711f7731b1861c25f673eb699df5d4000910b9f;p=mono.git diff --git a/mcs/build/executable.make b/mcs/build/executable.make index 7ac3b338462..7ac941ca839 100644 --- a/mcs/build/executable.make +++ b/mcs/build/executable.make @@ -19,7 +19,7 @@ executable_CLEAN_FILES += $(response) endif ifndef the_libdir -the_libdir = $(topdir)/class/lib/$(PROFILE)/ +the_libdir = $(topdir)/class/lib/$(PROFILE_DIRECTORY)/ ifdef PROGRAM_USE_INTERMEDIATE_FILE build_libdir = $(the_libdir)tmp/ else @@ -31,6 +31,9 @@ ifdef base_prog_config PROGRAM_config := $(build_libdir)$(PROGRAM).config endif +sn = $(topdir)/class/lib/$(BUILD_TOOLS_PROFILE)/sn.exe +SN = MONO_PATH="$(topdir)/class/lib/$(BUILD_TOOLS_PROFILE)$(PLATFORM_PATH_SEPARATOR)$$MONO_PATH" $(RUNTIME) $(RUNTIME_FLAGS) $(sn) -q + the_lib = $(the_libdir)$(base_prog) build_lib = $(build_libdir)$(base_prog) @@ -39,7 +42,24 @@ executable_CLEAN_FILES += $(build_lib) $(build_lib).so $(build_lib).mdb $(build_ makefrag = $(depsdir)/$(PROFILE)_$(base_prog).makefrag +ifdef TARGET_NET_REFERENCE +# System.*.dll references come from the TARGET_NET_REFERENCE dir, others from the profile dir +LIB_REFS_MONO = $(call _FILTER_OUT,System,$(LIB_REFS)) +LIB_REFS_SYSTEM = $(filter-out $(LIB_REFS_MONO),$(LIB_REFS)) + +MCS_REFERENCES = $(patsubst %,-r:$(topdir)/../external/binary-reference-assemblies/$(TARGET_NET_REFERENCE)/%.dll,$(LIB_REFS_SYSTEM)) +MCS_REFERENCES += $(patsubst %,-r:$(topdir)/class/lib/$(PROFILE_DIRECTORY)/%.dll,$(LIB_REFS_MONO)) +else +MCS_REFERENCES = $(patsubst %,-r:$(topdir)/class/lib/$(PROFILE_DIRECTORY)/%.dll,$(LIB_REFS)) +endif + +ifdef KEYFILE +LIB_MCS_FLAGS += /keyfile:$(KEYFILE) +endif + +ifndef NO_BUILD all-local: $(the_lib) $(PROGRAM_config) +endif install-local: all-local test-local: all-local @@ -58,6 +78,7 @@ install-local: $(MKINSTALLDIRS) $(DESTDIR)$(PROGRAM_INSTALL_DIR) $(INSTALL_BIN) $(the_lib) $(DESTDIR)$(PROGRAM_INSTALL_DIR) test ! -f $(the_lib).mdb || $(INSTALL_BIN) $(the_lib).mdb $(DESTDIR)$(PROGRAM_INSTALL_DIR) + test ! -f $(the_lib:.exe=.pdb) || $(INSTALL_BIN) $(the_lib:.exe=.pdb) $(DESTDIR)$(PROGRAM_INSTALL_DIR) ifdef PROGRAM_config $(INSTALL_DATA) $(PROGRAM_config) $(DESTDIR)$(PROGRAM_INSTALL_DIR) endif @@ -66,7 +87,8 @@ ifdef PLATFORM_AOT_SUFFIX endif uninstall-local: - -rm -f $(DESTDIR)$(PROGRAM_INSTALL_DIR)/$(base_prog) $(DESTDIR)$(PROGRAM_INSTALL_DIR)/$(base_prog).mdb $(DESTDIR)$(PROGRAM_INSTALL_DIR)/$(base_prog).config + -rm -f $(DESTDIR)$(PROGRAM_INSTALL_DIR)/$(base_prog) $(DESTDIR)$(PROGRAM_INSTALL_DIR)/$(base_prog).mdb \ + $(DESTDIR)$(PROGRAM_INSTALL_DIR)/$(base_prog:.exe=.pdb) $(DESTDIR)$(PROGRAM_INSTALL_DIR)/$(base_prog).config endif clean-local: @@ -107,10 +129,18 @@ ifndef PROGRAM_COMPILE PROGRAM_COMPILE = $(CSCOMPILE) endif -$(the_lib): $(the_libdir)/.stamp +$(the_lib): $(the_libdir)/.stamp $(if $(PROFILE_PLATFORM),$(if $(filter $(HOST_PLATFORM),$(BUILD_PLATFORM)),$(topdir)/class/lib/$(PROFILE)/.stamp)) + +ifdef PROFILE_PLATFORM +$(topdir)/class/lib/$(PROFILE)/.stamp: | $(topdir)/class/lib/$(PROFILE)-$(HOST_PLATFORM)/.stamp + $(if $(filter $(HOST_PLATFORM),$(BUILD_PLATFORM)),$(if $(filter $(BUILD_PLATFORM),win32),CYGWIN=winsymlinks:nativestrict) ln -s $(abspath $(topdir)/class/lib/$(PROFILE)-$(BUILD_PLATFORM)) $(abspath $(topdir)/class/lib/$(PROFILE))) +endif $(build_lib): $(BUILT_SOURCES) $(EXTRA_SOURCES) $(response) $(build_libdir:=/.stamp) - $(PROGRAM_COMPILE) -target:exe -out:$@ $(BUILT_SOURCES) $(EXTRA_SOURCES) @$(response) + $(PROGRAM_COMPILE) $(MCS_REFERENCES) -target:exe -out:$@ $(BUILT_SOURCES) $(EXTRA_SOURCES) @$(response) +ifdef PROGRAM_SNK + $(Q) $(SN) -R $@ $(PROGRAM_SNK) +endif ifdef PROGRAM_USE_INTERMEDIATE_FILE $(the_lib): $(build_lib) @@ -145,6 +175,15 @@ endif all-local: $(makefrag) $(extra_targets) +ifdef BUILT_SOURCES +library_CLEAN_FILES += $(BUILT_SOURCES) +ifeq (cat, $(PLATFORM_CHANGE_SEPARATOR_CMD)) +BUILT_SOURCES_cmdline = $(BUILT_SOURCES) +else +BUILT_SOURCES_cmdline = `echo $(BUILT_SOURCES) | $(PLATFORM_CHANGE_SEPARATOR_CMD)` +endif +endif + csproj-local: config_file=`basename $(PROGRAM) .exe`-$(PROFILE).input; \ echo $(thisdir):$$config_file >> $(topdir)/../msvc/scripts/order; \ @@ -155,6 +194,7 @@ csproj-local: echo $(build_lib); \ echo $(FRAMEWORK_VERSION); \ echo $(PROFILE); \ + echo $(RESOURCE_DEFS); \ echo $(response)) > $(topdir)/../msvc/scripts/inputs/$$config_file