The last folder we need for our own games is the one we'll be doing most of our work in as programmers. It's the place we'll be keeping all of our source code.
Now we've created a folder for our code to go in called AwesomeGame
, which is in the Development/Src
folder. In it we've created our first code file, AwesomeActor.uc
. We then edited DefaultEngine.ini
so the game would recognize our new code package.
The folders in the Development\Src
directory aren't automatically detected. The main reason for this is that in some cases we may not want or need the classes inside it. For instance, we may have different folders for a PC project and an iOS project. Both of them would be in the Development\Src
folder, but the PC version of our game wouldn't need the iOS code and vice versa. Remember when we went over the directory structure and we talked about the Config
folder? That folder contains all of the settings for our game. Let's take a look.
The file we added to, DefaultEngine
, contains things like the game's resolution and texture detail. It also contains the EditPackages list we added to, which tells the game which packages to compile and in what order.
As you can see, the names in this list can also be found as folders in the Development\Src
directory:
The list in DefaultEngine.ini
seems kind of short though, doesn't it? Well, much like the class we created is a child of Actor, DefaultEngine.ini
also has a parent. If we look at the top of DefaultEngine we can see this:
This .ini
file is actually based on another one, its parent DefaultEngineUDK.ini
. Let's close DefaultEngine.ini
and take a look at DefaultEngineUDK.ini
's EditPackages list.
That's a bit better. UDKBase and UTEditor are two more folders in our Development\Src
directory. But there are a lot more folders there, so what's the deal? Let's see if we can go higher up the ini tree to find out. At the top of DefaultEngineUDK.ini
we see that this file also has a parent:
Let's close DefaultEngineUDK.ini
and take a look at BaseEngine.ini
, which is in the Engine\Config
directory.
That's better! It looks like all of the folders are accounted for now, except for MyMod which is an empty example folder. And if we look at the top of BaseEngine.ini
we can see that this is the end of the chain, BaseEngine doesn't have a parent.
So how does the game use these files? If you haven't run the game or compiled the code when we installed ConTEXT, run the game real quick and exit out of it at the main menu. The first time the game is run, it uses all of the Default and Base ini files to generate the ones the game actually uses in the UDKGame\Config
directory:
So the obvious question is why are there so many files? Well, let's take another look inside BaseEngine.ini
to see why. About two-thirds of the way down the file we can see a list of system settings:
These settings control some of the visual effects in the game like motion blur and bloom. What would happen if we changed them? It would change the game's visual effects of course, but here's another question. While playing the game, in the Settings we're able to revert back to the defaults. If we changed the settings in these files, how would the game know what the default was? The game uses the Base and Default ini files to create the UDK ones, that way the player can change things like the resolution or keybinds, but the game will still have the known safe default settings available if it needs them. It may seem a bit complicated but it's pretty easy to work with. As the game's developer we would work in the Default and Base ini files to make the game work the way we want by default, and the player can change the settings if they want to.
Now that AwesomeGame has been added to the EditPackages list we'll be able to compile it. But why did we have to add AwesomeGame to the very end of the list? The way the compiler works is that it goes down the EditPackages list in order and looks for any changes to the files in the Development\Src
directory. If any .uc
files are changed it recompiles that package. It's also important to know that any package that our classes are dependent on has to be compiled before ours. As an example, let's take a look at DefaultEngine.ini
again. One of the EditPackages listed is UTGameContent
. In the UTGameContent
folder we can see a class called UTJumpBoots
. If we wanted to make our own jump boot class with UTJumpBoots
as its parent, we have to make sure that UTGameContent
is compiled before our package, otherwise the compiler won't know about that class yet and will give us an error saying our class' parent doesn't exist.