sepavloff added a comment. In https://reviews.llvm.org/D41179#964526, @faisalv wrote:
> In https://reviews.llvm.org/D41179#964522, @miyuki wrote: > > > In https://reviews.llvm.org/D41179#957992, @sepavloff wrote: > > > > > Classes do not have language linkage according to 10.5p1, just as > > > templates, so this code is valid. > > > > > > It looks like defining templates inside extern "C" blocks is OK. > > > > > > Currently both Clang and GCC diagnose class templates declared inside an > > 'extern "C"' block. I'm not sure how to proceed about this. > > > Given that Clause 17 p6 specifically uses 'shall' to call out templates - i > believe the implementation is expected to diagnose this. 10.5p1 (or is there > another mention in the standard?) does not explicitly call out 'classes' as > not having c language linkage - so implementations can get away not > diagnosing this - and perhaps even allow classes to have language linkage on > certain implementations?? (at least that's my squinty interpretation) This is a strange clause. The language linkage describes cases when an entity defined in one TU is identical to another entity in another TU implemented in different language. As templates have no meaning outside C++, so they merely cannot have C linkage. I guess the statement about C linkage in 17p6 is a remnant of those times when template were allowed to have `export` specifier. In that case templates would have external representation and in principle could be used in non C++ compilation. Maybe @rsmith could clarify this point? https://reviews.llvm.org/D41179 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits