File: README.md

package info (click to toggle)
freeorion 0.5.1-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 194,940 kB
  • sloc: cpp: 186,508; python: 40,969; ansic: 1,164; xml: 719; makefile: 32; sh: 7
file content (155 lines) | stat: -rw-r--r-- 5,352 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
# python directory

Python scripts, while modifiable, may require specific functions which return
an appropriate response to FreeOrion.
For example, turn_events/turn_events.py is a required file and should define
an `execute_turn_events()` function returning a boolean (successful completion).

## Contents

* `AI/` Python code which controls the computer players.  This is a
sub-module of the resource directory and can be changed with the --ai-path flag.
* `auth/` Python code which manages authentication information stored either in a file
or in a database.
* `chat/` Python code which manages chat history stored either in a file or in
a database.
* `common/` Common files for code utilized by both the AI and the server.
* `handlers/` debug and development features, see [handlers/README.md](handlers/README.md)
* `turn_events/` Python scripts that run at the beginning of every turn, and
can trigger events that would be impossible to do purely in FOCS.
* `universe_generation/` Python scripts that get run at the beginning of the
game and create the galaxy. You can customise the galaxy generation by
editing options.py and universe_tables.py, both of which have more information
in comments over there. The latter, specifically, controls which star types,
planet types, planet sizes, and also other content get placed.

# Development

## Setup environment
### Run game with AI files from the repository folder
This part is required if you use download builds. 
If you compile the code, it works with the repo folder.
- Run game
- Open Options
- Scroll left to Others
- Click generate persistent config
- Check `Config and log files path` value
- Open directory with config
- Edit `persistent_config.xml`
- ```xml
  <?xml version="1.0"?>
  <XMLDoc>
    <resource>
      <path>...repo_path\default</path>
      <stringtable>
        <path>...repo_path\default\stringtables\en.txt</path>
      </stringtable>
    </resource>
  </XMLDoc>
  ```
### Configure IDE
Add `default\python\` as content root.

### Install dependencies for code check tools
```sh
pip install -r default\python\requirements-dev.txt
```


## Developers routine

### It's recommended to install pre-commit hooks, see: [CONTRIBUTING.md](CONTRIBUTING.md)


### Manual code style check
You don't need to run this script manually, pre-commit hooks and CI will do it fo you.

We use [ruff](https://github.com/charliermarsh/ruff) for code style checks.
Settings for ruff are located in the `pyproject.toml`.

You could run ruff in any directory, and it will check the files in that directory only.
It's recommended to run in from the root.
```sh
ruff .
```

We use [black](https://pypi.org/project/black/) for code formatting.
Settings for black are located in `pyproject.toml`.

Black can be run on the top level directory:
```sh
black .
```

## Running test
We use [pytest](https://docs.pytest.org) as testing framework.
There is a various options to run tests.
I'd recommend running tests from your IDE, all modern has support of pytest.

Some useful command for console:
Run all tests recursively.
```shell
pytest
```

Run test from file/folder.
You could use relative or absolute paths.
```shell
pytest tests\AI\test_assertion_fails.py
```

Run specific test using test name.
```shell
tests/AI/test_assertion_fails.py::test_does_fail
```

## Debug via chat
To inspect current AI state in the game 
It's possible to start interactive console with AI.
It's the same REPL (Read-Print-Evaluate-Loop) as you have when 
starting Python from the console. With all AI variables in it.
You could print any AI variables, you could change them,
you could even reload some python files with `reload()`

Result is printed both to the chat and logs.

- Go to "logs and config" directory
- Open AI/default/config.ini
- Add `allow_debug_chat=1` to main section
  ```ini
  [main]
  allow_debug_chat=1
  ```
- Start application
- Start game
- Send `help` to chat
- Follow instructions

## Generating skeletons
To aid development we create skeleton files. 
This files looks like Python files with empty classes/function.

The only goal of these files is to provide autocomplete and basic static checks for code.

You could to regenerate files each time C++ API has changed. 
But since this is cosmetic only changes, this operation could be postponed.  

Generation is a bit tricky, we run script inside AI that try to extract data from the C++ API.
This process is not very precise and may produce slightly different result than real API.

To generate skeletons you need to run some hooks on AI, 
in order to do it  
- Run game with AI config 
  ```sh
  freeorion --ai-config freeorion\default\python\handlers\inspect_interface_config.ini 
  ```
  `freeorion` is a path to the game binary (freeorion.exe on Windows).
  `freeorion\default\python\handlers\inspect_interface_config.ini` path to file in this repository. 
  Note: that relative paths may not work, better specify an absolute path.
- Start a new game and wait until it exits to main menu with an error.
  Generated files will be saved to AI folder:
  - freeorion\default\python\freeorion.pyi
  - freeorion\default\python\AI\freeOrionAIInterface.pyi
  You can check full paths in `AI_1.log` and `freeoriond.log`
- If you run AI from the repo, generated files will be in place,
otherwise copy them to repository with replace and commit.