Fix up opps.
[reactos.git] / reactos / rules.mak
index 2feeab6..1b4098e 100644 (file)
-#
-# Important
-#
-.EXPORT_ALL_VARIABLES:
+# Default to half-verbose mode
+ifeq ($(VERBOSE),no)
+  Q = @
+  HALFVERBOSEECHO = @:
+  # Do not print "Entering directory ..."
+  export MAKEFLAGS += --no-print-directory
+  # Be silent
+  export MAKEFLAGS += --silent
+else
+ifeq ($(VERBOSE),yes)
+  Q =
+  HALFVERBOSEECHO = @:
+else
+  Q = @
+  # the following is a hack to get the target name for wine dlls
+  # it's disabled because it produces warnings about overriden rules for author.c
+  #ifeq ($(TARGET_TYPE),winedll)
+  #  export TOOLS_PATH = $(PATH_TO_TOP)/tools
+  #  -include Makefile.ros
+  #endif
+  ifeq ($(TARGET_NAME),)
+    HALFVERBOSEECHO = @echo
+  else
+    HALFVERBOSEECHO = @echo $(TARGET_NAME):
+  endif
+  # Do not print "Entering directory ..."
+  export MAKEFLAGS += --no-print-directory
+  # Be silent
+  export MAKEFLAGS += --silent
+endif
+endif
 
-# Windows is default host environment
+export MAKE := @$(MAKE)
+
+ifeq ($(VERBOSE),no)
+endif
+
+# detect Windows host environment
 ifeq ($(HOST),)
-HOST = mingw32-windows
+ifeq ($(word 1,$(shell gcc -dumpmachine)),mingw32)
+HOST=mingw32-windows
+else
+export HOST=mingw32-linux
+endif
+endif
+
+# Default to building map files which includes source and asm code
+# Other options are: yes
+ifeq ($(BUILD_MAP),)
+export BUILD_MAP = full
+endif
+
+# Default to dumping .sym files out of .nostrip files
+ifeq ($(BUILD_SYM),)
+export BUILD_SYM = yes
+endif
+
+# Default to minimal dependencies, making components not
+# depend on all import libraries
+ifeq ($(MINIMALDEPENDENCIES),)
+export MINIMALDEPENDENCIES = yes
 endif
 
 # Default to no PCH support
 ifeq ($(ROS_USE_PCH),)
-ROS_USE_PCH = no
+export ROS_USE_PCH = no
 endif
 
 # uncomment if you use bochs and it displays only 30 rows
 # BOCHS_30ROWS = yes
 
-ifeq ($(HOST),mingw32-linux)
-TOPDIR := $(shell if [ "$$PWD" != "" ]; then echo $$PWD; else pwd; fi)
-endif
-
 #
 # Choose various options
 #
 ifeq ($(HOST),mingw32-linux)
-NASM_FORMAT = win32
-PREFIX = mingw32-
-EXE_POSTFIX :=
-EXE_PREFIX := ./
-DLLTOOL = $(PREFIX)dlltool --as=$(PREFIX)as
-NASM_CMD = nasm
-DOSCLI =
-FLOPPY_DIR = /mnt/floppy
-SEP := /
-PIPE :=
+export NASM_FORMAT = win32
+export PREFIX = mingw32-
+export EXE_POSTFIX :=
+export EXE_PREFIX := ./
+export DLLTOOL = $(PREFIX)dlltool --as=$(PREFIX)as
+#
+# Do not change NASM_CMD to NASM because older versions of 
+# nasm doesn't like an environment variable NASM
+#
+export NASM_CMD = nasm
+export DOSCLI =
+export FLOPPY_DIR = /mnt/floppy
+export SEP := /
+export PIPE :=
 endif
 
 ifeq ($(HOST),mingw32-windows)
-NASM_FORMAT = win32
-PREFIX =
-EXE_PREFIX :=
-EXE_POSTFIX := .exe
-DLLTOOL = $(PREFIX)dlltool --as=$(PREFIX)as
-NASM_CMD = nasmw
-DOSCLI = yes
-FLOPPY_DIR = A:
-SEP := \$(EMPTY_VAR)
-PIPE := -pipe
+export NASM_FORMAT = win32
+export PREFIX =
+export EXE_PREFIX :=
+export EXE_POSTFIX := .exe
+export DLLTOOL = $(Q)$(PREFIX)dlltool --as=$(PREFIX)as
+#
+# Do not change NASM_CMD to NASM because older versions of 
+# nasm doesn't like an environment variable NASM
+#
+export NASM_CMD = $(Q)nasmw
+export DOSCLI = yes
+export FLOPPY_DIR = A:
+export SEP := \$(EMPTY_VAR)
+export PIPE := -pipe
 endif
 
+# TOPDIR is used by make bootcd but not defined anywhere.  Usurp pointed out
+# that it has the same meaning as PATH_TO_TOP.
+export TOPDIR = $(PATH_TO_TOP)
 
-# Set INSTALL_DIR to default value if not already set
-# ifeq ($(INSTALL_DIR),)
-INSTALL_DIR = $(PATH_TO_TOP)/reactos
-# endif
-
-# Set DIST_DIR to default value if not already set
-# ifeq ($(DIST_DIR),)
-DIST_DIR = $(PATH_TO_TOP)/dist
-# endif
-
-
-CC = $(PREFIX)gcc
-CXX = $(PREFIX)g++
-HOST_CC = gcc
-HOST_NM = nm
-LD = $(PREFIX)ld
-NM = $(PREFIX)nm
-OBJCOPY = $(PREFIX)objcopy
-STRIP = $(PREFIX)strip
-AS = $(PREFIX)gcc -c -x assembler-with-cpp
-CPP = $(PREFIX)cpp
-AR = $(PREFIX)ar
-RC = $(PREFIX)windres
-WRC = $(WINE_TOP)/tools/wrc/wrc
-RCINC = --include-dir $(PATH_TO_TOP)/include
-OBJCOPY = $(PREFIX)objcopy
-TOOLS_PATH = $(PATH_TO_TOP)/tools
-CP = $(TOOLS_PATH)/rcopy
-RM = $(TOOLS_PATH)/rdel
-RMDIR = $(TOOLS_PATH)/rrmdir
-RMKDIR = $(TOOLS_PATH)/rmkdir
-RSYM = $(TOOLS_PATH)/rsym
-RTOUCH = $(TOOLS_PATH)/rtouch
-MC = $(TOOLS_PATH)/wmc/wmc
-
-
-# Maybe we can delete these soon
-
-ifeq ($(HOST),mingw32-linux)
-CFLAGS := $(CFLAGS) -I$(PATH_TO_TOP)/include -pipe -march=i386 -D_M_IX86
-endif
+# Directory to build a bootable CD image in
+export BOOTCD_DIR=$(TOPDIR)/../bootcd/disk
+export LIVECD_DIR=$(TOPDIR)/../livecd/disk
 
+ifeq ($(LIVECD_INSTALL),yes)
+export INSTALL_DIR=$(LIVECD_DIR)/reactos
+else
+# Use environment var ROS_INSTALL to override default install dir
+ifeq ($(ROS_INSTALL),)
 ifeq ($(HOST),mingw32-windows)
-CFLAGS := $(CFLAGS) -I$(PATH_TO_TOP)/include -pipe -march=i386 -D_M_IX86
+export INSTALL_DIR = C:/reactos
+else
+export INSTALL_DIR = $(PATH_TO_TOP)/reactos
+endif
+else
+export INSTALL_DIR = $(ROS_INSTALL)
+endif
 endif
 
-CXXFLAGS = $(CFLAGS)
-NFLAGS = -i$(PATH_TO_TOP)/include/ -f$(NASM_FORMAT) -d$(NASM_FORMAT)
-ASFLAGS := $(ASFLAGS) -I$(PATH_TO_TOP)/include -D__ASM__
 
+export CC = $(Q)$(PREFIX)gcc
+export CXX = $(Q)$(PREFIX)g++
+export HOST_CC = $(Q)gcc
+export HOST_CXX = $(Q)g++
+export HOST_AR = $(Q)ar
+export HOST_NM = $(Q)nm
+export LD = $(Q)$(PREFIX)ld
+export NM = $(Q)$(PREFIX)nm
+export OBJCOPY = $(Q)$(PREFIX)objcopy
+export STRIP = $(Q)$(PREFIX)strip
+export AS = $(Q)$(PREFIX)gcc -c -x assembler-with-cpp
+export CPP = $(Q)$(PREFIX)cpp
+export AR = $(Q)$(PREFIX)ar
+export RC = $(Q)$(PREFIX)windres
+export WRC = $(Q)$(WINE_TOP)/tools/wrc/wrc
+export OBJCOPY = $(Q)$(PREFIX)objcopy
+export OBJDUMP =$(Q)$(PREFIX)objdump
+export TOOLS_PATH = $(PATH_TO_TOP)/tools
+export W32API_PATH = $(PATH_TO_TOP)/w32api
+export CP = $(Q)$(TOOLS_PATH)/rcopy
+export RM = $(Q)$(TOOLS_PATH)/rdel
+export RLINE = $(Q)$(TOOLS_PATH)/rline
+export RMDIR = $(Q)$(TOOLS_PATH)/rrmdir
+export RMKDIR = $(Q)$(TOOLS_PATH)/rmkdir
+export RSYM = $(Q)$(TOOLS_PATH)/rsym
+export RTOUCH = $(Q)$(TOOLS_PATH)/rtouch
+export REGTESTS = $(Q)$(TOOLS_PATH)/regtests
+export MC = $(Q)$(TOOLS_PATH)/wmc/wmc
+export CABMAN = $(Q)$(TOOLS_PATH)/cabman/cabman
+export WINEBUILD = $(Q)$(TOOLS_PATH)/winebuild/winebuild
+export WINE2ROS = $(Q)$(TOOLS_PATH)/wine2ros/wine2ros
+export MKHIVE = $(Q)$(TOOLS_PATH)/mkhive/mkhive
+export CDMAKE = $(Q)$(TOOLS_PATH)/cdmake/cdmake
+export BIN2RES = $(Q)$(TOOLS_PATH)/bin2res/bin2res
+export XSLTPROC = $(Q)xsltproc
+export MS2PS = $(Q)$(TOOLS_PATH)/ms2ps/ms2ps
+export WRC = $(Q)$(TOOLS_PATH)/wrc/wrc
+export WIDL = $(Q)$(TOOLS_PATH)/widl/widl
+
+export STD_CFLAGS = -I$(PATH_TO_TOP)/include -I$(W32API_PATH)/include -pipe -march=$(OARCH) -D_M_IX86
+export STD_CPPFLAGS = $(STD_CFLAGS)
+# Check for 3GB 
+ifeq ($(3GB), 1)
+export STD_ASFLAGS = -I$(PATH_TO_TOP)/include -I$(W32API_PATH)/include -D__ASM__ -D_M_IX86 -D__3GB__
+else
+export STD_ASFLAGS = -I$(PATH_TO_TOP)/include -I$(W32API_PATH)/include -D__ASM__ -D_M_IX86
+endif
+export STD_RCFLAGS = --include-dir $(PATH_TO_TOP)/include --include-dir $(W32API_PATH)/include
+export STD_NFLAGS = -f win32
 
 # Developer Kits
-DK_PATH=$(PATH_TO_TOP)/dk
+export DK_PATH=$(PATH_TO_TOP)/dk
 # Native and kernel mode
-DDK_PATH=$(DK_PATH)/nkm
-DDK_PATH_LIB=$(DDK_PATH)/lib
-DDK_PATH_INC=$(PATH_TO_TOP)/include
+export DDK_PATH=$(DK_PATH)/nkm
+export DDK_PATH_LIB=$(DDK_PATH)/lib
+export DDK_PATH_INC=$(PATH_TO_TOP)/include
 # Win32
-SDK_PATH=$(DK_PATH)/w32
-SDK_PATH_LIB=$(SDK_PATH)/lib
-SDK_PATH_INC=$(PATH_TO_TOP)/include
+export SDK_PATH=$(DK_PATH)/w32
+export SDK_PATH_LIB=$(SDK_PATH)/lib
+export SDK_PATH_INC=$(PATH_TO_TOP)/include
 # POSIX+
-XDK_PATH=$(DK_PATH)/psx
-XDK_PATH_LIB=$(XDK_PATH)/lib
-XDK_PATH_INC=$(XDK_PATH)/include
+export XDK_PATH=$(DK_PATH)/psx
+export XDK_PATH_LIB=$(XDK_PATH)/lib
+export XDK_PATH_INC=$(XDK_PATH)/include
 
 # Wine Integration
-WINE_PATH=$(PATH_TO_TOP)/../wine
-WINE_PATH_LIB=$(WINE_PATH)/lib
-WINE_PATH_INC=$(WINE_PATH)/include
+export WINE_PATH=$(PATH_TO_TOP)/../wine
+export WINE_PATH_LIB=$(WINE_PATH)/lib
+export WINE_PATH_INC=$(WINE_PATH)/include
 
 # Posix+ Integration
-POSIX_PATH=$(PATH_TO_TOP)/../posix
-POSIX_PATH_LIB=$(POSIX_PATH)/lib
-POSIX_PATH_INC=$(POSIX_PATH)/include
+export POSIX_PATH=$(PATH_TO_TOP)/../posix
+export POSIX_PATH_LIB=$(POSIX_PATH)/lib
+export POSIX_PATH_INC=$(POSIX_PATH)/include
 
 # OS/2 Integration
-OS2_PATH=$(PATH_TO_TOP)/../os2
-OS2_PATH_LIB=$(OS2_PATH)/lib
-OS2_PATH_INC=$(OS2_PATH)/include
+export OS2_PATH=$(PATH_TO_TOP)/../os2
+export OS2_PATH_LIB=$(OS2_PATH)/lib
+export OS2_PATH_INC=$(OS2_PATH)/include
 
 # Other systems integration
-ROOT_PATH=$(PATH_TO_TOP)/..
-
-COMCTL32_TARGET = comctl23
-
-SHELL32_TARGET = shell23
-
-COMDLG32_TARGET = comdlg23
-
-
+export REGTESTS_PATH=$(PATH_TO_TOP)/regtests
+export REGTESTS_PATH_INC=$(PATH_TO_TOP)/regtests/shared