PRB: Spaces in Inference Rules Corrupt NMAKE Macro Expansion (65084)



The information in this article applies to:

  • Microsoft NMAKE Utility for MS-DOS 1.01
  • Microsoft NMAKE Utility for MS-DOS 1.1
  • Microsoft NMAKE Utility for MS-DOS 1.11
  • Microsoft NMAKE Utility for MS-DOS 1.12
  • Microsoft NMAKE Utility for MS-DOS 1.13
  • Microsoft NMAKE Utility for MS-DOS 1.2
  • Microsoft NMAKE Utility for MS-DOS 1.3
  • Microsoft NMAKE Utility for MS-DOS 1.4
  • Microsoft NMAKE Utility for OS/2 1.01
  • Microsoft NMAKE Utility for OS/2 1.11
  • Microsoft NMAKE Utility for OS/2 1.12
  • Microsoft NMAKE Utility for OS/2 1.13
  • Microsoft NMAKE Utility for OS/2 1.21
  • Microsoft NMAKE Utility for Windows NT 1.4
  • Microsoft NMAKE Utility for Windows NT 1.5

This article was previously published under Q65084

SYMPTOMS

An attempt to use an NMAKE default macro fails and NMAKE generates a message such as the following:
warning u4006: special macro undefined : '$<'

CAUSE

A space has been inserted between the name of the target and the dependent extensions in an inference rule.

RESOLUTION

In an inference rule, list the dependent file extension followed by the target file extension without any intervening embedded spaces.

MORE INFORMATION

The following makefile examples demonstrate a few of the problems that can result when spaces are embedded in an inference rule. In both cases below, note that the embedded spaces cause NMAKE to run commands incorrectly. If you modify the files to remove the spaces, NMAKE generates the desired commands.

Sample Makefile 1

# The command executed by NMAKE:
#
#    cl {.}

{.}.c {c:\objs\}.obj:
   cl $*

c:\objs\test.obj: .\test.c
				

Sample Makefile 2

# The command executed by NMAKE:
#
#    cl

.c .obj:
  cl $<

ALL: myfile.obj

myfile.obj: myfile.c
				

Modification Type:MajorLast Reviewed:12/1/2003
Keywords:KB65084