-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME.txt
138 lines (103 loc) · 5.39 KB
/
README.txt
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
=== Information about Civ4 mod updater component ===
Features:
• Adds extra screen to main menu which inform user about mod updates.
• Installs mod updates (= unzip + some sugar) with one click within the game.
• Python code also works without starting Civ4. This allows updating
by command line, i.e.
'cd Mods/[MODNAME]; python Assets/Python/Extras/ModUpdater.py'
Usage:
As user: Just click on 'search updates' in the main screen.
If an error occours, remove update_config.json and update_info.json.
As mod developer:
To prepare your mod update, just…
1. Put all changed/new files of your mod into a zip archive.
Use the mod directory as root directory.
2. (optional) Add the file 'update_info.json' into the zip archive.
The name field should equals the link name in step 3!
{
"name": "Update 1.zip",
"desc": "My update description",
"mod_files_to_remove": ["Assets\\Python\\some_file.py"]
}
3. Put the archive on your webserver (or github, forum attachment, etc)
and add a link to your updates.html site, i.e.
<a href="example_update001.zip" checksum="-1">Update 1.zip</a><br />
4. (Optional) Add correct checksum of your update zip. Useful if you
not host the zip on your own...
On *nix systems use 'md5sum [Zip file]' to get the md5 checksum.
If you use git for your mod development you could automatize above steps with
following script:
createUpdate.py (for Linux, Windows with Git Bash Shell+7z)
Requirements:
• Web space to provide "updates.html" and the update zip's (i.e. update001.zip)
The html-file just lists links to all updates.
Use PBStats/tests/Updater/server as example/template for your mod.
• Implementation of some extra DLL functions, see dll_changes.diff
Copy the *.obj-Files into your CvGameCoreDLL folder! They contain some Boost libaries
for boost::thread, etc.
It is difficult to compile them today on your own because Boost 1.32
is very old…
• Adding of new Screen (Python/Screens/CvModUpdater.py, XML/Text/PBModUpdater.xml) and
updater file (Python/Extra/ModUpdater.py, Python/Extra/simplejson.py)
• Add update_config.json to your mod with following content:
{
"update_urls": ["http://localhost:8000/[MODNAME]"],
"visit_url": "http://Your_Mod_homepage",
"current_version": "__vanilla__",
"check_at_startup": 0
}
Notes:
Above struct could be out-dated. Current values can be found in ModUpdater.load_config(self)
The "mod_path" key should not be defined because it will be auto detect.
Implementation:
A minimal working example mod is included: Mods/Updater.
New Files:
./Python/Screens/CvModUpdaterScreen.py
./Python/Extras/simplejson.py
./Python/Extras/ModUpdater.py
./XML/Text/PBModUpdater.xml
./CvGameCoreDLL.dll
Changed Files: (search for 'Updater Mod')
./Python/Screens/CvScreenEnums.py
./Python/CvEventManager.py
Notes:
- To minimize the number of affected files, some function definitions will be made on runtime,
see Python/Screens/CvModUpdaterScreen.integrate()
- DLL changes could be found in Mods/Updater/CvGameCoreDLL/
A few more notes for Modders:
• The Python version of Civ4 has no encription libs included. You can not fetch files from https sites but http only.
• The Python version of Civ4 does not contain zlib-support, too! Thus, you can not just use the internal
python lib to unzip files, but the indirection over the dll.
• Normally, you can not decide if the user has installed the mod into the game installation directory
or My Games\Beyond the Sword\Mods. You can just guess, but in some corner cases not.
This Mod contains a reliable way to detect the correct path. It ask the operating system where
the CvGameCoreDLL.dll is located.
• Adding a Screen to the main menu is a bit tricky! You can not use the OnInit-Eventhandler
because it fires to early. At this game startup stage, it is not possible to draw anything
on the screen.
The only useful event handler is onWindowActivation. Unfortunately, the first call of this event
has two pitfalls.
Firstly, some data is still not initialized and i.e.
CyTranslator.getText can throw a C++-Exceptions and the call of
CvModUpdaterScreen.getScreen also fails.
Secondly, the drawing of the main menu begins after onWindowActivation(). This hides everything
behind the background image.
To solve this timing issue the first drawing of the screen is now
triggered in "CvGame::getActivePlayer". This will be called from the main menu event loop.
Issues:
• Unzipping does not work in WINE. The (correct) path is not acceptad as valid in…
The problematic code part:
pISD->NameSpace( InZipFile, &pZippedFile); // Returns NULL in Wine :-(
if (!pZippedFile)
{
pISD->Release();
LOG("Zip file not found.");
return 1;
}
As workaround you can update over cli:
Run Assets/Python/Extras/ModUpdater.py with a python2 interpreter.
Extras:
• To automate the update zip creation, the 'createUpdate.py' script can be used (Linux/Mac only).
Thanks:
The Caveman2Cosmos developer, who compiled the missing boost libraries for the ancient 1.32 version.
F1rpo: For the getActivePlayer suggestion and the hint how to rename exported functions.