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

BUG: technology which you can't learn cause of unique "Only available <before discovering [tech]" you can get for free when getting free technologies #7083

Merged
merged 3 commits into from Jun 8, 2022

Conversation

ghost
Copy link

@ghost ghost commented Jun 6, 2022

technology which you can't learn cause of unique "Only available <before discovering [tech]" you can get for free when getting free technologies

Comment on lines 145 to 148
for (unique in requiredTech.uniqueObjects
.filter { it.type == UniqueType.OnlyAvailableWhen && !it.conditionalsApply(civInfo) }) {
return false
}
Copy link
Collaborator

Choose a reason for hiding this comment

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

This could probably be replaced with

if (requiredTech.uniqueObjects.any { it.type == UniqueType.OnlyAvailableWhen && !it.conditionalsApply(civInfo) })
    return false

without changing the intended effect but it'd be wise to double check.

Copy link
Owner

Choose a reason for hiding this comment

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

Indeed

@Azzurite
Copy link
Collaborator

Azzurite commented Jun 6, 2022

Can you please state which specific bug this is fixing? So which technology exactly can you get via "free technology" that you shouldn't be able to get?

Because to me it seems like it's not necessary to go through all technologies that you needed to get to a point, because those are already done. Just because some technology in the past is "only available before x" doesn't mean that that should prevent the current technology from being researched.

@ghost
Copy link
Author

ghost commented Jun 7, 2022

thanks for OptimizedForDensity, now changes are correct

@ghost
Copy link
Author

ghost commented Jun 7, 2022

Just because some technology in the past is "only available before x" doesn't mean that that should prevent the current technology from being researched.

sorry for my wrong fix, it was just copy-paste from another place
OptimisedForDensity solved things out right.

how to reproduce problem:

  1. create one new technology after which researching all other technologies become unavailable. then research it or give tit at start as i had did
  2. then get technology which leads to some another (i got it via stealing tech)
    now this next technology become "green", but you can't research it cause
    all technologies unavailable now. but you can get it for free after building wonder "Alexander Library"

fix from OptimizedForDensity solves this problems:

  1. now next technologies no more shown as green
  2. you can't pick them as free technologies

@ghost
Copy link
Author

ghost commented Jun 7, 2022

screenshot

@ghost
Copy link
Author

ghost commented Jun 7, 2022

sorry, trying to find how to split translation pull request :(

@Azzurite
Copy link
Collaborator

Azzurite commented Jun 7, 2022

Aaaand this never would've happened if if without curly braces were not allowed.... wow.

@Azzurite
Copy link
Collaborator

Azzurite commented Jun 7, 2022

sorry, trying to find how to split translation pull request :(

Create a new branch, don't use master.

@ghost
Copy link
Author

ghost commented Jun 7, 2022

yes, in our company all java "if" must have { }
it is our company politics :)

Copy link
Owner

@yairm210 yairm210 left a comment

Choose a reason for hiding this comment

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

Not sure why the Lithuanian changes are in the same PR but not a blocker

@Azzurite Azzurite merged commit b05072d into yairm210:master Jun 8, 2022
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.

3 participants