722954e799
* atk/Makefile.am * glib/Makefile.am * Makefile.include: Added new 'moonlight' target, to build with smcs. svn path=/trunk/gtk-sharp/; revision=131780
94 lines
3.6 KiB
Text
94 lines
3.6 KiB
Text
SNK = gtk-sharp.snk
|
|
API = $(pkg)-api.xml
|
|
RAW_API = $(pkg)-api.raw
|
|
|
|
ASSEMBLY_NAME = $(pkg)-sharp
|
|
ASSEMBLY = $(ASSEMBLY_NAME).dll
|
|
|
|
TARGET = $(pkg:=-sharp.dll) $(pkg:=-sharp.dll.config) $(POLICY_ASSEMBLIES)
|
|
noinst_DATA = $(TARGET)
|
|
TARGET_API = $(pkg:=-api.xml)
|
|
gapidir = $(datadir)/gapi-2.0
|
|
gapi_DATA = $(TARGET_API)
|
|
CLEANFILES = $(ASSEMBLY) $(ASSEMBLY).mdb $(POLICY_ASSEMBLIES) generated-stamp generated/*.cs $(API) glue/generated.c $(SNK) AssemblyInfo.cs $(POLICY_CONFIGS)
|
|
DISTCLEANFILES = $(ASSEMBLY).config
|
|
|
|
POLICY_ASSEMBLIES = $(addsuffix .$(ASSEMBLY), $(addprefix policy., $(POLICY_VERSIONS)))
|
|
POLICY_CONFIGS = $(addsuffix .config, $(addprefix policy., $(POLICY_VERSIONS)))
|
|
|
|
EXTRA_DIST = $(RAW_API) $(SYMBOLS) $(ASSEMBLY).config.in $(METADATA) $(customs) $(sources) $(add_dist)
|
|
|
|
build_symbols = $(addprefix --symbols=$(srcdir)/, $(SYMBOLS))
|
|
|
|
$(API): $(METADATA) $(RAW_API) $(SYMBOLS) $(top_builddir)/parser/gapi-fixup.exe
|
|
cp $(srcdir)/$(RAW_API) $(API)
|
|
chmod u+w $(API)
|
|
@if test -n '$(METADATA)'; then \
|
|
echo "$(RUNTIME) $(top_builddir)/parser/gapi-fixup.exe --api=$(API) --metadata=$(srcdir)/$(METADATA) $(build_symbols)"; \
|
|
$(RUNTIME) $(top_builddir)/parser/gapi-fixup.exe --api=$(API) --metadata=$(srcdir)/$(METADATA) $(build_symbols); \
|
|
fi
|
|
|
|
build_customs = $(addprefix $(srcdir)/, $(customs))
|
|
api_includes = $(addprefix -I:, $(INCLUDE_API))
|
|
|
|
generated-stamp: $(API) $(INCLUDE_API) $(top_builddir)/generator/gapi_codegen.exe $(build_customs)
|
|
rm -f generated/* && \
|
|
$(RUNTIME) $(top_builddir)/generator/gapi_codegen.exe --generate $(API) \
|
|
$(api_includes) \
|
|
--outdir=generated --customdir=$(srcdir) --assembly-name=$(ASSEMBLY_NAME) \
|
|
--gluelib-name=$(pkg)sharpglue-2 --glue-filename=glue/generated.c \
|
|
--glue-includes=$(glue_includes) \
|
|
&& touch generated-stamp
|
|
|
|
$(SNK): $(top_srcdir)/$(SNK)
|
|
cp $(top_srcdir)/$(SNK) .
|
|
|
|
AssemblyInfo.cs: $(top_builddir)/AssemblyInfo.cs
|
|
cp $(top_builddir)/AssemblyInfo.cs .
|
|
|
|
policy.%.config: $(top_builddir)/policy.config
|
|
sed -e "s/@ASSEMBLY_NAME@/$(ASSEMBLY_NAME)/" -e "s/@POLICY@/$*/" $(top_builddir)/policy.config > $@
|
|
|
|
$(POLICY_ASSEMBLIES) : policy.%.$(ASSEMBLY): policy.%.config $(SNK)
|
|
$(AL) -link:policy.$*.config -out:$@ -keyfile:$(SNK)
|
|
|
|
build_sources = $(addprefix $(srcdir)/, $(sources)) AssemblyInfo.cs
|
|
build_references = $(addprefix /r:, $(references)) $(MONO_CAIRO_LIBS)
|
|
|
|
if PLATFORM_WIN32
|
|
GAPI_CDECL_INSERT=$(top_srcdir)/gapi-cdecl-insert --keyfile=$(SNK) $(ASSEMBLY)
|
|
else
|
|
GAPI_CDECL_INSERT=
|
|
endif
|
|
|
|
BUILD_PARAMS=$(CSFLAGS) -nowarn:0169,0612,0618 -unsafe -target:library $(GENERATED_SOURCES) $(build_sources)
|
|
|
|
$(ASSEMBLY): generated-stamp $(SNK) $(build_sources) $(references)
|
|
@rm -f $(ASSEMBLY).mdb
|
|
$(CSC) $(build_references) $(BUILD_PARAMS) -out:$(ASSEMBLY)
|
|
$(GAPI_CDECL_INSERT)
|
|
|
|
install-data-local:
|
|
@if test -n '$(pkg)'; then \
|
|
echo "$(GACUTIL) /i $(ASSEMBLY) /f $(GACUTIL_FLAGS)"; \
|
|
$(GACUTIL) /i $(ASSEMBLY) /f $(GACUTIL_FLAGS) || exit 1; \
|
|
if test -n '$(POLICY_VERSIONS)'; then \
|
|
for i in $(POLICY_VERSIONS); do \
|
|
echo "$(GACUTIL) /i policy.$$i.$(ASSEMBLY) /f $(GACUTIL_FLAGS)"; \
|
|
$(GACUTIL) /i policy.$$i.$(ASSEMBLY) /f $(GACUTIL_FLAGS) || exit 1; \
|
|
done \
|
|
fi \
|
|
fi
|
|
|
|
uninstall-local:
|
|
@if test -n '$(pkg)'; then \
|
|
echo "$(GACUTIL) /u $(ASSEMBLY_NAME) $(GACUTIL_FLAGS)"; \
|
|
$(GACUTIL) /u $(ASSEMBLY_NAME) $(GACUTIL_FLAGS) || exit 1; \
|
|
if test -n '$(POLICY_VERSIONS)'; then \
|
|
for i in $(POLICY_VERSIONS); do \
|
|
echo "$(GACUTIL) /u policy.$$i.$(ASSEMBLY_NAME) $(GACUTIL_FLAGS)"; \
|
|
$(GACUTIL) /u policy.$$i.$(ASSEMBLY_NAME) $(GACUTIL_FLAGS) || exit 1; \
|
|
done \
|
|
fi \
|
|
fi
|
|
|