Compare commits

...

1 Commits

Author SHA1 Message Date
Stefan Wallentowitz
f10b2919d7 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.)
2020-06-21 08:14:46 +02:00

View File

@ -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) {