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

Duantao/liberate city #1097

Merged
merged 12 commits into from
Sep 23, 2019
Merged

Conversation

ninjatao
Copy link
Contributor

No description provided.

@ninjatao
Copy link
Contributor Author

conquerCity is part of PostBattleActions and takes place before movement and XP calculation. But if player got to choose between Annex and Liberate city, it has to happen after the choice is made using PopAlert, therefore AFTER the rest calculations of PostBattleActions. This may cause so many problems.
So there are two options for me:

  1. Implement a new choice dialog that blocks the whole process. conquerCity only returns when the choice is made and city is properly transfered. But I have no idea how to do it in Kotlin.
  2. Cut PostBattleActions in two, postpone the 2nd part until city is transfered. This way is much easier to me.

Any suggestions?

@yairm210
Copy link
Owner

These should be 2 separate state changes.

One is military unit + city with low health + attack decision = annexed city
Second is annexed city + player decision = resisting city

This helps us later because you can then decide to 'take over' an annexed city at any point in time

@yairm210
Copy link
Owner

Not sure why you have a "conquerer" there, either

@ninjatao
Copy link
Contributor Author

These should be 2 separate state changes.

One is military unit + city with low health + attack decision = annexed city
Second is annexed city + player decision = resisting city

This helps us later because you can then decide to 'take over' an annexed city at any point in time

When do you think liberating city should take place, in 1st or 2nd part?

@yairm210
Copy link
Owner

Let's make sure we have the same terminology :)
Annex = city is on autopilot
Liberating = city starts resistance timer, after which it's a regular city of yours

At any point in time, you can liberate an annexed city

So, after conquering a city, it becomes annexed. That's in the "unit attack" phase.

Afterwards, we can give the user a choice whether to liberate now, raze now, or leave annexed.

When choosing to raze, we actually liberate (starting the resistance timer) - a city being razed doesn't provide production

@ninjatao
Copy link
Contributor Author

“Liberating = city starts resistance timer, after which it's a regular city of yours”

Liberating city gives it to its founder civ. So it should not be yours. Right?

@ninjatao
Copy link
Contributor Author

You mean liberating cities via diplomacy screen, instead of instant option after conquer?

@yairm210
Copy link
Owner

Ohhhhh
That's what you mean
I thought you mean annex vs conquer

@yairm210
Copy link
Owner

Sorry, by bad, I was the one who used the wrong terminology

image

I thought you were talking about puppet cities

I'll go though it all again =)

@yairm210
Copy link
Owner

Okay so!

If I understand the flow correctly, when you capture a city it becomes puppeted

The puppeted city can be given to the original owner upon capture only - that's called "liberating"

Puppeted cities can, at any point, be added to your own cities with resistance and unhappiness - that's called "annexing"

Razing is basically annexing, but also activating "raze".

1 similar comment
@yairm210
Copy link
Owner

Okay so!

If I understand the flow correctly, when you capture a city it becomes puppeted

The puppeted city can be given to the original owner upon capture only - that's called "liberating"

Puppeted cities can, at any point, be added to your own cities with resistance and unhappiness - that's called "annexing"

Razing is basically annexing, but also activating "raze".

@ninjatao
Copy link
Contributor Author

Totally agree. Will study what puppet cities do. As far as I remember we also need a "courthouse" building for this.

@ninjatao
Copy link
Contributor Author

Add a courthouse and it is almost done.

@yairm210 yairm210 merged commit 65b8fe5 into yairm210:master Sep 23, 2019
@ninjatao ninjatao deleted the duantao/liberate_city branch October 3, 2019 13:07
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants