1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-08 00:39:47 +02:00
vcmi/docs/developers/Code_Structure.md

124 lines
5.5 KiB
Markdown
Raw Normal View History

2024-07-16 20:29:20 +02:00
# Code Structure
2023-09-01 14:25:21 +02:00
The code of VCMI is divided into several main parts: client, server, lib and AIs, each one in a separate binary file.
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
## The big picture
2023-08-12 23:17:38 +02:00
2023-09-07 11:57:03 +02:00
VCMI contains three core projects: VCMI_lib (dll / so), VCMI_client (executable) and VCMI_server (executable). Server handles all game mechanics and events. Client presents game state and events to player and collects input from him.
2023-08-12 23:17:38 +02:00
2023-09-01 14:25:21 +02:00
During the game, we have one (and only one) server and one or more (one for each player computer) clients.
2023-08-12 23:17:38 +02:00
2023-09-01 14:25:21 +02:00
Important: State of the game and its mechanics are synchronized between clients and server. All changes to the game state or mechanics must be done by server which will send appropriate notices to clients.
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
### Game state
2023-08-12 23:17:38 +02:00
2023-09-01 14:25:21 +02:00
It's basically CGameState class object and everything that's accessible from it: map (with objects), player statuses, game options, etc.
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
### Bonus system
2023-08-12 23:17:38 +02:00
2023-09-07 11:57:03 +02:00
One of the more important pieces of VCMI is the [bonus system](Bonus_System.md). It's described in a separate article.
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
### Configuration
2023-08-12 23:17:38 +02:00
2023-09-01 14:25:21 +02:00
Most of VCMI configuration files uses Json format and located in "config" directory
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
#### Json parser and writer
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
## Client
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
### Main purposes of client
2023-08-12 23:17:38 +02:00
2023-09-07 11:57:03 +02:00
Client is responsible for:
2023-08-12 23:17:38 +02:00
- displaying state of game to human player
- capturing player's actions and sending requests to server
- displaying changes in state of game indicated by server
2024-07-16 20:29:20 +02:00
### Rendering of graphics
2023-08-12 23:17:38 +02:00
Rendering of graphics relies heavily on SDL. Currently we do not have any wrapper for SDL internal structures and most of rendering is about blitting surfaces using SDL_BlitSurface. We have a few function that make rendering easier or make specific parts of rendering (like printing text). They are places in client/SDL_Extensions and client/SDL_Framerate (the second one contains code responsible for keeping appropriate framerate, it should work more smart than just SDL_Delay(milliseconds)).
2023-09-01 14:25:21 +02:00
In rendering, Interface object system is quite helpful. Its base is CIntObject class that is basically a base class for our library of GUI components and other objects.
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
## Server
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
### Main purposes of server
2023-08-12 23:17:38 +02:00
2023-09-07 11:57:03 +02:00
Server is responsible for:
2023-08-12 23:17:38 +02:00
- maintaining state of the game
- handling requests from all clients participating in game
- informing all clients about changes in state of the game that are
visible to them
2024-07-16 20:29:20 +02:00
## Lib
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
### Main purposes of lib
2023-08-12 23:17:38 +02:00
2023-09-01 14:25:21 +02:00
VCMI_Lib is a library that contains code common to server and client, so we avoid it's duplication. Important: the library code is common for client and server and used by them, but the library instance (in opposition to the library as file) is not shared by them! Both client and server create their own "copies" of lib with all its class instances.
2023-09-07 11:57:03 +02:00
iOS platform pioneered single process build, where server is a static library and not a dedicated executable. For that to work, the lib had to be wrapped into special namespace that is defined by client and server targets on iOS, so that single process is able to contain 2 versions of the library. To make it more convenient, a few macros were introduced that can be found in [Global.h](https://github.com/vcmi/vcmi/blob/develop/Global.h). The most important ones are `VCMI_LIB_NAMESPACE_BEGIN` and `VCMI_LIB_NAMESPACE_END` which must be used anywhere a symbol from the lib is needed, otherwise building iOS (or any other platform that would use single process approach) fails.
2023-08-12 23:17:38 +02:00
2023-09-07 11:57:03 +02:00
Lib contains code responsible for:
2023-08-12 23:17:38 +02:00
- handling most of Heroes III files (.lod, .txt setting files)
2023-09-01 14:25:21 +02:00
- storing information common to server and client like state of the game
- managing armies, buildings, artifacts, spells, bonuses and other game objects
- handling general game mechanics and related actions (only adventure map objects; it's an unwanted remnant of past development - all game mechanics should be handled by the server)
2023-08-12 23:17:38 +02:00
- networking and serialization
2024-07-16 20:29:20 +02:00
#### Serialization
2023-08-12 23:17:38 +02:00
2023-09-01 14:25:21 +02:00
The serialization framework can serialize basic types, several standard containers among smart pointers and custom objects. Its design is based on the [boost serialization libraries](http://www.boost.org/doc/libs/1_52_0/libs/serialization/doc/index.html).
In addition to the basic functionality it provides light-weight transfer of CGObjectInstance objects by sending only the index/id.
2023-08-12 23:17:38 +02:00
2023-09-07 11:57:03 +02:00
Serialization page for all the details.
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
#### Wrapped namespace examples
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
##### Inside the lib
2023-08-12 23:17:38 +02:00
2023-09-01 14:25:21 +02:00
Both header and implementation of a new class inside the lib should have the following structure:
2023-08-12 23:17:38 +02:00
`<includes>`
`VCMI_LIB_NAMESPACE_BEGIN`
`<code>`
`VCMI_LIB_NAMESPACE_END`
2024-07-16 20:29:20 +02:00
##### Headers outside the lib
2023-08-12 23:17:38 +02:00
2023-09-01 14:25:21 +02:00
Forward declarations of the lib in headers of other parts of the project need to be wrapped in the macros:
2023-08-12 23:17:38 +02:00
`<includes>`
`VCMI_LIB_NAMESPACE_BEGIN`
`<lib forward declarations>`
`VCMI_LIB_NAMESPACE_END`
`<other forward declarations>`
`<classes>`
2024-07-16 20:29:20 +02:00
##### New project part
2023-08-12 23:17:38 +02:00
2023-09-01 14:25:21 +02:00
If you're creating new project part, place `VCMI_LIB_USING_NAMESPACE` in its `StdInc.h` to be able to use lib classes without explicit namespace in implementation files. Example: <https://github.com/vcmi/vcmi/blob/develop/launcher/StdInc.h>
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
## Artificial Intelligence
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
### StupidAI
2023-08-12 23:17:38 +02:00
Stupid AI is recent and used battle AI.
2024-07-16 20:29:20 +02:00
### Adventure AI
2023-08-12 23:17:38 +02:00
2023-09-01 14:25:21 +02:00
VCAI module is currently developed agent-based system driven by goals and heroes.
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
### Programming challenge
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
### Fuzzy logic
2023-08-12 23:17:38 +02:00
VCMI includes [FuzzyLite](http://code.google.com/p/fuzzy-lite/) library to make use of fuzzy rule-based algorithms. They are useful to handle uncertainty and resemble human behaviour who takes decisions based on rough observations. FuzzyLite is linked as separate static library in AI/FuzzyLite.lib file.
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
## Utilities
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
### Launcher
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
### Duels
2023-08-12 23:17:38 +02:00
2024-07-16 20:29:20 +02:00
### ERM parser