# MODULE : name of the main module being built
# EXTRALIBS : extra libraries to link in (optional)
# SPEC_SRCS16 : interface definition files for 16-bit dlls (optional)
-# SUBSYSTEM : (optional) subsystem (for native dlls)
#
# plus all variables required by the global Make.rules.in
#
DLLFLAGS = @DLLFLAGS@
-DLLEXT = @DLLEXT@
-IMPLIBEXT = @IMPLIBEXT@
-LDRPATH = @LDDLLRPATH@
+MINGWAR = @MINGWAR@
DEFS = -D__WINESRC__ $(EXTRADEFS)
BASEMODULE = $(MODULE:%.dll=%)
MAINSPEC = $(BASEMODULE).spec
-SPEC_DEF = lib$(BASEMODULE).def
+SPEC_DEF = $(BASEMODULE).def
WIN16_FILES = $(SPEC_SRCS16:.spec=.spec.o) $(C_SRCS16:.c=.o) $(EXTRA_OBJS16)
-ALL_OBJS = @WIN16_FILES@ $(OBJS) $(RC_SRCS:.rc=.res)
-ALL_LIBS = $(EXTRALIBS) $(LIBPORT) $(LDFLAGS) $(LIBS)
-ALL_IMPORTS = $(DELAYIMPORTS) $(IMPORTS)
+ALL_OBJS = @WIN16_FILES@ $(OBJS)
+ALL_LIBS = $(LIBPORT) $(EXTRALIBS) $(LDFLAGS) $(LIBS)
IMPLIB_OBJS = $(IMPLIB_SRCS:.c=.o)
-STATICIMPLIB= $(IMPORTLIB:.def=.def.a)
-DLL_LDPATH = -L$(DLLDIR) $(ALL_IMPORTS:%=-L$(DLLDIR)/%)
-
-all: $(MODULE)$(DLLEXT) $(SUBDIRS)
+IMPORTLIBFILE = $(IMPORTLIB:%=lib%.@IMPLIBEXT@)
+STATICIMPLIB = $(IMPORTLIBFILE:.def=.def.a)
+DLL_LDPATH = -L$(DLLDIR) $(DELAYIMPORTS:%=-L$(DLLDIR)/%) $(IMPORTS:%=-L$(DLLDIR)/%)
+INSTALLDIRS = $(DESTDIR)$(dlldir) $(DESTDIR)$(fakedlldir) $(DESTDIR)$(datadir)/wine
@MAKE_RULES@
-# Rules for .so files
-
-$(MODULE).so: $(MAINSPEC) $(ALL_OBJS) Makefile.in
- $(WINEGCC) -B$(TOOLSDIR)/tools/winebuild -shared $(SRCDIR)/$(MAINSPEC) $(ALL_OBJS) $(SUBSYSTEM:%=-Wb,--subsystem,%) $(BASEADDRESS:%=-Wl,--image-base,%) $(LDRPATH) -o $@ $(ALL_IMPORTS:%=-l%) $(DELAYIMPORTS:%=-Wb,-d%) $(ALL_LIBS)
+all: $(MODULE)$(DLLEXT) $(MODULE)$(FAKEEXT) $(SUBDIRS)
-# Rules for .dll files
-
-$(MODULE): $(RCOBJS) $(OBJS) $(SPEC_DEF) Makefile.in
- $(DLLWRAP) -k --def $(SPEC_DEF) -o $@ $(RCOBJS) $(OBJS) $(DLL_LDPATH) $(ALL_IMPORTS:%=-l%) $(LIBWINE) $(ALL_LIBS)
+$(MODULE) $(MODULE).so $(MODULE).fake: $(MAINSPEC) $(ALL_OBJS) Makefile.in
+ $(WINEGCC) -shared $(SRCDIR)/$(MAINSPEC) $(ALL_OBJS) $(EXTRADLLFLAGS) -o $@ $(DELAYIMPORTS:%=-l%) $(IMPORTS:%=-l%) $(DELAYIMPORTS:%=-Wb,-d%) $(ALL_LIBS)
# Rules for import libraries
-.PHONY: implib $(IMPLIB_OBJS:%=__static_implib__%)
+.PHONY: implib $(IMPLIB_SRCS:%=__static_implib__%)
-all implib: $(IMPORTLIB) $(IMPLIB_OBJS:%=__static_implib__%)
+all implib: $(IMPORTLIBFILE) $(IMPLIB_SRCS:%=__static_implib__%)
-$(IMPLIB_OBJS:%=__static_implib__%): $(STATICIMPLIB)
+$(IMPLIB_SRCS:%=__static_implib__%): $(STATICIMPLIB)
-lib$(BASEMODULE).def: $(MAINSPEC)
- $(WINEBUILD) -w --def -o $@ --export $(SRCDIR)/$(MAINSPEC)
+$(SPEC_DEF) $(IMPORTLIB:%=lib%.def): $(MAINSPEC)
+ $(WINEBUILD) $(TARGETFLAGS) -w --def -o $@ --export $(SRCDIR)/$(MAINSPEC)
-lib$(BASEMODULE).def.a: $(IMPLIB_OBJS)
+$(IMPORTLIB:%=lib%.def.a): $(IMPLIB_OBJS)
$(RM) $@
- $(AR) $@ $(IMPLIB_OBJS)
+ $(AR) $(ARFLAGS) $@ $(IMPLIB_OBJS)
$(RANLIB) $@
-lib$(BASEMODULE).a: $(SPEC_DEF) $(IMPLIB_OBJS)
+$(IMPORTLIB:%=lib%.a): $(SPEC_DEF) $(IMPLIB_OBJS)
$(DLLTOOL) -k -l $@ -d $(SPEC_DEF)
- $(AR) $@ $(IMPLIB_OBJS)
- $(RANLIB) $@
+ $(MINGWAR) rs $@ $(IMPLIB_OBJS)
$(SUBDIRS): implib
-# Rules for checking that no imports are missing
-
-.PHONY: checklink16 $(WIN16_FILES:%=__checklink16__%)
-
-$(WIN16_FILES:%=__checklink16__%): checklink16
-
-checklink16:: $(MAINSPEC).o $(OBJS) dummy
- $(CC) -o checklink -Wl,-rpath,$(TOPOBJDIR)/libs $(TOPSRCDIR)/dlls/checklink.c $(MAINSPEC).o $(OBJS) -L$(DLLDIR) $(ALL_LIBS) -lwinecrt0 -lm && $(RM) checklink $(MAINSPEC).o
-
-checklink:: $(WIN16_FILES:%=__checklink16__%)
-
# Rules for testing
-check test:: $(SUBDIRS:%=%/__test__)
-
-crosstest:: $(SUBDIRS:%=%/__crosstest__)
+check test:: $(SUBDIRS:%=%/__test__) dummy
-# Rule to explicitly generate the .spec.s for debugging
-
-$(MAINSPEC).s $(MAINSPEC).o: $(MAINSPEC) $(ALL_OBJS)
- $(WINEBUILD) $(WINEBUILDFLAGS) --dll -o $@ --export $(SRCDIR)/$(MAINSPEC) $(SUBSYSTEM:%=--subsystem %) $(ALL_OBJS) $(DLL_LDPATH) $(ALL_IMPORTS:%=-l%) $(DELAYIMPORTS:%=-d%) $(DLLDIR)/libwinecrt0.a
+crosstest:: $(SUBDIRS:%=%/__crosstest__) dummy
# Rules for auto documentation
-man: $(C_SRCS)
+man: $(C_SRCS) dummy
$(C2MAN) -o $(TOPOBJDIR)/documentation/man$(api_manext) -R$(TOPOBJDIR) -C$(SRCDIR) -S$(api_manext) $(INCLUDES) $(MAINSPEC:%=-w %) $(SPEC_SRCS16:%=-w %) $(C_SRCS) $(C_SRCS16)
-doc-html: $(C_SRCS)
+doc-html: $(C_SRCS) dummy
$(C2MAN) -o $(TOPOBJDIR)/documentation/html -R$(TOPOBJDIR) -C$(SRCDIR) $(INCLUDES) -Th $(MAINSPEC:%=-w %) $(SPEC_SRCS16:%=-w %) $(C_SRCS) $(C_SRCS16)
-doc-sgml: $(C_SRCS)
+doc-sgml: $(C_SRCS) dummy
$(C2MAN) -o $(TOPOBJDIR)/documentation/api-guide -R$(TOPOBJDIR) -C$(SRCDIR) $(INCLUDES) -Ts $(MAINSPEC:%=-w %) $(SPEC_SRCS16:%=-w %) $(C_SRCS) $(C_SRCS16)
-.PHONY: man doc-html doc-sgml
+doc-xml: $(C_SRCS) dummy
+ $(C2MAN) -o $(TOPOBJDIR)/documentation/api-guide-xml -R$(TOPOBJDIR) -C$(SRCDIR) $(INCLUDES) -Tx $(MAINSPEC:%=-w %) $(SPEC_SRCS16:%=-w %) $(C_SRCS) $(C_SRCS16)
+
+.PHONY: man doc-html doc-sgml doc-xml
# Rules for installation
-EXE_SPECS16 = $(SPEC_SRCS16:.exe.spec=.exe16)
-DRV_SPECS16 = $(EXE_SPECS16:.drv.spec=.drv16)
-ALL_SPECS16 = $(DRV_SPECS16:.spec=.dll16)
+.PHONY: install_static_implib_def install_static_implib_a
+.PHONY: $(IMPORTLIB:%=_install_/%) $(IMPLIB_SRCS:%=_install_static_implib_/%)
-WIN16_INSTALL = $(ALL_SPECS16:%=_install_/%)
+$(IMPORTLIB:%=_install_/%): $(IMPORTLIBFILE) $(DESTDIR)$(dlldir) dummy
+ $(INSTALL_DATA) $(IMPORTLIBFILE) $(DESTDIR)$(dlldir)/$(IMPORTLIBFILE)
-.PHONY: install_lib install_static_implib_def install_static_implib_a
-.PHONY: $(ALL_SPECS16:%=_install_/%) $(IMPORTLIB:%=_install_/%) $(IMPLIB_OBJS:%=_install_static_implib_/%)
+install_static_implib_def: $(STATICIMPLIB) $(DESTDIR)$(dlldir) dummy
+ $(INSTALL_DATA) $(STATICIMPLIB) $(DESTDIR)$(dlldir)/$(STATICIMPLIB)
-$(ALL_SPECS16:%=_install_/%): install_lib
- echo "$(MODULE)" > $(DESTDIR)$(dlldir)/`basename $@`
+install_static_implib_a:
-install_lib: $(MODULE)$(DLLEXT)
- $(MKINSTALLDIRS) $(DESTDIR)$(dlldir)
- $(INSTALL_PROGRAM) $(MODULE)$(DLLEXT) $(DESTDIR)$(dlldir)/$(MODULE)$(DLLEXT)
+$(IMPLIB_SRCS:%=_install_static_implib_/%): install_static_implib_$(IMPLIBEXT)
-$(IMPORTLIB:%=_install_/%): $(IMPORTLIB)
- $(MKINSTALLDIRS) $(DESTDIR)$(dlldir)
- $(INSTALL_DATA) $(IMPORTLIB) $(DESTDIR)$(dlldir)/$(IMPORTLIB)
+.PHONY: install_dll install_dll.so install_dll.fake
-install_static_implib_def: $(STATICIMPLIB)
- $(MKINSTALLDIRS) $(DESTDIR)$(dlldir)
- $(INSTALL_DATA) $(STATICIMPLIB) $(DESTDIR)$(dlldir)/$(STATICIMPLIB)
+install_dll: $(MODULE) $(DESTDIR)$(dlldir) dummy
+ $(INSTALL_PROGRAM) $(MODULE) $(DESTDIR)$(dlldir)/$(MODULE)
-install_static_implib_a:
+install_dll.so: $(MODULE).so $(DESTDIR)$(dlldir) dummy
+ $(INSTALL_PROGRAM) $(MODULE).so $(DESTDIR)$(dlldir)/$(MODULE).so
-$(IMPLIB_OBJS:%=_install_static_implib_/%): install_static_implib_$(IMPLIBEXT)
+install_dll.fake: $(MODULE).fake $(DESTDIR)$(fakedlldir) dummy
+ $(INSTALL_DATA) $(MODULE).fake $(DESTDIR)$(fakedlldir)/$(MODULE)
-install install-lib:: install_lib @WIN16_INSTALL@
+install install-lib:: install_dll$(DLLEXT) install_dll$(FAKEEXT)
-install install-dev:: $(IMPORTLIB:%=_install_/%) $(IMPLIB_OBJS:%=_install_static_implib_/%)
+install install-dev:: $(IMPORTLIB:%=_install_/%) $(IMPLIB_SRCS:%=_install_static_implib_/%) dummy
uninstall::
- -cd $(DESTDIR)$(dlldir) && $(RM) $(MODULE)$(DLLEXT) $(IMPORTLIB) $(STATICIMPLIB) $(ALL_SPECS16)
+ -cd $(DESTDIR)$(dlldir) && $(RM) $(MODULE)$(DLLEXT) $(IMPORTLIBFILE) $(STATICIMPLIB)
+ $(RM) $(DESTDIR)$(fakedlldir)/$(MODULE)
# Misc. rules
clean::
- $(RM) $(SPEC_DEF)
+ $(RM) $(SPEC_DEF) $(IMPORTLIBFILE)
$(SPEC_DEF) $(SPEC_SRCS16:.spec=.spec.o): $(WINEBUILD)