aboutsummaryrefslogtreecommitdiff
path: root/src/Java/binnie/core/genetics/MothBreedingSystem.java
blob: e1a45c9a9c9b09190fdaeda3e1b1266b288434f8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
package binnie.core.genetics;

import binnie.Binnie;
import binnie.core.BinnieCore;
import binnie.core.language.ManagerLanguage;
import binnie.core.resource.ManagerResource;
import binnie.extratrees.ExtraTrees;
import forestry.api.genetics.IAllele;
import forestry.api.genetics.IAlleleInteger;
import forestry.api.genetics.IBreedingTracker;
import forestry.api.genetics.IChromosomeType;
import forestry.api.genetics.IMutation;
import forestry.api.genetics.ISpeciesRoot;
import forestry.api.lepidopterology.EnumButterflyChromosome;
import forestry.api.lepidopterology.EnumFlutterType;
import forestry.api.lepidopterology.IButterflyRoot;
import forestry.api.lepidopterology.ILepidopteristTracker;
import java.util.TreeSet;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.item.ItemStack;

class MothBreedingSystem
  extends BreedingSystem
{
  public MothBreedingSystem()
  {
    this.iconUndiscovered = Binnie.Resource.getItemIcon(ExtraTrees.instance, "icon/undiscoveredMoth");
    this.iconDiscovered = Binnie.Resource.getItemIcon(ExtraTrees.instance, "icon/discoveredMoth");
  }
  
  public float getChance(IMutation mutation, EntityPlayer player, IAllele species1, IAllele species2)
  {
    return 0.0F;
  }
  
  public ISpeciesRoot getSpeciesRoot()
  {
    return Binnie.Genetics.getButterflyRoot();
  }
  
  public int getColour()
  {
    return 62194;
  }
  
  public Class<? extends IBreedingTracker> getTrackerClass()
  {
    return ILepidopteristTracker.class;
  }
  
  public String getAlleleName(IChromosomeType chromosome, IAllele allele)
  {
    if (chromosome == EnumButterflyChromosome.METABOLISM)
    {
      int metabolism = ((IAlleleInteger)allele).getValue();
      if (metabolism >= 19) {
        return Binnie.Language.localise(BinnieCore.instance, "allele.metabolism.highest");
      }
      if (metabolism >= 16) {
        return Binnie.Language.localise(BinnieCore.instance, "allele.metabolism.higher");
      }
      if (metabolism >= 13) {
        return Binnie.Language.localise(BinnieCore.instance, "allele.metabolism.high");
      }
      if (metabolism >= 10) {
        return Binnie.Language.localise(BinnieCore.instance, "allele.metabolism.normal");
      }
      if (metabolism >= 7) {
        return Binnie.Language.localise(BinnieCore.instance, "allele.metabolism.slow");
      }
      if (metabolism >= 4) {
        return Binnie.Language.localise(BinnieCore.instance, "allele.metabolism.slower");
      }
      return Binnie.Language.localise(BinnieCore.instance, "allele.metabolism.slowest");
    }
    if (chromosome == EnumButterflyChromosome.FERTILITY)
    {
      int metabolism = ((IAlleleInteger)allele).getValue();
      return metabolism + "x";
    }
    return super.getAlleleName(chromosome, allele);
  }
  
  public boolean isDNAManipulable(ItemStack member)
  {
    return ((IButterflyRoot)getSpeciesRoot()).getType(member) == EnumFlutterType.SERUM;
  }
  
  public int[] getActiveTypes()
  {
    return new int[] { EnumFlutterType.BUTTERFLY.ordinal(), EnumFlutterType.CATERPILLAR.ordinal(), EnumFlutterType.SERUM.ordinal() };
  }
  
  public void addExtraAlleles(IChromosomeType chromosome, TreeSet<IAllele> alleles)
  {
    switch (1.$SwitchMap$forestry$api$lepidopterology$EnumButterflyChromosome[((EnumButterflyChromosome)chromosome).ordinal()])
    {
    case 1: 
      for (ForestryAllele.Int a : ForestryAllele.Int.values()) {
        alleles.add(a.getAllele());
      }
      break;
    case 2: 
      for (ForestryAllele.Lifespan a : ForestryAllele.Lifespan.values()) {
        alleles.add(a.getAllele());
      }
      break;
    case 3: 
      for (ForestryAllele.Int a : ForestryAllele.Int.values()) {
        alleles.add(a.getAllele());
      }
      break;
    case 4: 
    case 5: 
    case 6: 
      for (ForestryAllele.Bool a : ForestryAllele.Bool.values()) {
        alleles.add(a.getAllele());
      }
      break;
    case 7: 
      for (ForestryAllele.Size a : ForestryAllele.Size.values()) {
        alleles.add(a.getAllele());
      }
      break;
    case 8: 
      for (ForestryAllele.Speed a : ForestryAllele.Speed.values()) {
        alleles.add(a.getAllele());
      }
      break;
    case 9: 
    case 10: 
      for (Tolerance a : Tolerance.values()) {
        alleles.add(a.getAllele());
      }
      break;
    }
  }
}