Home | History | Annotate | Line # | Download | only in unit-tests
      1 # $NetBSD: varname-dot-parsefile.mk,v 1.7 2023/06/21 07:30:50 rillig Exp $
      2 #
      3 # Tests for the special .PARSEFILE variable, which contains the basename part
      4 # of the file that is currently parsed.
      5 #
      6 # See also
      7 #	varname-dot-includedfromdir.mk
      8 #	varname-dot-includedfromfile.mk
      9 #	varname-dot-parsedir.mk
     10 #
     11 # History
     12 #	.PARSEDIR and .PARSEFILE were added on 1999-08-09.
     13 
     14 .if ${.PARSEFILE} != "varname-dot-parsefile.mk"
     15 .  error
     16 .endif
     17 
     18 # During parsing, it is possible to undefine .PARSEFILE.
     19 # Not that anyone would ever want to do this, but there's code in parse.c,
     20 # function PrintLocation, that explicitly handles this situation.
     21 .if !defined(.PARSEFILE)
     22 .  error
     23 .endif
     24 .undef .PARSEFILE
     25 .if defined(.PARSEFILE)
     26 .  error
     27 .endif
     28 
     29 # The variable .PARSEFILE is indirectly used by the .info directive,
     30 # via PrintLocation.
     31 # expect+1: At this point, .PARSEFILE is undefined.
     32 .info At this point, .PARSEFILE is undefined.
     33 
     34 # There is absolutely no point in faking the location of the file that is
     35 # being parsed.  Technically, it's possible though, but only if the file
     36 # being parsed is a relative pathname.  See PrintLocation for details.
     37 .PARSEFILE=	fake-parsefile
     38 .info The location can be faked in some cases.
     39 
     40 # After including another file, .PARSEFILE is reset.
     41 .include "/dev/null"
     42 # expect+1: The location is no longer fake.
     43 .info The location is no longer fake.
     44 
     45 all:
     46 	@echo At run time, .PARSEFILE is ${.PARSEFILE:Uundefined}.
     47