Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

QtFRED campaign editor #3392

Merged
merged 87 commits into from
Mar 15, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
87 commits
Select commit Hold shift + click to select a range
52427a7
Add initial CampaignEditorDialog
the-maddin Apr 19, 2021
3768473
Add more slots
the-maddin Apr 23, 2021
04c136f
add model with initial functionality
the-maddin Apr 23, 2021
7acd4c6
sync changes to model (initial)
the-maddin Apr 23, 2021
c4f84ea
alternative layout
the-maddin Apr 23, 2021
53e30ba
Connect some more signals/slots
the-maddin Apr 25, 2021
ca23d30
File ops UI logic, cleanup
the-maddin Apr 27, 2021
30237c8
initial updateUI, explicit model modification
the-maddin Apr 29, 2021
da83c3a
Tie campaignmodel to campaign file, use QStrings in
the-maddin Apr 30, 2021
e2b9a5a
Initial campaign loading & trivial uiUpdate
the-maddin May 2, 2021
5cbe64c
Implement initial ships/weapons lists, intialize
the-maddin May 4, 2021
f2cfac1
Fix compile issue, correct reload behaviour
the-maddin May 5, 2021
fc65df0
Register initial... lists changes
the-maddin May 5, 2021
232eb2a
Allow full-length paths for campaign files
the-maddin May 9, 2021
54a64cb
Deal with windows filenames in CFile
the-maddin May 13, 2021
881f476
Use CheckedDataListModel improvements
the-maddin May 25, 2021
20fc9d6
Create available mission list
the-maddin May 24, 2021
ca982fa
Immutable campaignType, file load & menu changes
the-maddin May 26, 2021
80fc7a5
gcc11: add missing include
the-maddin May 17, 2021
9241c49
Warn before dropping unloadable missionDropped
the-maddin May 27, 2021
6e2723a
Update widgets on mission selection change
the-maddin May 28, 2021
3349c99
Clean up data entry widget signalling
the-maddin May 29, 2021
1a81682
Show player number of multi campaigns
the-maddin May 30, 2021
144ae46
model initialisation cleanup
the-maddin May 30, 2021
f7ecb85
CampaignMissionData: load cmission, display
the-maddin May 30, 2021
61fb9c5
CMission Data: use combo boxes where possible
the-maddin May 30, 2021
c2e8ba9
Use campaign branch sexp_tree and load formulas
the-maddin Jun 13, 2021
b21d380
Handle branch tree selection
the-maddin Jun 15, 2021
3fd825b
SaveAs shortcut
the-maddin Jun 16, 2021
9011319
Use new CheckedDataListModel
the-maddin Jun 17, 2021
b64bd78
Some more clang fixes
the-maddin Jun 18, 2021
33b63e5
Implement FRED-Mission button
the-maddin Jun 19, 2021
f405496
Clang-tidy fixes
the-maddin Jun 19, 2021
c95fe1c
clang
the-maddin Jun 20, 2021
b193990
load and display loop data
the-maddin Jun 20, 2021
93a1f3e
Use finer UI update control instead of modelChanged
the-maddin Jun 26, 2021
a7badba
cleanup
the-maddin Jun 26, 2021
b97129d
Cleanup mission list loading, drop mission object
the-maddin Jun 27, 2021
dd2c5a2
Comboboxes for loop brief & anim
the-maddin Jun 28, 2021
856726d
pick pulled model changes
the-maddin Jun 28, 2021
16a5b1c
Improve mission list robustness
the-maddin Jun 28, 2021
ec84c71
comboBox tweak
the-maddin Jun 29, 2021
8db39a6
WIP note
the-maddin Jun 29, 2021
ae9b604
Merge branch 'master' into qt-campaign-editor
the-maddin Jun 29, 2021
5e57094
Merge branch 'master' into qt-campaign-editor
the-maddin Sep 19, 2021
41d6563
validate and use current branch index
the-maddin Jul 1, 2021
2f36134
Parse eligible & campaign missions for event names
the-maddin Jul 11, 2021
458d2f5
custom mission selection & linking context menu
the-maddin Jul 18, 2021
439f633
Add branches & conditions in model
the-maddin Aug 1, 2021
eec2ce1
Model structure and TextEdit cleanup
the-maddin Aug 4, 2021
2989034
Dialog cleanup
the-maddin Aug 12, 2021
30b484b
Use AssociatedPlainTextDocument
the-maddin Aug 12, 2021
b08109c
Fix branch sexptree popup menu part 1
the-maddin Aug 19, 2021
c41e5c9
Always replace corrupted model after load attempt
the-maddin Aug 22, 2021
19817f4
reorder model impl and lazy init some constants
the-maddin Aug 22, 2021
e209927
Fix branch sexptree popup menu part 2
the-maddin Aug 27, 2021
e37ca8f
Model data access fix
the-maddin Aug 27, 2021
e41bde6
Fix branch sexptree popup menu part 3
the-maddin Aug 31, 2021
413842c
Branch moving & branch UI misc
the-maddin Sep 19, 2021
15752d1
Integrate branch buttons into context menu
the-maddin Sep 24, 2021
5eb4c35
clang msvc
the-maddin Sep 28, 2021
a8483c5
Saving part 1: Output Campaign to file
the-maddin Oct 15, 2021
636f693
Ensure correct flags and loop state
the-maddin Nov 8, 2021
4857f32
Saving part 2: Campaign Specs to Campaign
the-maddin Jan 6, 2022
0d82ca5
clang stuff
the-maddin Jan 8, 2022
566d15d
Add first mission selection, always keep valid
the-maddin Jan 8, 2022
84cb7fd
Export campaign model to Campaign struct
the-maddin Mar 20, 2022
8bf51ff
fix CheckedDataListModel pointer issue
the-maddin Mar 24, 2022
48f99e3
Merge branch 'master' into qt-campaign-editor
the-maddin Mar 24, 2022
f142780
clang
the-maddin Mar 24, 2022
ccf8629
incorporate feedback
the-maddin Mar 28, 2022
e3a153e
Clarify abbreviations
the-maddin Apr 11, 2022
e5f80a1
incorporate feedback
the-maddin Apr 20, 2022
0a7ff1b
changes jg18 v3
the-maddin Apr 28, 2022
d9a9cb5
changes z64555 v1.1
the-maddin May 8, 2022
ec3ad17
changes z64555 v1.2
the-maddin May 8, 2022
9336d72
changes z64555 v1.3
the-maddin May 15, 2022
401a266
changes z64555 v1.4
the-maddin May 22, 2022
2eb6410
Merge branch 'master' into qt-campaign-editor
the-maddin May 22, 2022
5d0fadb
doxy
the-maddin May 23, 2022
3d5ae71
Merge remote-tracking branch 'refs/remotes/upstream/master' into qt-c…
the-maddin Jun 4, 2022
2c5f52a
Integrated error checking
the-maddin Jun 6, 2022
a1fc090
unified warning message handling
the-maddin Jun 12, 2022
db68e30
fix qvector error
the-maddin Jun 13, 2022
ddeb40a
checks fix
the-maddin Jun 24, 2022
439c22b
Merge branch 'master' into qt-campaign-editor
the-maddin Feb 20, 2023
4e9309a
Comment branch types
the-maddin Feb 20, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 3 additions & 3 deletions code/menuui/readyroom.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1312,7 +1312,7 @@ void api_sim_room_build_mission_list(bool API_Access)
//
void sim_room_do_frame(float /*frametime*/)
{
char buf[256];
char buf[CF_MAX_PATHNAME_LENGTH + 4]; // must hold at most the Campaign.name and a file extension (4 chars)
int i, k, y, line;
int font_height = gr_get_font_height();
int select_tease_line = -1; // line mouse is down on, but won't be selected until button released
Expand Down Expand Up @@ -1440,8 +1440,8 @@ void sim_room_do_frame(float /*frametime*/)
gr_printf_menu(list_x2, Mission_list_coords[gr_screen.res][1], "%s", buf);

// blit the proper icons if necessary
char full_name[256];
memset(full_name, 0, 256);
char full_name[CF_MAX_PATHNAME_LENGTH + 4];
memset(full_name, 0, CF_MAX_PATHNAME_LENGTH + 4);
strcpy_s(full_name, cf_add_ext(Campaign.filename,FS_CAMPAIGN_FILE_EXT));
fs_builtin_mission *fb = game_find_builtin_mission(full_name);
if(fb != NULL){
Expand Down
2 changes: 1 addition & 1 deletion code/mission/missioncampaign.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -463,7 +463,7 @@ int mission_campaign_load(const char* filename, const char* full_path, player* p

// copy filename to campaign structure minus the extension
auto len = strlen(filename) - 4;
Assert(len < MAX_FILENAME_LEN);
Assert(len + 1 < CF_MAX_PATHNAME_LENGTH);
strncpy(Campaign.filename, filename, len);
Campaign.filename[len] = '\0';

Expand Down
3 changes: 2 additions & 1 deletion code/mission/missioncampaign.h
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@

#include "stats/scoring.h"
#include "parse/sexp.h"
#include "cfile/cfile.h"
#include "parse/sexp_container.h"

struct sexp_variable;
Expand Down Expand Up @@ -108,7 +109,7 @@ class campaign
{
public:
char name[NAME_LENGTH]; // name of the campaign
char filename[MAX_FILENAME_LEN]; // filename the campaign info is in
char filename[CF_MAX_PATHNAME_LENGTH]; // filename the campaign info is in
the-maddin marked this conversation as resolved.
Show resolved Hide resolved
char *desc; // description of campaign
int type; // type of campaign
int flags; // flags - Goober5000
Expand Down
37 changes: 24 additions & 13 deletions fred2/campaigntreewnd.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -311,16 +311,20 @@ int campaign_tree_wnd::error_checker()

g_err = 0;
for (i=0; i<Total_links; i++) {
// #1 check: illegal source mission
if ( (Links[i].from < 0) || (Links[i].from >= Campaign.num_missions) )
return internal_error("Branch #%d has illegal source mission", i);
// #2 check: illegal target mission
if ( (Links[i].to < -1) || (Links[i].to >= Campaign.num_missions) )
return internal_error("Branch #%d has illegal target mission", i);
// #3 check: formula syntax
Sexp_useful_number = Links[i].from;
if (fred_check_sexp(Links[i].sexp, OPR_BOOL, "formula of branch #%d", i))
return -1;

z = Links[i].from;

// #4 check: always true loop
if (Links[i].is_mission_loop || Links[i].is_mission_fork) {
if (Links[i].sexp == Locked_sexp_true) {
if (error("Mission \"%s\" has a loop branch that is always true", Campaign.missions[z].name))
Expand All @@ -333,11 +337,13 @@ int campaign_tree_wnd::error_checker()
// total number of regular links
mcount[z]++;

// #5 check: always false branch
if (Links[i].sexp == Locked_sexp_false) {
if (error("Mission \"%s\" branch %d is always false", Campaign.missions[z].name, mcount[z]))
return 1;
}

// #6 check: true middle branch
if (Links[i].sexp == Locked_sexp_true) {
if (true_at[z] >= 0)
if (error("Mission \"%s\" branch %d is true but is not last branch", Campaign.missions[z].name, true_at[z]))
Expand All @@ -347,24 +353,13 @@ int campaign_tree_wnd::error_checker()
}
}

// check that all missions in a multiplayer game have the same number of players
if ( Campaign.type != CAMPAIGN_TYPE_SINGLE ) {
for (i = 0; i < Campaign.num_missions; i++ ) {
mission a_mission;

get_mission_info(Campaign.missions[i].name, &a_mission);
if ( a_mission.num_players != Campaign.num_players ) {
if ( error("Mission \"%s\" has %d players. Multiplayer campaign allows %d", Campaign.missions[i].name, a_mission.num_players, Campaign.num_players) )
return 1;
}
}
}

// #7 check: not always true last branch
for (i=0; i<Campaign.num_missions; i++)
if (mcount[i] && true_at[i] < mcount[i])
if (error("Mission \"%s\" last branch isn't set to true", Campaign.missions[i].name))
return 1;

// #8 check: duplicate mission
for (i=z=0; i<Campaign.num_missions; i++) {
for (j=0; j<Campaign.num_missions; j++)
if ((i != j) && !stricmp(Campaign.missions[i].name, Campaign.missions[j].name))
Expand All @@ -374,13 +369,29 @@ int campaign_tree_wnd::error_checker()
z++;
}

// #9 check: no first mission
if (!z)
if (error("No top level mission present in tree"))
return 1;

// #10 check: duplicate first mission
if (z > 1)
return internal_error("More than one top level mission present in tree");

// #11 check: Multi player number
// check that all missions in a multiplayer game have the same number of players
if ( Campaign.type != CAMPAIGN_TYPE_SINGLE ) {
for (i = 0; i < Campaign.num_missions; i++ ) {
mission a_mission;

get_mission_info(Campaign.missions[i].name, &a_mission);
if ( a_mission.num_players != Campaign.num_players ) {
if ( error("Mission \"%s\" has %d players. Multiplayer campaign allows %d", Campaign.missions[i].name, a_mission.num_players, Campaign.num_players) )
return 1;
}
}
}

return 0;
}

Expand Down
5 changes: 5 additions & 0 deletions qtfred/source_groups.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,8 @@ add_file_folder("Source/Mission/Dialogs"
src/mission/dialogs/AbstractDialogModel.h
src/mission/dialogs/AsteroidEditorDialogModel.cpp
src/mission/dialogs/AsteroidEditorDialogModel.h
src/mission/dialogs/CampaignEditorDialogModel.cpp
src/mission/dialogs/CampaignEditorDialogModel.h
src/mission/dialogs/CommandBriefingDialogModel.cpp
src/mission/dialogs/CommandBriefingDialogModel.h
src/mission/dialogs/CustomWingNamesDialogModel.cpp
Expand Down Expand Up @@ -100,6 +102,8 @@ add_file_folder("Source/UI/Dialogs"
src/ui/dialogs/BackgroundEditorDialog.cpp
src/ui/dialogs/BriefingEditorDialog.cpp
src/ui/dialogs/BriefingEditorDialog.h
src/ui/dialogs/CampaignEditorDialog.h
src/ui/dialogs/CampaignEditorDialog.cpp
src/ui/dialogs/CommandBriefingDialog.cpp
src/ui/dialogs/CommandBriefingDialog.h
src/ui/dialogs/CustomWingNamesDialog.cpp
Expand Down Expand Up @@ -171,6 +175,7 @@ add_file_folder("UI"
ui/AsteroidEditorDialog.ui
ui/BackgroundEditor.ui
ui/BriefingEditorDialog.ui
ui/CampaignEditorDialog.ui
ui/CommandBriefingDialog.ui
ui/CustomWingNamesDialog.ui
ui/EventEditorDialog.ui
Expand Down
Loading