[900] | 1 | Port of GNU Make to 32-bit protected mode on MSDOS and MS-Windows.
|
---|
| 2 |
|
---|
| 3 | Builds with DJGPP v2 port of GNU C/C++ compiler and utilities.
|
---|
| 4 |
|
---|
| 5 |
|
---|
| 6 | New (since 3.74) DOS-specific features:
|
---|
| 7 |
|
---|
| 8 | 1. Supports long filenames when run from DOS box on Windows 9x.
|
---|
| 9 |
|
---|
| 10 | 2. Supports both stock DOS COMMAND.COM and Unix-style shells
|
---|
[3140] | 11 | (details in 'Notes' below).
|
---|
[900] | 12 |
|
---|
| 13 | 3. Supports DOS drive letters in dependencies and pattern rules.
|
---|
| 14 |
|
---|
| 15 | 4. Better support for DOS-style backslashes in pathnames (but see
|
---|
[3140] | 16 | 'Notes' below).
|
---|
[900] | 17 |
|
---|
| 18 | 5. The $(shell) built-in can run arbitrary complex commands,
|
---|
| 19 | including pipes and redirection, even when COMMAND.COM is your
|
---|
| 20 | shell.
|
---|
| 21 |
|
---|
| 22 | 6. Can be built without floating-point code (see below).
|
---|
| 23 |
|
---|
| 24 | 7. Supports signals in child programs and restores the original
|
---|
| 25 | directory if the child was interrupted.
|
---|
| 26 |
|
---|
| 27 | 8. Can be built without (a previous version of) Make.
|
---|
| 28 |
|
---|
| 29 | 9. The build process requires only standard tools. (Optional
|
---|
| 30 | targets like "install:" and "clean:" still need additional
|
---|
| 31 | programs, though, see below.)
|
---|
| 32 |
|
---|
| 33 | 10. Beginning with v3.78, the test suite works in the DJGPP
|
---|
| 34 | environment (requires Perl and auxiliary tools; see below).
|
---|
| 35 |
|
---|
| 36 |
|
---|
| 37 | To install a binary distribution:
|
---|
| 38 |
|
---|
| 39 | Simply unzip the makNNNb.zip file (where NNN is the version number)
|
---|
| 40 | preserving the directory structure (-d switch if you use PKUNZIP).
|
---|
| 41 | If you are installing Make on Windows 9X or Windows 2000, use an
|
---|
| 42 | unzip program that supports long filenames in zip files. After
|
---|
| 43 | unzipping, make sure the directory with make.exe is on your PATH,
|
---|
| 44 | and that's all you need to use Make.
|
---|
| 45 |
|
---|
| 46 |
|
---|
| 47 | To build from sources:
|
---|
| 48 |
|
---|
| 49 | 1. Unzip the archive, preserving the directory structure (-d switch
|
---|
| 50 | if you use PKUNZIP). If you build Make on Windows 9X or Windows
|
---|
| 51 | 2000, use an unzip program that supports long filenames in zip
|
---|
| 52 | files.
|
---|
| 53 |
|
---|
| 54 | If you are unpacking an official GNU source distribution, use
|
---|
| 55 | either DJTAR (which is part of the DJGPP development
|
---|
| 56 | environment), or the DJGPP port of GNU Tar.
|
---|
| 57 |
|
---|
[3140] | 58 | 2. Invoke the 'configure.bat' batch file.
|
---|
[900] | 59 |
|
---|
| 60 | If you are building Make in-place, i.e. in the same directory
|
---|
| 61 | where its sources are kept, just type "configure.bat" and press
|
---|
| 62 | [Enter]. Otherwise, you need to supply the path to the source
|
---|
| 63 | directory as an argument to the batch file, like this:
|
---|
| 64 |
|
---|
[3140] | 65 | c:\djgpp\gnu\make-%VERSION%\configure.bat c:/djgpp/gnu/make-%VERSION%
|
---|
[900] | 66 |
|
---|
| 67 | Note the forward slashes in the source path argument: you MUST
|
---|
| 68 | use them here.
|
---|
| 69 |
|
---|
| 70 | 3. If configure.bat doesn't find a working Make, it will suggest to
|
---|
[3140] | 71 | use the 'dosbuild.bat' batch file to build Make. Either do as it
|
---|
[900] | 72 | suggests or install another Make program (a pre-compiled binary
|
---|
| 73 | should be available from the usual DJGPP sites) and rerun
|
---|
| 74 | configure.bat.
|
---|
| 75 |
|
---|
| 76 | 4. If you will need to run Make on machines without an FPU, you
|
---|
| 77 | might consider building a version of Make which doesn't issue
|
---|
| 78 | floating-point instructions (they don't help much on MSDOS
|
---|
| 79 | anyway). To this end, edit the Makefile created by
|
---|
| 80 | configure.bat and add -DNO_FLOAT to the value of CPPFLAGS.
|
---|
| 81 |
|
---|
| 82 | 5. Invoke Make.
|
---|
| 83 |
|
---|
| 84 | If you are building from outside of the source directory, you
|
---|
| 85 | need to tell Make where the sources are, like this:
|
---|
| 86 |
|
---|
[3140] | 87 | make srcdir=c:/djgpp/gnu/make-%VERSION%
|
---|
[900] | 88 |
|
---|
| 89 | (configure.bat will tell you this when it finishes). You MUST
|
---|
| 90 | use a full, not relative, name of the source directory here, or
|
---|
| 91 | else Make might fail.
|
---|
| 92 |
|
---|
| 93 | 6. After Make finishes, if you have a Unix-style shell installed,
|
---|
[3140] | 94 | you can use the 'install' target to install the package. You
|
---|
[900] | 95 | will also need GNU Fileutils and GNU Sed for this (they should
|
---|
| 96 | be available from the DJGPP sites).
|
---|
| 97 |
|
---|
| 98 | By default, GNU make will install into your DJGPP installation
|
---|
| 99 | area. If you wish to use a different directory, override the
|
---|
| 100 | DESTDIR variable when invoking "make install", like this:
|
---|
| 101 |
|
---|
[3140] | 102 | make install DESTDIR=c:/other/dir
|
---|
[900] | 103 |
|
---|
| 104 | This causes the make executable to be placed in c:/other/dir/bin,
|
---|
| 105 | the man pages in c:/other/dir/man, etc.
|
---|
| 106 |
|
---|
| 107 | Without a Unix-style shell, you will have to install programs
|
---|
| 108 | and the docs manually. Copy make.exe to a directory on your
|
---|
| 109 | PATH, make.i* info files to your Info directory, and update the
|
---|
[3140] | 110 | file 'dir' in your Info directory by adding the following item
|
---|
[900] | 111 | to the main menu:
|
---|
| 112 |
|
---|
[3140] | 113 | * Make: (make.info). The GNU make utility.
|
---|
[900] | 114 |
|
---|
[3140] | 115 | If you have the 'install-info' program (from the GNU Texinfo
|
---|
[900] | 116 | package), it will do that for you if you invoke it like this:
|
---|
| 117 |
|
---|
[3140] | 118 | install-info --info-dir=c:/djgpp/info c:/djgpp/info/make.info
|
---|
[900] | 119 |
|
---|
| 120 | (If your Info directory is other than C:\DJGPP\INFO, change this
|
---|
| 121 | command accordingly.)
|
---|
| 122 |
|
---|
[3140] | 123 | 7. The 'clean' targets also require Unix-style shell, and GNU Sed
|
---|
| 124 | and 'rm' programs (the latter from Fileutils).
|
---|
[900] | 125 |
|
---|
| 126 | 8. To run the test suite, type "make check". This requires a Unix
|
---|
| 127 | shell (I used the DJGPP port of Bash 2.03), Perl, Sed, Fileutils
|
---|
| 128 | and Sh-utils.
|
---|
| 129 |
|
---|
| 130 |
|
---|
| 131 | Notes:
|
---|
| 132 | -----
|
---|
| 133 |
|
---|
| 134 | 1. The shell issue.
|
---|
| 135 |
|
---|
| 136 | This is probably the most significant improvement, first
|
---|
| 137 | introduced in the port of GNU Make 3.75.
|
---|
| 138 |
|
---|
| 139 | The original behavior of GNU Make is to invoke commands
|
---|
| 140 | directly, as long as they don't include characters special to
|
---|
| 141 | the shell or internal shell commands, because that is faster.
|
---|
| 142 | When shell features like redirection or filename wildcards are
|
---|
| 143 | involved, Make calls the shell.
|
---|
| 144 |
|
---|
| 145 | This port supports both DOS shells (the stock COMMAND.COM and its
|
---|
| 146 | 4DOS/NDOS replacements), and Unix-style shells (tested with the
|
---|
[3140] | 147 | venerable Stewartson's 'ms_sh' 2.3 and the DJGPP port of 'bash' by
|
---|
[900] | 148 | Daisuke Aoyama <jack@st.rim.or.jp>).
|
---|
| 149 |
|
---|
| 150 | When the $SHELL variable points to a Unix-style shell, Make
|
---|
| 151 | works just like you'd expect on Unix, calling the shell for any
|
---|
| 152 | command that involves characters special to the shell or
|
---|
| 153 | internal shell commands. The only difference is that, since
|
---|
| 154 | there is no standard way to pass command lines longer than the
|
---|
| 155 | infamous DOS 126-character limit, this port of Make writes the
|
---|
| 156 | command line to a temporary disk file and then invokes the shell
|
---|
| 157 | on that file.
|
---|
| 158 |
|
---|
| 159 | If $SHELL points to a DOS-style shell, however, Make will not
|
---|
| 160 | call it automatically, as it does with Unix shells. Stock
|
---|
| 161 | COMMAND.COM is too dumb and would unnecessarily limit the
|
---|
| 162 | functionality of Make. For example, you would not be able to
|
---|
| 163 | use long command lines in commands that use redirection or
|
---|
| 164 | pipes. Therefore, when presented with a DOS shell, this port of
|
---|
| 165 | Make will emulate most of the shell functionality, like
|
---|
| 166 | redirection and pipes, and shall only call the shell when a
|
---|
| 167 | batch file or a command internal to the shell is invoked. (Even
|
---|
| 168 | when a command is an internal shell command, Make will first
|
---|
[3140] | 169 | search the $PATH for it, so that if a Makefile calls 'mkdir',
|
---|
| 170 | you can install, say, a port of GNU 'mkdir' and have it called
|
---|
[900] | 171 | in that case.)
|
---|
| 172 |
|
---|
[3140] | 173 | The key to all this is the extended functionality of 'spawn' and
|
---|
| 174 | 'system' functions from the DJGPP library; this port just calls
|
---|
| 175 | 'system' where it would invoke the shell on Unix. The most
|
---|
[900] | 176 | important aspect of these functions is that they use a special
|
---|
| 177 | mechanism to pass long (up to 16KB) command lines to DJGPP
|
---|
[3140] | 178 | programs. In addition, 'system' emulates some internal
|
---|
| 179 | commands, like 'cd' (so that you can now use forward slashes
|
---|
[900] | 180 | with it, and can also change the drive if the directory is on
|
---|
| 181 | another drive). Another aspect worth mentioning is that you can
|
---|
| 182 | call Unix shell scripts directly, provided that the shell whose
|
---|
| 183 | name is mentioned on the first line of the script is installed
|
---|
| 184 | anywhere along the $PATH. It is impossible to tell here
|
---|
| 185 | everything about these functions; refer to the DJGPP library
|
---|
| 186 | reference for more details.
|
---|
| 187 |
|
---|
| 188 | The $(shell) built-in is implemented in this port by calling
|
---|
[3140] | 189 | 'popen'. Since 'popen' calls 'system', the above considerations
|
---|
[900] | 190 | are valid for $(shell) as well. In particular, you can put
|
---|
| 191 | arbitrary complex commands, including pipes and redirection,
|
---|
| 192 | inside $(shell), which is in many cases a valid substitute for
|
---|
| 193 | the Unix-style command substitution (`command`) feature.
|
---|
| 194 |
|
---|
| 195 |
|
---|
| 196 | 2. "SHELL=/bin/sh" -- or is it?
|
---|
| 197 |
|
---|
| 198 | Many Unix Makefiles include a line which sets the SHELL, for
|
---|
| 199 | those versions of Make which don't have this as the default.
|
---|
[3140] | 200 | Since many DOS systems don't have 'sh' installed (in fact, most
|
---|
| 201 | of them don't even have a '/bin' directory), this port takes
|
---|
[900] | 202 | such directives with a grain of salt. It will only honor such a
|
---|
[3140] | 203 | directive if the basename of the shell name (like 'sh' in the
|
---|
[900] | 204 | above example) can indeed be found in the directory that is
|
---|
[3140] | 205 | mentioned in the SHELL= line ('/bin' in the above example), or
|
---|
[900] | 206 | in the current working directory, or anywhere on the $PATH (in
|
---|
| 207 | that order). If the basename doesn't include a filename
|
---|
| 208 | extension, Make will look for any known extension that indicates
|
---|
| 209 | an executable file (.exe, .com, .bat, .btm, .sh, and even .sed
|
---|
| 210 | and .pl). If any such file is found, then $SHELL will be
|
---|
| 211 | defined to the exact pathname of that file, and that shell will
|
---|
| 212 | hence be used for the rest of processing. But if the named
|
---|
| 213 | shell is *not* found, the line which sets it will be effectively
|
---|
| 214 | ignored, leaving the value of $SHELL as it was before. Since a
|
---|
| 215 | lot of decisions that this port makes depend on the gender of
|
---|
| 216 | the shell, I feel it doesn't make any sense to tailor Make's
|
---|
| 217 | behavior to a shell which is nowhere to be found.
|
---|
| 218 |
|
---|
| 219 | Note that the above special handling of "SHELL=" only happens
|
---|
| 220 | for Makefiles; if you set $SHELL in the environment or on the
|
---|
| 221 | Make command line, you are expected to give the complete
|
---|
| 222 | pathname of the shell, including the filename extension.
|
---|
| 223 |
|
---|
| 224 | The default value of $SHELL is computed as on Unix (see the Make
|
---|
| 225 | manual for details), except that if $SHELL is not defined in the
|
---|
| 226 | environment, $COMSPEC is used. Also, if an environment variable
|
---|
| 227 | named $MAKESHELL is defined, it takes precedence over both
|
---|
| 228 | $COMSPEC and $SHELL. Note that, unlike Unix, $SHELL in the
|
---|
| 229 | environment *is* used to set the shell (since on MSDOS, it's
|
---|
| 230 | unlikely that the interactive shell will not be suitable for
|
---|
| 231 | Makefile processing).
|
---|
| 232 |
|
---|
| 233 | The bottom line is that you can now write Makefiles where some
|
---|
| 234 | of the targets require a real (i.e. Unix-like) shell, which will
|
---|
| 235 | nevertheless work when such shell is not available (provided, of
|
---|
| 236 | course, that the commands which should always work, don't
|
---|
| 237 | require such a shell). More important, you can convert Unix
|
---|
| 238 | Makefiles to MSDOS and leave the line which sets the shell
|
---|
| 239 | intact, so that people who do have Unixy shell could use it for
|
---|
[3140] | 240 | targets which aren't converted to DOS (like 'install' and
|
---|
| 241 | 'uninstall', for example).
|
---|
[900] | 242 |
|
---|
| 243 |
|
---|
| 244 | 3. Default directories.
|
---|
| 245 |
|
---|
| 246 | GNU Make knows about standard directories where it searches for
|
---|
| 247 | library and include files mentioned in the Makefile. Since
|
---|
| 248 | MSDOS machines don't have standard places for these, this port
|
---|
| 249 | will search ${DJDIR}/lib and ${DJDIR}/include respectively.
|
---|
| 250 | $DJDIR is defined automatically by the DJGPP startup code as the
|
---|
| 251 | root of the DJGPP installation tree (unless you've tampered with
|
---|
| 252 | the DJGPP.ENV file). This should provide reasonable default
|
---|
| 253 | values, unless you moved parts of DJGPP to other directories.
|
---|
| 254 |
|
---|
| 255 |
|
---|
| 256 | 4. Letter-case in filenames.
|
---|
| 257 |
|
---|
| 258 | If you run Make on Windows 9x, you should be aware of the
|
---|
| 259 | letter-case issue. Make is internally case-sensitive, but all
|
---|
| 260 | file operations are case-insensitive on Windows 9x, so
|
---|
[3140] | 261 | e.g. files 'FAQ', 'faq' and 'Faq' all refer to the same file, as
|
---|
[900] | 262 | far as Windows is concerned. The underlying DJGPP C library
|
---|
| 263 | functions honor the letter-case of the filenames they get from
|
---|
| 264 | the OS, except that by default, they down-case 8+3 DOS filenames
|
---|
| 265 | which are stored in upper case in the directory and would break
|
---|
| 266 | many Makefiles otherwise. (The details of which filenames are
|
---|
| 267 | converted to lower case are explained in the DJGPP libc docs,
|
---|
[3140] | 268 | under the '_preserve_fncase' and '_lfn_gen_short_fname'
|
---|
[900] | 269 | functions, but as a thumb rule, any filename that is stored in
|
---|
| 270 | upper case in the directory, is a valid DOS 8+3 filename and
|
---|
| 271 | doesn't include characters invalid on MSDOS FAT filesystems,
|
---|
| 272 | will be automatically down-cased.) User reports that I have
|
---|
| 273 | indicate that this default behavior is generally what you'd
|
---|
| 274 | expect; however, your input is most welcome.
|
---|
| 275 |
|
---|
| 276 | In any case, if you hit a situation where you must force Make to
|
---|
| 277 | get the 8+3 DOS filenames in upper case, set FNCASE=y in the
|
---|
| 278 | environment or in the Makefile.
|
---|
| 279 |
|
---|
| 280 |
|
---|
| 281 | 5. DOS-style pathnames.
|
---|
| 282 |
|
---|
| 283 | There are a lot of places throughout the program sources which
|
---|
| 284 | make implicit assumptions about the pathname syntax. In
|
---|
[3140] | 285 | particular, the directories are assumed to be separated by '/',
|
---|
| 286 | and any pathname which doesn't begin with a '/' is assumed to be
|
---|
[900] | 287 | relative to the current directory. This port attempts to
|
---|
| 288 | support DOS-style pathnames which might include the drive letter
|
---|
| 289 | and use backslashes instead of forward slashes. However, this
|
---|
| 290 | support is not complete; I feel that pursuing this support too
|
---|
| 291 | far might break some more important features, particularly if
|
---|
| 292 | you use a Unix-style shell (where a backslash is a quote
|
---|
| 293 | character). I only consider support of backslashes desirable
|
---|
| 294 | because some Makefiles invoke non-DJGPP programs which don't
|
---|
| 295 | understand forward slashes. A notable example of such programs
|
---|
| 296 | is the standard programs which come with MSDOS. Otherwise, you
|
---|
| 297 | are advised to stay away from backslashes whenever possible. In
|
---|
| 298 | particular, filename globbing won't work on pathnames with
|
---|
[3140] | 299 | backslashes, because the GNU 'glob' library doesn't support them
|
---|
[900] | 300 | (backslash is special in filename wildcards, and I didn't want
|
---|
| 301 | to break that).
|
---|
| 302 |
|
---|
| 303 | One feature which *does* work with backslashes is the filename-
|
---|
| 304 | related built-in functions such as $(dir), $(notdir), etc.
|
---|
| 305 | Drive letters in pathnames are also fully supported.
|
---|
| 306 |
|
---|
| 307 |
|
---|
| 308 |
|
---|
| 309 | Bug reports:
|
---|
| 310 | -----------
|
---|
| 311 |
|
---|
| 312 | Bugs that are clearly related to the MSDOS/DJGPP port should be
|
---|
| 313 | reported first on the comp.os.msdos.djgpp news group (if you cannot
|
---|
| 314 | post to Usenet groups, write to the DJGPP mailing list,
|
---|
| 315 | <djgpp@delorie.com>, which is an email gateway into the above news
|
---|
| 316 | group). For other bugs, please follow the procedure explained in
|
---|
| 317 | the "Bugs" chapter of the Info docs. If you don't have an Info
|
---|
[3140] | 318 | reader, look up that chapter in the 'make.i1' file with any text
|
---|
[900] | 319 | browser/editor.
|
---|
| 320 |
|
---|
| 321 |
|
---|
| 322 | Enjoy,
|
---|
[3140] | 323 | Eli Zaretskii <eliz@is.elta.co.il>
|
---|
[900] | 324 |
|
---|
| 325 | |
---|
| 326 |
|
---|
[3140] | 327 | -------------------------------------------------------------------------------
|
---|
[900] | 328 | Copyright (C) 1996-2016 Free Software Foundation, Inc.
|
---|
| 329 | This file is part of GNU Make.
|
---|
| 330 |
|
---|
| 331 | GNU Make is free software; you can redistribute it and/or modify it under the
|
---|
[1993] | 332 | terms of the GNU General Public License as published by the Free Software
|
---|
| 333 | Foundation; either version 3 of the License, or (at your option) any later
|
---|
[900] | 334 | version.
|
---|
| 335 |
|
---|
| 336 | GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY
|
---|
| 337 | WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
---|
| 338 | A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
---|
| 339 |
|
---|
[1993] | 340 | You should have received a copy of the GNU General Public License along with
|
---|
| 341 | this program. If not, see <http://www.gnu.org/licenses/>.
|
---|