aaron.ballman added inline comments.

================
Comment at: clang/lib/Sema/SemaDecl.cpp:3220
+
+  // `type[]` is equivalent to `type *` and `type[*]`
+  if (NoSizeInfo(Old) && NoSizeInfo(New))
----------------



================
Comment at: clang/lib/Sema/SemaDecl.cpp:3224
+
+  // Don't try to compare VLA sizes, unless one of them has the star modifier
+  if (Old->isVariableArrayType() && New->isVariableArrayType()) {
----------------



================
Comment at: clang/lib/Sema/SemaDecl.cpp:3234
+
+  // Only compare size, ignore Size modifiers and CVR
+  if (Old->isConstantArrayType() && New->isConstantArrayType())
----------------



================
Comment at: clang/lib/Sema/SemaDecl.cpp:3274-3278
+      S.Diag(NewParam->getLocation(), diag::warn_inconsistent_array_form)
+          << NewParam->getName()
+          << NewParamOT->getCanonicalTypeInternal().getAsString();
+      S.Diag(OldParam->getLocation(), diag::note_previous_declaration_as)
+          << OldParamOT->getCanonicalTypeInternal().getAsString();
----------------
The diagnostics engine knows how to format `NamedDecl` objects as well as 
types. Can you do this instead and still get reasonable diagnostics?


================
Comment at: clang/test/Sema/array-parameter.c:2
+// RUN: %clang_cc1 -triple x86_64-pc-linux-gnu -fsyntax-only -Warray-parameter 
-verify %s
+
+void f0(int a[]);
----------------
aaron.ballman wrote:
> I'd like to see some additional test cases:
> ```
> void func(int *p);
> void func(int a[2]); // Diagnose this one, I presume?
> void func(int a[]); // But also diagnose this one as well, yes?
> void func(int a[2]) {} // Do we then diagnose this as well, or is this 
> matching a previous declaration and thus fine?
> 
> void other(int n, int m, int a[n]);
> void other(int n, int m, int a[m]); // Hopefully we diagnose this set!
> 
> void another(int n, int array[n]);
> void another(int n, int array[*]); // I *think* this should be warned, but 
> I'm still a bit on the fence about it
> ```
> 
> Also, if this is expected to work in C++ as well, we should probably have 
> cases like:
> ```
> template <int N>
> void func(int i[10]);
> 
> template <int N>
> void func(int i[N]); // Should we diagnose this before instantiation or wait 
> until we see the instantiation and only diagnose if differs?
> 
> static constexpr int Extent = 10;
> void other(int i[10]);
> void other(int i[Extent]); // Should not be diagnosed
> ```
Do you plan to add the C++ tests?


CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D128449/new/

https://reviews.llvm.org/D128449

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to