|
|
a3e2b5 |
From 1dd326b6dd0a23d1a9ee1c567962c6d5d4ef03ca Mon Sep 17 00:00:00 2001
|
|
|
a3e2b5 |
From: Jan Synacek <jsynacek@redhat.com>
|
|
|
a3e2b5 |
Date: Wed, 30 Jan 2019 12:22:41 +0100
|
|
|
a3e2b5 |
Subject: [PATCH] rule-syntax-check: allow PROGRAM as an assignment
|
|
|
a3e2b5 |
|
|
|
a3e2b5 |
(cherry picked from commit ed2dc503da57b0110819563e0d1c85d023435e07)
|
|
|
a3e2b5 |
---
|
|
|
a3e2b5 |
test/rule-syntax-check.py | 5 ++++-
|
|
|
a3e2b5 |
1 file changed, 4 insertions(+), 1 deletion(-)
|
|
|
a3e2b5 |
|
|
|
a3e2b5 |
diff --git a/test/rule-syntax-check.py b/test/rule-syntax-check.py
|
|
|
a3e2b5 |
index 706d93632e..c7c0a1a656 100755
|
|
|
a3e2b5 |
--- a/test/rule-syntax-check.py
|
|
|
a3e2b5 |
+++ b/test/rule-syntax-check.py
|
|
|
a3e2b5 |
@@ -17,6 +17,8 @@ if not rules_files:
|
|
|
a3e2b5 |
|
|
|
a3e2b5 |
quoted_string_re = r'"(?:[^\\"]|\\.)*"'
|
|
|
a3e2b5 |
no_args_tests = re.compile(r'(ACTION|DEVPATH|KERNELS?|NAME|SYMLINK|SUBSYSTEMS?|DRIVERS?|TAG|PROGRAM|RESULT|TEST)\s*(?:=|!)=\s*' + quoted_string_re + '$')
|
|
|
a3e2b5 |
+# PROGRAM can also be specified as an assignment.
|
|
|
a3e2b5 |
+program_assign = re.compile(r'PROGRAM\s*=\s*' + quoted_string_re + '$')
|
|
|
a3e2b5 |
args_tests = re.compile(r'(ATTRS?|ENV|TEST){([a-zA-Z0-9/_.*%-]+)}\s*(?:=|!)=\s*' + quoted_string_re + '$')
|
|
|
a3e2b5 |
no_args_assign = re.compile(r'(NAME|SYMLINK|OWNER|GROUP|MODE|TAG|RUN|LABEL|GOTO|WAIT_FOR|OPTIONS|IMPORT)\s*(?:\+=|:=|=)\s*' + quoted_string_re + '$')
|
|
|
a3e2b5 |
args_assign = re.compile(r'(ATTR|ENV|IMPORT|RUN){([a-zA-Z0-9/_.*%-]+)}\s*(=|\+=)\s*' + quoted_string_re + '$')
|
|
|
a3e2b5 |
@@ -51,7 +53,8 @@ for path in rules_files:
|
|
|
a3e2b5 |
for clause_match in comma_separated_group_re.finditer(line):
|
|
|
a3e2b5 |
clause = clause_match.group().strip()
|
|
|
a3e2b5 |
if not (no_args_tests.match(clause) or args_tests.match(clause) or
|
|
|
a3e2b5 |
- no_args_assign.match(clause) or args_assign.match(clause)):
|
|
|
a3e2b5 |
+ no_args_assign.match(clause) or args_assign.match(clause) or
|
|
|
a3e2b5 |
+ program_assign.match(clause)):
|
|
|
a3e2b5 |
|
|
|
a3e2b5 |
print('Invalid line {}:{}: {}'.format(path, lineno, line))
|
|
|
a3e2b5 |
print(' clause:', clause)
|