C++: Simplify a bit and remove two noopts that don't seem to make a difference.

This commit is contained in:
Geoffrey White 2021-06-29 18:16:29 +01:00
Родитель 5bf7e453e6
Коммит dcc7a6360f
1 изменённых файлов: 2 добавлений и 16 удалений

Просмотреть файл

@ -19,17 +19,10 @@ import cpp
* Holds if the argument corresponding to the `pos` conversion specifier
* of `ffc` is expected to have type `expected`.
*/
pragma[noopt]
private predicate formattingFunctionCallExpectedType(
FormattingFunctionCall ffc, int pos, Type expected
) {
exists(FormattingFunction f, int i, FormatLiteral fl |
ffc instanceof FormattingFunctionCall and
ffc.getTarget() = f and
f.getFormatParameterIndex() = i and
ffc.getArgument(i) = fl and
fl.getConversionType(pos) = expected
)
ffc.getFormat().(FormatLiteral).getConversionType(pos) = expected
}
/**
@ -37,17 +30,10 @@ private predicate formattingFunctionCallExpectedType(
* of `ffc` could alternatively have type `expected`, for example on a different
* platform.
*/
pragma[noopt]
private predicate formattingFunctionCallAlternateType(
FormattingFunctionCall ffc, int pos, Type expected
) {
exists(FormattingFunction f, int i, FormatLiteral fl |
ffc instanceof FormattingFunctionCall and
ffc.getTarget() = f and
f.getFormatParameterIndex() = i and
ffc.getArgument(i) = fl and
fl.getConversionTypeAlternate(pos) = expected
)
ffc.getFormat().(FormatLiteral).getConversionTypeAlternate(pos) = expected
}
/**