11

Recent versions of Visual Studio have seen improving support for C99. Does the latest version, VS2017, now support all of C99?

If not, what features of C99 are still missing?

user200783
  • 12,313
  • 10
  • 58
  • 110

2 Answers2

17

No.

https://docs.microsoft.com/en-us/cpp/visual-cpp-language-conformance

The compiler’s support for C99 Preprocessor rules is incomplete in Visual Studio 2017. Variadic macros are supported, but there are many bugs in the preprocessor’s behavior.

https://docs.microsoft.com/en-us/cpp/build/walkthrough-compile-a-c-program-on-the-command-line

The Visual C++ C compiler is generally compatible with the ISO C99 standard, but not strictly compliant. In most cases, portable C code will compile and run as expected. Visual C++ does not support most of the changes in ISO C11. Certain library functions and POSIX function names are deprecated by the Visual C++ compiler. The functions are supported, but the preferred names have changed. For more information, see Security Features in the CRT and Compiler Warning (level 3) C4996.

Remember that Visual C++ is ultimately a C++ implementation and not a true C environment. The compatibility is a nice side-effect of C and C++’s shared heritage but despite superficial syntactical similarities the two are very different languages.

Dai
  • 110,988
  • 21
  • 188
  • 277
  • 2
    I really don't understand what the big freaking deal is with these Microsoft people. Is it really that hard for a multi-billion dollar corporation just to add measly support for C99? Talk about a bunch C++ elitists. – annoying_squid Jul 24 '19 at 15:57
  • A notable absence is _Complex – Bruce Adams Jan 09 '20 at 17:12
  • 1
    @annoying_squid: I'd rather have a compiler vendor invest effort in reliably supporting the constructs I need than one that I'd have no interest in using even if supported. Further, while its definition of `__restrict` doesn't propagate the notion of "based upon", the way C99 defines "based upon" has so many corner cases that are goofy, ambiguous, nonsensical, and unworkable that I wouldn't really fault a compiler vendor for refusing to try to implement it until the authors of the Standard come up with something sensible. – supercat Mar 17 '20 at 15:45
6

Largely, yes, although some core language features are implemented non-compliantly (some with bugs and some are missing)

  • Variable Length Arrays are not supported (although these are now officially optional)
  • restrict qualifier is not supported, __restrict is supported instead, but it is not exactly the same
  • Top-level qualifiers in array declarations in function parameters are not supported (e.g. void foo(int a[const])) as well as keyword static in the same context

However, each new version of Visual Studio brings improvements in C99 support, so this work is not frozen apparently.

Answer to this question from 2015 has a number of relevant links, including MS roadmap for C support.

AnT
  • 291,388
  • 39
  • 487
  • 734