+# $Id: Makefile,v 1.235 2004/07/10 21:44:14 sedwards Exp $
#
# Global makefile
#
# acpi isapnp pci
BUS = acpi isapnp pci
+# Filesystem libraries
+# vfatlib
+LIB_FSLIB = vfatlib
+
+# Static libraries
+LIB_STATIC = string rosrtl epsapi uuid libwine zlib rtl tgetopt pseh
+
+# Keyboard layout libraries
+DLLS_KBD = kbddv kbdfr kbdgr kbdse kbduk kbdus
+
+# Control Panels
+DLLS_CPL = cpl
+
# User mode libraries
-# advapi32 crtdll fmifs gdi32 kernel32 libpcap packet msafd msvcrt ntdll ole32
-# oleaut32 psapi rpcrt4 secur32 shell32 user32 version ws2help ws2_32 wsock32 wshirda
-DLLS = advapi32 crtdll fmifs gdi32 kernel32 packet msafd msvcrt ntdll \
- secur32 user32 version winedbgc ws2help ws2_32 wshirda #winmm
+# advapi32 cards crtdll comdlg32 fmifs gdi32 imagehlp kernel32 libpcap packet msafd msvcrt ntdll
+# epsapi psapi richedit rpcrt4 secur32 user32 version ws2help ws2_32 wsock32 wshirda mswsock
+# imagehlp imm32
+DLLS = acledit advapi32 cabinet cards comctl32 crtdll comdlg32 d3d8thk expat fmifs freetype gdi32 \
+ imm32 iphlpapi kernel32 lzexpand mpr msafd msgina msimg32 msvcrt msvcrt20 msvideo mswsock \
+ netapi32 ntdll ole32 oleaut32 oledlg packet psapi richedit rpcrt4 samlib secur32 \
+ setupapi shell32 shlwapi snmpapi syssetup twain unicode user32 userenv version wininet \
+ winmm winspool ws2help ws2_32 wsock32 wshirda imagehlp $(DLLS_KBD) $(DLLS_CPL)
SUBSYS = smss win32k csrss ntvdm
LOADERS = dos
# Driver support libraries
-#bzip2 zlib
-DRIVERS_LIB = bzip2 zlib
+#bzip2 zlib oskittcp
+DRIVERS_LIB = bzip2 oskittcp csq
# Kernel mode device drivers
# Obsolete: ide
-# beep blue floppy null parallel ramdrv serenum serial vga vidport
-DEVICE_DRIVERS = beep blue floppy null serial vga vidport
+# beep blue floppy null parallel ramdrv serenum serial
+DEVICE_DRIVERS = beep blue debugout null serial bootvid
# Kernel mode input drivers
-# keyboard mouclass psaux sermouse
-INPUT_DRIVERS = keyboard mouclass psaux
+INPUT_DRIVERS = keyboard mouclass psaux sermouse
# Kernel mode file system drivers
# cdfs ext2 fs_rec ms np vfat
NET_DRIVERS = afd ndis npf tcpip tdi wshtcpip
# Kernel mode networking device drivers
-# ne2000
-NET_DEVICE_DRIVERS = ne2000
+# ne2000 pcnet
+NET_DEVICE_DRIVERS = ne2000 pcnet
# Kernel mode storage drivers
# atapi cdrom class2 disk scsiport
-STORAGE_DRIVERS = atapi cdrom class2 disk scsiport
+STORAGE_DRIVERS = atapi cdrom class2 disk floppy scsiport diskdump
# System applications
-# autochk lsass services shell winlogon
-SYS_APPS = autochk services shell winlogon gstart usetup
+# autochk cmd format services setup usetup welcome winlogon
+SYS_APPS = autochk cmd explorer expand format services setup taskmgr userinit usetup welcome vmwinst winlogon regedit
# System services
# rpcss eventlog
APPS = tests testsets utils
-# External (sub)systems for ReactOS
-# rosapps wine posix os2 (requires c++) java (non-existant)
-EXTERNALS = rosapps wine posix os2
+# External modules and (sub)systems for ReactOS
+# rosapps posix os2 (requires c++) java (non-existant)
+EXTERNALS = rosapps
ifeq ($(ROS_BUILD_EXT),yes)
EXT_MODULES = $(EXTERNALS)
endif
KERNEL_DRIVERS = $(DRIVERS_LIB) $(DEVICE_DRIVERS) $(INPUT_DRIVERS) $(FS_DRIVERS) \
- $(NET_DRIVERS) $(NET_DEVICE_DRIVERS) $(STORAGE_DRIVERS)
+ $(NET_DRIVERS) $(NET_DEVICE_DRIVERS) $(STORAGE_DRIVERS) VIDEO_DRIVERS
+
+# Regression tests
+REGTESTS = regtests
-all: tools dk implib $(COMPONENTS) $(HALS) $(BUS) $(DLLS) $(SUBSYS) \
+all: tools dk implib $(LIB_STATIC) $(COMPONENTS) $(REGTESTS) $(HALS) $(BUS) $(LIB_FSLIB) $(DLLS) $(SUBSYS) \
$(LOADERS) $(KERNEL_DRIVERS) $(SYS_APPS) $(SYS_SVC) \
$(APPS) $(EXT_MODULES)
#config: $(TOOLS:%=%_config)
-depends: $(DLLS:%=%_depends) $(SUBSYS:%=%_depends) $(SYS_SVC:%=%_depends) \
+depends: $(LIB_STATIC:%=%_depends) $(LIB_FSLIB:%=%_depends) $(DLLS:%=%_depends) $(SUBSYS:%=%_depends) $(SYS_SVC:%=%_depends) \
$(EXT_MODULES:%=%_depends) $(POSIX_LIBS:%=%_depends)
implib: $(COMPONENTS:%=%_implib) $(HALS:%=%_implib) $(BUS:%=%_implib) \
- $(DLLS:%=%_implib) $(LOADERS:%=%_implib) \
- $(KERNEL_DRIVERS:%=%_implib) $(SUBSYS:%=%_implib) \
- $(SYS_APPS:%=%_implib) $(SYS_SVC:%=%_implib) \
- $(APPS:%=%_implib) $(EXT_MODULES:%=%_implib)
+ $(LIB_STATIC:%=%_implib) $(LIB_FSLIB:%=%_implib) $(DLLS:%=%_implib) $(LOADERS:%=%_implib) \
+ $(KERNEL_DRIVERS:%=%_implib) $(SUBSYS:%=%_implib) \
+ $(SYS_SVC:%=%_implib) $(EXT_MODULES:%=%_implib)
clean: tools dk_clean $(HALS:%=%_clean) \
- $(COMPONENTS:%=%_clean) $(BUS:%=%_clean) $(DLLS:%=%_clean) \
+ $(COMPONENTS:%=%_clean) $(BUS:%=%_clean) $(LIB_STATIC:%=%_clean) $(LIB_FSLIB:%=%_clean) $(DLLS:%=%_clean) \
$(LOADERS:%=%_clean) $(KERNEL_DRIVERS:%=%_clean) $(SUBSYS:%=%_clean) \
$(SYS_APPS:%=%_clean) $(SYS_SVC:%=%_clean) \
$(NET_APPS:%=%_clean) \
- $(APPS:%=%_clean) $(EXT_MODULES:%=%_clean) \
+ $(APPS:%=%_clean) $(EXT_MODULES:%=%_clean) $(REGTESTS:%=%_clean) \
clean_after tools_clean
clean_after:
$(RM) $(PATH_TO_TOP)/include/roscfg.h
-install: tools install_dirs install_before \
+fastinstall: tools install_dirs install_before \
$(COMPONENTS:%=%_install) $(HALS:%=%_install) $(BUS:%=%_install) \
- $(DLLS:%=%_install) $(LOADERS:%=%_install) \
+ $(LIB_STATIC:%=%_install) $(LIB_FSLIB:%=%_install) $(DLLS:%=%_install) $(LOADERS:%=%_install) \
$(KERNEL_DRIVERS:%=%_install) $(SUBSYS:%=%_install) \
$(SYS_APPS:%=%_install) $(SYS_SVC:%=%_install) \
- $(APPS:%=%_install) $(EXT_MODULES:%=%_install)
-
-dist: $(TOOLS_PATH)/rcopy$(EXE_POSTFIX) dist_clean dist_dirs \
- $(HALS:%=%_dist) $(COMPONENTS:%=%_dist) $(BUS:%=%_dist) $(DLLS:%=%_dist) \
- $(LOADERS:%=%_dist) $(KERNEL_DRIVERS:%=%_dist) $(SUBSYS:%=%_dist) \
- $(SYS_APPS:%=%_dist) $(SYS_SVC:%=%_dist) \
- $(NET_APPS:%=%_dist) \
- $(APPS:%=%_dist) $(EXT_MODULES:%=%_dist)
-
-.PHONY: all depends implib clean clean_before install dist
+ $(APPS:%=%_install) $(EXT_MODULES:%=%_install) $(REGTESTS:%=%_install)
+install: fastinstall registry
+
+FREELDR_DIR = ../freeldr
+
+freeldr:
+ $(MAKE) -C $(FREELDR_DIR)
+
+bootcd_directory_layout:
+ $(RMKDIR) $(BOOTCD_DIR)
+ $(RMKDIR) $(BOOTCD_DIR)/bootdisk
+ $(RMKDIR) $(BOOTCD_DIR)/loader
+ $(RMKDIR) $(BOOTCD_DIR)/reactos
+ $(RMKDIR) $(BOOTCD_DIR)/reactos/system32
+ $(CP) ${FREELDR_DIR}/bootsect/isoboot.bin ${BOOTCD_DIR}/../isoboot.bin
+ $(CP) ${FREELDR_DIR}/bootsect/dosmbr.bin ${BOOTCD_DIR}/loader/dosmbr.bin
+ $(CP) ${FREELDR_DIR}/bootsect/ext2.bin ${BOOTCD_DIR}/loader/ext2.bin
+ $(CP) ${FREELDR_DIR}/bootsect/fat.bin ${BOOTCD_DIR}/loader/fat.bin
+ $(CP) ${FREELDR_DIR}/bootsect/fat32.bin ${BOOTCD_DIR}/loader/fat32.bin
+ $(CP) ${FREELDR_DIR}/bootsect/isoboot.bin ${BOOTCD_DIR}/loader/isoboot.bin
+ $(CP) ${FREELDR_DIR}/freeldr/obj/i386/freeldr.sys ${BOOTCD_DIR}/loader/freeldr.sys
+ $(CP) ${FREELDR_DIR}/freeldr/obj/i386/setupldr.sys ${BOOTCD_DIR}/loader/setupldr.sys
+
+bootcd_bootstrap_files: $(COMPONENTS:%=%_bootcd) $(HALS:%=%_bootcd) $(BUS:%=%_bootcd) \
+ $(LIB_STATIC:%=%_bootcd) $(LIB_FSLIB:%=%_bootcd) $(DLLS:%=%_bootcd) $(KERNEL_DRIVERS:%=%_bootcd) \
+ $(SUBSYS:%=%_bootcd) $(SYS_APPS:%=%_bootcd)
+
+bootcd_install_before:
+ $(RLINE) bootdata/autorun.inf $(BOOTCD_DIR)/autorun.inf
+ $(RLINE) bootdata/readme.txt $(BOOTCD_DIR)/readme.txt
+ $(RLINE) bootdata/hivecls.inf $(BOOTCD_DIR)/reactos/hivecls.inf
+ $(RLINE) bootdata/hivedef.inf $(BOOTCD_DIR)/reactos/hivedef.inf
+ $(RLINE) bootdata/hivesft.inf $(BOOTCD_DIR)/reactos/hivesft.inf
+ $(RLINE) bootdata/hivesys.inf $(BOOTCD_DIR)/reactos/hivesys.inf
+ $(RLINE) bootdata/txtsetup.sif $(BOOTCD_DIR)/reactos/txtsetup.sif
+ $(CP) bootdata/icon.ico $(BOOTCD_DIR)/icon.ico
+ $(CP) subsys/system/welcome/welcome.exe $(BOOTCD_DIR)/reactos/welcome.exe
+ $(CP) media/nls/c_1252.nls $(BOOTCD_DIR)/reactos/c_1252.nls
+ $(CP) media/nls/c_437.nls $(BOOTCD_DIR)/reactos/c_437.nls
+ $(CP) media/nls/l_intl.nls $(BOOTCD_DIR)/reactos/l_intl.nls
+ $(CP) media/drivers/etc/services $(BOOTCD_DIR)/reactos/services
+
+bootcd_basic: bootcd_directory_layout bootcd_bootstrap_files bootcd_install_before
+
+bootcd_makecd:
+ $(CABMAN) /C bootdata/packages/reactos.dff /L $(BOOTCD_DIR)/reactos /I
+ $(CABMAN) /C bootdata/packages/reactos.dff /RC $(BOOTCD_DIR)/reactos/reactos.inf /L $(BOOTCD_DIR)/reactos /N
+ - $(RM) $(BOOTCD_DIR)/reactos/reactos.inf
+ $(TOOLS_PATH)/cdmake/cdmake -v -m -b $(BOOTCD_DIR)/../isoboot.bin $(BOOTCD_DIR) REACTOS ReactOS.iso
+
+ubootcd_unattend:
+ $(CP) bootdata/unattend.inf $(BOOTCD_DIR)/reactos/unattend.inf
+
+livecd_directory_layout:
+ $(RMKDIR) $(LIVECD_DIR)
+ $(RMKDIR) $(LIVECD_DIR)/loader
+ $(RMKDIR) $(LIVECD_DIR)/reactos
+ $(RMKDIR) $(LIVECD_DIR)/Profiles/All\ Users/Desktop
+ $(RMKDIR) $(LIVECD_DIR)/Profiles/Default\ User/Desktop
+ $(RMKDIR) $(LIVECD_DIR)/Profiles/Default\ User/My\ Documents
+ $(CP) ${FREELDR_DIR}/bootsect/isoboot.bin ${LIVECD_DIR}/../isoboot.bin
+ $(CP) ${FREELDR_DIR}/freeldr/obj/i386/freeldr.sys ${LIVECD_DIR}/loader/setupldr.sys
+ $(RLINE) bootdata/livecd.ini $(LIVECD_DIR)/freeldr.ini
+
+livecd_bootstrap_files:
+ $(MAKE) LIVECD_INSTALL=yes fastinstall
+
+livecd_install_before:
+ $(TOOLS_PATH)/mkhive/mkhive$(EXE_POSTFIX) bootdata $(LIVECD_DIR)/reactos/system32/config bootdata/livecd.inf bootdata/hiveinst.inf
+
+livecd_basic: livecd_directory_layout livecd_bootstrap_files livecd_install_before
+
+livecd_makecd:
+ $(TOOLS_PATH)/cdmake/cdmake -m -j -b $(LIVECD_DIR)/../isoboot.bin $(LIVECD_DIR) REACTOS roslive.iso
+
+bootcd: bootcd_basic bootcd_makecd
+
+ubootcd: bootcd_basic ubootcd_unattend bootcd_makecd
+
+livecd: livecd_basic livecd_makecd
+
+registry: tools
+ $(TOOLS_PATH)/mkhive/mkhive$(EXE_POSTFIX) bootdata $(INSTALL_DIR)/system32/config bootdata/hiveinst.inf
+
+.PHONY: all depends implib clean clean_before install freeldr bootcd_directory_layout \
+bootcd_bootstrap_files bootcd_install_before bootcd_basic bootcd_makecd ubootcd_unattend bootcd
#
# System Applications
#
$(SYS_APPS): %:
- make -C subsys/system/$*
+ $(MAKE) -C subsys/system/$*
$(SYS_APPS:%=%_implib): %_implib:
- make -C subsys/system/$* implib
+ $(MAKE) -C subsys/system/$* implib
$(SYS_APPS:%=%_clean): %_clean:
- make -C subsys/system/$* clean
-
-$(SYS_APPS:%=%_dist): %_dist:
- make -C subsys/system/$* dist
+ $(MAKE) -C subsys/system/$* clean
$(SYS_APPS:%=%_install): %_install:
- make -C subsys/system/$* install
+ $(MAKE) -C subsys/system/$* install
+
+$(SYS_APPS:%=%_bootcd): %_bootcd:
+ $(MAKE) -C subsys/system/$* bootcd
-.PHONY: $(SYS_APPS) $(SYS_APPS:%=%_implib) $(SYS_APPS:%=%_clean) $(SYS_APPS:%=%_install) $(SYS_APPS:%=%_dist)
+.PHONY: $(SYS_APPS) $(SYS_APPS:%=%_implib) $(SYS_APPS:%=%_clean) $(SYS_APPS:%=%_install) $(SYS_APPS:%=%_bootcd)
#
# System Services
#
$(SYS_SVC): %:
- make -C services/$*
+ $(MAKE) -C services/$*
$(SYS_SVC:%=%_depends): %_depends:
- make -C services/$* depends
+ $(MAKE) -C services/$* depends
$(SYS_SVC:%=%_implib): %_implib:
- make -C services/$* implib
+ $(MAKE) -C services/$* implib
$(SYS_SVC:%=%_clean): %_clean:
- make -C services/$* clean
-
-$(SYS_SVC:%=%_dist): %_dist:
- make -C services/$* dist
+ $(MAKE) -C services/$* clean
$(SYS_SVC:%=%_install): %_install:
- make -C services/$* install
+ $(MAKE) -C services/$* install
-.PHONY: $(SYS_SVC) $(SYS_SVC:%=%_depends) $(SYS_SVC:%=%_implib) $(SYS_SVC:%=%_clean) $(SYS_SVC:%=%_install) $(SYS_SVC:%=%_dist)
+.PHONY: $(SYS_SVC) $(SYS_SVC:%=%_depends) $(SYS_SVC:%=%_implib) $(SYS_SVC:%=%_clean) $(SYS_SVC:%=%_install)
#
# Extra (optional system) Applications
#
$(APPS): %:
- make -C apps/$*
+ $(MAKE) -C apps/$*
-$(APPS:%=%_implib): %_implib:
- make -C apps/$* implib
+# Not needed
+# $(APPS:%=%_implib): %_implib:
+# $(MAKE) -C apps/$* implib
$(APPS:%=%_clean): %_clean:
- make -C apps/$* clean
-
-$(APPS:%=%_dist): %_dist:
- make -C apps/$* dist
+ $(MAKE) -C apps/$* clean
$(APPS:%=%_install): %_install:
- make -C apps/$* install
+ $(MAKE) -C apps/$* install
-.PHONY: $(APPS) $(APPS:%=%_implib) $(APPS:%=%_clean) $(APPS:%=%_install) $(APPS:%=%_dist)
+.PHONY: $(APPS) $(APPS:%=%_implib) $(APPS:%=%_clean) $(APPS:%=%_install)
#
# External ports and subsystem personalities
#
$(EXTERNALS): %:
- make -C $(ROOT_PATH)/$*
+ $(MAKE) -C $(ROOT_PATH)/$*
$(EXTERNALS:%=%_depends): %_depends:
- make -C $(ROOT_PATH)/$* depends
+ $(MAKE) -C $(ROOT_PATH)/$* depends
$(EXTERNALS:%=%_implib): %_implib:
- make -C $(ROOT_PATH)/$* implib
+ $(MAKE) -C $(ROOT_PATH)/$* implib
$(EXTERNALS:%=%_clean): %_clean:
- make -C $(ROOT_PATH)/$* clean
-
-$(EXTERNALS:%=%_dist): %_dist:
- make -C $(ROOT_PATH)/$* dist
+ $(MAKE) -C $(ROOT_PATH)/$* clean
$(EXTERNALS:%=%_install): %_install:
- make -C $(ROOT_PATH)/$* install
+ $(MAKE) -C $(ROOT_PATH)/$* install
-.PHONY: $(EXTERNALS) $(EXTERNALS:%=%_depends) $(EXTERNALS:%=%_implib) $(EXTERNALS:%=%_clean) $(EXTERNALS:%=%_install) $(EXTERNALS:%=%_dist)
+.PHONY: $(EXTERNALS) $(EXTERNALS:%=%_depends) $(EXTERNALS:%=%_implib) $(EXTERNALS:%=%_clean) $(EXTERNALS:%=%_install)
#
# Tools
#
tools:
- make -C tools
+ $(MAKE) -C tools
tools_implib:
tools_clean:
- make -C tools clean
+ $(MAKE) -C tools clean
tools_install:
-tools_dist:
-
-.PHONY: tools tools_implib tools_clean tools_install tools_dist
+.PHONY: tools tools_implib tools_clean tools_install
#
dk_install:
-dk_dist:
-
-.PHONY: dk dk_implib dk_clean dk_install dk_dist
+.PHONY: dk dk_implib dk_clean dk_install
#
# Interfaces
#
iface_native:
- make -C iface/native
+ $(MAKE) -C iface/native
iface_native_implib:
iface_native_clean:
- make -C iface/native clean
+ $(MAKE) -C iface/native clean
iface_native_install:
-iface_native_dist:
+iface_native_bootcd:
iface_additional:
- make -C iface/addsys
+ $(MAKE) -C iface/addsys
iface_additional_implib:
iface_additional_clean:
- make -C iface/addsys clean
+ $(MAKE) -C iface/addsys clean
iface_additional_install:
-iface_additional_dist:
+iface_additional_bootcd:
.PHONY: iface_native iface_native_implib iface_native_clean iface_native_install \
- iface_native_dist \
+ iface_native_bootcd \
iface_additional iface_additional_implib iface_additional_clean \
- iface_additional_install iface_additional_dist
+ iface_additional_install iface_additional_bootcd
+
#
# Bus driver rules
#
$(BUS): %:
- make -C drivers/bus/$*
+ $(MAKE) -C drivers/bus/$*
$(BUS:%=%_implib): %_implib:
- make -C drivers/bus/$* implib
+ $(MAKE) -C drivers/bus/$* implib
$(BUS:%=%_clean): %_clean:
- make -C drivers/bus/$* clean
+ $(MAKE) -C drivers/bus/$* clean
$(BUS:%=%_install): %_install:
- make -C drivers/bus/$* install
+ $(MAKE) -C drivers/bus/$* install
-$(BUS:%=%_dist): %_dist:
- make -C drivers/bus/$* dist
+$(BUS:%=%_bootcd): %_bootcd:
+ $(MAKE) -C drivers/bus/$* bootcd
.PHONY: $(BUS) $(BUS:%=%_implib) $(BUS:%=%_clean) \
- $(BUS:%=%_install) $(BUS:%=%_dist)
+ $(BUS:%=%_install) $(BUS:%=%_bootcd)
+
#
# Driver support libraries rules
#
$(DRIVERS_LIB): %:
- make -C drivers/lib/$*
+ $(MAKE) -C drivers/lib/$*
$(DRIVERS_LIB:%=%_implib): %_implib:
- make -C drivers/lib/$* implib
+ $(MAKE) -C drivers/lib/$* implib
$(DRIVERS_LIB:%=%_clean): %_clean:
- make -C drivers/lib/$* clean
+ $(MAKE) -C drivers/lib/$* clean
$(DRIVERS_LIB:%=%_install): %_install:
- make -C drivers/lib/$* install
+ $(MAKE) -C drivers/lib/$* install
-$(DRIVERS_LIB:%=%_dist): %_dist:
- make -C drivers/lib/$* dist
+$(DRIVERS_LIB:%=%_bootcd): %_bootcd:
+ $(MAKE) -C drivers/lib/$* bootcd
.PHONY: $(DRIVERS_LIB) $(DRIVERS_LIB:%=%_implib) $(DRIVERS_LIB:%=%_clean) \
- $(DRIVERS_LIB:%=%_install) $(DRIVERS_LIB:%=%_dist)
+ $(DRIVERS_LIB:%=%_install) $(DRIVERS_LIB:%=%_bootcd)
+
#
# Device driver rules
#
$(DEVICE_DRIVERS): %:
- make -C drivers/dd/$*
+ $(MAKE) -C drivers/dd/$*
$(DEVICE_DRIVERS:%=%_implib): %_implib:
- make -C drivers/dd/$* implib
+ $(MAKE) -C drivers/dd/$* implib
$(DEVICE_DRIVERS:%=%_clean): %_clean:
- make -C drivers/dd/$* clean
+ $(MAKE) -C drivers/dd/$* clean
$(DEVICE_DRIVERS:%=%_install): %_install:
- make -C drivers/dd/$* install
+ $(MAKE) -C drivers/dd/$* install
-$(DEVICE_DRIVERS:%=%_dist): %_dist:
- make -C drivers/dd/$* dist
+$(DEVICE_DRIVERS:%=%_bootcd): %_bootcd:
+ $(MAKE) -C drivers/dd/$* bootcd
.PHONY: $(DEVICE_DRIVERS) $(DEVICE_DRIVERS:%=%_implib) $(DEVICE_DRIVERS:%=%_clean) \
- $(DEVICE_DRIVERS:%=%_install) $(DEVICE_DRIVERS:%=%_dist)
+ $(DEVICE_DRIVERS:%=%_install) $(DEVICE_DRIVERS:%=%_bootcd)
+
+
+#
+# Video device driver rules
+#
+VIDEO_DRIVERS:
+ $(MAKE) -C drivers/video
+
+VIDEO_DRIVERS_implib:
+ $(MAKE) -C drivers/video implib
+
+VIDEO_DRIVERS_clean:
+ $(MAKE) -C drivers/video clean
+
+VIDEO_DRIVERS_install:
+ $(MAKE) -C drivers/video install
+
+VIDEO_DRIVERS_bootcd:
+ $(MAKE) -C drivers/video bootcd
+
+.PHONY: VIDEO_DRIVERS VIDEO_DRIVERS_implib VIDEO_DRIVERS_clean \
+ VIDEO_DRIVERS_install VIDEO_DRIVERS_bootcd
+
#
# Input driver rules
#
$(INPUT_DRIVERS): %:
- make -C drivers/input/$*
+ $(MAKE) -C drivers/input/$*
$(INPUT_DRIVERS:%=%_implib): %_implib:
- make -C drivers/input/$* implib
+ $(MAKE) -C drivers/input/$* implib
$(INPUT_DRIVERS:%=%_clean): %_clean:
- make -C drivers/input/$* clean
+ $(MAKE) -C drivers/input/$* clean
$(INPUT_DRIVERS:%=%_install): %_install:
- make -C drivers/input/$* install
+ $(MAKE) -C drivers/input/$* install
-$(INPUT_DRIVERS:%=%_dist): %_dist:
- make -C drivers/input/$* dist
+$(INPUT_DRIVERS:%=%_bootcd): %_bootcd:
+ $(MAKE) -C drivers/input/$* bootcd
.PHONY: $(INPUT_DRIVERS) $(INPUT_DRIVERS:%=%_implib) $(INPUT_DRIVERS:%=%_clean)\
- $(INPUT_DRIVERS:%=%_install) $(INPUT_DRIVERS:%=%_dist)
+ $(INPUT_DRIVERS:%=%_install) $(INPUT_DRIVERS:%=%_bootcd)
+#
+# Filesystem driver rules
+#
$(FS_DRIVERS): %:
- make -C drivers/fs/$*
+ $(MAKE) -C drivers/fs/$*
$(FS_DRIVERS:%=%_implib): %_implib:
- make -C drivers/fs/$* implib
+ $(MAKE) -C drivers/fs/$* implib
$(FS_DRIVERS:%=%_clean): %_clean:
- make -C drivers/fs/$* clean
+ $(MAKE) -C drivers/fs/$* clean
$(FS_DRIVERS:%=%_install): %_install:
- make -C drivers/fs/$* install
+ $(MAKE) -C drivers/fs/$* install
-$(FS_DRIVERS:%=%_dist): %_dist:
- make -C drivers/fs/$* dist
+$(FS_DRIVERS:%=%_bootcd): %_bootcd:
+ $(MAKE) -C drivers/fs/$* bootcd
.PHONY: $(FS_DRIVERS) $(FS_DRIVERS:%=%_implib) $(FS_DRIVERS:%=%_clean) \
- $(FS_DRIVERS:%=%_install) $(FS_DRIVERS:%=%_dist)
+ $(FS_DRIVERS:%=%_install) $(FS_DRIVERS:%=%_bootcd)
+
#
# Network driver rules
#
$(NET_DRIVERS): %:
- make -C drivers/net/$*
+ $(MAKE) -C drivers/net/$*
$(NET_DRIVERS:%=%_implib): %_implib:
- make -C drivers/net/$* implib
+ $(MAKE) -C drivers/net/$* implib
$(NET_DRIVERS:%=%_clean): %_clean:
- make -C drivers/net/$* clean
+ $(MAKE) -C drivers/net/$* clean
$(NET_DRIVERS:%=%_install): %_install:
- make -C drivers/net/$* install
+ $(MAKE) -C drivers/net/$* install
-$(NET_DRIVERS:%=%_dist): %_dist:
- make -C drivers/net/$* dist
+$(NET_DRIVERS:%=%_bootcd): %_bootcd:
+ $(MAKE) -C drivers/net/$* bootcd
.PHONY: $(NET_DRIVERS) $(NET_DRIVERS:%=%_implib) $(NET_DRIVERS:%=%_clean) \
- $(NET_DRIVERS:%=%_install) $(NET_DRIVERS:%=%_dist)
+ $(NET_DRIVERS:%=%_install) $(NET_DRIVERS:%=%_bootcd)
+
+#
+# Network device driver rules
+#
$(NET_DEVICE_DRIVERS): %:
- make -C drivers/net/dd/$*
+ $(MAKE) -C drivers/net/dd/$*
$(NET_DEVICE_DRIVERS:%=%_implib): %_implib:
- make -C drivers/net/dd/$* implib
+ $(MAKE) -C drivers/net/dd/$* implib
$(NET_DEVICE_DRIVERS:%=%_clean): %_clean:
- make -C drivers/net/dd/$* clean
+ $(MAKE) -C drivers/net/dd/$* clean
$(NET_DEVICE_DRIVERS:%=%_install): %_install:
- make -C drivers/net/dd/$* install
+ $(MAKE) -C drivers/net/dd/$* install
-$(NET_DEVICE_DRIVERS:%=%_dist): %_dist:
- make -C drivers/net/dd/$* dist
+$(NET_DEVICE_DRIVERS:%=%_bootcd): %_bootcd:
+ $(MAKE) -C drivers/net/dd/$* bootcd
.PHONY: $(NET_DEVICE_DRIVERS) $(NET_DEVICE_DRIVERS:%=%_clean) $(NET_DEVICE_DRIVERS:%=%_implib) \
- $(NET_DEVICE_DRIVERS:%=%_install) $(NET_DEVICE_DRIVERS:%=%_dist)
+ $(NET_DEVICE_DRIVERS:%=%_install) $(NET_DEVICE_DRIVERS:%=%_bootcd)
+
#
# storage driver rules
#
$(STORAGE_DRIVERS): %:
- make -C drivers/storage/$*
+ $(MAKE) -C drivers/storage/$*
$(STORAGE_DRIVERS:%=%_implib): %_implib:
- make -C drivers/storage/$* implib
+ $(MAKE) -C drivers/storage/$* implib
$(STORAGE_DRIVERS:%=%_clean): %_clean:
- make -C drivers/storage/$* clean
+ $(MAKE) -C drivers/storage/$* clean
$(STORAGE_DRIVERS:%=%_install): %_install:
- make -C drivers/storage/$* install
+ $(MAKE) -C drivers/storage/$* install
+
+$(STORAGE_DRIVERS:%=%_bootcd): %_bootcd:
+ $(MAKE) -C drivers/storage/$* bootcd
-$(STORAGE_DRIVERS:%=%_dist): %_dist:
- make -C drivers/storage/$* dist
+.PHONY: $(STORAGE_DRIVERS) $(STORAGE_DRIVERS:%=%_clean) $(STORAGE_DRIVERS:%=%_implib) \
+ $(STORAGE_DRIVERS:%=%_install) $(STORAGE_DRIVERS:%=%_bootcd)
-.PHONY: $(STORAGE_DRIVERS) $(STORAGE_DRIVERS:%=%_clean) \
- $(STORAGE_DRIVERS:%=%_install) $(STORAGE_DRIVERS:%=%_dist)
#
# Kernel loaders
#
-
$(LOADERS): %:
- make -C loaders/$*
+ $(MAKE) -C loaders/$*
$(LOADERS:%=%_implib): %_implib:
$(LOADERS:%=%_clean): %_clean:
- make -C loaders/$* clean
+ $(MAKE) -C loaders/$* clean
$(LOADERS:%=%_install): %_install:
- make -C loaders/$* install
+ $(MAKE) -C loaders/$* install
-$(LOADERS:%=%_dist): %_dist:
- make -C loaders/$* dist
+.PHONY: $(LOADERS) $(LOADERS:%=%_implib) $(LOADERS:%=%_clean) $(LOADERS:%=%_install)
-.PHONY: $(LOADERS) $(LOADERS:%=%_implib) $(LOADERS:%=%_clean) $(LOADERS:%=%_install) \
- $(LOADERS:%=%_dist)
#
# Required system components
#
-
ntoskrnl:
- make -C ntoskrnl
+ $(MAKE) -C ntoskrnl
ntoskrnl_implib:
- make -C ntoskrnl implib
+ $(MAKE) -C ntoskrnl implib
ntoskrnl_clean:
- make -C ntoskrnl clean
+ $(MAKE) -C ntoskrnl clean
ntoskrnl_install:
- make -C ntoskrnl install
+ $(MAKE) -C ntoskrnl install
-ntoskrnl_dist:
- make -C ntoskrnl dist
+ntoskrnl_bootcd:
+ $(MAKE) -C ntoskrnl bootcd
+
+.PHONY: ntoskrnl ntoskrnl_implib ntoskrnl_clean ntoskrnl_install ntoskrnl_bootcd
-.PHONY: ntoskrnl ntoskrnl_implib ntoskrnl_clean ntoskrnl_install ntoskrnl_dist
#
# Hardware Abstraction Layer import library
#
-
hallib:
- make -C hal/hal
+ $(MAKE) -C hal/hal
hallib_implib:
- make -C hal/hal implib
+ $(MAKE) -C hal/hal implib
hallib_clean:
- make -C hal/hal clean
+ $(MAKE) -C hal/hal clean
hallib_install:
- make -C hal/hal install
+ $(MAKE) -C hal/hal install
+
+hallib_bootcd:
+ $(MAKE) -C hal/hal bootcd
-hallib_dist:
- make -C hal/hal dist
+.PHONY: hallib hallib_implib hallib_clean hallib_install hallib_bootcd
-.PHONY: hallib hallib_implib hallib_clean hallib_install hallib_dist
#
# Hardware Abstraction Layers
#
-
$(HALS): %:
- make -C hal/$*
+ $(MAKE) -C hal/$*
$(HALS:%=%_implib): %_implib:
- make -C hal/$* implib
+ $(MAKE) -C hal/$* implib
$(HALS:%=%_clean): %_clean:
- make -C hal/$* clean
+ $(MAKE) -C hal/$* clean
$(HALS:%=%_install): %_install:
- make -C hal/$* install
+ $(MAKE) -C hal/$* install
+
+$(HALS:%=%_bootcd): %_bootcd:
+ $(MAKE) -C hal/$* bootcd
-$(HALS:%=%_dist): %_dist:
- make -C hal/$* dist
+.PHONY: $(HALS) $(HALS:%=%_implib) $(HALS:%=%_clean) $(HALS:%=%_install) $(HALS:%=%_bootcd)
-.PHONY: $(HALS) $(HALS:%=%_implib) $(HALS:%=%_clean) $(HALS:%=%_install) $(HALS:%=%_dist)
#
-# Required DLLs
+# File system libraries
#
+$(LIB_FSLIB): %:
+ $(MAKE) -C lib/fslib/$*
+$(LIB_FSLIB:%=%_depends): %_depends:
+ $(MAKE) -C lib/fslib/$* depends
+
+$(LIB_FSLIB:%=%_implib): %_implib:
+ $(MAKE) -C lib/fslib/$* implib
+
+$(LIB_FSLIB:%=%_clean): %_clean:
+ $(MAKE) -C lib/fslib/$* clean
+
+$(LIB_FSLIB:%=%_install): %_install:
+ $(MAKE) -C lib/fslib/$* install
+
+$(LIB_FSLIB:%=%_bootcd): %_bootcd:
+ $(MAKE) -C lib/fslib/$* bootcd
+
+.PHONY: $(LIB_FSLIB) $(LIB_FSLIB:%=%_depends) $(LIB_FSLIB:%=%_implib) $(LIB_FSLIB:%=%_clean) \
+ $(LIB_FSLIB:%=%_install) $(LIB_FSLIB:%=%_bootcd)
+
+
+#
+# Static libraries
+#
+$(LIB_STATIC): %:
+ $(MAKE) -C lib/$*
+
+$(LIB_STATIC:%=%_depends): %_depends:
+ $(MAKE) -C lib/string depends
+
+$(LIB_STATIC:%=%_implib): %_implib:
+ $(MAKE) -C lib/$* implib
+
+$(LIB_STATIC:%=%_clean): %_clean:
+ $(MAKE) -C lib/$* clean
+
+$(LIB_STATIC:%=%_install): %_install:
+ $(MAKE) -C lib/$* install
+
+$(LIB_STATIC:%=%_bootcd): %_bootcd:
+ $(MAKE) -C lib/$* bootcd
+
+.PHONY: $(LIB_STATIC) $(LIB_STATIC:%=%_depends) $(LIB_STATIC:%=%_implib) $(LIB_STATIC:%=%_clean) \
+ $(LIB_STATIC:%=%_install) $(LIB_STATIC:%=%_bootcd)
+
+
+#
+# DLLs
+#
$(DLLS): %:
- make -C lib/$*
+ $(MAKE) -C lib/$*
$(DLLS:%=%_depends): %_depends:
- make -C lib/$* depends
+ $(MAKE) -C lib/$* depends
$(DLLS:%=%_implib): %_implib:
- make -C lib/$* implib
+ $(MAKE) -C lib/$* implib
$(DLLS:%=%_clean): %_clean:
- make -C lib/$* clean
+ $(MAKE) -C lib/$* clean
$(DLLS:%=%_install): %_install:
- make -C lib/$* install
+ $(MAKE) -C lib/$* install
-$(DLLS:%=%_dist): %_dist:
- make -C lib/$* dist
+$(DLLS:%=%_bootcd): %_bootcd:
+ $(MAKE) -C lib/$* bootcd
+
+.PHONY: $(DLLS) $(DLLS:%=%_depends) $(DLLS:%=%_implib) $(DLLS:%=%_clean) $(DLLS:%=%_install) \
+ $(DLLS:%=%_bootcd)
-.PHONY: $(DLLS) $(DLLS:%=%_depends) $(DLLS:%=%_implib) $(DLLS:%=%_clean) $(DLLS:%=%_install) $(DLLS:%=%_dist)
#
# Subsystem support modules
#
-
$(SUBSYS): %:
- make -C subsys/$*
+ $(MAKE) -C subsys/$*
$(SUBSYS:%=%_depends): %_depends:
- make -C subsys/$* depends
+ $(MAKE) -C subsys/$* depends
$(SUBSYS:%=%_implib): %_implib:
- make -C subsys/$* implib
+ $(MAKE) -C subsys/$* implib
$(SUBSYS:%=%_clean): %_clean:
- make -C subsys/$* clean
+ $(MAKE) -C subsys/$* clean
$(SUBSYS:%=%_install): %_install:
- make -C subsys/$* install
+ $(MAKE) -C subsys/$* install
-$(SUBSYS:%=%_dist): %_dist:
- make -C subsys/$* dist
+$(SUBSYS:%=%_bootcd): %_bootcd:
+ $(MAKE) -C subsys/$* bootcd
.PHONY: $(SUBSYS) $(SUBSYS:%=%_depends) $(SUBSYS:%=%_implib) $(SUBSYS:%=%_clean) $(SUBSYS:%=%_install) \
- $(SUBSYS:%=%_dist)
+ $(SUBSYS:%=%_bootcd)
+
+#
+# Regression testsuite
+#
+
+$(REGTESTS): %:
+ $(MAKE) -C regtests
+
+$(REGTESTS:%=%_clean): %_clean:
+ $(MAKE) -C regtests clean
+
+$(REGTESTS:%=%_install): %_install:
+ $(MAKE) -C regtests install
+
+.PHONY: $(REGTESTS) $(REGTESTS:%=%_depends) $(SUBSYS:%=%_clean) $(REGTESTS:%=%_install)
+
#
# Create an installation
$(RMKDIR) $(INSTALL_DIR)/system32
$(RMKDIR) $(INSTALL_DIR)/system32/config
$(RMKDIR) $(INSTALL_DIR)/system32/drivers
+ $(RMKDIR) $(INSTALL_DIR)/system32/drivers/etc
install_before:
$(CP) bootc.lst $(INSTALL_DIR)/bootc.lst
$(CP) boot.bat $(INSTALL_DIR)/boot.bat
$(CP) aboot.bat $(INSTALL_DIR)/aboot.bat
- $(CP) system.hiv $(INSTALL_DIR)/system32/config/system.hiv
- $(CP) media/fonts/helb____.ttf $(INSTALL_DIR)/media/fonts/helb____.ttf
- $(CP) media/fonts/timr____.ttf $(INSTALL_DIR)/media/fonts/timr____.ttf
+ $(CP) media/fonts $(INSTALL_DIR)/media/fonts
+ $(CP) media/nls $(INSTALL_DIR)/system32
+ $(CP) media/nls/c_1252.nls $(INSTALL_DIR)/system32/ansi.nls
+ $(CP) media/nls/c_437.nls $(INSTALL_DIR)/system32/oem.nls
+ $(CP) media/nls/l_intl.nls $(INSTALL_DIR)/system32/casemap.nls
+ $(CP) media/drivers/etc/services \
+ $(INSTALL_DIR)/system32/drivers/etc/services
.PHONY: install_clean install_dirs install_before
-#
-# Make a distribution saveset
-#
+etags:
+ find . -name "*.[ch]" -print | etags --language=c -
-dist_clean:
- $(RM) $(DIST_DIR)/symbols/*.sym
- $(RM) $(DIST_DIR)/drivers/*.sys
- $(RM) $(DIST_DIR)/subsys/*.exe
- $(RM) $(DIST_DIR)/dlls/*.dll
- $(RM) $(DIST_DIR)/apps/*.exe
- $(RM) $(DIST_DIR)/*.exe
- $(RMDIR) $(DIST_DIR)/symbols
- $(RMDIR) $(DIST_DIR)/subsys
- $(RMDIR) $(DIST_DIR)/drivers
- $(RMDIR) $(DIST_DIR)/dlls
- $(RMDIR) $(DIST_DIR)/apps
- $(RMDIR) $(DIST_DIR)
-dist_dirs:
- $(RMKDIR) $(DIST_DIR)
- $(RMKDIR) $(DIST_DIR)/apps
- $(RMKDIR) $(DIST_DIR)/dlls
- $(RMKDIR) $(DIST_DIR)/drivers
- $(RMKDIR) $(DIST_DIR)/subsys
- $(RMKDIR) $(DIST_DIR)/symbols
+docu:
+ echo generating ReactOS NTOSKRNL documentation ...
+ $(MAKE) -C ntoskrnl docu
-.PHONY: dist_clean dist_dirs
+ echo generating ReactOS drivers documentation ...
+ $(MAKE) -C drivers docu
+ echo generating ReactOS NTDLL documentation ...
+ $(MAKE) -C lib/ntdll docu
+
+ echo generating ReactOS Freetype documentation ...
+ $(MAKE) -C lib/freetype docu
+
+ echo generating ReactOS libs documentation ...
+ $(MAKE) -C lib docu
+
+ echo generating ReactOS WIN32K documentation ...
+ $(MAKE) -C subsys/win32k docu
+
+ echo generating ReactOS apps+tools documentation ...
+ $(MAKE) -C apps docu
+
+ echo generating ReactOS explorer documentation ...
+ $(MAKE) -C subsys/system/explorer full-docu
+
+ echo generating remaining ReactOS documentation ...
+ doxygen Doxyfile
+
+.PHONY: docu
-etags:
- find . -name "*.[ch]" -print | etags --language=c -
# EOF