1*67e74705SXin Li // RUN: %clang_cc1 -fsyntax-only -verify %s 2*67e74705SXin Li // expected-no-diagnostics 3*67e74705SXin Li 4*67e74705SXin Li struct mystruct { 5*67e74705SXin Li int member; 6*67e74705SXin Li }; 7*67e74705SXin Li 8*67e74705SXin Li template <int i> foo()9*67e74705SXin Liint foo() { 10*67e74705SXin Li mystruct s[1]; 11*67e74705SXin Li return s->member; 12*67e74705SXin Li } 13*67e74705SXin Li main()14*67e74705SXin Liint main() { 15*67e74705SXin Li foo<1>(); 16*67e74705SXin Li } 17*67e74705SXin Li 18*67e74705SXin Li // PR7405 19*67e74705SXin Li struct hb_sanitize_context_t { 20*67e74705SXin Li int start; 21*67e74705SXin Li }; sanitize()22*67e74705SXin Litemplate <typename Type> static bool sanitize() { 23*67e74705SXin Li hb_sanitize_context_t c[1]; 24*67e74705SXin Li return !c->start; 25*67e74705SXin Li } 26*67e74705SXin Li bool closure = sanitize<int>(); 27*67e74705SXin Li 28*67e74705SXin Li // PR16206 29*67e74705SXin Li typedef struct { 30*67e74705SXin Li char x[4]; 31*67e74705SXin Li } chars; 32*67e74705SXin Li 33*67e74705SXin Li chars getChars(); 34*67e74705SXin Li void use(char *); 35*67e74705SXin Li test()36*67e74705SXin Livoid test() { 37*67e74705SXin Li use(getChars().x); 38*67e74705SXin Li } 39