summaryrefslogtreecommitdiff
path: root/pkgtools
diff options
context:
space:
mode:
authorrillig <rillig@pkgsrc.org>2019-09-12 21:15:48 +0000
committerrillig <rillig@pkgsrc.org>2019-09-12 21:15:48 +0000
commitc13c5875b08139c1c1668bcd37e70ed248356c65 (patch)
treea3899befa6caa73cfcff11d4cfa854d9bd38274f /pkgtools
parentc6b5c0c210aed4ef50fb97e6e910d32b02086c35 (diff)
downloadpkgsrc-c13c5875b08139c1c1668bcd37e70ed248356c65.tar.gz
pkgtools/pkglint: update to 5.7.24
Changes since 5.7.23: * Improved the _VARGROUPS check for ignored variables * Removed wrong warnings for variable expressions like ${VAR:Dyes:Uno} * Used correct terminology for the :Q modifier (it's not an operator)
Diffstat (limited to 'pkgtools')
-rw-r--r--pkgtools/pkglint/Makefile4
-rw-r--r--pkgtools/pkglint/files/logging.go4
-rw-r--r--pkgtools/pkglint/files/logging_test.go12
-rw-r--r--pkgtools/pkglint/files/mkline.go17
-rw-r--r--pkgtools/pkglint/files/mkline_test.go26
-rw-r--r--pkgtools/pkglint/files/mklinechecker.go8
-rw-r--r--pkgtools/pkglint/files/mklinechecker_test.go4
-rw-r--r--pkgtools/pkglint/files/mktypes.go9
-rw-r--r--pkgtools/pkglint/files/shell_test.go10
-rw-r--r--pkgtools/pkglint/files/util.go2
-rw-r--r--pkgtools/pkglint/files/vardefs.go6
-rw-r--r--pkgtools/pkglint/files/vardefs_test.go2
-rw-r--r--pkgtools/pkglint/files/vargroups.go50
-rw-r--r--pkgtools/pkglint/files/vargroups_test.go93
14 files changed, 192 insertions, 55 deletions
diff --git a/pkgtools/pkglint/Makefile b/pkgtools/pkglint/Makefile
index 90428517451..b2708c09117 100644
--- a/pkgtools/pkglint/Makefile
+++ b/pkgtools/pkglint/Makefile
@@ -1,6 +1,6 @@
-# $NetBSD: Makefile,v 1.596 2019/09/08 22:47:47 rillig Exp $
+# $NetBSD: Makefile,v 1.597 2019/09/12 21:15:48 rillig Exp $
-PKGNAME= pkglint-5.7.23
+PKGNAME= pkglint-5.7.24
CATEGORIES= pkgtools
DISTNAME= tools
MASTER_SITES= ${MASTER_SITE_GITHUB:=golang/}
diff --git a/pkgtools/pkglint/files/logging.go b/pkgtools/pkglint/files/logging.go
index 53bc5219a20..e066a8743ba 100644
--- a/pkgtools/pkglint/files/logging.go
+++ b/pkgtools/pkglint/files/logging.go
@@ -180,7 +180,7 @@ func (l *Logger) shallBeLogged(format string) bool {
//
// See Logf for logging arbitrary messages.
func (l *Logger) Diag(line *Line, level *LogLevel, format string, args ...interface{}) {
- if l.Opts.ShowAutofix || l.Opts.Autofix {
+ if l.IsAutofix() {
// In these two cases, the only interesting diagnostics are those that can
// be fixed automatically. These are logged by Autofix.Apply.
l.suppressExpl = true
@@ -200,7 +200,7 @@ func (l *Logger) Diag(line *Line, level *LogLevel, format string, args ...interf
}
if l.Opts.ShowSource {
- if !l.IsAutofix() && line != l.prevLine && level != Fatal {
+ if line != l.prevLine {
l.out.Separate()
}
l.showSource(line)
diff --git a/pkgtools/pkglint/files/logging_test.go b/pkgtools/pkglint/files/logging_test.go
index 835c448749c..2a56c159738 100644
--- a/pkgtools/pkglint/files/logging_test.go
+++ b/pkgtools/pkglint/files/logging_test.go
@@ -1071,3 +1071,15 @@ func (s *Suite) Test_SeparatorWriter_Separate(c *check.C) {
t.CheckEquals(sb.String(), "a\n\nc\n")
}
+
+func (s *Suite) Test_SeparatorWriter_Separate__at_the_beginning(c *check.C) {
+ t := s.Init(c)
+
+ var sb strings.Builder
+ wr := NewSeparatorWriter(&sb)
+
+ wr.Separate()
+ wr.WriteLine("a")
+
+ t.CheckEquals(sb.String(), "a\n")
+}
diff --git a/pkgtools/pkglint/files/mkline.go b/pkgtools/pkglint/files/mkline.go
index 1876f3c1da7..32122cfa262 100644
--- a/pkgtools/pkglint/files/mkline.go
+++ b/pkgtools/pkglint/files/mkline.go
@@ -920,12 +920,12 @@ func (p MkLineParser) parseDirective(line *Line, data mkLineSplitResult) *MkLine
return &MkLine{line, &mkLineDirective{indent, directive, args, trimmedComment, nil, nil, nil}}
}
-// VariableNeedsQuoting determines whether the given variable needs the :Q operator
-// in the given context.
+// VariableNeedsQuoting determines whether the given variable needs the :Q
+// modifier in the given context.
//
-// This decision depends on many factors, such as whether the type of the context is
-// a list of things, whether the variable is a list, whether it can contain only
-// safe characters, and so on.
+// This decision depends on many factors, such as whether the type of the
+// context is a list of things, whether the variable is a list, whether it
+// can contain only safe characters, and so on.
func (mkline *MkLine) VariableNeedsQuoting(mklines *MkLines, varuse *MkVarUse, vartype *Vartype, vuc *VarUseContext) (needsQuoting YesNoUnknown) {
if trace.Tracing {
defer trace.Call(varuse, vartype, vuc, trace.Result(&needsQuoting))()
@@ -934,6 +934,13 @@ func (mkline *MkLine) VariableNeedsQuoting(mklines *MkLines, varuse *MkVarUse, v
// TODO: Systematically test this function, each and every case, from top to bottom.
// TODO: Re-check the order of all these if clauses whether it really makes sense.
+ if varuse.HasModifier("D") && varuse.HasModifier("U") {
+ // Take the simple way for now. Handling this kind of
+ // conditional expressions correctly and completely would
+ // require a larger rewrite.
+ return unknown
+ }
+
vucVartype := vuc.vartype
if vartype == nil || vucVartype == nil || vartype.basicType == BtUnknown {
return unknown
diff --git a/pkgtools/pkglint/files/mkline_test.go b/pkgtools/pkglint/files/mkline_test.go
index 36e1eeba162..de5d4f73496 100644
--- a/pkgtools/pkglint/files/mkline_test.go
+++ b/pkgtools/pkglint/files/mkline_test.go
@@ -648,7 +648,7 @@ func (s *Suite) Test_MkLine_VariableNeedsQuoting__eval_shell(c *check.C) {
MkLineChecker{mklines, mklines.mklines[1]}.checkVarassign()
t.CheckOutputLines(
- "NOTE: builtin.mk:2: The :Q operator isn't necessary for ${BUILTIN_PKG.Xfixes} here.")
+ "NOTE: builtin.mk:2: The :Q modifier isn't necessary for ${BUILTIN_PKG.Xfixes} here.")
}
func (s *Suite) Test_MkLine_VariableNeedsQuoting__command_in_single_quotes(c *check.C) {
@@ -930,7 +930,7 @@ func (s *Suite) Test_MkLine_VariableNeedsQuoting__tool_in_CONFIGURE_ENV(c *check
// for invoking the tool properly (e.g. touch -t).
// Therefore, no quoting is necessary.
t.CheckOutputLines(
- "NOTE: Makefile:3: The :Q operator isn't necessary for ${TOOLS_TAR} here.")
+ "NOTE: Makefile:3: The :Q modifier isn't necessary for ${TOOLS_TAR} here.")
}
func (s *Suite) Test_MkLine_VariableNeedsQuoting__backticks(c *check.C) {
@@ -1026,6 +1026,28 @@ func (s *Suite) Test_MkLine_VariableNeedsQuoting__tool_in_shell_command(c *check
t.CheckOutputEmpty()
}
+func (s *Suite) Test_MkLine_VariableNeedsQuoting__D_and_U_modifiers(c *check.C) {
+ t := s.Init(c)
+
+ t.SetUpVartypes()
+
+ mklines := t.SetUpFileMkLines("Makefile",
+ MkCvsID,
+ "",
+ "SUBST_CLASSES+=\t\turl2pkg",
+ "SUBST_STAGE.url2pkg=\tpost-configure",
+ "SUBST_FILES.url2pkg=\t*.in",
+ "SUBST_SED.url2pkg=\t-e 's,@PKGSRCDIR@,${BATCH:D/usr/pkg:U${PKGSRCDIR}},'")
+
+ mklines.Check()
+
+ // Since the value of the BATCH variable does not appear in the output,
+ // there should be no warning saying that "BATCH should be quoted".
+ // If any, the variable PKGSRCDIR should be quoted, but that is a safe
+ // variable since it is a pkgsrc-specific directory.
+ t.CheckOutputEmpty()
+}
+
// As of October 2018, these examples from real pkgsrc end up in the
// final "unknown" case.
func (s *Suite) Test_MkLine_VariableNeedsQuoting__uncovered_cases(c *check.C) {
diff --git a/pkgtools/pkglint/files/mklinechecker.go b/pkgtools/pkglint/files/mklinechecker.go
index cd6931ed3c6..3c51f25cb90 100644
--- a/pkgtools/pkglint/files/mklinechecker.go
+++ b/pkgtools/pkglint/files/mklinechecker.go
@@ -847,11 +847,11 @@ func (ck MkLineChecker) checkVarUseQuoting(varUse *MkVarUse, vartype *Vartype, v
mod := varUse.Mod()
// In GNU configure scripts, a few variables need to be passed through
- // the :M* operator before they reach the configure scripts. Otherwise
+ // the :M* modifier before they reach the configure scripts. Otherwise
// the leading or trailing spaces will lead to strange caching errors
// since the GNU configure scripts cannot handle these space characters.
//
- // When doing checks outside a package, the :M* operator is needed for safety.
+ // When doing checks outside a package, the :M* modifier is needed for safety.
needMstar := (G.Pkg == nil || G.Pkg.vars.Defined("GNU_CONFIGURE")) &&
matches(varname, `^(?:.*_)?(?:CFLAGS|CPPFLAGS|CXXFLAGS|FFLAGS|LDFLAGS|LIBS)$`)
@@ -958,9 +958,9 @@ func (ck MkLineChecker) checkVarUseQuoting(varUse *MkVarUse, vartype *Vartype, v
good := "${" + varname + strings.TrimSuffix(mod, ":Q") + "}"
fix := mkline.Line.Autofix()
- fix.Notef("The :Q operator isn't necessary for ${%s} here.", varname)
+ fix.Notef("The :Q modifier isn't necessary for ${%s} here.", varname)
fix.Explain(
- "Many variables in pkgsrc do not need the :Q operator since they",
+ "Many variables in pkgsrc do not need the :Q modifier since they",
"are not expected to contain whitespace or other special characters.",
"Examples for these \"safe\" variables are:",
"",
diff --git a/pkgtools/pkglint/files/mklinechecker_test.go b/pkgtools/pkglint/files/mklinechecker_test.go
index e891ba78edf..f8868ce2627 100644
--- a/pkgtools/pkglint/files/mklinechecker_test.go
+++ b/pkgtools/pkglint/files/mklinechecker_test.go
@@ -1191,7 +1191,7 @@ func (s *Suite) Test_MkLineChecker_checkVarassignRightVaruse(c *check.C) {
t.CheckOutputLines(
"WARN: module.mk:2: Please use PREFIX instead of LOCALBASE.",
- "NOTE: module.mk:2: The :Q operator isn't necessary for ${LOCALBASE} here.")
+ "NOTE: module.mk:2: The :Q modifier isn't necessary for ${LOCALBASE} here.")
}
func (s *Suite) Test_MkLineChecker_checkVarusePermissions(c *check.C) {
@@ -2275,7 +2275,7 @@ func (s *Suite) Test_MkLineChecker_checkVarUseQuoting__q_not_needed(c *check.C)
G.Check(pkg)
t.CheckOutputLines(
- "NOTE: ~/category/package/Makefile:6: The :Q operator isn't necessary for ${HOMEPAGE} here.")
+ "NOTE: ~/category/package/Makefile:6: The :Q modifier isn't necessary for ${HOMEPAGE} here.")
}
func (s *Suite) Test_MkLineChecker_checkVarUseQuoting__undefined_list_in_word_in_shell_command(c *check.C) {
diff --git a/pkgtools/pkglint/files/mktypes.go b/pkgtools/pkglint/files/mktypes.go
index 77bd1c4b527..8212d3ff34e 100644
--- a/pkgtools/pkglint/files/mktypes.go
+++ b/pkgtools/pkglint/files/mktypes.go
@@ -159,3 +159,12 @@ func (vu *MkVarUse) IsQ() bool {
mlen := len(vu.modifiers)
return mlen > 0 && vu.modifiers[mlen-1].IsQ()
}
+
+func (vu *MkVarUse) HasModifier(prefix string) bool {
+ for _, mod := range vu.modifiers {
+ if hasPrefix(mod.Text, prefix) {
+ return true
+ }
+ }
+ return false
+}
diff --git a/pkgtools/pkglint/files/shell_test.go b/pkgtools/pkglint/files/shell_test.go
index 081c1fa68fc..8e761018fce 100644
--- a/pkgtools/pkglint/files/shell_test.go
+++ b/pkgtools/pkglint/files/shell_test.go
@@ -180,7 +180,7 @@ func (s *Suite) Test_ShellLineChecker_CheckShellCommandLine(c *check.C) {
"before using a semicolon (after \"uname=`uname`\") to separate commands.")
test("echo ${PKGNAME:Q}", // VucQuotPlain
- "NOTE: filename.mk:1: The :Q operator isn't necessary for ${PKGNAME} here.")
+ "NOTE: filename.mk:1: The :Q modifier isn't necessary for ${PKGNAME} here.")
test("echo \"${CFLAGS:Q}\"", // VucQuotDquot
"WARN: filename.mk:1: The :Q modifier should not be used inside double quotes.",
@@ -316,7 +316,7 @@ func (s *Suite) Test_ShellLineChecker_CheckShellCommandLine__nofix(c *check.C) {
ck.CheckShellCommandLine("echo ${PKGNAME:Q}")
t.CheckOutputLines(
- "NOTE: Makefile:1: The :Q operator isn't necessary for ${PKGNAME} here.")
+ "NOTE: Makefile:1: The :Q modifier isn't necessary for ${PKGNAME} here.")
}
func (s *Suite) Test_ShellLineChecker_CheckShellCommandLine__show_autofix(c *check.C) {
@@ -332,7 +332,7 @@ func (s *Suite) Test_ShellLineChecker_CheckShellCommandLine__show_autofix(c *che
ck.CheckShellCommandLine("echo ${PKGNAME:Q}")
t.CheckOutputLines(
- "NOTE: Makefile:1: The :Q operator isn't necessary for ${PKGNAME} here.",
+ "NOTE: Makefile:1: The :Q modifier isn't necessary for ${PKGNAME} here.",
"AUTOFIX: Makefile:1: Replacing \"${PKGNAME:Q}\" with \"${PKGNAME}\".")
}
@@ -479,10 +479,10 @@ func (s *Suite) Test_ShellLineChecker_CheckWord(c *check.C) {
nil...)
test("\"${DISTINFO_FILE:Q}\"", true,
- "NOTE: filename.mk:1: The :Q operator isn't necessary for ${DISTINFO_FILE} here.")
+ "NOTE: filename.mk:1: The :Q modifier isn't necessary for ${DISTINFO_FILE} here.")
test("embed${DISTINFO_FILE:Q}ded", true,
- "NOTE: filename.mk:1: The :Q operator isn't necessary for ${DISTINFO_FILE} here.")
+ "NOTE: filename.mk:1: The :Q modifier isn't necessary for ${DISTINFO_FILE} here.")
test("s,\\.,,", true,
nil...)
diff --git a/pkgtools/pkglint/files/util.go b/pkgtools/pkglint/files/util.go
index 3e9c20648f6..413b1c29ce6 100644
--- a/pkgtools/pkglint/files/util.go
+++ b/pkgtools/pkglint/files/util.go
@@ -267,7 +267,7 @@ func isIgnoredFilename(filename string) bool {
case ".", "..", "CVS", ".svn", ".git", ".hg", ".idea":
return true
}
- return false
+ return hasPrefix(filename, ".#")
}
func dirglob(dirname string) []string {
diff --git a/pkgtools/pkglint/files/vardefs.go b/pkgtools/pkglint/files/vardefs.go
index a7e71f923e4..1a752b150d3 100644
--- a/pkgtools/pkglint/files/vardefs.go
+++ b/pkgtools/pkglint/files/vardefs.go
@@ -305,7 +305,7 @@ func (reg *VarTypeRegistry) cmdline(varname string, basicType *BasicType) {
func (reg *VarTypeRegistry) infralist(varname string, basicType *BasicType) {
reg.acllist(varname, basicType,
List,
- "*: set, append")
+ "*: set, append, use")
}
// compilerLanguages reads the available languages that are typically
@@ -1043,6 +1043,7 @@ func (reg *VarTypeRegistry) Init(src *Pkgsrc) {
reg.pkg("DYNAMIC_SITES_CMD", BtShellCommand)
reg.pkg("DYNAMIC_SITES_SCRIPT", BtPathname)
reg.sysbl3("ECHO", BtShellCommand)
+ reg.sysbl3("ECHO_BUILDLINK_MSG", BtShellCommand)
reg.sysbl3("ECHO_MSG", BtShellCommand)
reg.sysbl3("ECHO_N", BtShellCommand)
reg.pkg("EGDIR", BtPathname) // Not defined anywhere but used in many places like this.
@@ -1588,6 +1589,7 @@ func (reg *VarTypeRegistry) Init(src *Pkgsrc) {
reg.syslist("TOOLS_NOOP", BtTool)
reg.sys("TOOLS_PATH.*", BtPathname)
reg.sysload("TOOLS_PLATFORM.*", BtShellCommand)
+ reg.sysload("TOOLS_SHELL", BtShellCommand)
reg.syslist("TOUCH_FLAGS", BtShellWord)
reg.pkglist("UAC_REQD_EXECS", BtPrefixPathname)
reg.pkglistbl3("UNLIMIT_RESOURCES",
@@ -1675,7 +1677,7 @@ func (reg *VarTypeRegistry) Init(src *Pkgsrc) {
reg.infralist("_SYS_VARS.*", BtVariableName)
reg.infralist("_DEF_VARS.*", BtVariableName)
reg.infralist("_USE_VARS.*", BtVariableName)
- reg.infralist("_IGN_VARS.*", BtVariableName)
+ reg.infralist("_IGN_VARS.*", BtVariableNamePattern)
reg.infralist("_SORTED_VARS.*", BtVariableNamePattern)
reg.infralist("_LISTED_VARS.*", BtVariableNamePattern)
}
diff --git a/pkgtools/pkglint/files/vardefs_test.go b/pkgtools/pkglint/files/vardefs_test.go
index eaf2a31b073..55f62921fc7 100644
--- a/pkgtools/pkglint/files/vardefs_test.go
+++ b/pkgtools/pkglint/files/vardefs_test.go
@@ -185,7 +185,7 @@ func (s *Suite) Test_VarTypeRegistry_Init__LP64PLATFORMS(c *check.C) {
G.Check(pkg)
- // No warning about a missing :Q operator.
+ // No warning about a missing :Q modifier.
t.CheckOutputEmpty()
}
diff --git a/pkgtools/pkglint/files/vargroups.go b/pkgtools/pkglint/files/vargroups.go
index 8fc17242d0b..7734daa35a5 100644
--- a/pkgtools/pkglint/files/vargroups.go
+++ b/pkgtools/pkglint/files/vargroups.go
@@ -1,6 +1,9 @@
package pkglint
-import "strings"
+import (
+ "path"
+ "strings"
+)
// VargroupsChecker checks that the _VARGROUPS section of an infrastructure
// file matches the rest of the file content:
@@ -147,7 +150,7 @@ func (ck *VargroupsChecker) checkDef(mkline *MkLine) {
varname := mkline.Varname()
delete(ck.undefinedVars, varname)
- if ck.ignoreDef(varname) {
+ if ck.ignore(varname) {
return
}
@@ -156,19 +159,6 @@ func (ck *VargroupsChecker) checkDef(mkline *MkLine) {
}
}
-func (ck *VargroupsChecker) ignoreDef(varname string) bool {
- switch {
- case containsVarRef(varname),
- ck.registered[varname] != nil,
- hasSuffix(varname, "_MK"),
- ck.isVargroups(varname),
- varname == "PKG_FAIL_REASON":
- return true
- }
-
- return false
-}
-
func (ck *VargroupsChecker) checkUse(mkline *MkLine) {
mkline.ForEachUsed(func(varUse *MkVarUse, _ VucTime) { ck.checkUseVar(mkline, varUse) })
}
@@ -177,7 +167,7 @@ func (ck *VargroupsChecker) checkUseVar(mkline *MkLine, varUse *MkVarUse) {
varname := varUse.varname
delete(ck.unusedVars, varname)
- if ck.ignoreUse(varname) {
+ if ck.ignore(varname) {
return
}
@@ -186,30 +176,36 @@ func (ck *VargroupsChecker) checkUseVar(mkline *MkLine, varUse *MkVarUse) {
}
}
-func (ck *VargroupsChecker) ignoreUse(varname string) bool {
+func (ck *VargroupsChecker) ignore(varname string) bool {
switch {
case containsVarRef(varname),
hasSuffix(varname, "_MK"),
- varname == ".TARGET",
- varname == "TOOLS_SHELL",
- varname == "TOUCH_FLAGS",
- varname == strings.ToLower(varname),
+ ck.registered[varname] != nil,
G.Pkgsrc.Tools.ExistsVar(varname),
+ ck.isVargroups(varname),
+ varname == strings.ToLower(varname),
ck.isShellCommand(varname),
- ck.registered[varname] != nil,
- ck.isVargroups(varname):
+ varname == ".TARGET",
+ varname == "BUILD_DEFS",
+ varname == "BUILD_DEFS_EFFECTS",
+ varname == "PKG_FAIL_REASON",
+ varname == "TOUCH_FLAGS":
return true
}
+ for pattern := range ck.ignVars {
+ matched, err := path.Match(pattern, varname)
+ if err == nil && matched {
+ return true
+ }
+ }
+
return false
}
func (ck *VargroupsChecker) isShellCommand(varname string) bool {
vartype := G.Pkgsrc.VariableType(ck.mklines, varname)
- if vartype != nil && vartype.basicType == BtShellCommand {
- return true
- }
- return false
+ return vartype != nil && vartype.basicType == BtShellCommand
}
func (ck *VargroupsChecker) isVargroups(varname string) bool {
diff --git a/pkgtools/pkglint/files/vargroups_test.go b/pkgtools/pkglint/files/vargroups_test.go
index 6978fe3d973..a86d52ee04b 100644
--- a/pkgtools/pkglint/files/vargroups_test.go
+++ b/pkgtools/pkglint/files/vargroups_test.go
@@ -61,15 +61,16 @@ func (s *Suite) Test_VargroupsChecker__variable_reference(c *check.C) {
"",
"_VARGROUPS+=\t\tgroup",
"_USER_VARS.group=\t${:Uparam:@param@VAR.${param}@}",
+ "_LISTED_VARS.group=\t${:Uparam:@param@VAR.${param}@}",
"",
"VAR.param=\tvalue")
mklines.Check()
t.CheckOutputLines(
- "WARN: Makefile:6: VAR.param is defined but not used.",
+ "WARN: Makefile:7: VAR.param is defined but not used.",
// FIXME: Hmmm, that's going to be complicated to get right.
- "WARN: Makefile:6: Variable VAR.param is defined but not mentioned in the _VARGROUPS section.")
+ "WARN: Makefile:7: Variable VAR.param is defined but not mentioned in the _VARGROUPS section.")
}
func (s *Suite) Test_VargroupsChecker__public_underscore(c *check.C) {
@@ -115,6 +116,49 @@ func (s *Suite) Test_VargroupsChecker__declared_but_undefined(c *check.C) {
"WARN: Makefile:8: The variable UNDEFINED is not actually defined in this file.")
}
+func (s *Suite) Test_VargroupsChecker__defined_but_undeclared(c *check.C) {
+ t := s.Init(c)
+
+ t.SetUpVartypes()
+ mklines := t.NewMkLines("Makefile",
+ MkCvsID,
+ "",
+ ".if !defined(MAKEFILE_MK)",
+ "MAKEFILE_MK=",
+ "",
+ "_VARGROUPS+=\t\tgroup",
+ "",
+ "PKG_FAIL_REASON+=\tReason",
+ "",
+ ".endif")
+
+ mklines.Check()
+
+ t.CheckOutputEmpty()
+}
+
+func (s *Suite) Test_VargroupsChecker__used_but_undeclared(c *check.C) {
+ t := s.Init(c)
+
+ t.SetUpVartypes()
+ t.SetUpTool("touch", "TOUCH", AtRunTime)
+ mklines := t.NewMkLines("Makefile",
+ MkCvsID,
+ "",
+ "_VARGROUPS+=\tgroup",
+ "",
+ "pre-configure:",
+ "\t${TOOLS_SHELL} -c ':'",
+ "\t${TOUCH} ${TOUCH_FLAGS} ${.TARGET}",
+ "\t: ${PKGNAME}")
+
+ mklines.Check()
+
+ t.CheckOutputLines(
+ "WARN: Makefile:8: Variable PKGNAME is used " +
+ "but not mentioned in the _VARGROUPS section.")
+}
+
func (s *Suite) Test_VargroupsChecker__declared_but_unused(c *check.C) {
t := s.Init(c)
@@ -140,3 +184,48 @@ func (s *Suite) Test_VargroupsChecker__declared_but_unused(c *check.C) {
"WARN: Makefile:11: Variable UNDECLARED is used but not mentioned in the _VARGROUPS section.",
"WARN: Makefile:8: The variable UNUSED is not actually used in this file.")
}
+
+func (s *Suite) Test_VargroupsChecker__used_in_BUILD_DEFS(c *check.C) {
+ t := s.Init(c)
+
+ t.SetUpVartypes()
+
+ mklines := t.NewMkLines("Makefile",
+ MkCvsID,
+ "",
+ "# USER_VAR",
+ "#\tDocumentation.",
+ "#\tDocumentation.",
+ "",
+ "_VARGROUPS+=\t\tgroup",
+ "_USER_VARS.group=\tUSER_VAR",
+ "",
+ ".if ${USER_VAR:U}",
+ ".endif",
+ "BUILD_DEFS+=\t${_USER_VARS.group}")
+
+ mklines.Check()
+
+ // No warning about _USER_VARS.group being a write-only variable.
+ t.CheckOutputEmpty()
+}
+
+func (s *Suite) Test_VargroupsChecker__ignore(c *check.C) {
+ t := s.Init(c)
+
+ t.SetUpVartypes()
+
+ mklines := t.NewMkLines("Makefile",
+ MkCvsID,
+ "",
+ "_VARGROUPS+=\t\tgroup",
+ "_IGN_VARS.group=\tPREFER_*",
+ "",
+ ".if ${PREFER_PKGSRC:U} || ${WRKOBJDIR:U}",
+ ".endif")
+
+ mklines.Check()
+
+ t.CheckOutputLines(
+ "WARN: Makefile:6: Variable WRKOBJDIR is used but not mentioned in the _VARGROUPS section.")
+}