com.sonar.cpp.plugin.SonarLintSensor.execute throws IllegalStateException

  • Operating system: Windows 10
  • SonarLint plugin version: 3.5.4
  • Is connected mode used: no
  • We are using the ARM GNU toolchain available at developer.arm.com

SonarLint analysis works with this compiler when running VSCode in Linux, but in Windows we receive IllegalStateException.

arm-none-eabi-g++ is in the system PATH, and the compile command works when executing from the command prompt. I expect to see 1 issue found for “Argument of “printf” should be a format string (cpp:S5281)”

Logs, configuration, and reproducer attached below.

SonarLint logs:

[Debug - 14:28:54.176] Queuing analysis of file 'file:///c:/projects/sonar-test/main.cpp' (version 94)
The 'file:///c:/projects/sonar-test/main.cpp' file is not in a git repo, consider as not ignored
[Debug - 14:28:54.177] Cached SCM ignore status for file 'file:///c:/projects/sonar-test/main.cpp': Not ignored
[Info  - 14:28:54.177] Analyzing file 'file:///c:/projects/sonar-test/main.cpp'...
[Debug - 14:28:54.178] Analysis triggered with configuration:
[
  baseDir: c:\projects\sonar-test
  extraProperties: {sonar.cfamily.reproducer=C:\projects\sonar-test\main.cpp, sonar.cfamily.compile-commands=c:\projects\sonar-test\compile_commands.json}
  moduleKey: file:///c:/projects/sonar-test
  excludedRules: []
  includedRules: [cpp:S2260]
  ruleParameters: {}
  inputFiles: [
    file:///c:/projects/sonar-test/main.cpp (UTF-8) [cpp]
  ]
]

[Debug - 14:28:54.191] Start analysis
[Info  - 14:28:54.194] Index files
[Debug - 14:28:54.196] Language of file 'file:///c:/projects/sonar-test/main.cpp' is set to 'C++'
[Info  - 14:28:54.196] 1 file indexed
[Debug - 14:28:54.207] 'JavaSensor' skipped because there is no related files in the current project
[Debug - 14:28:54.207] Execute Sensor: CFamily
[Info  - 14:28:54.208] sonar.cfamily.reproducer=C:\projects\sonar-test\main.cpp
[Info  - 14:28:54.213] Parsing compilation database c:\projects\sonar-test\compile_commands.json
[Debug - 14:28:54.214] Time to parse Compilation Database: 2ms
[Debug - 14:28:54.214] Probing compiler: [arm-none-eabi-g++, -x, c++, --std, gnu++14, -mcpu=cortex-m4, -funsigned-char, -fno-exceptions, -fno-rtti, -mfloat-abi=softfp, -mfpu=fpv4-sp-d16, -mthumb, -v, -dM, -E, -]
[Debug - 14:28:54.299] stdout:
#define __DBL_MIN_EXP__ (-1021)
#define __HQ_FBIT__ 15
#define __cpp_attributes 200809
#define __UINT_LEAST16_MAX__ 0xffff
#define __ARM_SIZEOF_WCHAR_T 4
#define __ATOMIC_ACQUIRE 2
#define __SFRACT_IBIT__ 0
#define __FLT_MIN__ 1.1754943508222875e-38F
#define __GCC_IEC_559_COMPLEX 0
#define __cpp_aggregate_nsdmi 201304
#define __UFRACT_MAX__ 0XFFFFP-16UR
#define __UINT_LEAST8_TYPE__ unsigned char
#define __DQ_FBIT__ 63
#define __INTMAX_C(c) c ## LL
#define __ARM_FEATURE_SAT 1
#define __ULFRACT_FBIT__ 32
#define __SACCUM_EPSILON__ 0x1P-7HK
#define __CHAR_BIT__ 8
#define __USQ_IBIT__ 0
#define __UINT8_MAX__ 0xff
#define __ACCUM_FBIT__ 15
#define __WINT_MAX__ 0xffffffffU
#define __cpp_static_assert 200410
#define __USFRACT_FBIT__ 8
#define __ORDER_LITTLE_ENDIAN__ 1234
#define __SIZE_MAX__ 0xffffffffU
#define __WCHAR_MAX__ 0xffffffffU
#define __LACCUM_IBIT__ 32
#define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
#define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
#define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
#define __DBL_DENORM_MIN__ double(4.9406564584124654e-324L)
#define __GCC_ATOMIC_CHAR_LOCK_FREE 2
#define __GCC_IEC_559 0
#define __FLT_EVAL_METHOD__ 0
#define __cpp_binary_literals 201304
#define __LLACCUM_MAX__ 0X7FFFFFFFFFFFFFFFP-31LLK
#define __GCC_ATOMIC_CHAR32_T_LOCK_FREE 2
#define __FRACT_FBIT__ 15
#define __cpp_variadic_templates 200704
#define __UINT_FAST64_MAX__ 0xffffffffffffffffULL
#define __SIG_ATOMIC_TYPE__ int
#define __UACCUM_FBIT__ 16
#define __DBL_MIN_10_EXP__ (-307)
#define __FINITE_MATH_ONLY__ 0
#define __ARMEL__ 1
#define __cpp_variable_templates 201304
#define __ARM_FEATURE_UNALIGNED 1
#define __LFRACT_IBIT__ 0
#define __GNUC_PATCHLEVEL__ 1
#define __LFRACT_MAX__ 0X7FFFFFFFP-31LR
#define __UINT_FAST8_MAX__ 0xffffffffU
#define __has_include(STR) __has_include__(STR)
#define __DEC64_MAX_EXP__ 385
#define __INT8_C(c) c
#define __UINT_LEAST64_MAX__ 0xffffffffffffffffULL
#define __SA_FBIT__ 15
#define __SHRT_MAX__ 0x7fff
#define __LDBL_MAX__ 1.7976931348623157e+308L
#define __ARM_FEATURE_IDIV 1
#define __FRACT_MAX__ 0X7FFFP-15R
#define __thumb2__ 1
#define __UFRACT_FBIT__ 16
#define __ARM_FP 4
#define __UFRACT_MIN__ 0.0UR
#define __UINT_LEAST8_MAX__ 0xff
#define __GCC_ATOMIC_BOOL_LOCK_FREE 2
#define __UINTMAX_TYPE__ long long unsigned int
#define __LLFRACT_EPSILON__ 0x1P-63LLR
#define __DEC32_EPSILON__ 1E-6DF
#define __CHAR_UNSIGNED__ 1
#define __UINT32_MAX__ 0xffffffffUL
#define __GXX_EXPERIMENTAL_CXX0X__ 1
#define __ULFRACT_MAX__ 0XFFFFFFFFP-32ULR
#define __TA_IBIT__ 64
#define __LDBL_MAX_EXP__ 1024
#define __WINT_MIN__ 0U
#define __ARM_ASM_SYNTAX_UNIFIED__ 1
#define __ULLFRACT_MIN__ 0.0ULLR
#define __SCHAR_MAX__ 0x7f
#define __WCHAR_MIN__ 0U
#define __INT64_C(c) c ## LL
#define __DBL_DIG__ 15
#define __GCC_ATOMIC_POINTER_LOCK_FREE 2
#define __LLACCUM_MIN__ (-0X1P31LLK-0X1P31LLK)
#define __SIZEOF_INT__ 4
#define __SIZEOF_POINTER__ 4
#define __GCC_ATOMIC_CHAR16_T_LOCK_FREE 2
#define __USACCUM_IBIT__ 8
#define __USER_LABEL_PREFIX__ 
#define __STDC_HOSTED__ 1
#define __LDBL_HAS_INFINITY__ 1
#define __LFRACT_MIN__ (-0.5LR-0.5LR)
#define __HA_IBIT__ 8
#define __TQ_IBIT__ 0
#define __FLT_EPSILON__ 1.1920928955078125e-7F
#define __APCS_32__ 1
#define __GXX_WEAK__ 1
#define __USFRACT_IBIT__ 0
#define __LDBL_MIN__ 2.2250738585072014e-308L
#define __FRACT_MIN__ (-0.5R-0.5R)
#define __DEC32_MAX__ 9.999999E96DF
#define __DA_IBIT__ 32
#define __ARM_SIZEOF_MINIMAL_ENUM 1
#define __INT32_MAX__ 0x7fffffffL
#define __UQQ_FBIT__ 8
#define __SIZEOF_LONG__ 4
#define __UACCUM_MAX__ 0XFFFFFFFFP-16UK
#define __UINT16_C(c) c
#define __DECIMAL_DIG__ 17
#define __LFRACT_EPSILON__ 0x1P-31LR
#define __ULFRACT_MIN__ 0.0ULR
#define __has_include_next(STR) __has_include_next__(STR)
#define __LDBL_HAS_QUIET_NAN__ 1
#define __ULACCUM_IBIT__ 32
#define __UACCUM_EPSILON__ 0x1P-16UK
#define __GNUC__ 6
#define __ULLACCUM_MAX__ 0XFFFFFFFFFFFFFFFFP-32ULLK
#define __cpp_delegating_constructors 200604
#define __HQ_IBIT__ 0
#define __FLT_HAS_DENORM__ 1
#define __SIZEOF_LONG_DOUBLE__ 8
#define __BIGGEST_ALIGNMENT__ 8
#define __STDC_UTF_16__ 1
#define __GNUC_STDC_INLINE__ 1
#define __DQ_IBIT__ 0
#define __DBL_MAX__ double(1.7976931348623157e+308L)
#define __ULFRACT_IBIT__ 0
#define __cpp_raw_strings 200710
#define __INT_FAST32_MAX__ 0x7fffffff
#define __DBL_HAS_INFINITY__ 1
#define __INT64_MAX__ 0x7fffffffffffffffLL
#define __ACCUM_IBIT__ 16
#define __DEC32_MIN_EXP__ (-94)
#define __THUMB_INTERWORK__ 1
#define __LACCUM_MAX__ 0X7FFFFFFFFFFFFFFFP-31LK
#define __INT_FAST16_TYPE__ int
#define __LDBL_HAS_DENORM__ 1
#define __ARM_FEATURE_LDREX 7
#define __cplusplus 201402L
#define __cpp_ref_qualifiers 200710
#define __DEC128_MAX__ 9.999999999999999999999999999999999E6144DL
#define __INT_LEAST32_MAX__ 0x7fffffffL
#define __ARM_PCS 1
#define __DEC32_MIN__ 1E-95DF
#define __ACCUM_MAX__ 0X7FFFFFFFP-15K
#define __DEPRECATED 1
#define __cpp_rvalue_references 200610
#define __DBL_MAX_EXP__ 1024
#define __USACCUM_EPSILON__ 0x1P-8UHK
#define __DEC128_EPSILON__ 1E-33DL
#define __SFRACT_MAX__ 0X7FP-7HR
#define __FRACT_IBIT__ 0
#define __PTRDIFF_MAX__ 0x7fffffff
#define __UACCUM_MIN__ 0.0UK
#define __UACCUM_IBIT__ 16
#define __GNUG__ 6
#define __LONG_LONG_MAX__ 0x7fffffffffffffffLL
#define __SIZEOF_SIZE_T__ 4
#define __ULACCUM_MAX__ 0XFFFFFFFFFFFFFFFFP-32ULK
#define __cpp_rvalue_reference 200610
#define __cpp_nsdmi 200809
#define __SIZEOF_WINT_T__ 4
#define __cpp_initializer_lists 200806
#define __SA_IBIT__ 16
#define __ULLACCUM_MIN__ 0.0ULLK
#define __cpp_hex_float 201603
#define __GXX_ABI_VERSION 1010
#define __UTA_FBIT__ 64
#define __FLT_MIN_EXP__ (-125)
#define __USFRACT_MAX__ 0XFFP-8UHR
#define __UFRACT_IBIT__ 0
#define __cpp_lambdas 200907
#define __ARM_FEATURE_QBIT 1
#define __INT_FAST64_TYPE__ long long int
#define __FP_FAST_FMAF 1
#define __DBL_MIN__ double(2.2250738585072014e-308L)
#define __FLT_MIN_10_EXP__ (-37)
#define __LACCUM_MIN__ (-0X1P31LK-0X1P31LK)
#define __ULLACCUM_FBIT__ 32
#define __GXX_TYPEINFO_EQUALITY_INLINE 0
#define __ULLFRACT_EPSILON__ 0x1P-64ULLR
#define __USES_INITFINI__ 1
#define __DEC128_MIN__ 1E-6143DL
#define __REGISTER_PREFIX__ 
#define __UINT16_MAX__ 0xffff
#define __DBL_HAS_DENORM__ 1
#define __ACCUM_MIN__ (-0X1P15K-0X1P15K)
#define __SQ_IBIT__ 0
#define __UINT8_TYPE__ unsigned char
#define __UHA_FBIT__ 8
#define __NO_INLINE__ 1
#define __SFRACT_MIN__ (-0.5HR-0.5HR)
#define __UTQ_FBIT__ 128
#define __FLT_MANT_DIG__ 24
#define __VERSION__ "6.3.1 20170620 (release) [ARM/embedded-6-branch revision 249437]"
#define __UINT64_C(c) c ## ULL
#define __ULLFRACT_FBIT__ 64
#define __cpp_unicode_characters 200704
#define __FRACT_EPSILON__ 0x1P-15R
#define __ULACCUM_MIN__ 0.0ULK
#define __UDA_FBIT__ 32
#define __cpp_decltype_auto 201304
#define __LLACCUM_EPSILON__ 0x1P-31LLK
#define __ARM_FEATURE_FMA 1
#define __GCC_ATOMIC_INT_LOCK_FREE 2
#define __FLOAT_WORD_ORDER__ __ORDER_LITTLE_ENDIAN__
#define __USFRACT_MIN__ 0.0UHR
#define __ULLACCUM_IBIT__ 32
#define __UQQ_IBIT__ 0
#define __INT32_C(c) c ## L
#define __DEC64_EPSILON__ 1E-15DD
#define __ORDER_PDP_ENDIAN__ 3412
#define __DEC128_MIN_EXP__ (-6142)
#define __UHQ_FBIT__ 16
#define __LLACCUM_FBIT__ 31
#define __INT_FAST32_TYPE__ int
#define __UINT_LEAST16_TYPE__ short unsigned int
#define __INT16_MAX__ 0x7fff
#define __SIZE_TYPE__ unsigned int
#define __UINT64_MAX__ 0xffffffffffffffffULL
#define __UDQ_FBIT__ 64
#define __INT8_TYPE__ signed char
#define __thumb__ 1
#define __cpp_digit_separators 201309
#define __ELF__ 1
#define __ULFRACT_EPSILON__ 0x1P-32ULR
#define __LLFRACT_FBIT__ 63
#define __FLT_RADIX__ 2
#define __INT_LEAST16_TYPE__ short int
#define __ARM_ARCH_PROFILE 77
#define __LDBL_EPSILON__ 2.2204460492503131e-16L
#define __UINTMAX_C(c) c ## ULL
#define __SACCUM_MAX__ 0X7FFFP-7HK
#define __SIG_ATOMIC_MAX__ 0x7fffffff
#define __GCC_ATOMIC_WCHAR_T_LOCK_FREE 2
#define __cpp_sized_deallocation 201309
#define __VFP_FP__ 1
#define __SIZEOF_PTRDIFF_T__ 4
#define __LACCUM_EPSILON__ 0x1P-31LK
#define __DEC32_SUBNORMAL_MIN__ 0.000001E-95DF
#define __INT_FAST16_MAX__ 0x7fffffff
#define __UINT_FAST32_MAX__ 0xffffffffU
#define __UINT_LEAST64_TYPE__ long long unsigned int
#define __USACCUM_MAX__ 0XFFFFP-8UHK
#define __SFRACT_EPSILON__ 0x1P-7HR
#define __FLT_HAS_QUIET_NAN__ 1
#define __FLT_MAX_10_EXP__ 38
#define __LONG_MAX__ 0x7fffffffL
#define __DEC128_SUBNORMAL_MIN__ 0.000000000000000000000000000000001E-6143DL
#define __FLT_HAS_INFINITY__ 1
#define __cpp_unicode_literals 200710
#define __USA_FBIT__ 16
#define __UINT_FAST16_TYPE__ unsigned int
#define __DEC64_MAX__ 9.999999999999999E384DD
#define __ARM_32BIT_STATE 1
#define __CHAR16_TYPE__ short unsigned int
#define __PRAGMA_REDEFINE_EXTNAME 1
#define __INT_LEAST16_MAX__ 0x7fff
#define __DEC64_MANT_DIG__ 16
#define __UINT_LEAST32_MAX__ 0xffffffffUL
#define __SACCUM_FBIT__ 7
#define __GCC_ATOMIC_LONG_LOCK_FREE 2
#define __INT_LEAST64_TYPE__ long long int
#define __ARM_FEATURE_CLZ 1
#define __INT16_TYPE__ short int
#define __INT_LEAST8_TYPE__ signed char
#define __SQ_FBIT__ 31
#define __DEC32_MAX_EXP__ 97
#define __ARM_ARCH_ISA_THUMB 2
#define __INT_FAST8_MAX__ 0x7fffffff
#define __ARM_ARCH 7
#define __INTPTR_MAX__ 0x7fffffff
#define __QQ_FBIT__ 7
#define __cpp_range_based_for 200907
#define __UTA_IBIT__ 64
#define __LDBL_MANT_DIG__ 53
#define __SFRACT_FBIT__ 7
#define __SACCUM_MIN__ (-0X1P7HK-0X1P7HK)
#define __DBL_HAS_QUIET_NAN__ 1
#define __SIG_ATOMIC_MIN__ (-__SIG_ATOMIC_MAX__ - 1)
#define __cpp_return_type_deduction 201304
#define __INTPTR_TYPE__ int
#define __UINT16_TYPE__ short unsigned int
#define __WCHAR_TYPE__ unsigned int
#define __SIZEOF_FLOAT__ 4
#define __THUMBEL__ 1
#define __USQ_FBIT__ 32
#define __UINTPTR_MAX__ 0xffffffffU
#define __DEC64_MIN_EXP__ (-382)
#define __cpp_decltype 200707
#define __INT_FAST64_MAX__ 0x7fffffffffffffffLL
#define __GCC_ATOMIC_TEST_AND_SET_TRUEVAL 1
#define __FLT_DIG__ 6
#define __UINT_FAST64_TYPE__ long long unsigned int
#define __INT_MAX__ 0x7fffffff
#define __LACCUM_FBIT__ 31
#define __USACCUM_MIN__ 0.0UHK
#define __UHA_IBIT__ 8
#define __INT64_TYPE__ long long int
#define __FLT_MAX_EXP__ 128
#define __UTQ_IBIT__ 0
#define __DBL_MANT_DIG__ 53
#define __cpp_inheriting_constructors 200802
#define __INT_LEAST64_MAX__ 0x7fffffffffffffffLL
#define __DEC64_MIN__ 1E-383DD
#define __WINT_TYPE__ unsigned int
#define __UINT_LEAST32_TYPE__ long unsigned int
#define __SIZEOF_SHORT__ 2
#define __ULLFRACT_IBIT__ 0
#define __LDBL_MIN_EXP__ (-1021)
#define __arm__ 1
#define __UDA_IBIT__ 32
#define __INT_LEAST8_MAX__ 0x7f
#define __LFRACT_FBIT__ 31
#define __WCHAR_UNSIGNED__ 1
#define __LDBL_MAX_10_EXP__ 308
#define __ATOMIC_RELAXED 0
#define __DBL_EPSILON__ double(2.2204460492503131e-16L)
#define __ARM_ARCH_7EM__ 1
#define __ARM_FEATURE_SIMD32 1
#define __UINT8_C(c) c
#define __INT_LEAST32_TYPE__ long int
#define __SIZEOF_WCHAR_T__ 4
#define __UINT64_TYPE__ long long unsigned int
#define __LLFRACT_MAX__ 0X7FFFFFFFFFFFFFFFP-63LLR
#define __TQ_FBIT__ 127
#define __INT_FAST8_TYPE__ int
#define __ULLACCUM_EPSILON__ 0x1P-32ULLK
#define __UHQ_IBIT__ 0
#define __ARM_FEATURE_COPROC 15
#define __LLACCUM_IBIT__ 32
#define __DBL_DECIMAL_DIG__ 17
#define __STDC_UTF_32__ 1
#define __DEC_EVAL_METHOD__ 2
#define __TA_FBIT__ 63
#define __UDQ_IBIT__ 0
#define __ORDER_BIG_ENDIAN__ 4321
#define __cpp_runtime_arrays 198712
#define __ACCUM_EPSILON__ 0x1P-15K
#define __UINT32_C(c) c ## UL
#define __INTMAX_MAX__ 0x7fffffffffffffffLL
#define __cpp_alias_templates 200704
#define __BYTE_ORDER__ __ORDER_LITTLE_ENDIAN__
#define __FLT_DENORM_MIN__ 1.4012984643248171e-45F
#define __LLFRACT_IBIT__ 0
#define __INT8_MAX__ 0x7f
#define __UINT_FAST32_TYPE__ unsigned int
#define __CHAR32_TYPE__ long unsigned int
#define __FLT_MAX__ 3.4028234663852886e+38F
#define __cpp_constexpr 201304
#define __USACCUM_FBIT__ 8
#define __INT32_TYPE__ long int
#define __SIZEOF_DOUBLE__ 8
#define __UFRACT_EPSILON__ 0x1P-16UR
#define __INTMAX_TYPE__ long long int
#define __DEC128_MAX_EXP__ 6145
#define __ATOMIC_CONSUME 1
#define __GNUC_MINOR__ 3
#define __UINTMAX_MAX__ 0xffffffffffffffffULL
#define __DEC32_MANT_DIG__ 7
#define __HA_FBIT__ 7
#define __DBL_MAX_10_EXP__ 308
#define __LDBL_DENORM_MIN__ 4.9406564584124654e-324L
#define __INT16_C(c) c
#define __cpp_generic_lambdas 201304
#define __STDC__ 1
#define __PTRDIFF_TYPE__ int
#define __LLFRACT_MIN__ (-0.5LLR-0.5LLR)
#define __ATOMIC_SEQ_CST 5
#define __DA_FBIT__ 31
#define __UINT32_TYPE__ long unsigned int
#define __ARM_ARCH_EXT_IDIV__ 1
#define __UINTPTR_TYPE__ unsigned int
#define __USA_IBIT__ 16
#define __DEC64_SUBNORMAL_MIN__ 0.000000000000001E-383DD
#define __ARM_EABI__ 1
#define __DEC128_MANT_DIG__ 34
#define __LDBL_MIN_10_EXP__ (-307)
#define __SIZEOF_LONG_LONG__ 8
#define __ULACCUM_EPSILON__ 0x1P-32ULK
#define __cpp_user_defined_literals 200809
#define __SACCUM_IBIT__ 8
#define __GCC_ATOMIC_LLONG_LOCK_FREE 1
#define __LDBL_DIG__ 15
#define __FLT_DECIMAL_DIG__ 9
#define __UINT_FAST16_MAX__ 0xffffffffU
#define __GCC_ATOMIC_SHORT_LOCK_FREE 2
#define __ULLFRACT_MAX__ 0XFFFFFFFFFFFFFFFFP-64ULLR
#define __UINT_FAST8_TYPE__ unsigned int
#define __USFRACT_EPSILON__ 0x1P-8UHR
#define __ULACCUM_FBIT__ 32
#define __ARM_FEATURE_DSP 1
#define __QQ_IBIT__ 0
#define __cpp_init_captures 201304
#define __ATOMIC_ACQ_REL 4
#define __ATOMIC_RELEASE 3

[Debug - 14:28:54.299] stderr:
Using built-in specs.
COLLECT_GCC=arm-none-eabi-g++
Target: arm-none-eabi
Configured with: /tmp/jenkins-GCC-6-buildandreg-223_20170621_1498033910/src/gcc/configure --build=x86_64-linux-gnu --host=i686-w64-mingw32 --target=arm-none-eabi --prefix=/tmp/jenkins-GCC-6-buildandreg-223_20170621_1498033910/install-mingw --libexecdir=/tmp/jenkins-GCC-6-buildandreg-223_20170621_1498033910/install-mingw/lib --infodir=/tmp/jenkins-GCC-6-buildandreg-223_20170621_1498033910/install-mingw/share/doc/gcc-arm-none-eabi/info --mandir=/tmp/jenkins-GCC-6-buildandreg-223_20170621_1498033910/install-mingw/share/doc/gcc-arm-none-eabi/man --htmldir=/tmp/jenkins-GCC-6-buildandreg-223_20170621_1498033910/install-mingw/share/doc/gcc-arm-none-eabi/html --pdfdir=/tmp/jenkins-GCC-6-buildandreg-223_20170621_1498033910/install-mingw/share/doc/gcc-arm-none-eabi/pdf --enable-languages=c,c++ --enable-mingw-wildcard --disable-decimal-float --disable-libffi --disable-libgomp --disable-libmudflap --disable-libquadmath --disable-libssp --disable-libstdcxx-pch --disable-nls --disable-shared --disable-threads --disable-tls --with-gnu-as --with-gnu-ld --with-headers=yes --with-newlib --with-python-dir=share/gcc-arm-none-eabi --with-sysroot=/tmp/jenkins-GCC-6-buildandreg-223_20170621_1498033910/install-mingw/arm-none-eabi --with-libiconv-prefix=/tmp/jenkins-GCC-6-buildandreg-223_20170621_1498033910/build-mingw/host-libs/usr --with-gmp=/tmp/jenkins-GCC-6-buildandreg-223_20170621_1498033910/build-mingw/host-libs/usr --with-mpfr=/tmp/jenkins-GCC-6-buildandreg-223_20170621_1498033910/build-mingw/host-libs/usr --with-mpc=/tmp/jenkins-GCC-6-buildandreg-223_20170621_1498033910/build-mingw/host-libs/usr --with-isl=/tmp/jenkins-GCC-6-buildandreg-223_20170621_1498033910/build-mingw/host-libs/usr --with-libelf=/tmp/jenkins-GCC-6-buildandreg-223_20170621_1498033910/build-mingw/host-libs/usr --with-host-libstdcxx='-static-libgcc -Wl,-Bstatic,-lstdc++,-Bdynamic -lm' --with-pkgversion='GNU Tools for ARM Embedded Processors 6-2017-q2-update' --with-multilib-list=rmprofile
Thread model: single
gcc version 6.3.1 20170620 (release) [ARM/embedded-6-branch revision 249437] (GNU Tools for ARM Embedded Processors 6-2017-q2-update) 
COLLECT_GCC_OPTIONS='-std=gnu++14' '-mcpu=cortex-m4' '-funsigned-char' '-fno-exceptions' '-fno-rtti' '-mfloat-abi=softfp' '-mfpu=fpv4-sp-d16' '-mthumb' '-v' '-dM' '-E'
 c:/program files (x86)/gnu tools arm embedded/6 2017-q2-update/bin/../lib/gcc/arm-none-eabi/6.3.1/cc1plus.exe -E -quiet -v -imultilib thumb/v7e-m/fpv4-sp/softfp -iprefix c:\program files (x86)\gnu tools arm embedded\6 2017-q2-update\bin\../lib/gcc/arm-none-eabi/6.3.1/ -isysroot c:\program files (x86)\gnu tools arm embedded\6 2017-q2-update\bin\../arm-none-eabi -D__USES_INITFINI__ - -mcpu=cortex-m4 -mfloat-abi=softfp -mfpu=fpv4-sp-d16 -mthumb -std=gnu++14 -funsigned-char -fno-exceptions -fno-rtti -dM
ignoring duplicate directory "c:/program files (x86)/gnu tools arm embedded/6 2017-q2-update/lib/gcc/../../lib/gcc/arm-none-eabi/6.3.1/../../../../arm-none-eabi/include/c++/6.3.1"
ignoring duplicate directory "c:/program files (x86)/gnu tools arm embedded/6 2017-q2-update/lib/gcc/../../lib/gcc/arm-none-eabi/6.3.1/../../../../arm-none-eabi/include/c++/6.3.1/arm-none-eabi/thumb/v7e-m/fpv4-sp/softfp"
ignoring duplicate directory "c:/program files (x86)/gnu tools arm embedded/6 2017-q2-update/lib/gcc/../../lib/gcc/arm-none-eabi/6.3.1/../../../../arm-none-eabi/include/c++/6.3.1/backward"
ignoring duplicate directory "c:/program files (x86)/gnu tools arm embedded/6 2017-q2-update/lib/gcc/../../lib/gcc/arm-none-eabi/6.3.1/include"
ignoring nonexistent directory "c:\program files (x86)\gnu tools arm embedded\6 2017-q2-update\bin\../arm-none-eabi/tmp/jenkins-GCC-6-buildandreg-223_20170621_1498033910/install-mingw/lib/gcc/arm-none-eabi/6.3.1/../../../../include"
ignoring duplicate directory "c:/program files (x86)/gnu tools arm embedded/6 2017-q2-update/lib/gcc/../../lib/gcc/arm-none-eabi/6.3.1/include-fixed"
ignoring duplicate directory "c:/program files (x86)/gnu tools arm embedded/6 2017-q2-update/lib/gcc/../../lib/gcc/arm-none-eabi/6.3.1/../../../../arm-none-eabi/include"
ignoring nonexistent directory "c:\program files (x86)\gnu tools arm embedded\6 2017-q2-update\bin\../arm-none-eabi/usr/include"
#include "..." search starts here:
#include <...> search starts here:
 c:\program files (x86)\gnu tools arm embedded\6 2017-q2-update\bin\../lib/gcc/arm-none-eabi/6.3.1/../../../../arm-none-eabi/include/c++/6.3.1
 c:\program files (x86)\gnu tools arm embedded\6 2017-q2-update\bin\../lib/gcc/arm-none-eabi/6.3.1/../../../../arm-none-eabi/include/c++/6.3.1/arm-none-eabi/thumb/v7e-m/fpv4-sp/softfp
 c:\program files (x86)\gnu tools arm embedded\6 2017-q2-update\bin\../lib/gcc/arm-none-eabi/6.3.1/../../../../arm-none-eabi/include/c++/6.3.1/backward
 c:\program files (x86)\gnu tools arm embedded\6 2017-q2-update\bin\../lib/gcc/arm-none-eabi/6.3.1/include
 c:\program files (x86)\gnu tools arm embedded\6 2017-q2-update\bin\../lib/gcc/arm-none-eabi/6.3.1/include-fixed
 c:\program files (x86)\gnu tools arm embedded\6 2017-q2-update\bin\../lib/gcc/arm-none-eabi/6.3.1/../../../../arm-none-eabi/include
End of search list.
COMPILER_PATH=c:/program files (x86)/gnu tools arm embedded/6 2017-q2-update/bin/../lib/gcc/arm-none-eabi/6.3.1/;c:/program files (x86)/gnu tools arm embedded/6 2017-q2-update/bin/../lib/gcc/;c:/program files (x86)/gnu tools arm embedded/6 2017-q2-update/bin/../lib/gcc/arm-none-eabi/6.3.1/../../../../arm-none-eabi/bin/
LIBRARY_PATH=c:/program files (x86)/gnu tools arm embedded/6 2017-q2-update/bin/../lib/gcc/arm-none-eabi/6.3.1/thumb/v7e-m/fpv4-sp/softfp/;c:/program files (x86)/gnu tools arm embedded/6 2017-q2-update/bin/../lib/gcc/arm-none-eabi/6.3.1/../../../../arm-none-eabi/lib/thumb/v7e-m/fpv4-sp/softfp/;c:/program files (x86)/gnu tools arm embedded/6 2017-q2-update/bin/../arm-none-eabi/lib/thumb/v7e-m/fpv4-sp/softfp/;c:/program files (x86)/gnu tools arm embedded/6 2017-q2-update/bin/../lib/gcc/arm-none-eabi/6.3.1/;c:/program files (x86)/gnu tools arm embedded/6 2017-q2-update/bin/../lib/gcc/;c:/program files (x86)/gnu tools arm embedded/6 2017-q2-update/bin/../lib/gcc/arm-none-eabi/6.3.1/../../../../arm-none-eabi/lib/;c:/program files (x86)/gnu tools arm embedded/6 2017-q2-update/bin/../arm-none-eabi/lib/
COLLECT_GCC_OPTIONS='-std=gnu++14' '-mcpu=cortex-m4' '-funsigned-char' '-fno-exceptions' '-fno-rtti' '-mfloat-abi=softfp' '-mfpu=fpv4-sp-d16' '-mthumb' '-v' '-dM' '-E'

[Info  - 14:28:54.301] [pool-9-thread-1] C:\projects\sonar-test\main.cpp
[Error - 14:28:54.365] 
A file named "sonar-cfamily.reproducer" has been generated to help the problem investigation.
Please contact SonarSource support providing the following file to help improving the analyzer:
  C:\Users\jadavidson\.sonarlint\work\.sonartmp_6132929191950140696\2930103561424362699\sonar-cfamily.reproducer

[Error - 14:28:54.365] Error executing sensor: 'CFamily'
[Error - 14:28:54.365] java.lang.IllegalStateException: 
A file named "sonar-cfamily.reproducer" has been generated to help the problem investigation.
Please contact SonarSource support providing the following file to help improving the analyzer:
  C:\Users\jadavidson\.sonarlint\work\.sonartmp_6132929191950140696\2930103561424362699\sonar-cfamily.reproducer

	at com.sonar.cpp.plugin.SonarLintSensor.execute(SonarLintSensor.java:116)
	at com.sonar.cpp.plugin.CFamilySensor.execute(CFamilySensor.java:173)
	at org.sonarsource.sonarlint.core.analysis.container.analysis.sensor.SensorsExecutor.executeSensor(SensorsExecutor.java:81)
	at org.sonarsource.sonarlint.core.analysis.container.analysis.sensor.SensorsExecutor.execute(SensorsExecutor.java:72)
	at org.sonarsource.sonarlint.core.analysis.container.analysis.AnalysisContainer.doAfterStart(AnalysisContainer.java:122)
	at org.sonarsource.sonarlint.core.plugin.commons.pico.ComponentContainer.startComponents(ComponentContainer.java:119)
	at org.sonarsource.sonarlint.core.plugin.commons.pico.ComponentContainer.execute(ComponentContainer.java:104)
	at org.sonarsource.sonarlint.core.analysis.container.module.ModuleContainer.analyze(ModuleContainer.java:71)
	at org.sonarsource.sonarlint.core.analysis.command.AnalyzeCommand.execute(AnalyzeCommand.java:58)
	at org.sonarsource.sonarlint.core.analysis.command.AnalyzeCommand.execute(AnalyzeCommand.java:32)
	at org.sonarsource.sonarlint.core.analysis.AnalysisEngine$AsyncCommand.execute(AnalysisEngine.java:152)
	at org.sonarsource.sonarlint.core.analysis.AnalysisEngine.executeQueuedCommands(AnalysisEngine.java:70)
	at java.base/java.lang.Thread.run(Thread.java:829)

[Debug - 14:28:54.365] Execute Sensor: Sonar Secrets Detection Sensor
[Debug - 14:28:54.366] 'PHP sensor' skipped because there is no related files in the current project
[Debug - 14:28:54.366] 'Analyzer for "php.ini" files' skipped because there is no related files in the current project
[Debug - 14:28:54.366] 'XML Sensor' skipped because there is no related files in the current project
[Debug - 14:28:54.366] Execute Sensor: HTML
[Debug - 14:28:54.366] 'Python Sensor' skipped because there is no related files in the current project
[Info  - 14:28:54.367] Found 0 issues

settings.json:

{
"sonarlint.output.showVerboseLogs": true,
"sonarlint.output.showAnalyzerLogs": true,
"sonarlint.analyzerProperties": {
    "sonar.cfamily.reproducer": "C:\\projects\\sonar-test\\main.cpp"
},
"sonarlint.rules": {
    "cpp:S2260": {
        "level": "on"
    }
}
}

compile_commands.json:

[
 {
  "directory": "C:/projects/sonar-test/BUILD",
  "arguments": [
   "arm-none-eabi-g++",
   "-c",
   "-g3",
   "-std=gnu++14",
   "-fno-rtti",
   "-Wvla",
   "-c",
   "-g3",
   "-std=gnu++14",
   "-fno-rtti",
   "-Wvla",
   "-Wall",
   "-Wextra",
   "-Wno-unused-parameter",
   "-Wno-missing-field-initializers",
   "-fmessage-length=0",
   "-fno-exceptions",
   "-ffunction-sections",
   "-fdata-sections",
   "-funsigned-char",
   "-MMD",
   "-fomit-frame-pointer",
   "-Og",
   "-mcpu=cortex-m4",
   "-mthumb",
   "-mfpu=fpv4-sp-d16",
   "-mfloat-abi=softfp",
   "-o",
   "main.o",
   "../main.cpp"
  ],
  "file": "../main.cpp"
 }
]

main.cpp:

#include <cstdio>
void f(char* userInput) {
        std::printf(userInput);
}
int main() {
        f("input");
        return 3;
}

sonar-cfamily.reproducer (276.2 KB)

Hello @jadavidson-sep,

The exception is thrown because you are defining the reproducer option:

"sonarlint.analyzerProperties": {
    "sonar.cfamily.reproducer": "C:\\projects\\sonar-test\\main.cpp"
},

This option throws an exception and generates a reproducer file to reproduce the analysis.

On my side, I see that we raise two issues on your file:
Line 4 S5281:format string is not a string literal (potentially insecure).
Line 3 S995:Make the type of this parameter a pointer-to-const. The current type of “userInput” is “char *”.

Try to remove the reproducer option and try again. If it doesn’t work, please share again the analysis verbose log after removing the option.

Thanks,

Hi @jadavidson-sep, any update?