We do often include affiliate links to earn us some pennies. See more here.

As we retweeted last night from one of the Unity developers (too late to do an article when I saw it), they've now opened up the UnityEngine and UnityEditor source code for referencing.

The key thing to note here, is that Unity is not making steps towards their engine and editor being open source, they do say it's specifically for developers to reference and to understand what it's doing behind the scenes. Something the Unity developers hope might help developers.

It's interesting to see them do this, hopefully they will reconsider their stance on actually open sourcing it in future. They make it clear they're not against it, but they don't think they would be able to remain in business if they did (source):

We are not releasing Unity as open source. Not even a little bit. (Sorry.) It’s not that we don’t like open source. We’d open source all of Unity today if we thought we could get away with it and still be in business tomorrow, and we do have a growing number of open source projects. But the main engine will remain proprietary for the foreseeable future, and the C# reference source code is released under a license which only permits you to read the code, not modify it. Please consult the full license text for details before you get carried away.

You can find it here on GitHub.

Ps. If you do need a fully open game engine, there's always Godot.

Article taken from GamingOnLinux.com.
13 Likes
About the author -
author picture
I am the owner of GamingOnLinux. After discovering Linux back in the days of Mandrake in 2003, I constantly checked on the progress of Linux until Ubuntu appeared on the scene and it helped me to really love it. You can reach me easily by emailing GamingOnLinux directly. You can also follow my personal adventures on Bluesky.
See more from me
The comments on this article are closed.
All posts need to follow our rules. For users logged in: please hit the Report Flag icon on any post that breaks the rules or contains illegal / harmful content. Guest readers can email us for any issues.
18 comments Subscribe

Doc Angelo 26 Mar 2018
The C# part of the Unity engine and editor source code.

Now this is an interesting step. Yet, it is only a part of it. Unreal and Cryengine are open and can be compiled by users. That's not the case with Unity. Apparently, you can get a "Source Code license" to see everything, but those will likely come with NDAs.
DamonLinuxPL 26 Mar 2018
Key word - reference purposes. So just look at part of this code and dont even try use it :) Anyway I think this is good move.

Crytek made a better move - two years ago published a CryEngine on github and few days ago also pulished Sandbox Editor :)
Asu 26 Mar 2018
hats off to unity.
oldrocker99 26 Mar 2018
View PC info
  • Supporter Plus
Crytek made a better move - two years ago published a CryEngine on github and few days ago also published Sandbox Editor :)

And it is a good a move for then as Google's having made Android free was for them.
STiAT 26 Mar 2018
and the C# reference source code is released under a license which only permits you to read the code, not modify it.

That means they're giving us the source code but don't let us help improve and bugfix the engine/editor if something is found? That's quite a strange step. Nobody says they'd have to give royalties out of hand, but that's a little strange to me. Maybe just the first step.
Purple Library Guy 26 Mar 2018
and the C# reference source code is released under a license which only permits you to read the code, not modify it.

That means they're giving us the source code but don't let us help improve and bugfix the engine/editor if something is found? That's quite a strange step. Nobody says they'd have to give royalties out of hand, but that's a little strange to me. Maybe just the first step.
The point is, if you want it, legally you still have to buy it. If they open source it, they can still charge for it, but they can't stop other people from distributing it for free, so who'd pay? They'd need some kind of support model or something to not go out of business.
johndoe 26 Mar 2018
I think they should go the UE4 (UnrealEngine4) way.


Last edited by johndoe on 26 Mar 2018 at 7:10 pm UTC
GustyGhost 26 Mar 2018
Strategic closedness. Unreal Engine are doing the same, I believe.

Maybe Godot will eat their lunch if they're not careful.
Doc Angelo 26 Mar 2018
Strategic closedness. Unreal Engine are doing the same, I believe.

With Unreal, the full source code is openly visible, and it is expected that you compile it yourself. With Unity, only a part of the source code is openly visible. If you want to see the rest of the code and compile the engine yourself, you have to purchase a "Source Code License".
aislan 27 Mar 2018
Strategic closedness. Unreal Engine are doing the same, I believe.

Maybe Godot will eat their lunch if they're not careful.

Do you think Godot is better or on par with Unity right now?
TheSHEEEP 27 Mar 2018
View PC info
  • Supporter Plus
Strategic closedness. Unreal Engine are doing the same, I believe.

Maybe Godot will eat their lunch if they're not careful.

Do you think Godot is better or on par with Unity right now?
It clearly isn't.
But that is also clearly a "yet".

Of all the engines, I think Godot has the greatest promise so far. It is just that well thought out and "manufactured".
If they can manage to get even more examples and documentation together, as well as improve the tech*, of course, they will be in a very good spot.

*Not that their current tech is bad, but the C#/Mono support is still not quite there. Instead they have this custom Python-like language which keeps many people away for "I don't wanna learn ANOTHER language" and performance reasons. It's really not a bad scripting language, but I would vastly prefer C# for the auto-completion capabilities and performance alone - and my personal distaste for non-static typed languages ;).
Also, Vulkan is on the horizon, which is awesome for obvious reasons.

I didn't dig in too deep, yet, so I don't really know about other fine details like performance in case of thousands of nodes on the screen, (does it have instancing?), etc.

Either way, the mere fact that it is pretty damn good already AND free is a huge plus.


Last edited by TheSHEEEP on 27 Mar 2018 at 2:51 pm UTC
tuubi 27 Mar 2018
View PC info
  • Supporter Plus
*Not that their current tech is bad, but the C#/Mono support is still not quite there. Instead they have this custom JS-like language which keeps many people away for "I don't wanna learn ANOTHER language" and performance reasons. It's really not a bad scripting language, but I would vastly prefer C# for the auto-completion capabilities and performance alone - and my personal distaste for non-static typed languages ;).
If your code is performance critical, you want GDNative and its C++, Rust or D bindings.

In any case, GDScript seems much closer to Python than JS based on code snippets.
STiAT 27 Mar 2018
and the C# reference source code is released under a license which only permits you to read the code, not modify it.

That means they're giving us the source code but don't let us help improve and bugfix the engine/editor if something is found? That's quite a strange step. Nobody says they'd have to give royalties out of hand, but that's a little strange to me. Maybe just the first step.
The point is, if you want it, legally you still have to buy it. If they open source it, they can still charge for it, but they can't stop other people from distributing it for free, so who'd pay? They'd need some kind of support model or something to not go out of business.

Well, that's about licensing, and yes, it's (partly) open source already since the source code is available. It's not free software though.

I don't say they should make it free software, but it would be nice if they allowed us to edit the code and send them patches for bugs or improvements found. I'm thinking about the way Id is doing it with the Unreal-Engine. You get the code if you subscribe, and you are still not allowed to redistribute it, but you are allowed to edit and send patches.
nattydread 27 Mar 2018
C#. Yuck.


Last edited by nattydread on 27 Mar 2018 at 12:47 pm UTC
Doc Angelo 27 Mar 2018
I absolutely love Godot. The first time I used it, it just clicked. The Scene/Node-System is just very nice to work with.

Some people say that Godot is better than Unity, Unreal and CryEngine. Some people say that it looks better and performs better. I have yet to see actual demos that back up these claims. And I don't think I will see one in the next few years.

You can't just outperform commercial products that are being in development for multiple years by a developer that has an own department just for the renderer, where multiple people work only on this part of the engine full time for many years. Godots renderer was completely rewritten over the last 2 years, if I remember correctly, for the most part by one single person, and not full time.

Godot is nice just the way it is. FOSS is more important to me than pure technical prowess. That's why I use Godot.


Last edited by Doc Angelo on 27 Mar 2018 at 1:17 pm UTC
TheSHEEEP 27 Mar 2018
View PC info
  • Supporter Plus
In any case, GDScript seems much closer to Python than JS based on code snippets.
Indeed, it is. Edited my post.
No idea how I came up with JavaScript *shrugs*

I like it for prototyping, but if I had to write something production ready in a game that I know will have certain performance bottlenecks, I'd rather write in something fast as Mono to begin with.
You can't write every piece of code that has a performance impact in C++, especially not if you are planning to deliver a game with modding capabilities (so you will use the same API modders will, more or less).
Plus, writing in a scripting language is just way faster, which is also worth a lot - otherwise you could just write the whole game in C++, and who does that any more?


Last edited by TheSHEEEP on 27 Mar 2018 at 2:51 pm UTC
GustyGhost 27 Mar 2018
Strategic closedness. Unreal Engine are doing the same, I believe.

Maybe Godot will eat their lunch if they're not careful.

Do you think Godot is better or on par with Unity right now?

I have at most done only hobbyist size projects in either and it's been a while since I'd tried Unity so for whatever it's worth, if you're just cooking up simple 3D projects using one of the available scripting languages Unity and Godot are functionally identical (aside from that Godot groups everything as "nodes").
Purple Library Guy 27 Mar 2018
Strategic closedness. Unreal Engine are doing the same, I believe.

Maybe Godot will eat their lunch if they're not careful.
Looking at how things have worked out in much of the software world, it's distinctly possible whether they're careful or not. Maybe not today, maybe not tomorrow, but in a few years. There are a whole pile of areas where anything platformy has tended to go open source over time. We happen to be operating in the one glaring exception (the desktop operating system), but as a general tendency the pull seems to be strong.
While you're here, please consider supporting GamingOnLinux on:

Reward Tiers: Patreon. Plain Donations: PayPal.

This ensures all of our main content remains totally free for everyone! Patreon supporters can also remove all adverts and sponsors! Supporting us helps bring good, fresh content. Without your continued support, we simply could not continue!

You can find even more ways to support us on this dedicated page any time. If you already are, thank you!
The comments on this article are closed.
Buy Games
Buy games with our affiliate / partner links: