|Initial release||March 4, 2009|
|Written in||C, C++, C#|
|Type||Web Application framework|
|License||LGPL 2 with proprietary codecs|
Moonlight was a free and open source implementation for Linux and other Unix-based operating systems of the now deprecated Microsoft Silverlight application framework, developed and then abandoned by the Mono Project. Like Silverlight, Moonlight was a web application framework which provided capabilities similar to those of Adobe Flash, integrating multimedia, graphics, animations and interactivity into a single runtime environment.
History and overview
|2010-02-03||Moonlight 3.0 Preview 1|
|2011-02-15||Moonlight 4 Preview 1|
In an interview in the beginning of June 2007, Miguel de Icaza said the Mono team expected to offer a "feasibility 'alpha' demo" in mid-June 2007, with support for Mozilla Firefox on Linux by the end of the year.
After a 21-day hacking spree by the Mono team (including Chris Toshok, Larry Ewing and Jeffrey Stedfast among others), a public demo was shown at Microsoft ReMIX conference in Paris, France on June 21, 2007.
However, in September 2007, developers still needed to install and compile a lot of Mono and Olive (the experimental Mono subproject for .NET 3.0 support) modules from the Mono SVN repository to be able to test Moonlight. A Moonlight IDE, named Lunar Eclipse, exists in SVN for XAML designs. Moonlight uses Cairo for rendering.
Moonlight was provided as a plugin for Firefox and Chrome on popular Linux distributions. The plugin itself does not include a media codec pack, but when the Moonlight plugin detects playable media it refers users to download a free Media codec pack from Microsoft.
Moonlight 2.0 tracked the Silverlight 2.0 implementation. The first completed version, Moonlight 1.0, supporting Silverlight 1.0, was released in January 2009. Moonlight 2.0 was released in December 2009. The Moonlight 2.0 release also contained some features of Silverlight 3 including a pluggable media framework which allowed Moonlight to work with pluggable open codecs, such as Theora and Dirac.
Preview releases of Moonlight 4.0, targeting Silverlight 4 compatibility, were released in early 2011.
In April 2011, the Moonlight team demonstrated Moonlight running on Android tablets and phones at the MIX11 Web Developers conference in Las Vegas.
Shortly after the April 2011 release, Attachmate, parent to developer Mono, laid off an undisclosed number of Mono employees, and announced a deal with startup Xamarin for Mono development and support. At that time, Xamarin CEO Nat Friedman affirmed their commitment to the Moonlight project, although there were no outward signs of any further development afterward.
In December 2011, de Icaza announced that work on Moonlight had stopped with no future plans. He explained that Microsoft had "cut the air supply" to it by omitting cross-platform components, making it a web-only plugin, and including Windows-only features. He advised developers to separate user interface code from the rest of their application development to ensure "a great UI experience on every platform (Mac, Linux, Android, iOS, Windows and Web)" without being dependent on third party APIs.
Silverlight supports Digital Rights Management in its multimedia stack, but Microsoft will not license their PlayReady DRM software for the Moonlight project to use and so Moonlight is unable to play encrypted content.
MoonBase is an experimental set of helper classes built on top of Moonlight.Gtk that can be used to create full blown C# desktop applications using the Moonlight (Silverlight 4.0) widgets and XAML files. MoonBase also has a related XAML editor/previewer.
Shortly after the first demo at MIX 07 in Paris, Microsoft began cooperating with Novell to help with the building of Moonlight. Support included giving exclusive access to Novell for the following Silverlight artifacts:
- Microsoft's Test suites for Silverlight,
- Silverlight specification details, beyond those available on the web,
- Proprietary codecs made available free-of-charge for Windows Media Video and Audio, for VC-1 and MP3, and in the future H.264 and AAC, only licensed for use with Moonlight when running in a web browser. Other potential decoders include GStreamer and FFmpeg (used during the development stage) but Novell will not provide prepackaged versions of Moonlight with those libraries, because those decoders have not been granted licensing for the use of patented codec technologies.
Microsoft released two public covenants not to sue for the infringement of its patents when using Moonlight. The first one covered Moonlight 1 and 2, is quite restrictive and covered only the use of Moonlight as a plugin in a browser, only implementations that are not GPLv3 licensed, and only if the Moonlight implementation has been obtained from Novell. It also notes that Microsoft may rescind these usage rights.
The second covenant was an updated and broader covenant that no longer limits the covenant to users that obtain Moonlight from Novell, it covers any uses of Moonlight regardless of where it was obtained. The updated covenant covers the implementations as shipped by Novell for versions 3 and 4, it no longer distinguishes Novell from other distributions of Moonlight and expands the covenant to desktop applications created with Moonlight. The covenant does not extend to forks licensed under the GNU GPL (Moonlight itself uses the Lesser GPLv2).
Although Moonlight is free software, the final version was going to use binary-only audio and video codecs provided by Microsoft which will be licensed for use with Moonlight only when used as a browser plugin (see above). The Windows media pack is not distributed together with the Moonlight plugin but the first time when media content in Silverlight is detected the user will be prompted to download the pack containing the codecs used in Silverlight directly from Microsoft.
Self built versions could still use the FFmpeg library and there was discussion about adding GStreamer support as an alternative to using Microsoft's binary codecs for those who wish to use GStreamer instead and also for use when used outside of a browser.
Mono architect Miguel de Icaza blogged that the Mono team prototyped Moonlight multimedia support using the LGPL-licensed FFmpeg engine but that they were unable to redistribute packaged versions that used that library due to FFmpeg codec licensing issues inside of the United States.
Moonlight in other distributions
After the release of Moonlight 2, a covenant provided by Microsoft was updated to ensure that other third party distributors can distribute Moonlight without their users having to worry about getting sued over patent infringement by Microsoft. This covenant can be found on the Microsoft website.
The version of Moonlight that was going to be available direct from Novell would have access to licensed closed source media codecs provided free of charge by Microsoft. Third-party distributions of Moonlight would only be able to play non-patent encumbered media like Vorbis, Theora and Ogg. To support other formats, the distributors would have had to choose from a few licensing options:
- Negotiate licences directly with individual media codec owners (e.g. MPEG-LA, Fraunhofer Society)
- Negotiate access to Microsoft's Media Pack as Novell have done
- Use GStreamer or a commercial codec license
- Use a hardware-specific software like VDPAU
At the PDC conference on October 13, 2008, Microsoft placed the 'Silverlight XAML Vocabulary' under the Microsoft Open Specification Promise, stating in a press release, "The Silverlight XAML vocabulary specification, released under the Microsoft Open Specification Promise, will better enable third-party ISVs to create products that can read and write XAML for Silverlight." Since Moonlight is essentially a XAML reader, Debian's position is that Moonlight is safe for them to redistribute (leaving each user to agree to their own licensing for Microsoft's and others' binary codecs).
- Miguel de Icaza (May 29, 2012). "Miguel de Icaza on ASP.NET MVC, Moonlight, and the Android Lawsuit". InfoQ.com. Retrieved 2014-02-06.
- Foley, Mary-Jo. "Xamarin abandons its Silverlight for Linux technology". All About Microsoft. ZDNet. Retrieved 1 June 2012.
- Dana Gardner. "the FASTforward blog: Expect a June demo of Silverlight on Linux, sans browser". Archived from the original on 2007-09-28. Retrieved 2007-06-06.
- "Implementing Silverlight in 21 Days". Miguel de Icaza. Retrieved 2007-06-22.
- "Implementing Silverlight in 21 Days". Jeffrey Stedfast. Retrieved 2007-06-21.
- "Moonlight". Chris Toshok. Archived from the original on 2007-11-14. Retrieved 2007-06-21.
- "Mono Silverlight implementation emerges after epic hackathon". Ars Technica. Retrieved 2007-06-22.
- "Moonlight: Getting started". Mono Team. Retrieved 2007-09-02.
- Moonlight Notes
- "Moonlight Supported Platforms". mono-project.com. Retrieved 2009-05-17.
- "Moonlight 2 is now available". The Silverlight Team blog. 2009-12-17. Archived from the original on 2012-03-02. Retrieved 2009-12-19.
- "First Moonlight 2.0 Preview is Out". Miguel de Icaza. Retrieved 2009-05-04.
We have developed a handful of open source codecs for Dirac, Vorbis and ADPCM that can be used with Silverlight 3/Moonlight Preview based on existing C# and Java implementations. Hopefully someone will help us fill in the blanks with more codecs (like Theora).
- "Moonlight 4 Preview Now Available". The Silverlight Team Blog. 2011-02-15.
- "Moonlight on Android". A Moment of Zen. 2011-04-15.
- "Attachmate lays off Mono employees". 2011-05-03.
- "SUSE Joins Xamarin for Mono". 2011-08-10.
- "Moonlight Mailing List". Xamarin. 2011.
- "Discussion on official Silverlight forum".
- "Moonlight Desklets demo on YouTube". Mono Team. Retrieved 2007-06-25.
- Foley, Mary Jo (2007-09-25). "Microsoft officially 'extends support' for Novell's Silverlight Linux port". zdnet.com. Retrieved 2007-10-13.
- de Icaza, Miguel (2007-09-05). "Microsoft/Novell Collaboration on Silverlight". Retrieved 2007-10-13.
- "Covenant to Downstream Recipients of Moonlight - Microsoft & Novell Interoperability Collaboration". Microsoft. 2007-09-28. Retrieved 2008-03-08.
"Downstream Recipient" means an entity or individual that uses for its intended purpose a Moonlight Implementation obtained directly from Novell or through an Intermediate Recipient... Microsoft reserves the right to update (including discontinue) the foregoing covenant... "Moonlight Implementation" means only those specific portions of Moonlight 1.0 or Moonlight 1.1 that run only as a plug-in to a browser on a Personal Computer and are not licensed under GPLv3 or a Similar License.
- "Covenant to End Users of Moonlight 3 and 4". Microsoft. Retrieved 2010-05-11.
- Ramji, Sam (2007-09-05). "The Novell-Microsoft Wheeler Dealers Speak". Archived from the original on 2012-03-02. Retrieved 2007-10-13.
After a great deal of work between the Moonlight and .NET teams, we’re ready to formally announce that we (Microsoft and Novell) will be bringing Silverlight to Linux (Sam Ramji is Director of Microsoft's Open Source Software Lab)
- Miguel de Icaza (2009-12-17). "Releasing Moonlight 2, Roadmap to Moonlight 3 and 4". Retrieved 2009-12-18.
- Tom Callaway (December 23, 2009). "Re: New covenant published". gmane.linux.redhat.fedora.devel. Archived from the original on March 2, 2012. Retrieved 2010-01-11.
- "Microsoft Releases Silverlight 2, Already Reaching One in Four Consumers Worldwide". Microsoft. 2008-10-13. Retrieved 2008-10-13.
- "Moonlight for Debian". Debian Wiki. Retrieved 28 April 2017.