forked from pool/cppcheck
Marcus Meissner
f08159343a
- Update to version 2.3 Improved C++ parser: * types * wrong operands in ast * better simplification of templates Improved clang import, various fixes. Improved value flow analysis Fixed false positives Improved configuration in library files * boost.cfg * googletest.cfg * qt.cfg * windows.cfg * wxwidgets.cfg Added several Misra rules: * 6.1 * 6.2 * 7.2 * 7.4 * 9.2 * 10.2 * 15.4 Added platforms: * elbrus e1c+ * pic * pic8 * mips - Update to version 2.2 New checks: * incorrect usage of mutexes and lock guards * Dereference end iterator * Iterating a known empty container * outOfBounds check for iterators to containers Removed 'operator=' check that ensures reference to self is returned. That is not about safety. Improved parser * various ast fixes Clang parser * The Clang import feature in Cppcheck should be considered to be experimental for now. There are problems. Improved bug hunting * variable constraints * handling of multidimension arrays * function calls, execute functions that are in same TU * improved handling of containers * several improvements for uninitialized variables check * improved analysis of for loops * added a hash value for warnings that can be used for suppressions Improved data flow * one more heuristic for ternary operators * improved data flow for containers CLI: * Fixed some addon execution problems when there are spaces etc GUI: * Fix handling of tags * Exclude files cppcheck-htmlreport: * several result files can be combined into 1 output Suppressions: * comments can be added at end of suppression in suppressions file OBS-URL: https://build.opensuse.org/request/show/855374 OBS-URL: https://build.opensuse.org/package/show/devel:tools/cppcheck?expand=0&rev=72
121 lines
3.6 KiB
RPMSpec
121 lines
3.6 KiB
RPMSpec
#
|
|
# spec file for package cppcheck
|
|
#
|
|
# Copyright (c) 2020 SUSE LLC
|
|
#
|
|
# All modifications and additions to the file contributed by third parties
|
|
# remain the property of their copyright owners, unless otherwise agreed
|
|
# upon. The license for this file, and modifications and additions to the
|
|
# file, is the same license as for the pristine package itself (unless the
|
|
# license for the pristine package is not an Open Source License, in which
|
|
# case the license is the MIT License). An "Open Source License" is a
|
|
# license that conforms to the Open Source Definition (Version 1.9)
|
|
# published by the Open Source Initiative.
|
|
|
|
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
|
#
|
|
|
|
|
|
Name: cppcheck
|
|
Version: 2.3
|
|
Release: 0
|
|
Summary: A tool for static C/C++ code analysis
|
|
License: GPL-3.0-or-later
|
|
URL: http://cppcheck.sourceforge.net/
|
|
Source: https://downloads.sourceforge.net/cppcheck/cppcheck-%{version}.tar.bz2
|
|
BuildRequires: cmake
|
|
BuildRequires: docbook-xsl-stylesheets
|
|
BuildRequires: gcc-c++
|
|
BuildRequires: libqt5-linguist-devel
|
|
BuildRequires: pkgconfig
|
|
BuildRequires: python3-base
|
|
BuildRequires: xsltproc
|
|
BuildRequires: z3-devel
|
|
BuildRequires: pkgconfig(Qt5Core)
|
|
BuildRequires: pkgconfig(Qt5Gui)
|
|
BuildRequires: pkgconfig(Qt5Help)
|
|
BuildRequires: pkgconfig(Qt5PrintSupport)
|
|
BuildRequires: pkgconfig(Qt5Widgets)
|
|
BuildRequires: pkgconfig(libpcre)
|
|
Requires: python3-Pygments
|
|
|
|
%description
|
|
This program tries to detect bugs that your C/C++ compiler don't see. Cppcheck
|
|
is versatile. You can check non-standard code that includes various compiler
|
|
extensions, inline assembly code, etc. Checking covers for example these
|
|
errors:
|
|
|
|
* Out of bounds
|
|
* Uninitialized member variable 'classname::varname'
|
|
* Using 'memfunc' on class
|
|
* Using 'memfunc' on struct that contains a 'std::classname'
|
|
* Class Base which is inherited by class Derived does not have a virtual
|
|
destructor
|
|
* Memory leak: varname
|
|
* Resource leak: varname
|
|
* Deallocating a deallocated pointer: varname
|
|
* Using 'varname' after it is deallocated / released
|
|
* Invalid radix in call to strtol or strtoul. Must be 0 or 2-36
|
|
* Overlapping data buffer varname
|
|
* Unsigned division. The result will be wrong.
|
|
* Unusual pointer arithmetic
|
|
|
|
%package gui
|
|
Summary: A tool for static C/C++ code analysis
|
|
Requires: cppcheck
|
|
|
|
%description gui
|
|
|
|
This is the gui for Cppcheck, a program to detect bugs that your C/C++ compiler
|
|
doesn't see.
|
|
|
|
%prep
|
|
%autosetup
|
|
|
|
%build
|
|
%cmake \
|
|
-DCMAKE_CXX_FLAGS="-DNDEBUG %{optflags}" \
|
|
-DFILESDIR="%{_datadir}/%{name}" \
|
|
-DBUILD_GUI=ON \
|
|
-DBUILD_TESTS=ON \
|
|
-DHAVE_RULES=yes \
|
|
-DUSE_Z3=yes
|
|
%cmake_build
|
|
|
|
# does not work with CMake, directly call provided Makefile from source directory
|
|
cd ..
|
|
%make_build man \
|
|
DB2MAN=%{_datadir}/xml/docbook/stylesheet/nwalsh/current/manpages/docbook.xsl
|
|
|
|
# use python3 as interpreter
|
|
sed -i "s|env python|python3|g" htmlreport/cppcheck-htmlreport
|
|
|
|
%check
|
|
export CXXFLAGS="%{optflags}"
|
|
%ctest
|
|
|
|
%install
|
|
install -Dpm 0755 build/bin/cppcheck \
|
|
%{buildroot}%{_bindir}/cppcheck
|
|
install -Dpm 0755 htmlreport/cppcheck-htmlreport \
|
|
%{buildroot}%{_bindir}/cppcheck-htmlreport
|
|
install -Dpm 0755 build/bin/cppcheck-gui \
|
|
%{buildroot}%{_bindir}/cppcheck-gui
|
|
install -Dpm 0644 cppcheck.1 \
|
|
%{buildroot}%{_mandir}/man1/cppcheck.1
|
|
install -d %{buildroot}%{_datadir}/%{name}/cfg
|
|
install -pm 0644 cfg/*.cfg %{buildroot}%{_datadir}/%{name}/cfg
|
|
|
|
%files
|
|
%doc AUTHORS
|
|
%license COPYING
|
|
%{_bindir}/cppcheck
|
|
%{_bindir}/cppcheck-htmlreport
|
|
%{_datadir}/%{name}/
|
|
%{_mandir}/man1/cppcheck.1%{?ext_man}
|
|
|
|
%files gui
|
|
%{_bindir}/cppcheck-gui
|
|
|
|
%changelog
|