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

Feature: Multi-tile depots #9577

Open
wants to merge 17 commits into
base: master
Choose a base branch
from

Conversation

J0anJosep
Copy link
Contributor

@J0anJosep J0anJosep commented Sep 26, 2021

Motivation / Problem

Replacing thousands of old steam trains with monorail replacements is tiresome.
Also, if trains have a "Go to depot X", several trains may be waiting for entering a depot if one train is already entering or leaving the depot.

Description

This PR allows joining several depot tiles for the same vehicle type into one single depot. For joining them, I have tried to use the same criteria as for joining station tiles.

Replacements with different railtypes are enabled with the option "allow replacing rail vehicles with incompatible railtype". The same applies for road vehicles. Then, users can build a monorail depot tile joined to a normal rail type depot and replacements are much easier.
replacement

If trains get stuck when trying to enter a depot, add more tiles to the depot for easing it.
depot_interaction

#8480 adds extended depots (which are not included here) and also contains the commits of this PR.

Limitations

If a hangar or depot has several tiles, user cannot control in which tile a new vehicle is bought. (On the other hand, the hangar window shows all vehicles in all hangars of the airport: I see this as something good, as in this way it is more difficult to miss stopped aircraft in an airport.)

I don't know whether this feature can be accepted. It adds more settings and getting used to this feature takes time.

The PR touches thousands of lines of code. There are some things I am not happy with yet and I don't have much time to revise it. Code reviews of this PR can help me to improve it, as it will hint me which parts I need to work on.

Possible To-do (discarded by now)

  • Check exploit when rearranging train chains. (add cost for moving vehicles inside the depot/move train chain to some tile to make the exploit more difficult). This can also happen when transferring cargo from one train to another using a station. But as loading/unloading takes time, it is difficult to exploit it.
  • When buying a new train vehicle and appending it to an existing chain, keep the tile of the existing chain. Add no cost.
  • When issuing a move train chain command, add a cost for vehicles that teleport (distance + heightlevelincrease).
    Note: leaving the depot at a speed of 0 is a penalty to consider, but maybe not enough for steep landscapes.

Checklist for review

Some things are not automated, and forgotten often. This list is a reminder for the reviewers.

  • The bug fix is important enough to be backported? No (label: 'backport requested')
  • This PR touches english.txt or translations? Yes Check the guidelines
  • This PR affects the save game format? Yes (label 'savegame upgrade')
  • This PR affects the GS/AI API? Yes (label 'needs review: Script API')
    • ai_changelog.hpp, gs_changelog.hpp need updating.
    • The compatibility wrappers (compat_*.nut) need updating.
  • This PR affects the NewGRF API? No

@J0anJosep J0anJosep changed the title Multi-tile depots Feature: Multi-tile depots Sep 26, 2021
@nielsmh
Copy link
Contributor

nielsmh commented Sep 26, 2021

So just to make sure I understand this: This is not about allowing "long" depots, or requiring that players build larger depots to contain bigger train or more trains, but simply letting multiple adjacent depots act as one single depot with multiple entryways?
Does this protect against "teleportation" exploits?

Sorry, something went wrong.

@J0anJosep
Copy link
Contributor Author

J0anJosep commented Sep 26, 2021

So just to make sure I understand this: This is not about allowing "long" depots, or requiring that players build larger depots to contain bigger train or more trains, but simply letting multiple adjacent depots act as one single depot with multiple entryways?

Yes

Does this protect against "teleportation" exploits?

No, it can be exploited by rearranging train chains. Currently depot size is limited by station_spread setting. So users could "teleport" wagons up to 64 tiles. I will look into it and think about adding a cost for moving vehicles from one tile to the other or moving the whole chain to an appropriate tile for making exploits more difficult.

Sorry, something went wrong.

@PeterN
Copy link
Member

PeterN commented Sep 27, 2021

Are non-contiguous depots prevented?

Sorry, something went wrong.

@2TallTyler
Copy link
Member

2TallTyler commented Sep 27, 2021

I like this a lot. Is it a (large) baby step toward #8480, or an alternative proposal?

@J0anJosep
Copy link
Contributor Author

J0anJosep commented Sep 27, 2021

Are non-contiguous depots prevented?

It should work the same way as building stations do. I (ab)use the same settings used for stations for "station spread" and "allow building distant stations not directly adjacent".
If "Allow to join stations not directly adjacent" is on, you can press Ctrl and join a new depot tile to another close depot. If the same setting is off, no non-contiguous depots can be built directly.

Whether it is necessary to create two new settings or rename the existing ones is something I haven't decided yet.

I like this a lot. Is it a (large) baby step toward #8480, or an alternative proposal?

It is the first part of #8480, but without including extended depots. This is no alternative proposal, but a first step.

I will try and fix the possible exploit and change the current draft state. Anyway, adding another setting for depot spread and setting it to "2" would fix it.

@glx22
Copy link
Contributor

glx22 commented Sep 27, 2021

I did a quick test, joining 2 depots of the same type but on different network is not a good idea :). Newly built train is stuck on the northern depot which is on the wrong network. But that's a user error I think.

@J0anJosep
Copy link
Contributor Author

I have added a setting for controlling depot spread instead of reusing the station spread setting.

About the teleportation exploit, it is very difficult to know in which tile a vehicle ends up after a rearrangement or replacement. Yet it is a possible exploit, it is difficult to apply and to get an advantage of. Anyway, setting a low value for max. depot spread should help with this and I do not want to add extra cost for moving vehicles.

Also, this last year I have had in mind modular airports while working in the "multi-tile depots" and the "extended depot" concept. This month I have finished reviewing how aircraft and hangars are integrated in this PR, so it doesn't make modular airports more difficult to be introduced (at least with my idea of how modular airports should work).

I have finished working on this PR. If it is acceptable to start reviewing it (even with the teleportation exploit not being fixed), I could remove the "Draft" state. Just let me know.

@2TallTyler
Copy link
Member

IMO, limiting depot spread is a perfectly valid way of preventing a possible teleportation aspect, since it's similar to how we control station teleportation.

@J0anJosep J0anJosep force-pushed the MultitilingDepots branch 2 times, most recently from 8d18bb2 to 7666495 Compare November 13, 2021 20:14
@J0anJosep J0anJosep force-pushed the MultitilingDepots branch 2 times, most recently from f5f8877 to 4e117c3 Compare December 20, 2021 13:44
@J0anJosep J0anJosep marked this pull request as ready for review December 20, 2021 13:45
@J0anJosep J0anJosep force-pushed the MultitilingDepots branch 5 times, most recently from bad2a47 to bab4284 Compare December 24, 2021 16:04
@J0anJosep J0anJosep force-pushed the MultitilingDepots branch from 6be3ce9 to eb80adf Compare July 13, 2022 19:43
@J0anJosep
Copy link
Contributor Author

J0anJosep commented Jul 16, 2024

I only got partway through the commits, but will come back later to keep reading. 🙂

For a PR like this, it's unavoidable to have a lot of commits, but in my opinion there are two that could be split off to make reviewing a bit easier:

* [Change: Refactor some code in build_vehicle_gui.](https://github.com/OpenTTD/OpenTTD/pull/9577/commits/d643e77800497b883fdc1b1f58c33d0a874b81fd) can be a separate PR now

* [Feature: Allow vehicle replacements even if new road or rail type is not compatible](https://github.com/OpenTTD/OpenTTD/pull/9577/commits/ced241ed87a26da4d681cbb0727441f5519b3294) can be a separate PR after this is merged.

It will be broken into more PRs than you are suggesting, about 8 or more smaller PRs (the first being about hangars). And I keep this PR for getting a global idea of where I want to go. We talked about it somewhere last year and I think it is the way to go. But I am not going to create all the PRs right now as it would be very difficult to keep track of them.

Once the PR about hangars is reviewed and it is ok (thoroughly reviewed, not necessarily accepted), I will revise some other commits and create another small branch to review.

I think it is better to review and put the efforts on the first commits and then move on.

Anyway, I will correct the things you pointed at here. But as I said, I think it is better to go step by step, amending the mistakes on the shorter PRs, and then move on to the next commits.

@WenSimEHRP
Copy link
Contributor

I built the PR several days ago and I noticed that when I click on the train button in the extended depot view the game crashed. Sorry I provide a crash dump for that. It's basically this button.
image

@J0anJosep
Copy link
Contributor Author

I built the PR several days ago and I noticed that when I click on the train button in the extended depot view the game crashed. Sorry I provide a crash dump for that. It's basically this button.

Thanks. It will be fixed next time I update the PR.

src/depot.cpp Outdated
delete this;
}

InvalidateWindowData(WC_SELECT_DEPOT, this->veh_type);

Check failure

Code scanning / CodeQL

Potential use after free Critical

Memory may have been previously freed by delete.
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yep! I will amend it.

J0anJosep added 14 commits July 17, 2024 22:23

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
…ndows.

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
…ndex.

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature.

Unverified

This user has not yet uploaded their public signing key.
…Index.
# Conflicts:
#	src/saveload/saveload.h
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
preview This PR is receiving preview builds size: large This Pull Request is large in size; review will take a while work: needs rebase This Pull Request needs a rebase
Projects
None yet
Development

Successfully merging this pull request may close these issues.

None yet

9 participants