diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 1d0d653e7c..6dd09ba7e3 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -183,6 +183,7 @@ jobs: key: ${{ steps.os.outputs.image }}-build-${{ env.cache-name }}-${{ env.CPPCHECK_VER }} - run: sudo scripts/install_cppcheck_dependencies_with_apt.sh $CPPCHECK_VER - run: ./bootstrap + - run: ./configure - run: scripts/install_cppcheck.sh $CPPCHECK_REPO $CPPCHECK_VER - run: scripts/run_cppcheck.sh -v $CPPCHECK_VER diff --git a/fontutils/mkfv1.c b/fontutils/mkfv1.c index a0cdc337fb..9ed16a4b3b 100644 --- a/fontutils/mkfv1.c +++ b/fontutils/mkfv1.c @@ -37,11 +37,9 @@ static const struct const char *err_msg; } ft_errors[] = #include - -#if 0 - /* These lines fix problems with astyle formatting following the ft_errors - * definition */ -} +#ifdef __cppcheck__ + // avoid syntaxError by providing the array contents + {}; #endif diff --git a/scripts/install_cppcheck_dependencies_with_apt.sh b/scripts/install_cppcheck_dependencies_with_apt.sh index 95887e78ba..c5a055dd78 100755 --- a/scripts/install_cppcheck_dependencies_with_apt.sh +++ b/scripts/install_cppcheck_dependencies_with_apt.sh @@ -1,7 +1,8 @@ #!/bin/sh set -eufx -PACKAGES="libz3-dev z3" +# these are the packages necessary to run ./configure so config_ac.h is generated +PACKAGES="libpam0g-dev libxfixes-dev libxrandr-dev nasm" usage() { @@ -15,6 +16,8 @@ if [ $# -ne 1 ]; then fi CPPCHECK_VER="$1" +apt-get update + case "$CPPCHECK_VER" in 1.*) # no dependencies @@ -23,7 +26,8 @@ case "$CPPCHECK_VER" in # Cppcheck 2.8 removed the dependency on z3 ;; 2.*) - apt-get update - apt-get -yq --no-install-suggests --no-install-recommends install $PACKAGES + PACKAGES="$PACKAGES libz3-dev z3" ;; esac + +apt-get -yq --no-install-suggests --no-install-recommends install $PACKAGES diff --git a/scripts/run_cppcheck.sh b/scripts/run_cppcheck.sh index 545af41b2e..7d817a50f7 100755 --- a/scripts/run_cppcheck.sh +++ b/scripts/run_cppcheck.sh @@ -43,7 +43,10 @@ fi # Supply default flags passed to cppcheck if necessary if [ -z "$CPPCHECK_FLAGS" ]; then CPPCHECK_FLAGS="--quiet --force --std=c11 --std=c++11 --inline-suppr \ - --enable=warning --error-exitcode=1 -i third_party" + --enable=warning --error-exitcode=1 -i third_party \ + --suppress=uninitMemberVar:ulalaca/ulalaca.cpp \ + --suppress=shiftTooManyBits:libxrdp/xrdp_mppc_enc.c \ + -I . -I common" fi CPPCHECK_FLAGS="$CPPCHECK_FLAGS -D__cppcheck__" diff --git a/sesman/chansrv/clipboard.c b/sesman/chansrv/clipboard.c index b01990bd15..8117478a62 100644 --- a/sesman/chansrv/clipboard.c +++ b/sesman/chansrv/clipboard.c @@ -2572,14 +2572,12 @@ clipboard_event_property_notify(XEvent *xevent) format_in_bytes = FORMAT_TO_BYTES(actual_format_return); new_data_len = nitems_returned * format_in_bytes; cptr = (char *) g_malloc(g_clip_s2c.total_bytes + new_data_len, 0); - g_memcpy(cptr, g_clip_s2c.data, g_clip_s2c.total_bytes); - g_free(g_clip_s2c.data); - if (cptr == NULL) { + /* cannot add any more data */ + g_free(g_clip_s2c.data); g_clip_s2c.data = 0; - /* cannot add any more data */ if (data != 0) { XFree(data); @@ -2588,14 +2586,15 @@ clipboard_event_property_notify(XEvent *xevent) XDeleteProperty(g_display, g_wnd, g_clip_s2c.property); return 0; } + g_memcpy(cptr, g_clip_s2c.data, g_clip_s2c.total_bytes); + g_free(g_clip_s2c.data); LOG_DEVEL(LOG_LEVEL_DEBUG, "clipboard_event_property_notify: new_data_len %d", new_data_len); g_clip_s2c.data = cptr; - g_memcpy(g_clip_s2c.data + g_clip_s2c.total_bytes, data, new_data_len); - g_clip_s2c.total_bytes += new_data_len; - if (data) { + g_memcpy(g_clip_s2c.data + g_clip_s2c.total_bytes, data, new_data_len); + g_clip_s2c.total_bytes += new_data_len; XFree(data); }