mirror of
https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm.git
synced 2025-01-10 00:44:10 -08:00
Fixes errors with week data
This commit is contained in:
parent
e83fd18dec
commit
403e4a226e
teavm-classlib/src/main/java/org/teavm/classlib
teavm-samples/src/main
|
@ -47,7 +47,7 @@ public class JCLPlugin implements TeaVMPlugin {
|
|||
Generator localeGen = new LocaleSettingsNativeGenerator(host.getClassLoader(), host.getProperties());
|
||||
host.add(new MethodReference("java.util.Locale", "readLanguagesFromCLDR", ValueType.VOID), localeGen);
|
||||
host.add(new MethodReference("java.util.Locale", "readCountriesFromCLDR", ValueType.VOID), localeGen);
|
||||
host.add(new MethodReference("java.util.Calendar", "readWeeksFromCLDR", ValueType.VOID), localeGen);
|
||||
host.add(new MethodReference("java.util.Calendar", "readWeeksFromCDLR", ValueType.VOID), localeGen);
|
||||
host.add(new MethodReference(CLDRHelper.class.getName(), "readLikelySubtagsFromCLDR", ValueType.VOID),
|
||||
localeGen);
|
||||
host.add(new MethodReference("java.util.Locale", "getDefaultLocale", ValueType.object("java.lang.String")),
|
||||
|
|
|
@ -199,7 +199,7 @@ public class LocaleSettingsNativeGenerator implements Generator {
|
|||
case "readCountriesFromCLDR":
|
||||
generateReadCountriesFromCLDR(writer);
|
||||
break;
|
||||
case "readWeeksFromCLDR":
|
||||
case "readWeeksFromCDLR":
|
||||
generateReadWeeksFromCDLR(writer);
|
||||
break;
|
||||
case "readLikelySubtagsFromCLDR":
|
||||
|
@ -310,14 +310,14 @@ public class LocaleSettingsNativeGenerator implements Generator {
|
|||
}
|
||||
first = false;
|
||||
writer.append('"').append(Renderer.escapeString(entry.getKey())).append('"').ws().append(':')
|
||||
.ws().append('"').append(entry.getValue()).append('"');
|
||||
.ws().append(entry.getValue());
|
||||
}
|
||||
writer.outdent().append("};").softNewLine();
|
||||
}
|
||||
|
||||
private void generateReadLikelySubtagsFromCLDR(SourceWriter writer) throws IOException {
|
||||
generateDefender(writer, "likelySubtags");
|
||||
writer.append("java.util.Locale").append(".$CLDR.likelySubtags = {").indent().softNewLine();
|
||||
writer.appendClass("java.util.Locale").append(".$CLDR.likelySubtags = {").indent().softNewLine();
|
||||
boolean first = true;
|
||||
for (Map.Entry<String, String> entry : likelySubtags.entrySet()) {
|
||||
if (!first) {
|
||||
|
|
|
@ -181,7 +181,7 @@ public abstract class TCalendar implements TSerializable, TCloneable, TComparabl
|
|||
return day;
|
||||
}
|
||||
|
||||
@GeneratedBy(LocaleSettingsNativeGenerator.class)
|
||||
@GeneratedBy(CalendarNativeGenerator.class)
|
||||
private static native int getFirstDayOfWeek(String localeCode);
|
||||
|
||||
private static int resolveMinimalDaysInFirstWeek(TLocale locale) {
|
||||
|
@ -193,7 +193,7 @@ public abstract class TCalendar implements TSerializable, TCloneable, TComparabl
|
|||
return days;
|
||||
}
|
||||
|
||||
@GeneratedBy(LocaleSettingsNativeGenerator.class)
|
||||
@GeneratedBy(CalendarNativeGenerator.class)
|
||||
private static native int getMinimalDaysInFirstWeek(String localeCode);
|
||||
|
||||
abstract public void add(int field, int value);
|
||||
|
|
|
@ -16,6 +16,7 @@
|
|||
package org.teavm.samples;
|
||||
|
||||
import java.util.Date;
|
||||
import java.util.GregorianCalendar;
|
||||
import java.util.Locale;
|
||||
import org.teavm.dom.browser.TimerHandler;
|
||||
import org.teavm.dom.browser.Window;
|
||||
|
@ -34,7 +35,10 @@ import org.teavm.jso.JS;
|
|||
public class DateTime {
|
||||
private static Window window = (Window)JS.getGlobal();
|
||||
private static HTMLDocument document = window.getDocument();
|
||||
private static HTMLSelectElement localeElem = (HTMLSelectElement)document.getElementById("locale");
|
||||
private static Date currentDate;
|
||||
private static Locale[] locales;
|
||||
private static Locale currentLocale;
|
||||
|
||||
public static void main(String[] args) {
|
||||
fillLocales();
|
||||
|
@ -44,11 +48,12 @@ public class DateTime {
|
|||
updateCurrentTime();
|
||||
}
|
||||
}, 250);
|
||||
updateCurrentLocale();
|
||||
}
|
||||
|
||||
private static void fillLocales() {
|
||||
final HTMLSelectElement localeElem = (HTMLSelectElement)document.getElementById("locale");
|
||||
for (Locale locale : Locale.getAvailableLocales()) {
|
||||
locales = Locale.getAvailableLocales();
|
||||
for (Locale locale : locales) {
|
||||
HTMLOptionElement option = (HTMLOptionElement)document.createElement("option");
|
||||
option.setValue(locale.toString());
|
||||
option.setLabel(locale.getDisplayName(Locale.getDefault()));
|
||||
|
@ -56,11 +61,21 @@ public class DateTime {
|
|||
}
|
||||
localeElem.addEventListener("change", new EventListener() {
|
||||
@Override public void handleEvent(Event evt) {
|
||||
// Don't do anything
|
||||
updateCurrentLocale();
|
||||
updateCurrentTimeText();
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
private static void updateCurrentLocale() {
|
||||
currentLocale = locales[localeElem.getSelectedIndex()];
|
||||
GregorianCalendar calendar = new GregorianCalendar(currentLocale);
|
||||
HTMLInputElement weekStartElem = (HTMLInputElement)document.getElementById("week-start");
|
||||
weekStartElem.setValue(String.valueOf(calendar.getFirstDayOfWeek()));
|
||||
HTMLInputElement weekLengthElem = (HTMLInputElement)document.getElementById("week-length");
|
||||
weekLengthElem.setValue(String.valueOf(calendar.getMinimalDaysInFirstWeek()));
|
||||
}
|
||||
|
||||
private static void updateCurrentTime() {
|
||||
setCurrentTime(new Date());
|
||||
}
|
||||
|
|
|
@ -13,7 +13,13 @@
|
|||
</div>
|
||||
<div>
|
||||
<label for="current-time">Current time is:</label>
|
||||
<input type="text" id="current-time" readonly>
|
||||
<input type="text" id="current-time" readonly size="50">
|
||||
</div>
|
||||
<div>
|
||||
<label for="week-start">Week starts at:</label>
|
||||
<input type="text" id="week-start" readonly size="5">
|
||||
<label for="week-length">, first week length is:</label>
|
||||
<input type="text" id="week-length" readonly size="5">
|
||||
</div>
|
||||
<div>
|
||||
<label for="field">Pick a field:</label>
|
||||
|
|
Loading…
Reference in New Issue
Block a user