Refactor locationToName method for improved readability and performance and update license

This commit is contained in:
HoosierTransfer 2024-06-21 18:14:26 -04:00
parent a8347a5126
commit aaa11a11ac
9 changed files with 44412 additions and 44615 deletions

1034
LICENSE

File diff suppressed because it is too large Load Diff

File diff suppressed because one or more lines are too long

BIN
javascript/update.cert Normal file

Binary file not shown.

View File

@ -20,14 +20,21 @@ import org.apache.commons.lang3.StringUtils;
/**
* Copyright (c) 2024 lax1dude. All Rights Reserved.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED.
* IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY
* DIRECT,
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
* LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
* OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*
@ -57,72 +64,76 @@ public class GuiUpdateCheckerOverlay extends Gui {
}
public void setResolution(Minecraft mc, int w, int h) {
if(!UpdateService.supported()) {
if (!UpdateService.supported()) {
return;
}
this.mc = mc;
this.width = w;
this.height = h;
checkForUpdatesButton = new GuiButton(0, 0, 0, 150, 20, I18n.format("update.button") + " " + I18n.format(mc.gameSettings.enableUpdateSvc ? "gui.yes" : "gui.no"));
checkForUpdatesButton = new GuiButton(0, 0, 0, 150, 20, I18n.format("update.button") + " "
+ I18n.format(mc.gameSettings.enableUpdateSvc ? "gui.yes" : "gui.no"));
startDownloadButton = new GuiButton(1, 1, 0, 115, 20, I18n.format("update.startDownload"));
viewAllUpdatesButton = new GuiButton(2, 1, 0, 115, 20, I18n.format("update.viewAll", 0));
dismissUpdatesButton = new GuiButton(3, 1, 0, 115, 20, I18n.format("update.dismiss"));
}
public void drawScreen(int mx, int my, float partialTicks) {
if(!UpdateService.supported()) {
if (!UpdateService.supported()) {
return;
}
UpdateProgressStruct progressState = UpdateService.getUpdatingStatus();
if(progressState.isBusy) {
if (progressState.isBusy) {
drawScreenBusy(mx, my, partialTicks, progressState);
return;
}
checkForUpdatesButton.visible = isIngame;
startDownloadButton.visible = false;
viewAllUpdatesButton.visible = false;
dismissUpdatesButton.visible = false;
totalHeightOffset = 0;
int i = UpdateService.getAvailableUpdates().size();
boolean shownSP = i > 0 || !mc.isSingleplayer() || LANServerController.isHostingLAN();
checkForUpdatesButton.visible &= shownSP;
if(mc.gameSettings.enableUpdateSvc) {
if (mc.gameSettings.enableUpdateSvc) {
String str;
UpdateCertificate cert = UpdateService.getLatestUpdateFound();
if(cert != null) {
if (cert != null) {
startDownloadButton.visible = true;
viewAllUpdatesButton.visible = true;
dismissUpdatesButton.visible = true;
viewAllUpdatesButton.displayString = I18n.format("update.viewAll", i);
str = I18n.format("update.found");
mc.fontRendererObj.drawStringWithShadow(str, 3, 22, 0xFFFFAA);
int embedY = 35;
int embedWidth = 115;
int embedWidth2 = (int)(embedWidth / 0.75f);
List<String> lst = cert.bundleVersionComment.length() == 0 ? null : mc.fontRendererObj.listFormattedStringToWidth(cert.bundleVersionComment, embedWidth2 - 14);
int embedWidth2 = (int) (embedWidth / 0.75f);
List<String> lst = cert.bundleVersionComment.length() == 0 ? null
: mc.fontRendererObj.listFormattedStringToWidth(cert.bundleVersionComment, embedWidth2 - 14);
int embedHeight = 44;
if(lst != null) {
if (lst != null) {
embedHeight += 3 + lst.size() * 6;
}
GlStateManager.pushMatrix();
GlStateManager.translate(1.0f, embedY, 0.0f);
GlStateManager.scale(0.75f, 0.75f, 0.75f);
int embedHeight2 = (int)(embedHeight / 0.75f);
int embedHeight2 = (int) (embedHeight / 0.75f);
drawGradientRect(1, 1, embedWidth2 - 1, embedHeight2 - 1, 0xFFFFFFAA, 0xFFFFFFAA);
drawGradientRect(0, 1, embedWidth2, 2, 0xFF000000, 0xFF000000);
drawGradientRect(0, embedHeight2 - 1, embedWidth2, embedHeight2, 0xFF000000, 0xFF000000);
drawGradientRect(0, 1, 1, embedHeight2 - 1, 0xFF000000, 0xFF000000);
drawGradientRect(embedWidth2 - 1, 1, embedWidth2, embedHeight2 - 1, 0xFF000000, 0xFF000000);
mc.getTextureManager().bindTexture(eaglerIcons);
GlStateManager.pushMatrix();
GlStateManager.scale(0.3f, 0.3f, 0.3f);
@ -131,34 +142,37 @@ public class GuiUpdateCheckerOverlay extends Gui {
drawTexturedModalRect(25, 25, 156, 0, 100, 100);
EaglercraftGPU.glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
GlStateManager.popMatrix();
mc.fontRendererObj.drawString(EnumChatFormatting.UNDERLINE + cert.bundleDisplayName, 45, 11, 0x000000);
mc.fontRendererObj.drawString(I18n.format("update.update") + " " + EnumChatFormatting.DARK_RED + cert.bundleDisplayVersion, 45, 25, 0x000000);
if(lst != null) {
for(int j = 0, l = lst.size(); j < l; ++j) {
mc.fontRendererObj.drawString(
I18n.format("update.update") + " " + EnumChatFormatting.DARK_RED + cert.bundleDisplayVersion,
45, 25, 0x000000);
if (lst != null) {
for (int j = 0, l = lst.size(); j < l; ++j) {
mc.fontRendererObj.drawString(lst.get(j), 5, 42 + j * 8, 0x000000);
}
}
mc.fontRendererObj.drawString(I18n.format("update.author") + " " + cert.bundleAuthorName, 5, 44 + (lst == null ? 0 : (3 + lst.size() * 8)), 0x777777);
mc.fontRendererObj.drawString(I18n.format("update.author") + " " + cert.bundleAuthorName, 5,
44 + (lst == null ? 0 : (3 + lst.size() * 8)), 0x777777);
startDownloadButton.yPosition = embedHeight + embedY + 5;
viewAllUpdatesButton.yPosition = startDownloadButton.yPosition + 22;
dismissUpdatesButton.yPosition = viewAllUpdatesButton.yPosition + 22;
totalHeightOffset = dismissUpdatesButton.yPosition + 20;
GlStateManager.popMatrix();
}else if(isIngame) {
if(shownSP) {
} else if (isIngame) {
if (shownSP) {
str = I18n.format("update.noneNew");
mc.fontRendererObj.drawString(str, 3, 22, 0xDDDDDD);
if(i > 0) {
if (i > 0) {
viewAllUpdatesButton.yPosition = 40;
viewAllUpdatesButton.visible = true;
viewAllUpdatesButton.displayString = I18n.format("update.viewAll", i);
totalHeightOffset = 60;
}else {
} else {
totalHeightOffset = 32;
}
}
@ -172,7 +186,7 @@ public class GuiUpdateCheckerOverlay extends Gui {
}
public void drawScreenBusy(int mx, int my, float partialTicks, UpdateProgressStruct progressState) {
if(!UpdateService.supported()) {
if (!UpdateService.supported()) {
return;
}
checkForUpdatesButton.visible = false;
@ -185,12 +199,12 @@ public class GuiUpdateCheckerOverlay extends Gui {
mc.fontRendererObj.drawStringWithShadow(str, 2, 2, 0xFFFFAA);
GlStateManager.translate(0.0f, 14.0f, 0.0f);
GlStateManager.scale(0.75f, 0.75f, 0.75f);
if(!StringUtils.isAllBlank(progressState.statusString1)) {
if (!StringUtils.isAllBlank(progressState.statusString1)) {
str = progressState.statusString1;
mc.fontRendererObj.drawStringWithShadow(str, 3, 0, 0xFFFFFF);
}
int cc = isIngame ? 0xBBBBBB : 0xFFFFFF;
if(!StringUtils.isAllBlank(progressState.statusString2)) {
if (!StringUtils.isAllBlank(progressState.statusString2)) {
str = progressState.statusString2;
mc.fontRendererObj.drawStringWithShadow(str, 3, 11, cc);
}
@ -199,56 +213,58 @@ public class GuiUpdateCheckerOverlay extends Gui {
int progX2 = 135;
int progY2 = 32;
float prog = progressState.progressBar;
if(prog >= 0.0f) {
if (prog >= 0.0f) {
int bk = 0xFFBBBBBB;
int fg = 0xFFDD0000;
drawGradientRect(progX1 + 1, progY1 + 1, progX1 + (int)((progX2 - progX1 - 1) * prog), progY2 - 1, fg, fg);
drawGradientRect(progX1 + (int)((progX2 - progX1 - 1) * prog), progY1 + 1, progX2 - 1, progY2 - 1, bk, bk);
drawGradientRect(progX1 + 1, progY1 + 1, progX1 + (int) ((progX2 - progX1 - 1) * prog), progY2 - 1, fg, fg);
drawGradientRect(progX1 + (int) ((progX2 - progX1 - 1) * prog), progY1 + 1, progX2 - 1, progY2 - 1, bk, bk);
drawGradientRect(progX1, progY1, progX2, progY1 + 1, 0xFF000000, 0xFF000000);
drawGradientRect(progX1, progY2 - 1, progX2, progY2, 0xFF000000, 0xFF000000);
drawGradientRect(progX1, progY1 + 1, progX1 + 1, progY2 - 1, 0xFF000000, 0xFF000000);
drawGradientRect(progX2 - 1, progY1 + 1, progX2, progY2 - 1, 0xFF000000, 0xFF000000);
}
totalHeightOffset = 32;
if(!StringUtils.isAllBlank(progressState.statusString3)) {
if (!StringUtils.isAllBlank(progressState.statusString3)) {
GlStateManager.translate(0.0f, progY2 + 2, 0.0f);
GlStateManager.scale(0.66f, 0.66f, 0.66f);
str = progressState.statusString3;
List<String> wrappedURL = mc.fontRendererObj.listFormattedStringToWidth(str, (int)((progX2 - progX1) * 1.5f));
for(int i = 0, l = wrappedURL.size(); i < l; ++i) {
List<String> wrappedURL = mc.fontRendererObj.listFormattedStringToWidth(str,
(int) ((progX2 - progX1) * 1.5f));
for (int i = 0, l = wrappedURL.size(); i < l; ++i) {
str = wrappedURL.get(i);
mc.fontRendererObj.drawStringWithShadow(str, 5, i * 11, cc);
}
totalHeightOffset += (int)(wrappedURL.size() * 5.5f);
totalHeightOffset += (int) (wrappedURL.size() * 5.5f);
}
GlStateManager.popMatrix();
}
public void mouseClicked(int mx, int my, int btn) {
if(!UpdateService.supported()) {
if (!UpdateService.supported()) {
return;
}
if (btn == 0) {
if(checkForUpdatesButton.mousePressed(mc, mx, my)) {
if (checkForUpdatesButton.mousePressed(mc, mx, my)) {
mc.gameSettings.enableUpdateSvc = !mc.gameSettings.enableUpdateSvc;
mc.gameSettings.saveOptions();
checkForUpdatesButton.displayString = I18n.format("update.button") + " " + I18n.format(mc.gameSettings.enableUpdateSvc ? "gui.yes" : "gui.no");
checkForUpdatesButton.displayString = I18n.format("update.button") + " "
+ I18n.format(mc.gameSettings.enableUpdateSvc ? "gui.yes" : "gui.no");
}
if(startDownloadButton.mousePressed(mc, mx, my)) {
if(!UpdateService.getUpdatingStatus().isBusy) {
if (startDownloadButton.mousePressed(mc, mx, my)) {
if (!UpdateService.getUpdatingStatus().isBusy) {
UpdateCertificate cert = UpdateService.getLatestUpdateFound();
if(cert != null) {
if (cert != null) {
UpdateService.startClientUpdateFrom(cert);
}
}
}
if(viewAllUpdatesButton.mousePressed(mc, mx, my)) {
if (viewAllUpdatesButton.mousePressed(mc, mx, my)) {
mc.displayGuiScreen(new GuiUpdateVersionList(backScreen));
}
if(dismissUpdatesButton.mousePressed(mc, mx, my)) {
if (dismissUpdatesButton.mousePressed(mc, mx, my)) {
UpdateCertificate cert = UpdateService.getLatestUpdateFound();
if(cert != null) {
if (cert != null) {
UpdateService.dismiss(cert);
}
}

View File

@ -109,6 +109,7 @@ public class UpdateService {
}
byte[] latestUpdate = PlatformApplication.getLocalStorage(EaglercraftVersion.updateLatestLocalStorageKey,
false);
if (latestUpdate != null) {
addCertificateToSet(latestUpdate, false);
}

View File

@ -56,8 +56,13 @@ public abstract class AbstractResourcePack implements IResourcePack {
}
private static String locationToName(ResourceLocation location) {
return HString.format("%s/%s/%s",
new Object[] { "assets", location.getResourceDomain(), location.getResourcePath() });
String namespace = location.getResourceDomain();
String path = location.getResourcePath();
// uses a StringBuilder internally
return "assets/" +
namespace +
'/' +
path;
}
public InputStream getInputStream(ResourceLocation location) throws IOException {