# $NetBSD: varname-dot-parsefile.mk,v 1.7 2023/06/21 07:30:50 rillig Exp $ # # Tests for the special .PARSEFILE variable, which contains the basename part # of the file that is currently parsed. # # See also # varname-dot-includedfromdir.mk # varname-dot-includedfromfile.mk # varname-dot-parsedir.mk # # History # .PARSEDIR and .PARSEFILE were added on 1999-08-09. .if ${.PARSEFILE} != "varname-dot-parsefile.mk" . error .endif # During parsing, it is possible to undefine .PARSEFILE. # Not that anyone would ever want to do this, but there's code in parse.c, # function PrintLocation, that explicitly handles this situation. .if !defined(.PARSEFILE) . error .endif .undef .PARSEFILE .if defined(.PARSEFILE) . error .endif # The variable .PARSEFILE is indirectly used by the .info directive, # via PrintLocation. # expect+1: At this point, .PARSEFILE is undefined. .info At this point, .PARSEFILE is undefined. # There is absolutely no point in faking the location of the file that is # being parsed. Technically, it's possible though, but only if the file # being parsed is a relative pathname. See PrintLocation for details. .PARSEFILE= fake-parsefile .info The location can be faked in some cases. # After including another file, .PARSEFILE is reset. .include "/dev/null" # expect+1: The location is no longer fake. .info The location is no longer fake. all: @echo At run time, .PARSEFILE is ${.PARSEFILE:Uundefined}.