-
Notifications
You must be signed in to change notification settings - Fork 336
Glossary
Welcome to the Project Reunion Glossary. This page will be updated weekly.
Used in this repository, a polyfill is when an interface provides a substitute implementation when the desired implementation is not present. For example – assume Project Reunion wants to expose Muffin objects that are first present in Windows 10 RS5 as a platform feature; when Project Reunion app is installed on Windows 10 RS3, Project Reunion provides its own implementation of the Muffin functionality which is close enough.
WinRT is based on Component Object Models (COM) and is designed to be accessed through language projections. A language projection hides the details of COM and provides a more natural programming experience for a given language.
A developer of certain functionality expresses the shape of the API in metadata and then implements the functionality in a binary (typically a DLL). The API that is directly callable from the binary is called "Application Binary Interface" or ABI. It involves the actual invocation of an API in a native language such as C++. A language projection adapts the API into the syntax and semantics of a particular language, e.g. a property on a class that runs a particular type is written in ABI as:
HRESULT MyValue(int* value);
in this case, the "MyValue" property returns an integer and reports its success via HRESULT. This is an odd convention in most languages, which would normally like to call this API in the following manner (this is an example in C#):
var value = myClass.MyValue;
and throw an exception in case of an error condition. The re-shaping of the API call, in this case to its more natural form of the property being a direct return value and the translation of the error condition into an exception illustrates some of the essential jobs of a language projection. Other facilities may make the natural flow of asynchronous programming easier to write, often in the form of await or coroutines.
The Xlang open source project is building three language projections: C++ WinRT (cppwinrt), C# Winrt (cswint), and Rust/WinRT
Referenced throughout this repo, the term "UWP" references a Universal Windows Platform App - an app running inside an app container, at a lower privilege level, with package identity, delivered via an MSIX. This app's lifecycle from activation through termination is controlled by the platform for best power and resource usage. Its access to the user's resources are gated by a Request model so the user is in control. Windows and views created by the app are positioned by the OS shell. Its UX is either drawn using XAML or Composition objects or a framework that produces XAML or Composition objects.