A modern C++ projection for the Win32 SDK
Перейти к файлу
Kenny Kerr 8a6b250773
Fix the URL of the Win32 Metadata Project
2021-01-22 09:51:50 -08:00
cppwin32 Hoist apis and constants into namespace scope 2021-01-21 08:08:19 -08:00
test Hoist apis and constants into namespace scope 2021-01-21 08:08:19 -08:00
.gitattributes Add new format winmd 2020-11-24 22:33:41 -08:00
.gitignore Enums and structs (minus unions) 2020-10-09 15:06:13 -07:00
CODE_OF_CONDUCT.md Initial CODE_OF_CONDUCT.md commit 2020-10-09 13:05:47 -07:00
LICENSE Updating LICENSE to template content 2020-10-09 13:05:50 -07:00
README.md Fix the URL of the Win32 Metadata Project 2021-01-22 17:14:07 +09:00
SECURITY.md Initial SECURITY.md commit 2020-10-09 13:05:55 -07:00

README.md

The C++ Windows SDK projection

C++/Win32 (cppwin32) is a standard C++ language projection for Windows SDK APIs. True, the Windows SDK already releases headers that can be consumed from C++, but those headers have some severe historical and compatiblity constraints that hamper C++ developers that wish to enjoy modern language features. Goals include:

  • Better compliance with C++ standards, particularly C++17 and newer.
  • Eliminating the use of macros for constants, enumerations, and functions, and instead using C++ language constructs that participate in the type system and respect scope.
  • Paving the way towards a Windows SDK that can be used with C++ modules.

Another goal under investigation and discussion is to converge this projection with the C++/WinRT projection.

How it works

This projection is similar to C++/WinRT in that it generates projection header files from metadata. Instead of using Windows Runtime metadata, it uses metadata produced by the Win32 Metadata Project.

This project is still in the early stages and will continue to grow and evolve. Watch for a Nuget package soon.

Contributing

This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.

When you submit a pull request, a CLA bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.

This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.

Trademarks

This project may contain trademarks or logos for projects, products, or services. Authorized use of Microsoft trademarks or logos is subject to and must follow Microsoft's Trademark & Brand Guidelines. Use of Microsoft trademarks or logos in modified versions of this project must not cause confusion or imply Microsoft sponsorship. Any use of third-party trademarks or logos are subject to those third-party's policies.