Merge pull request #636 from tterrag1098/betterModList
Fix control codes being used for mod list sort. Clean up sorting code.
This commit is contained in:
commit
5a5ef86da9
1 changed files with 32 additions and 28 deletions
|
@ -37,6 +37,7 @@ import net.minecraft.client.renderer.texture.TextureManager;
|
||||||
import net.minecraft.client.resources.I18n;
|
import net.minecraft.client.resources.I18n;
|
||||||
import net.minecraft.client.resources.IResourcePack;
|
import net.minecraft.client.resources.IResourcePack;
|
||||||
import net.minecraft.util.ResourceLocation;
|
import net.minecraft.util.ResourceLocation;
|
||||||
|
import net.minecraft.util.StringUtils;
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
import net.minecraftforge.fml.common.FMLLog;
|
||||||
import net.minecraftforge.fml.common.Loader;
|
import net.minecraftforge.fml.common.Loader;
|
||||||
import net.minecraftforge.fml.common.ModContainer;
|
import net.minecraftforge.fml.common.ModContainer;
|
||||||
|
@ -62,7 +63,10 @@ public class GuiModList extends GuiScreen
|
||||||
private SortType(int buttonID)
|
private SortType(int buttonID)
|
||||||
{
|
{
|
||||||
this.buttonID = buttonID;
|
this.buttonID = buttonID;
|
||||||
|
this.comparator = new ModComparator(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private final ModComparator comparator;
|
||||||
|
|
||||||
public static SortType getTypeForButton(GuiButton button)
|
public static SortType getTypeForButton(GuiButton button)
|
||||||
{
|
{
|
||||||
|
@ -75,6 +79,31 @@ public class GuiModList extends GuiScreen
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static class ModComparator implements Comparator<ModContainer>
|
||||||
|
{
|
||||||
|
private SortType type;
|
||||||
|
private ModComparator(SortType type)
|
||||||
|
{
|
||||||
|
this.type = type;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int compare(ModContainer o1, ModContainer o2)
|
||||||
|
{
|
||||||
|
String name1 = StringUtils.stripControlCodes(o1.getName()).toLowerCase();
|
||||||
|
String name2 = StringUtils.stripControlCodes(o2.getName()).toLowerCase();
|
||||||
|
switch(type)
|
||||||
|
{
|
||||||
|
case A_TO_Z:
|
||||||
|
return name1.compareTo(name2);
|
||||||
|
case Z_TO_A:
|
||||||
|
return name2.compareTo(name1);
|
||||||
|
default:
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private GuiScreen mainMenu;
|
private GuiScreen mainMenu;
|
||||||
private GuiSlotModList modList;
|
private GuiSlotModList modList;
|
||||||
private int selected = -1;
|
private int selected = -1;
|
||||||
|
@ -161,7 +190,7 @@ public class GuiModList extends GuiScreen
|
||||||
{
|
{
|
||||||
super.mouseClicked(x, y, button);
|
super.mouseClicked(x, y, button);
|
||||||
search.mouseClicked(x, y, button);
|
search.mouseClicked(x, y, button);
|
||||||
if (button == 1 && x >= search.xPosition && x < search.xPosition + this.width && y >= search.yPosition && y < search.yPosition + this.height) {
|
if (button == 1 && x >= search.xPosition && x < search.xPosition + search.width && y >= search.yPosition && y < search.yPosition + search.height) {
|
||||||
search.setText("");
|
search.setText("");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -187,33 +216,8 @@ public class GuiModList extends GuiScreen
|
||||||
|
|
||||||
if (!sorted)
|
if (!sorted)
|
||||||
{
|
{
|
||||||
switch (sortType)
|
reloadMods();
|
||||||
{
|
Collections.sort(mods, sortType.comparator);
|
||||||
case A_TO_Z:
|
|
||||||
Collections.sort(modList.getMods(), new Comparator<ModContainer>()
|
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public int compare(ModContainer o1, ModContainer o2)
|
|
||||||
{
|
|
||||||
return o1.getName().toLowerCase().compareTo(o2.getName().toLowerCase());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
break;
|
|
||||||
case Z_TO_A:
|
|
||||||
Collections.sort(modList.getMods(), new Comparator<ModContainer>()
|
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public int compare(ModContainer o1, ModContainer o2)
|
|
||||||
{
|
|
||||||
return o2.getName().toLowerCase().compareTo(o1.getName().toLowerCase());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
reloadMods();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
mods = modList.getMods();
|
|
||||||
selected = modList.selectedIndex = mods.indexOf(selectedMod);
|
selected = modList.selectedIndex = mods.indexOf(selectedMod);
|
||||||
sorted = true;
|
sorted = true;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue