Common Language Infrastructure

The Common Language Infrastructure (CLI) is an open specification and technical standard originally developed by Microsoft and standardized by ISO/IEC (ISO/IEC 23271) and Ecma International (ECMA 335)[1][2] that describes executable code and a runtime environment that allows multiple high-level languages to be used on different computer platforms without being rewritten for specific architectures. This implies it is platform agnostic. The .NET Framework, .NET and Mono are implementations of the CLI. The metadata format is also used to specify the API definitions exposed by the Windows Runtime.[3][4]

Common Language Infrastructure
ISO/IEC 23271:2012(E)
AbbreviationCLI
StatusPublished
Year started2000; 24 years ago (2000)
First published2001; 23 years ago (2001) (Ecma) and 2003; 21 years ago (2003) (ISO/IEC)
Latest versionSixth edition
June 2012; 12 years ago (2012-06)
OrganizationDeveloped by: Microsoft, Hewlett-Packard, Intel, and others
Standardized by: Ecma, ISO/IEC
CommitteeISO/IEC JTC 1/SC 22
DomainCommon Language (Cross-platform)
LicenseRAND
WebsiteECMA-335,
ISO/IEC 23271

Overview

edit
 
Visual overview of the Common Language Infrastructure (CLI)

Among other things, the CLI specification describes the following five aspects:

The Common Type System (CTS)
A set of data types and operations that are shared by all CTS-compliant programming languages.
The Metadata
Information about program structure is language-agnostic, so that it can be referenced between languages and tools, making it easy to work with code written in a language the developer is not using.
The Common Language Specification (CLS)
The CLS, a subset of the CTS, are rules to which components developed with/for the supported languages must adhere.
They apply to consumers (developers who are programmatically accessing a component that is CLS-compliant), frameworks (developers who are using a language compiler to create CLS-compliant libraries), and extenders (developers who are creating a tool such as a language compiler or a code parser that creates CLS-compliant components).
The Virtual Execution System (VES)
The VES loads and executes CLI-compatible programs, using the metadata to combine separately generated pieces of code at runtime.
All compatible languages compile to Common Intermediate Language (CIL), which is an intermediate language that is abstracted from the platform hardware. When the code is executed, the platform-specific VES will compile the CIL to the machine language according to the specific hardware and operating system.
In the CLI standard initially developed by Microsoft, the VES is implemented by the Common Language Runtime (CLR).
The Standard Libraries
A set of libraries providing many common functions, such as file reading and writing. Their core is the Base Class Library (BCL).

Standardization and licensing

edit

In August 2000, Microsoft, Hewlett-Packard, Intel, and others worked to standardize CLI. By December 2001, it was ratified by the Ecma, with ISO/IEC standardization following in April 2003.

Microsoft and its partners hold patents for CLI. Ecma and ISO/IEC require that all patents essential to implementation be made available under "reasonable and non-discriminatory (RAND) terms." It is common for RAND licensing to require some royalty payment, which could be a cause for concern with Mono. As of January 2013, neither Microsoft nor its partners have identified any patents essential to CLI implementations subject to RAND terms.

As of July 2009,[5] Microsoft added C# and CLI to the list of specifications that the Microsoft Community Promise applies to,[6] so anyone can safely implement specified editions of the standards without fearing a patent lawsuit from Microsoft. To implement the CLI standard requires conformance to one of the supported and defined profiles of the standard, the minimum of which is the kernel profile. The kernel profile is actually a very small set of types to support in comparison to the well known core library of default .NET installations. However, the conformance clause of the CLI allows for extending the supported profile by adding new methods and types to classes, as well as deriving from new namespaces. But it does not allow for adding new members to interfaces. This means that the features of the CLI can be used and extended, as long as the conforming profile implementation does not change the behavior of a program intended to run on that profile, while allowing for unspecified behavior from programs written specifically for that implementation.

In 2012, Ecma and ISO/IEC published the new edition of the CLI standard.[1][2]

Implementations

edit
  • .NET Framework is Microsoft's original commercial implementation of the CLI. It only supports Windows. It was superseded by .NET in November 2020.
  • .NET, previously known as .NET Core, is the free and open-source multi-platform successor to .NET Framework, released under the MIT License
  • .NET Compact Framework is Microsoft's commercial implementation of the CLI for portable devices and Xbox 360.
  • .NET Micro Framework is an open source implementation of the CLI for resource-constrained devices.
  • Mono is an alternative open source implementation of CLI and accompanying technologies, mainly used for mobile and game development.
  • DotGNU is a decommissioned part of the GNU Project started in January 2001 that aimed to provide a free and open source software alternative to Microsoft's .NET Framework.

See also

edit

Notes

edit
  1. ^ a b "ISO/IEC 23271:2012 - Information technology -- Common Language Infrastructure (CLI)". ISO. Archived from the original on July 2, 2023.
  2. ^ a b "ECMA-335". ECMA International. June 2012. Archived from the original on October 16, 2023.
  3. ^ "Introduction to Advanced Windows Store App Development using HTML5 and JavaScript". Microsoft Press Store. October 15, 2013. Archived from the original on March 30, 2023.
  4. ^ de Icaza, Miguel (September 15, 2011). "WinRT demystified". Archived from the original on November 30, 2023.
  5. ^ Galli, Peter (July 6, 2009). "The Ecma C# and CLI Standards". Port 25. Archived from the original on July 9, 2009. Retrieved September 26, 2009.
  6. ^ v-alje (March 16, 2023). "[MS-DEVCENTLP]: Microsoft Community Promise". Microsoft Learn. Retrieved May 1, 2023.

References

edit
edit