Waivers Tab
The waivers tab can be used to add, remove, edit and inspect waivers and pre-waivers.
There are three types of waivers:
Manually defined waivers
Manually defined pre-waivers
Inline waivers (collected from code)
Waivers are used to change the status of the failures or remove the failures that are matched. Pre-waivers are used to exclude files from linting, therefore reducing the total linting time.
data:image/s3,"s3://crabby-images/98ba0/98ba0865424cbac152c2abd982866ebf4c1de0a1" alt="../../_images/vlogdt-uvm-compliance-waivers-tab.png"
Waivers Editor
Manually defined waivers can be created using New… button from the Waivers tab. The Lint Waivers Editor dialog offers an easy way to configure a waiver. The parameters that can be configured are:
File: the file where the waiver will be saved (from the waivers include tree)
Name: an unique name for the waiver
Description: a short explanation for the waiver
Status: the status that will be applied to the matched failures
Apply on: the scope of the waiver (it applies on matched or non matched failures)
Paths: the file paths on which this waiver applies to
Check Names: the name of the checks this waiver applies to
Message Patterns: the regular expression this waiver must match (Perl-like or simple regular expression)
Line Ranges: the line, or line ranges (StartLine:EndLine) this waiver must match
Elements: the elements used to obtain a set of files that will be waived; files containing only such elements and all the files included in the scope of those elements will be waived
The status option can be set to:
DISABLED: failures are removed
ERROR: failures are reported as errors
WARNING: failures are reported as warnings
INFO: failures are reported as info
The waiver will match a failure if all defined parameters match the failure properties (the check that generated the failure, line, file, or message). If a parameter is empty (not defined) it will match any value.
data:image/s3,"s3://crabby-images/fa029/fa02937308c1a7ecc68e4db99c46bc61c8a03174" alt="../../_images/waiver-dialog-showcase.png"
Pre-Waivers Editor
Manually defined pre-waivers can be created using New… button from the Waivers tab and setting the Waiver Type to PRE-WAIVER. The parameters that can be configured are:
File: the file where the pre-waiver will be saved (from the waivers include tree)
Name: an unique name for the pre-waiver
Description: a short explanation for the pre-waiver
Apply on: the scope of the pre-waiver (it applies on matched or non matched paths)
Paths: the paths on which this waiver applies to
Check Names: the name of the checks this pre-waiver applies to
Elements: the elements used to obtain a set of files that will be pre-waived; files containing only such elements and all the files included in the scope of those elements will be pre-waived
data:image/s3,"s3://crabby-images/9b49b/9b49b52db23c7b8475d0d04af28e4b60c332e11a" alt="../../_images/pre-waiver-dialog-showcase.png"
Inline Waivers
Inline Lint Waivers can be inserted in code as comments with the following syntax:
// @DVT_LINTER_WAIVER_START ["NAME"] STATUS [CHECK_1, CHECK_2]
code line
...
code line
// @DVT_LINTER_WAIVER_END ["NAME"]
Where:
NAME: is the waiver unique name (optional) and must be enclosed within quotation marks
STATUS: is the status applied to the hits (mandatory) and must be one of the valid status values (DISABLE, ERROR, WARNING, INFO)
CHECK_1, CHECK_2: is a list of check names (optional) this waiver applies to, if it’s not defined the waiver applies to all checks
data:image/s3,"s3://crabby-images/af23c/af23cc63f149ca73a16f76aa692406458e8ac0ed" alt="../../_images/vlogdt-uvm-compliance-code-waiver.png"
data:image/s3,"s3://crabby-images/32919/3291959b4be2e491ed6f3b65e214a057144695f2" alt="../../_images/code-waiver-dialog-showcase.png"