llvm/clang/test/Sema/builtin-memcpy.c

// RUN: %clang_cc1 %s -triple x86_64-unknown-linux -fsyntax-only -verify=c
// RUN: %clang_cc1 -x c++ %s -triple x86_64-unknown-linux -fsyntax-only -verify=cxx

// cxx-no-diagnostics


/// Zero-sized structs should not crash.
int b() {
  struct {      } a[10];
  __builtin_memcpy(&a[2], a, 2); // c-warning {{buffer has size 0, but size argument is 2}}
  return 0;
}

#ifdef __cplusplus
// FIXME: This is UB and GCC correctly diagnoses it. Clang should do the same.
constexpr int b2() {
  struct {      } a[10];
  __builtin_memcpy(&a[2], a, 2);
  return 0;
}
static_assert(b2() == 0, "");
#endif