Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

273 lines
14 KiB

  1. This directory contains "build rules" you can use for your particular project.
  2. Typically, a build rule script executes various post-build.exe operations on a set of
  3. existing binaries. For example, a build rule script can invoke iexpress.exe in order
  4. to generate a cab file or a self-extracting executable.
  5. E-mail MLekas or ntball with questions regarding the US builds and MattHoe or ntbintl
  6. with questions regarding the International builds.
  7. To add a new build rule script:
  8. 1. Copy "template" to <your_project_build_rule>.cmd.
  9. 2. Edit <your_project_build_rule>.cmd according to the guidelines below.
  10. a. Build rule scripts must be general enough to run in various contexts.
  11. The build rule scripts are part of the US Windows 2000 build procedures.
  12. The Redmond-based and the Dublin-based International Windows 2000 builds use them
  13. too. Some of the build rule scripts are released with the source release kits.
  14. These various contexts need to be considered when implementing the build rule scripts.
  15. For example, the build rule scripts should avoid using hard-coded machine names:
  16. * If your script propagates binaries from one build machine to another,
  17. call %_ntbindir%\bldrules\localbrs.bat, then use variable names instead of
  18. hard-coded machine names.
  19. Let's say your script must copy files from \\x86fre\binaries to \\alphafre\binaries.
  20. Replace
  21. xcopy \\x86fre\binaries\%myfiles% \\alphafre\binaries\
  22. with
  23. call %_ntbindir%\bldrules\localbrs.bat
  24. ..
  25. if /I "%computername%" == "%alphafre%" (
  26. xcopy \\%x86fre%\%binshare%\%myfiles% \\%alphafre%\%binshare%\
  27. )
  28. By using a different localbrs.txt, International builds can use their own machine names,
  29. shares, etc and still run the same build rule scripts as the US builds.
  30. * If your script must be executed on a particular build machine only (x86fre for example),
  31. add a particular entry to localbrs.txt, then use variable names instead of machine names.
  32. For example, drvcab.cmd runs "slm in sorted.lst" on the official US build machines only.
  33. The sequence
  34. REM Only US build machines should check in sorted.lst
  35. set checkin=
  36. if /i "%computername%" == "x86fre" set checkin=yes
  37. if /i "%computername%" == "alphafre" set checkin=yes
  38. if /i "%computername%" == "axp64fre" set checkin=yes
  39. if /i "%computername%" == "ia64fre" set checkin=yes
  40. can be replaced with
  41. call %_ntbindir%\bldrules\localbrs.bat
  42. ..
  43. REM Only US build machines should check in sorted.lst
  44. set checkin=
  45. if /i "%computername%" == "%USx86fre%" set checkin=yes
  46. if /i "%computername%" == "%USalphafre%" set checkin=yes
  47. if /i "%computername%" == "%USaxp64fre%" set checkin=yes
  48. if /i "%computername%" == "%USia64fre%" set checkin=yes
  49. b. Build rule scripts must be able to run in particular contexts as well.
  50. * Not everything from a build rule script is applicable to the International builds.
  51. _AUTORUN.CMD is an example. The script applies to the US builds only.
  52. Use IsIntlBld.cmd (-s \\orville\razzle -p public\tools) to determine if the script
  53. is being run for International builds and skip the execution of some particular code
  54. if the code is not applicable for language builds.
  55. call IsIntlBld.cmd
  56. if errorlevel 1 (
  57. REM Write code specific to non-International builds
  58. ) else (
  59. REM Write code specific to International builds.
  60. )
  61. Also, as environment variable LANG is defined at the time the US build rule script is
  62. invoked, you can use it if you need to write code specific to a particular language.
  63. Nec_98 is considered a language, even though it is in fact an architecture specific to
  64. Japanese builds and built on the x86 machines.
  65. * Not everything from a build rule script is (might be) applicable to both Redmond and
  66. Dublin-based International builds.
  67. You can use the same IsIntlBld.cmd to determine if the script is being run for a specific
  68. International build:
  69. call IsIntlBld.cmd Redmond
  70. if errorlevel 1 (
  71. REM Not a Redmond-based International build.
  72. ) else (
  73. REM Write code specific to the Redmond-based International builds.
  74. )
  75. call IsIntlBld.cmd Dublin
  76. if errorlevel 1 (
  77. REM Not a Dublin-based International build.
  78. ) else (
  79. REM Write code specific to the Dublin-based International builds.
  80. )
  81. Currently, there is no build rule script to need special processing for one
  82. International type build, but not for the other.
  83. * Not all languages ship server, advanced server, or datacenter Windows 2000 products.
  84. Some of the build rule scripts use perinf, blainf, sbsinf, srvinf, entinf, and/or dtcinf. Before using these
  85. directories, a build rule script should verify if they are applicable in the current context.
  86. REM Use CkSKU.pm to validate the SKU against the given language and architecture.
  87. perl %RazzleToolPath%\cksku.pm -t:per -l:%lang% -a:%_BuildArch%
  88. if %errorlevel% EQU 0 (
  89. REM Execute code based on perinf files. Ex:
  90. perl makelist.pl -q %bin_in%\perinf\excdosnt.inf ...
  91. )
  92. perl %RazzleToolPath%\cksku.pm -t:bla -l:%lang% -a:%_BuildArch%
  93. if %errorlevel% EQU 0 (
  94. REM Execute code based on blainf files. Ex:
  95. perl makelist.pl -q %bin_in%\blainf\excdosnt.inf ...
  96. )
  97. perl %RazzleToolPath%\cksku.pm -t:sbs -l:%lang% -a:%_BuildArch%
  98. if %errorlevel% EQU 0 (
  99. REM Execute code based on sbsinf files. Ex:
  100. perl makelist.pl -q %bin_in%\sbsinf\excdosnt.inf ...
  101. )
  102. perl %RazzleToolPath\%cksku.pm -t:srv -l:%lang% -a:%_BuildArch%
  103. if %errorlevel% EQU 0 (
  104. REM Execute code based on srvinf files. Ex:
  105. perl makelist.pl -q %bin_in%\srvinf\excdosnt.inf ...
  106. )
  107. perl %RazzleToolPath%\cksku.pm -t:ads -l:%lang% -a:%_BuildArch%
  108. if %errorlevel% EQU 0 (
  109. REM Execute code based on adsinf files. Ex:
  110. perl makelist.pl -q %bin_in%\entinf\excdosnt.inf ...
  111. )
  112. perl %RazzleToolPath%\cksku.pm -t:dtc -l:%lang% -a:%_BuildArch%
  113. if %errorlevel% EQU 0 (
  114. REM Execute code based on dtcinf files. Ex:
  115. perl makelist.pl -q %bin_in%\dtcinf\excdosnt.inf ...
  116. )
  117. c. Build rule scripts need to respect the following set of rules when using and/or defining
  118. environment variables:
  119. * Any razzle variable is allowed to be used inside a build rule script, except for "BINARIES".
  120. _NTDRIVE, _NTROOT, NTDEBUG, _TARGET are examples of razzle variables.
  121. On both US and International build machines, %BINARIES% represents the directory to which
  122. files get binplaced. Typically, the files from the %BINARIES% directory are not localized.
  123. On the International build machines, the tree containing the localized binaries is called
  124. RELBINS and is different from BINARIES. In general, the build rule scripts apply to binaries
  125. already built and, for International, localized. To avoid confusion and inappropriate
  126. redefinitions of BINARIES that would persist after a build rule script finishes its execution,
  127. the build rule scripts define a special variable called MYBINARIES as follows:
  128. if not defined MYBINARIES set MYBINARIES=%BINARIES%
  129. * A build rule script can define any new variable under the requirement that they preserve the
  130. existing value of that variable, if any.
  131. if not defined build_rule_script_local_variable (
  132. set build_rule_script_local_variable=<value>
  133. )
  134. This mechanism allows the International builds to define these variables according to their
  135. particular context before invoking the US build rules. The gain is that US and International
  136. builds are able to share the same build rule scripts.
  137. d. A build rule script should avoid executing builds in the private tree or using binaries from the
  138. private tree.
  139. The files processed by a build rule script must be accessible to the international builds.
  140. The international build machines do not have the whole private tree. Their private tree is
  141. restricted to those projects requiring compile time localization.
  142. Whenever your build rule script invokes builds.exe under private or uses files from private,
  143. it breaks the International builds, as they cannot use your build rule script.
  144. If you must run build instructions from a build rule script, put these instructions into
  145. PRECONGEAL.
  146. Or avoid building on international build machines by using the IsIntlBld.cmd logic described
  147. above. Keep in mind that international build machines only build sources that are localized,
  148. which are very few and usually belong in a language-specific directory like \jpn for Japanese.
  149. The rest of the binaries are inherited from the US build machines' %BINARIES% so international
  150. machines avoid running build.exe under private in order to get the unlocalized binaries one
  151. build rule script needs.
  152. In cases where localized sources absolutely need to be re-built inside a build rules script
  153. (ie, drvcab.cmd rebuilds dosnet.inf), please discuss with the international build team contacts
  154. at the top of this document so special international needs can be addressed.
  155. Also, any file from the private tree used by a build rule script should be binplaced to the
  156. %BINARIES% tree, as opposed to being copied to %BINARIES%. Having a file listed in binplace.log
  157. makes the investigation of build problems easier, as the name and location of the source tree
  158. producing the file becomes apparent.
  159. Last but not least, the binaries from the private tree typically have the symbol information not
  160. split. It is wrong to include non-split binaries in the product. Binplacing files will enforce
  161. that the proper symbolic information is present and split out to the proper .dbg and/or .pdb files
  162. so customers receive split binaries with valid symbols, not non-split binaries that can be reverse
  163. engineered.
  164. e. Build rule scripts should be able to run incrementally.
  165. The build rule scripts are currently invoked from congeal.cmd.
  166. Typically, they run cleanly whenever invoked, even though just a few files changed.
  167. Every time you write a build rule script, multiply its execution time with 21 (7 Redmond-based
  168. languages and 14 Dublin-based languages) and assess whether its execution time is still acceptable.
  169. Even when they run in parallel for different languages, the build rule scripts can take a lot of
  170. time to execute.
  171. Whenever possible, write and/or use incremental tools. For example, use makefiles to define
  172. dependencies and generate the targets, in order to take the advantage of NMAKE.EXE's incremental
  173. nature.
  174. f. A build rule script should be very specific about the location of the tools it uses.
  175. A build rule script using an idw or mstools tool must invoke the tool by using its full name,
  176. including the path. It is error prone to assume that the right version of signcode.exe, for example,
  177. comes first in the PATH.
  178. if not defined idw set idw=%windir%\idw
  179. %idw%\signcode.exe ...
  180. iexpress.exe should always be used from IEXPRESS_PATH, as the language builds need localized
  181. version of advpack.dll and wextract.exe:
  182. if not defined IEXPRESS_PATH set IEXPRESS_PATH=%windir%\idw
  183. set PATH=%IEXPRESS_PATH%;%PATH%
  184. iexpress.exe ...
  185. g. A build rule script should provide logging and error information on the screen and in logging files.
  186. Follow the template script's guidelines in logging information on the screen and in log files:
  187. * use ErrMsg.cmd to log errors, LogMsg.cmd to log non-error information and LogMsg.cmd /t
  188. to mark the start and the end script's execution times.
  189. * exit with a non-zero errorlevel if the script encountered errors during execution by calling
  190. seterror.exe <errno> in the end.
  191. h. A build rule script should be enabled to run in parallel with other build rules scripts.
  192. Every build rule script must be enabled to run in parallel with the other build rule scripts.
  193. For every option it implements (NEWVER, PREREBASE, CONGEAL, etc), a build rule creates a tag file
  194. in the tmp directory, tag file to be deleted when the execution of the build rule script finishes.
  195. The existence of the tag file shows that the build rule script is still executing.
  196. i. A build rule script should contain detailed comments about its purpose, the algorithm it uses to
  197. generate its output, particular tools it relies on, caveats, etc.
  198. 3. Check in <your_project_build_rule>.cmd.
  199. The NT build process will run the new added .cmd file at the appropriate time as part of the normal
  200. NT build.
  201. 4. Make any changes to <your_project_build_rule>.cmd in accordance with the guidelines detailed at step 2.
  202. If your .cmd file becomes obsolete, remove (delfile) it from the "bldrules" project.
  203. Until you remove the .cmd file, the build process will continue to run it with every US and
  204. International build.