When King of Thieves was started as a codebase, the decision was to use XNA. It was a rather nice framework around DirectX which provided a sprite batch, sound system, xinput, basically everything you need to get started on writing a game. Unfortunately for us, Microsoft decided to pull the plug on it.
Refer to
this article here.
This poses a huge problem as this means that the engine will deprecate with XNA. Not good. My intent is just to get the idea out there that some grunt work has to be done to save King of Thieves from the blackhole that is XNA. Anyone can go in their own direction with how they feel they should solve this problem, so keep this in mind that the team controlling King of Thieves may or may not accept your merge request if you decide to fix this problem!
So, we have ourselves a few exit plans:
(Note: I am going over every possible case that I can think of, and list everything out. And King of Thieves in this thread = the game engine, NOT the game)
- Find a drop-in replacement framework(like MonoGame) which implements the entire XNA Stack.
Pros:
No code changes needed on our end
Less maintenance
Cons:
Uncertainty with licensing. i.e. MonoGame requires users to pay a fee if they intend selling their game. Sure, we are making fan games with this but what if someone were to use this codebase for making a game?
- Replace the XNA functions that we use with our own implementations.
Pros:
Minimalizes the amount of extra code that could possibly be introduced by adding a drop-in XNA replacement.
In-The-Middle:
Makes KoT more of a "game engine framework" than just a "game framework".
Cons:
Extra maintenance
Potential for added code complexity
-Continue using XNA.
Pros:
Wooo no work needed on us!
Cons:
Deprecation of XNA.
Annd.. this being an open source project, I am going to actually work on chasing after my own solution. It's something I feel would be a "fun" project, a new entry to my resume, and why the hell not. Even if the team don't accept my work, it can be used by anyone else who may want to use it!
I'm leaning towards cherry-picking out the XNA-specific extensions that are used in King of Thieves and to write my own drop-in replacements for them. I am arguing that MonoGame's not exactly the solution we're looking for in terms of King of Thieves as it adds yet another level of complexity(at least in terms of SDKs), and maybe King of Thieves should resemble a game engine. Since there's a reference implementation already in place that works with XNA, this would actually act as a good way to show that you can swap out the internals for different technologies to meet your needs, if you need to.
I am doing research now as to whether or not I want to use OpenTK, SDL, or SFML. There are pros and cons to each and every one of these paths.. I am simply looking for something that may or may not work.
At the time this post has been written, I've only managed to convert the codebases over to VS 2013. They're not committed quite yet. So, the repos are exactly matched with the base.
Repository URL:
https://github.com/gm112/King-of-ThievesShare your thoughts!