Why is mono so controversial?

Oftentimes when I'm reading about some program, be it GNOME Do or Banshee or something else, I see people writing that they use mono -- and the implication is pejorative. Why is this? Are these comments made on practical grounds, ideological ones, or something else?


Solution 1:

Ideologically

Mono is supposed by some to be supporting Microsoft and its .Net platform. Some people believe this is counter to the goals of Ubuntu, or at least their own personal goals, and they want to avoid that.

Sorry for the wiggle words, but I'm staying objective. The discussion of whether Mono actually does this, and even whether supporting Microsoft is a good or bad thing, belongs elsewhere.

Practically

Programs which use a virtual machine (as those written in Java and C# do), tend to use more memory, in my experience, compared to equivalents that don't. This generalization doesn't always hold. While there are users for which this is a valid concern, people often worry about performance more than necessary.

For example, I'm using a laptop with only 1GB of memory: this used to be huge. The machine is starting to show it's age, but I can still run most things comfortably. Users with 4GB of memory will not notice "memory hogs" nearly as much and should focus on other concerns. (And I'll come back here in 5 years and laugh at that 4GB number.)

Solution 2:

Some people believe that Microsoft holds software patents over aspects of .NET, and that as an implementation of .NET, Mono violates those patents. Thus these people feel that using Mono could leave one open to patent lawsuits.

I suppose Mono is so controversial because patent law in general is controversial. But then there are specific instances where entities that promote Mono have made agreements with Microsoft that look a lot like patent agreements, which could then be seen to strengthen Microsoft's argument for the validity of any such patents. (Of course, Microsoft hasn't actually provided any proof that the patents exist, thus maintaining a state of uncertainty, just as with their claim of patents violated by the linux kernel.) These agreements result in feelings of betrayal and distrust from other community members, because the agreement seems to hurt the community as a whole (by increasing the perceived patent risk) while benefiting the entity that made the agreement with Microsoft. So that leads to another reason that Mono is controversial: because some of Mono's main proponents have made controversial agreements with Microsoft.

By the way, I should mention that I write from the perspective of a spectator, and I have no detailed or specific knowledge of the whole situation. I've tried to remain unbiased and have mostly eschewed proper nouns so as to avoid dragging this question into the controversy that it asks about.

Edit: In the comments, someone pointed out that Microsoft has a community promise not to assert patent rights against .NET implementations. But the promise has enough legalese in it that I don't feel I can really be sure that the promise provides air-tight protection without hiring a lawyer to go over it. After reading it, I can think of some potential loopholes that could allow Microsoft to assert patent rights over Mono, but since IANAL, I have no idea whether any of these loopholes are legally defensible, or just my misunderstanding of Microsoft's legalese. So while the community promise is encouraging, it certainly cannot end the controversy among over Mono's possible patent liability.