Hi guys.
I'm just wondering if it's possible to get rid of all the XML by cegui and load everything programmatically. Now you may think this makes no sense but it would be nice for me to know that I have this possibility. Having XML that are parsed at every startup of a game, when the output is always the same makes little sense. I would prefer to just populate everything with function calls, which would be much faster and it reduces the file dependencies.
Also it simplifies support enormously. Consider a normal file corruption, it's easy to know when a binary is corrupt but how do you detect that a xml is corrupt? Your user will never be able to tell and you'll end up telling them to reinstall the game in many cases. The less stuff that is outside the binary the better. Also, currently my app consists of a single exe which is pretty cool, I wouldn't want to lose this because of cegui,
So, is this possible at all?
- For XML resources, to construct them with calls to the api.
- For binary resources such as fonts and imageset textures to have them as resources of your exe and send them to cegui somehow.
If so, any pointers would be appreciated. (And please don't do like many open source projects and just tell me that I don't need to do this, I have my own reasons and I would like to know if it's possible).
Thanks in advance!
Getting rid of XML resources
Moderators: CEGUI MVP, CEGUI Team
Re: Getting rid of XML resources
You can always create a custom ResourceProvider. There are no existing ResourceProviders that do what you want, afaik. I think the OGRE ResourceProvider can load resources from zip files. I don't suspect it would be too difficult to create a custom provider to load resources from a binary file and/or directly from memory/the exe.
If somebody helps you by replying to your thread, upvote him/her as a thanks! Make sure to include your CEGUI.log and everything you tried when posting! And remember that we are not magicians!
- CrazyEddie
- CEGUI Project Lead
- Posts: 6760
- Joined: Wed Jan 12, 2005 12:06
- Location: England
- Contact:
Re: Getting rid of XML resources
(And please don't do like many open source projects and just tell me that I don't need to do this, I have my own reasons and I would like to know if it's possible).
This is actually one of my pet hates. The number of times you see it on forums where a very specific question is asked, and rather than seeing the question answered you'll invariably find a dozen guys saying why not to do that, and how they'd do it instead - well that's all fine and dandy, but it's not what was asked I think it's totally cool for people to give alternative ideas and implementations, BUT ANSWER THE FUCKING QUESTION, TOO!!
Anyway, getting back to CEGUI...
It is generally possible to create via code everything that's possible to create via XML files (somewhat version dependant, since there was/is some nasty 'friend' abuse going on, especially in the Font classes - I don't remember if I removed that in 0.7.0 or just grimaced and thought that I'll get rid of it later!). The interfaces for doing this are sometimes less documented (thinking of the Falagard stuff here), but they are there (you'd have to ask for specifics, once you get that far). This being said, defining an entire looknfeel skin in code is not something I'd ever want to try (But, the question you asked is answered )
I do think Jamarr's suggestion of a custom ResourceProvider that accesses resources from the executable module is the way to go. So you'll perhaps still have XML - at least for some things (thinking of skin definitions here) - but it's embedded with the other resources and so allows you to maintain your single file approach.
BTW, to get a single file linked output for CEGUI (i.e. no DLLs at all), you'll likely need the v0-7 svn code and the updated dependencies since prior to this we had some issues and some of the deps were still DLL based even for static linking. The 0.7.1 release will fix this (expected some time in the next couple of weeks).
CE.
Useful Links: Forum Guidelines | Documentation | Tutorials | HOWTO | Videos | Donate to CEGUI | CEGUI Twitter
-
- Just popping in
- Posts: 5
- Joined: Mon Oct 12, 2009 13:55
Re: Getting rid of XML resources
Sorry for reviving an old thread, I wanted to answer sooner but I didn't have my password at hand and since you can't recover a pass... (I know, I know it's sourceforge's fault).
So thanks a lot for your answers. I think I'll try the resource provider route and just have my XML's as constants or resources in my exe, doesn't solve the efficiency problem but it gives me what I want for support reasons.
haha, yeah, i hate that too. I was specially bitter the day I created this thread because I had asked 2 questions in Ogre's forums and I got the same answer both times, saying that I don't really need that, and one of them was *really* rude.
So thanks a lot for your answers. I think I'll try the resource provider route and just have my XML's as constants or resources in my exe, doesn't solve the efficiency problem but it gives me what I want for support reasons.
This is actually one of my pet hates. The number of times you see it on forums where a very specific question is asked, and rather than seeing the question answered you'll invariably find a dozen guys saying why not to do that, and how they'd do it instead - well that's all fine and dandy, but it's not what was asked I think it's totally cool for people to give alternative ideas and implementations, BUT ANSWER THE FUCKING QUESTION, TOO!!
haha, yeah, i hate that too. I was specially bitter the day I created this thread because I had asked 2 questions in Ogre's forums and I got the same answer both times, saying that I don't really need that, and one of them was *really* rude.
Who is online
Users browsing this forum: No registered users and 4 guests