-
Notifications
You must be signed in to change notification settings - Fork 177
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
Add basic force generator role functionality to MekHQ scenario random unit generation #4214
Conversation
…c atmosphere, wind, gravity
…added parameter to getLance for passing mandatory roles to entity creation methods
…ts/javadoc for readability
…ling infantry armor kit swaps
…arantee each unit's starting force roles are unique and can be modified independently.
… specific unit type
This looks amazing and allows for so many new possibilities. So if I read it correctly anytime X infantry is spawned it will check the weather and give them the appropriate kit? Will it work for the fixed mul units? E.g. the Horse Cavalary or the Air Mobile Infantry or Crack Field Artillery (which are always the same units given how the .muls work)? Id understand if it doesnt work that way with them. I may bug you with lots of questions! |
The fixed MUL units are generated in another method, so I don't think the infantry armor kit swaps will address those. The method which handles the replacement process should be callable for the fixed MUL forces, although there might need to be some jiggery-pokery to get environmental conditions to pass to that method. Not sure about the viability of a branth in parka, or breathing gear for horses though... |
if (scenario.getWind().isTornadoF1ToF3() || scenario.getWind().isTornadoF4()) { | ||
allowsConvInfantry = false; | ||
if (scenario.getWind().isTornadoF4()) { | ||
allowsTanks = false; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Freakin' glorious, this is excellent!
I see you added a new XML tag, would you mind Discord DMing me the process you took to do this? An improperly added XML tag was the cause of the incorrectly loading Fixed MUL issue and I'd like to not fall into that trap again. |
# Conflicts: # MekHQ/src/mekhq/campaign/mission/AtBDynamicScenarioFactory.java # MekHQ/src/mekhq/campaign/mission/ScenarioForceTemplate.java
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Tested and seems to work.
… specific unit type
…y-unit-type # Conflicts: # MekHQ/src/mekhq/campaign/mission/AtBDynamicScenarioFactory.java
@SuperStucco I'm not sure all the merges went well; it looks like some of the older CI files got pulled in as well. I will examine more closely when I get the time. |
Are you using IDEA? If so, check out |
Another option, would be to manually-copy paste your changes into a new branch and just chalk this one up as a loss. If there are still merge issues at that point, DM me on Discord and I'll walk you through resolving them. |
Wanted to check on this. Do you still need any help sorting this out? |
Yeah. Not sure what/how is getting messed up here, not exactly doing well with the build script (?) updates, and a number of related issues. Not even sure what I've got here is everything that was originally submitted. Quick edit: just double checked and I'm still getting some 'SerialKiller' thing which mean I can't even build to make debug passes. |
OK, I think I've gotten the issues worked out and it's building properly here. There's no code updates to push, and the failed check looked to be the gradle version/build script update problem which I've hopefully updated. |
Hi Stucco, it looks like you need to update your MM and (presumably) your MML repos to current. I spoke with Tex and they confirmed that's the current cause behind the Gradle test failing. In their words...
|
Might be part of the issue - I'm not working off a specifically named 'master' branch as parent. I've had more than a few issues in the past I consider the actual 'master' branch completely unreliable at this point. So I'm working off a number of other branches which are named other-than-master e..g. master-v3 for MM and master-mhq for MHQ. |
Someone else is going to have to take a whack at fixing this, because I'm just going in circles - SerialKiller error, then than goes away and is replaced with code errors (even though I haven't changed anything), then back again. |
Did you update your MM repo with the same branch name to the latest code of master? That is where the SerialKiller issue is coming from. Make sure all repos have been rebased with master for latest updates to build scripts. |
Closing as superceded by #4418 |
This is another chunky PR, touches lots of bits and pieces inside AtBDynamicScenarioFactory, some just for readability improvements (so I could follow along easily while testing). There's a minor interaction with pending #4164 (improved bomb selection), in that the populateAeroBombs(...) method gets called towards the bottom of the generateForce(...) method, but the two are complete independent.
Side note: due to the fixed MUL loading issue from #4213 and using similar functionality, did additional checking specifically for fixed MUL affects.
All these changes allow roles (EDIT: these are the force generator roles, from .../docs/RAT Stuff/rat-generator.txt) to be passed down from the 'generated force' level to the individual random unit selection. This has two immediate effects: artillery, and infantry in hostile environments.
Previously, artillery was read from a flag in the scenario settings and passed down through multiple levels using a specific boolean method parameter. That parameter has been removed, and the scenario flag is now used to add the ARTILLERY role to the force selection.
Infantry for hostile environments is an entirely new feature. When certain hostile conditions are present, either the XCT or MARINE roles are automatically added to the force selection for infantry, limiting what types of infantry are generated. Because there are so few official units that fit these parameters, a fall-back position has been included - if no explicit hostile environment infantry is available, normal infantry is generated and the armor kit is swapped out for hostile environment suits. As a bonus, under less hostile conditions that are still deadly to unprotected infantry, normal infantry will have their infantry kit swapped out for something appropriate e.g. snow/heatsuits for temperature, light environmental suits for low atmosphere pressure. The role selection and armor kit changes are applied to base scenario forces and scenario modifier forces, including infantry that is loaded into transport bays of APCs.
This PR adds in hooks to to allow force generator role filters to be added to the scenario template and scenario modifier XMLs. Each force can have an optional roleChoices element with one or more forceRole elements, using the same role formatting as the force generator XMLs. A single forceRole element will always be used while multiple instances will result in random selection. As an example, the HostileFacility.XML scenario template might look like this:
Two thirds of the time the Primary OpFor force will generate using the URBAN role, while the rest will be normal generation without roles (current behavior).
Similarly, the AlliedReinforcments.XML might look like this:
Each time the modifier is used, it randomly chooses between standard generation and fire support.
Using an empty forceRole entry will select with no roles, as does not including the block (which is current behavior).
Multiple roles can combined using commas and no spaces e.g. "support,cargo". The more roles that are combined the smaller the number to choose from, so use with caution. Roles may have restrictions that are incompatible with other force properties e.g. the RECON role should not be used on a force that may generate heavy or assault weight units. Naturally these role selection elements have no affect on fixed MUL unit selection, but should still be omitted for clarity.