forked from github/verilator
Add WIDTHEXACT rule
There are many cases where users perceive WIDTH warnings too pedantic and the sheer amount often leads to users using -Wno-WIDTH, thereby hiding those that are more critical. This adds a new rule WIDTHEXACT that is a style lint and thus not enabled by default. It will contain WIDTH warnings that are strict in expecting equal sizes, which is okay with the LRM, but can be a mistake. WIDTH will probably contain mostly warnings that are even not good with the LRM semantics (too large assignment, mismatch in comparison, etc.)
This commit is contained in:
parent
23e4a0f784
commit
f10b2919d7
@ -122,6 +122,7 @@ public:
|
|||||||
VARHIDDEN, // Hiding variable
|
VARHIDDEN, // Hiding variable
|
||||||
WIDTH, // Width mismatch
|
WIDTH, // Width mismatch
|
||||||
WIDTHCONCAT, // Unsized numbers/parameters in concatenations
|
WIDTHCONCAT, // Unsized numbers/parameters in concatenations
|
||||||
|
WIDTHEXACT, // Expect exact widths
|
||||||
_ENUM_MAX
|
_ENUM_MAX
|
||||||
// ***Add new elements below also***
|
// ***Add new elements below also***
|
||||||
};
|
};
|
||||||
@ -165,7 +166,7 @@ public:
|
|||||||
"UNDRIVEN", "UNOPT", "UNOPTFLAT", "UNOPTTHREADS",
|
"UNDRIVEN", "UNOPT", "UNOPTFLAT", "UNOPTTHREADS",
|
||||||
"UNPACKED", "UNSIGNED", "UNUSED",
|
"UNPACKED", "UNSIGNED", "UNUSED",
|
||||||
"USERERROR", "USERFATAL", "USERINFO", "USERWARN",
|
"USERERROR", "USERFATAL", "USERINFO", "USERWARN",
|
||||||
"VARHIDDEN", "WIDTH", "WIDTHCONCAT",
|
"VARHIDDEN", "WIDTH", "WIDTHCONCAT", "WIDTHEXACT",
|
||||||
" MAX"
|
" MAX"
|
||||||
};
|
};
|
||||||
// clang-format on
|
// clang-format on
|
||||||
@ -200,7 +201,8 @@ public:
|
|||||||
return (m_e == ASSIGNDLY // More than style, but for backward compatibility
|
return (m_e == ASSIGNDLY // More than style, but for backward compatibility
|
||||||
|| m_e == BLKSEQ || m_e == DEFPARAM || m_e == DECLFILENAME || m_e == IMPORTSTAR
|
|| m_e == BLKSEQ || m_e == DEFPARAM || m_e == DECLFILENAME || m_e == IMPORTSTAR
|
||||||
|| m_e == INCABSPATH || m_e == PINCONNECTEMPTY || m_e == PINNOCONNECT
|
|| m_e == INCABSPATH || m_e == PINCONNECTEMPTY || m_e == PINNOCONNECT
|
||||||
|| m_e == SYNCASYNCNET || m_e == UNDRIVEN || m_e == UNUSED || m_e == VARHIDDEN);
|
|| m_e == SYNCASYNCNET || m_e == UNDRIVEN || m_e == UNUSED || m_e == VARHIDDEN
|
||||||
|
|| m_e == WIDTHEXACT);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
inline bool operator==(const V3ErrorCode& lhs, const V3ErrorCode& rhs) {
|
inline bool operator==(const V3ErrorCode& lhs, const V3ErrorCode& rhs) {
|
||||||
|
Loading…
Reference in New Issue
Block a user