simplified verbosity
authorRoyce Mitchell III <royce3@ev1.net>
Thu, 10 Mar 2005 19:56:46 +0000 (19:56 +0000)
committerRoyce Mitchell III <royce3@ev1.net>
Thu, 10 Mar 2005 19:56:46 +0000 (19:56 +0000)
svn path=/branches/xmlbuildsystem/; revision=13915

reactos/Makefile
reactos/tools/Makefile
reactos/tools/buildno/makefile
reactos/tools/cdmake/makefile
reactos/tools/nci/makefile
reactos/tools/rbuild/backend/mingw/modulehandler.cpp
reactos/tools/rbuild/makefile
reactos/tools/unicode/makefile
reactos/tools/wmc/makefile
reactos/tools/wpp/Makefile
reactos/tools/wrc/makefile

index 13931a2..c4a08fb 100644 (file)
@@ -1,16 +1,53 @@
 # Default to half-verbose mode
 ifeq ($(VERBOSE),no)
   Q = @
-  HALFVERBOSEECHO = @:
+  HALFVERBOSEECHO = no
 else
 ifeq ($(VERBOSE),yes)
   Q =
-  HALFVERBOSEECHO = @:
+  HALFVERBOSEECHO = no
 else
   Q = @
-  HALFVERBOSEECHO = @echo
+  HALFVERBOSEECHO = yes
 endif
 endif
+ifeq ($(HALFVERBOSEECHO),yes)
+  ECHO_INVOKE =@echo [INVOKE]  $<
+  ECHO_PCH    =@echo [PCH]     $@
+  ECHO_CC     =@echo [CC]      $<
+  ECHO_GAS    =@echo [GAS]     $<
+  ECHO_NASM   =@echo [NASM]    $<
+  ECHO_AR     =@echo [AR]      $@
+  ECHO_WINEBLD=@echo [WINEBLD] $@
+  ECHO_WRC    =@echo [WRC]     $@
+  ECHO_BIN2RES=@echo [BIN2RES] $<
+  ECHO_DLLTOOL=@echo [DLLTOOL] $@
+  ECHO_LD     =@echo [LD]      $@
+  ECHO_RBUILD =@echo [RBUILD]  $@
+  ECHO_RSYM   =@echo [RSYM]    $@
+  ECHO_NCI    =@echo [NCI]     $@
+  ECHO_CABMAN =@echo [CABMAN]  $<
+  ECHO_CDMAKE =@echo [CDMAKE]  $@
+  ECHO_TEST   =@echo [TEST]    $@
+else
+  ECHO_INVOKE =@true
+  ECHO_PCH    =@true
+  ECHO_CC     =@true
+  ECHO_GAS    =@true
+  ECHO_NASM   =@true
+  ECHO_AR     =@true
+  ECHO_WINEBLD=@true
+  ECHO_WRC    =@true
+  ECHO_BIN2RES=@true
+  ECHO_DLLTOOL=@true
+  ECHO_LD     =@true
+  ECHO_RBUILD =@true
+  ECHO_RSYM   =@true
+  ECHO_NCI    =@true
+  ECHO_CABMAN =@true
+  ECHO_CDMAKE =@true
+  ECHO_TEST   =@true
+endif
 
 
 host_gcc = $(Q)gcc
@@ -77,7 +114,7 @@ PREAUTO := \
 
 makefile.auto: $(RMKDIR_TARGET) $(BUILDNO_TARGET) $(NCI_SERVICE_FILES) $(WMC_TARGET) $(WRC_TARGET) \
                $(RSYM_TARGET) $(CDMAKE_TARGET) $(RBUILD_TARGET) $(PREAUTO) $(XMLBUILDFILES)
-       $(HALFVERBOSEECHO) [RBUILD]  makefile.auto
+       $(ECHO_RBUILD)
        $(Q)tools$(SEP)rbuild$(SEP)rbuild$(EXEPOSTFIX) mingw
 
 
index db16985..44d1dd0 100644 (file)
@@ -14,11 +14,11 @@ RMKDIR_HOST_CFLAGS = -g -Werror -Wall
 RMKDIR_HOST_LFLAGS = -g
 
 $(RMKDIR_TARGET): $(RMKDIR_OBJECTS)
-       $(HALFVERBOSEECHO) [LD]      $@
+       $(ECHO_LD)
        ${host_gcc} $(RMKDIR_OBJECTS) $(RMKDIR_HOST_LFLAGS) -o $(RMKDIR_TARGET)
 
 $(RMKDIR_OBJECTS): %.o : %.c
-       $(HALFVERBOSEECHO) [CC]      $<
+       $(ECHO_CC)
        ${host_gcc} $(RMKDIR_HOST_CFLAGS) -c $< -o $@
 
 .PHONY: rmkdir_clean
@@ -43,11 +43,11 @@ RSYM_HOST_CFLAGS = -g -Werror -Wall
 RSYM_HOST_LFLAGS = -g
 
 $(RSYM_TARGET): $(RSYM_OBJECTS)
-       $(HALFVERBOSEECHO) [LD]      $@
+       $(ECHO_LD)
        ${host_gcc} $(RSYM_OBJECTS) $(RSYM_HOST_LFLAGS) -o $(RSYM_TARGET)
 
 $(RSYM_OBJECTS): %.o : %.c
-       $(HALFVERBOSEECHO) [CC]      $<
+       $(ECHO_CC)
        ${host_gcc} $(RSYM_HOST_CFLAGS) -c $< -o $@
 
 .PHONY: rsym_clean
index 33aebff..520b649 100644 (file)
@@ -17,11 +17,11 @@ BUILDNO_HOST_CFLAGS = -Iinclude/reactos -g -Werror -Wall
 BUILDNO_HOST_LFLAGS = -g
 
 $(BUILDNO_TARGET): $(BUILDNO_OBJECTS)
-       $(HALFVERBOSEECHO) [LD]      $@
+       $(ECHO_LD)
        ${host_gpp} $(BUILDNO_OBJECTS) $(BUILDNO_HOST_CFLAGS) -o $(BUILDNO_TARGET)
 
 $(BUILDNO_OBJECTS): %.o : %.cpp include$(SEP)reactos$(SEP)version.h
-       $(HALFVERBOSEECHO) [CC]      $<
+       $(ECHO_CC)
        ${host_gpp} $(BUILDNO_HOST_CFLAGS) -c $< -o $@
 
 .PHONY: buildno_clean
index 36a0151..1a38ba8 100644 (file)
@@ -15,11 +15,11 @@ CDMAKE_HOST_CFLAGS = -Iinclude -g -Werror -Wall
 CDMAKE_HOST_LFLAGS = -g
 
 $(CDMAKE_TARGET): $(CDMAKE_OBJECTS)
-       $(HALFVERBOSEECHO) [LD]      $@
+       $(ECHO_LD)
        ${host_gcc} $(CDMAKE_OBJECTS) $(CDMAKE_HOST_CFLAGS) -o $(CDMAKE_TARGET)
 
 $(CDMAKE_OBJECTS): %.o : %.c
-       $(HALFVERBOSEECHO) [CC]      $<
+       $(ECHO_CC)
        ${host_gcc} $(CDMAKE_CFLAGS) -c $< -o $@
 
 .PHONY: cdmake_clean
index 3eaa91a..9b4d21f 100644 (file)
@@ -14,11 +14,11 @@ NCI_HOST_CFLAGS = -Iinclude -g -Werror -Wall
 NCI_HOST_LFLAGS = -g
 
 $(NCI_TARGET): $(NCI_OBJECTS)
-       $(HALFVERBOSEECHO) [LD]      $@
+       $(ECHO_LD)
        ${host_gcc} $(NCI_OBJECTS) $(NCI_HOST_CFLAGS) -o $(NCI_TARGET)
 
 $(NCI_OBJECTS): %.o : %.c
-       $(HALFVERBOSEECHO) [CC]      $<
+       $(ECHO_CC)
        ${host_gcc} $(NCI_HOST_CFLAGS) -c $< -o $@
 
 .PHONY: nci_clean
@@ -47,7 +47,7 @@ NCI_SERVICE_FILES = \
        $(WIN32K_USER_STUBS)
 
 $(NCI_SERVICE_FILES): $(NCI_TARGET)
-       $(HALFVERBOSEECHO) [NCI]     $@
+       $(ECHO_NCI)
        $(Q)$(EXEPREFIX)$(NCI_TARGET) \
                $(KERNEL_SVC_DB) \
                $(WIN32K_SVC_DB) \
index 25e2de9..7656034 100644 (file)
@@ -726,7 +726,7 @@ MingwModuleHandler::GenerateGccCommand ( const Module& module,
                  "%s: %s\n",\r
                  objectFilename.c_str (),\r
                  deps.c_str () );\r
-       fprintf ( fMakefile, "\t$(HALFVERBOSEECHO) [CC]      $<\n" );\r
+       fprintf ( fMakefile, "\t$(ECHO_CC)\n" );\r
        fprintf ( fMakefile,\r
                 "\t%s -c %s -o %s %s\n",\r
                 cc.c_str (),\r
@@ -746,7 +746,7 @@ MingwModuleHandler::GenerateGccAssemblerCommand ( const Module& module,
                  "%s: %s\n",\r
                  objectFilename.c_str (),\r
                  sourceFilename.c_str () );\r
-       fprintf ( fMakefile, "\t$(HALFVERBOSEECHO) [GAS]     $<\n" );\r
+       fprintf ( fMakefile, "\t$(ECHO_GAS)\n" );\r
        fprintf ( fMakefile,\r
                  "\t%s -x assembler-with-cpp -c %s -o %s -D__ASM__ %s\n",\r
                  cc.c_str (),\r
@@ -765,7 +765,7 @@ MingwModuleHandler::GenerateNasmCommand ( const Module& module,
                  "%s: %s\n",\r
                  objectFilename.c_str (),\r
                  sourceFilename.c_str () );\r
-       fprintf ( fMakefile, "\t$(HALFVERBOSEECHO) [NASM]    $<\n" );\r
+       fprintf ( fMakefile, "\t$(ECHO_NASM)\n" );\r
        fprintf ( fMakefile,\r
                  "\t%s -f win32 %s -o %s %s\n",\r
                  "$(Q)nasm",\r
@@ -788,7 +788,7 @@ MingwModuleHandler::GenerateWindresCommand ( const Module& module,
                  "%s: %s\n",\r
                  objectFilename.c_str (),\r
                  sourceFilename.c_str () );\r
-       fprintf ( fMakefile, "\t$(HALFVERBOSEECHO) [WRC]     $@\n" );\r
+       fprintf ( fMakefile, "\t$(ECHO_WRC)\n" );\r
        fprintf ( fMakefile,\r
                 "\t${gcc} -xc -E -DRC_INVOKED ${%s} %s > %s\n",\r
                 windresflagsMacro.c_str (),\r
@@ -829,7 +829,7 @@ MingwModuleHandler::GenerateWinebuildCommands (
                  "%s: %s\n",\r
                  def_file.c_str (),\r
                  sourceFilename.c_str () );\r
-       fprintf ( fMakefile, "\t$(HALFVERBOSEECHO) [WINEBLD] $@\n" );\r
+       fprintf ( fMakefile, "\t$(ECHO_WINEBLD)\n" );\r
        fprintf ( fMakefile,\r
                  "\t%s --def=%s -o %s\n",\r
                  "${winebuild}",\r
@@ -840,7 +840,7 @@ MingwModuleHandler::GenerateWinebuildCommands (
                  "%s: %s\n",\r
                  stub_file.c_str (),\r
                  sourceFilename.c_str () );\r
-       fprintf ( fMakefile, "\t$(HALFVERBOSEECHO) [WINEBLD] $@\n" );\r
+       fprintf ( fMakefile, "\t$(ECHO_WINEBLD)\n" );\r
        fprintf ( fMakefile,\r
                  "\t%s --pedll=%s -o %s\n",\r
                  "${winebuild}",\r
@@ -929,7 +929,7 @@ MingwModuleHandler::GenerateLinkerCommand (
        const string& libsMacro,\r
        string_list& clean_files ) const\r
 {\r
-       fprintf ( fMakefile, "\t$(HALFVERBOSEECHO) [LD]      $@\n" );\r
+       fprintf ( fMakefile, "\t$(ECHO_LD)\n" );\r
        string targetName ( module.GetTargetName () );\r
        string target ( FixupTargetFilename ( module.GetPath () ) );\r
        if ( module.importLibrary != NULL )\r
@@ -996,7 +996,7 @@ MingwModuleHandler::GenerateLinkerCommand (
                          GetLinkerMacro ( module ).c_str () );\r
        }\r
 \r
-       fprintf ( fMakefile, "\t$(HALFVERBOSEECHO) [RSYM]    $@\n" );\r
+       fprintf ( fMakefile, "\t$(ECHO_RSYM)\n" );\r
        fprintf ( fMakefile,\r
                  "\t${rsym} %s %s\n\n",\r
                  target.c_str (),\r
@@ -1066,7 +1066,7 @@ MingwModuleHandler::GenerateObjectFileTargets (
                        "%s: %s\n",\r
                        gch_file.c_str(),\r
                        pch_file.c_str() );\r
-               fprintf ( fMakefile, "\t$(HALFVERBOSEECHO) [PCH]     $@\n" );\r
+               fprintf ( fMakefile, "\t$(ECHO_PCH)\n" );\r
                fprintf (\r
                        fMakefile,\r
                        "\t%s -c %s -o %s %s\n\n",\r
@@ -1115,7 +1115,7 @@ MingwModuleHandler::GenerateArchiveTarget ( const Module& module,
                  archiveFilename.c_str (),\r
                  objs_macro.c_str ());\r
 \r
-       fprintf ( fMakefile, "\t$(HALFVERBOSEECHO) [AR]      $@\n" );\r
+       fprintf ( fMakefile, "\t$(ECHO_AR)\n" );\r
 \r
        fprintf ( fMakefile,\r
                  "\t%s -rc %s %s\n\n",\r
@@ -1320,7 +1320,7 @@ MingwModuleHandler::GenerateInvocations ( const Module& module ) const
                          "%s: %s\n",\r
                          invoke.GetTargets ().c_str (),\r
                          FixupTargetFilename ( invoke.invokeModule->GetPath () ).c_str () );\r
-               fprintf ( fMakefile, "\t$(HALFVERBOSEECHO) [INVOKE]  $<\n" );\r
+               fprintf ( fMakefile, "\t$(ECHO_INVOKE)\n" );\r
                fprintf ( fMakefile,\r
                          "\t%s %s\n\n",\r
                          FixupTargetFilename ( invoke.invokeModule->GetPath () ).c_str (),\r
@@ -1415,7 +1415,7 @@ MingwModuleHandler::GenerateImportLibraryTargetIfNeeded (
                          library_target.c_str (),\r
                          definitionDependencies.c_str () );\r
 \r
-               fprintf ( fMakefile, "\t$(HALFVERBOSEECHO) [DLLTOOL] $@\n" );\r
+               fprintf ( fMakefile, "\t$(ECHO_DLLTOOL)\n" );\r
 \r
                string killAt = module.mangledSymbols ? "" : "--kill-at";\r
                fprintf ( fMakefile,\r
@@ -1506,7 +1506,7 @@ MingwBuildToolModuleHandler::GenerateBuildToolModuleTarget ( const Module& modul
                  target.c_str (),\r
                  objectsMacro.c_str (),\r
                  linkDepsMacro.c_str () );\r
-       fprintf ( fMakefile, "\t$(HALFVERBOSEECHO) [LD]      $@\n" );\r
+       fprintf ( fMakefile, "\t$(ECHO_LD)\n" );\r
        fprintf ( fMakefile,\r
                  "\t%s %s -o %s %s %s\n\n",\r
                  linker.c_str (),\r
@@ -1561,7 +1561,7 @@ MingwKernelModuleHandler::GenerateKernelModuleTarget ( const Module& module, str
                  target.c_str (),\r
                  objectsMacro.c_str (),\r
                  linkDepsMacro.c_str () );\r
-       fprintf ( fMakefile, "\t$(HALFVERBOSEECHO) [LD]      $@\n" );\r
+       fprintf ( fMakefile, "\t$(ECHO_LD)\n" );\r
        fprintf ( fMakefile,\r
                  "\t${gcc} %s %s -Wl,--base-file,%s -o %s %s %s\n",\r
                  GetLinkerMacro ( module ).c_str (),\r
@@ -1594,7 +1594,7 @@ MingwKernelModuleHandler::GenerateKernelModuleTarget ( const Module& module, str
        fprintf ( fMakefile,\r
                  "\t-@${rm} %s\n",\r
                  temp_exp.c_str () );\r
-       fprintf ( fMakefile, "\t$(HALFVERBOSEECHO) [RSYM]    $@\n" );\r
+       fprintf ( fMakefile, "\t$(ECHO_RSYM)\n" );\r
        fprintf ( fMakefile,\r
                      "\t${rsym} %s %s\n\n",\r
                      target.c_str (),\r
@@ -1914,7 +1914,7 @@ MingwWin32DLLModuleHandler::GenerateExtractWineDLLResourcesTarget ( const Module
                if ( extension == ".rc" || extension == ".RC" )\r
                {\r
                        string resource = FixupTargetFilename ( file.name );\r
-                       fprintf ( fMakefile, "\t$(HALFVERBOSEECHO) [BIN2RES] $<\n" );\r
+                       fprintf ( fMakefile, "\t$(ECHO_BIN2RES)\n" );\r
                        fprintf ( fMakefile, "\t@:echo ${bin2res} -f -x %s\n",\r
                                  resource.c_str () );\r
                }\r
@@ -2130,7 +2130,7 @@ MingwBootLoaderModuleHandler::GenerateBootLoaderModuleTarget (
                  objectsMacro.c_str (),\r
                  linkDepsMacro.c_str () );\r
 \r
-       fprintf ( fMakefile, "\t$(HALFVERBOSEECHO) [LD]      $@\n" );\r
+       fprintf ( fMakefile, "\t$(ECHO_LD)\n" );\r
 \r
        fprintf ( fMakefile,\r
                  "\t${ld} %s -N -Ttext=0x8000 -o %s %s %s\n",\r
@@ -2346,7 +2346,7 @@ MingwIsoModuleHandler::GenerateIsoModuleTarget ( const Module& module, string_li
                  isoboot.c_str (),\r
                  cdDirectories.c_str (),\r
                  cdFiles.c_str () );\r
-       fprintf ( fMakefile, "\t$(HALFVERBOSEECHO) [CABMAN]  $<\n" );\r
+       fprintf ( fMakefile, "\t$(ECHO_CABMAN)\n" );\r
        fprintf ( fMakefile,\r
                  "\t${cabman} -C %s -L %s -I\n",\r
                  reactosDff.c_str (),\r
@@ -2363,7 +2363,7 @@ MingwIsoModuleHandler::GenerateIsoModuleTarget ( const Module& module, string_li
                                          module );\r
        OutputCdfileCopyCommands ( bootcdDirectory,\r
                                   module );\r
-       fprintf ( fMakefile, "\t$(HALFVERBOSEECHO) [CDMAKE]  $@\n" );\r
+       fprintf ( fMakefile, "\t$(ECHO_CDMAKE)\n" );\r
        fprintf ( fMakefile,\r
                  "\t${cdmake} -v -m -b %s %s REACTOS ReactOS.iso\n",\r
                  isoboot.c_str (),\r
index 0dad9ca..59d0425 100644 (file)
@@ -85,29 +85,29 @@ RBUILD_HOST_CXXFLAGS = -g -I$(RBUILD_BASE) -Werror -Wall
 RBUILD_HOST_LFLAGS = -g\r
 \r
 $(RBUILD_TARGET): $(RBUILD_OBJECTS)\r
-       $(HALFVERBOSEECHO) [LD]      $@\r
+       $(ECHO_LD)\r
        ${host_gpp} $(RBUILD_OBJECTS) $(RBUILD_HOST_LFLAGS) -o $(RBUILD_TARGET)\r
 \r
 $(RBUILD_COMMON_OBJECTS): %.o: %.cpp\r
-       $(HALFVERBOSEECHO) [CC]      $<\r
+       $(ECHO_CC)\r
        ${host_gpp} $(RBUILD_HOST_CXXFLAGS) -c $< -o $@\r
 \r
 $(RBUILD_SPECIAL_OBJECTS): %.o: %.cpp\r
-       $(HALFVERBOSEECHO) [CC]      $<\r
+       $(ECHO_CC)\r
        ${host_gpp} $(RBUILD_HOST_CXXFLAGS) -c $< -o $@\r
 \r
 $(RBUILD_TEST_TARGET): $(RBUILD_TEST_OBJECTS)\r
-       $(HALFVERBOSEECHO) [LD]      $@\r
+       $(ECHO_LD)\r
        ${host_gpp} $(RBUILD_TEST_OBJECTS) $(RBUILD_HOST_LFLAGS) -o $(RBUILD_TEST_TARGET)\r
 \r
 $(RBUILD_TEST_SPECIAL_OBJECTS): %.o: %.cpp\r
-       $(HALFVERBOSEECHO) [CC]      $<\r
+       $(ECHO_CC)\r
        ${host_gpp} $(RBUILD_HOST_CXXFLAGS) -c $< -o $@\r
 \r
 .PHONY: rbuild_test\r
 \r
 rbuild_test: $(RBUILD_TEST_TARGET)\r
-       $(HALFVERBOSEECHO) [TEST]    $@\r
+       $(ECHO_TEST)\r
        $(Q)$(RBUILD_TEST_TARGET)\r
 \r
 .PHONY: rbuild_clean\r
index 0d40bd7..401d973 100644 (file)
@@ -83,12 +83,15 @@ UNICODE_HOST_CFLAGS = \
        -Dwchar_t="unsigned short" -D_WCHAR_T_DEFINED \
        -I$(UNICODE_BASE) -Iinclude/wine -Iw32api/include
 
+.PHONY: unicode
+unicode: $(UNICODE_TARGET)
+
 $(UNICODE_TARGET): $(UNICODE_OBJECTS)
-       $(HALFVERBOSEECHO) [AR]      $@
+       $(ECHO_AR)
        ${host_ar} -rc $(UNICODE_TARGET) $(UNICODE_OBJECTS)
 
 $(UNICODE_OBJECTS): %.o : %.c
-       $(HALFVERBOSEECHO) [CC]      $<
+       $(ECHO_CC)
        ${host_gcc} $(UNICODE_HOST_CFLAGS) -c $< -o $@
 
 .PHONY: unicode_clean
index e51f945..7e39f9a 100644 (file)
@@ -21,11 +21,11 @@ WMC_HOST_CXXFLAGS = -I$(WMC_BASE) -g -Werror -Wall
 WMC_HOST_LFLAGS = -g
 
 $(WMC_TARGET): $(WMC_OBJECTS)
-       $(HALFVERBOSEECHO) [LD]      $@
+       $(ECHO_LD)
        ${host_gcc} $(WMC_OBJECTS) $(WMC_HOST_LFLAGS) -o $(WMC_TARGET)
 
 $(WMC_OBJECTS): %.o : %.c
-       $(HALFVERBOSEECHO) [CC]      $<
+       $(ECHO_CC)
        ${host_gcc} $(WMC_HOST_CXXFLAGS) -c $< -o $@
 
 .PHONY: wmc_clean
index dce245f..965d6f1 100644 (file)
@@ -15,11 +15,11 @@ WPP_OBJECTS = \
 WPP_HOST_CFLAGS = -D__USE_W32API -I$(WPP_BASE) -Iinclude -Iinclude/wine -g
 
 $(WPP_TARGET): $(WPP_OBJECTS)
-       $(HALFVERBOSEECHO) [AR]      $@
+       $(ECHO_AR)
        ${host_ar} -rc $(WPP_TARGET) $(WPP_OBJECTS)
 
 $(WPP_OBJECTS): %.o : %.c
-       $(HALFVERBOSEECHO) [CC]      $<
+       $(ECHO_CC)
        ${host_gcc} $(WPP_HOST_CFLAGS) -c $< -o $@
 
 .PHONY: wpp_clean
index 204a940..a5a4d35 100644 (file)
@@ -28,11 +28,11 @@ WRC_HOST_CFLAGS = -I$(WRC_BASE) -g -Werror -Wall \
 WRC_HOST_LFLAGS = -g
 
 $(WRC_TARGET): $(WRC_OBJECTS) $(UNICODE_TARGET) $(WPP_TARGET)
-       $(HALFVERBOSEECHO) [LD]      $@
+       $(ECHO_LD)
        ${host_gcc} $(WRC_OBJECTS) $(UNICODE_TARGET) $(WPP_TARGET) $(WRC_HOST_LFLAGS) -o $(WRC_TARGET)
 
 $(WRC_OBJECTS): %.o : %.c
-       $(HALFVERBOSEECHO) [CC]      $<
+       $(ECHO_CC)
        ${host_gcc} $(WRC_HOST_CFLAGS) -c $< -o $@
 
 .PHONY: wrc_clean