X-Git-Url: https://git.ktnx.net/?p=mobile-ledger.git;a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Futils%2FGlobals.java;h=e1ce8eea5430e287e122a7aecbf2be9f02a57c98;hp=fe0cbe08e3d968127c730cd2620e436669ee51e5;hb=217da55a224e2ae899d0b50604e2e54f882ec04f;hpb=c0f56397f7912e5a316f19fa36599a4267d9d916 diff --git a/app/src/main/java/net/ktnx/mobileledger/utils/Globals.java b/app/src/main/java/net/ktnx/mobileledger/utils/Globals.java index fe0cbe08..e1ce8eea 100644 --- a/app/src/main/java/net/ktnx/mobileledger/utils/Globals.java +++ b/app/src/main/java/net/ktnx/mobileledger/utils/Globals.java @@ -1,5 +1,5 @@ /* - * Copyright © 2019 Damyan Ivanov. + * Copyright © 2020 Damyan Ivanov. * This file is part of MoLe. * MoLe is free software: you can distribute it and/or modify it * under the term of the GNU General Public License as published by @@ -25,7 +25,6 @@ import android.view.inputmethod.InputMethodManager; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Calendar; -import java.util.Date; import java.util.Locale; import java.util.regex.Matcher; import java.util.regex.Pattern; @@ -58,43 +57,48 @@ public final class Globals { imm.hideSoftInputFromWindow(v.getWindowToken(), 0); } } - public static Date parseLedgerDate(String dateString) throws ParseException { + public static SimpleDate parseLedgerDate(String dateString) throws ParseException { Matcher m = reLedgerDate.matcher(dateString); if (!m.matches()) throw new ParseException( String.format("'%s' does not match expected pattern '%s'", dateString, reLedgerDate.toString()), 0); - String year = m.group(1); - String month = m.group(2); - String day = m.group(3); + String yearStr = m.group(1); + String monthStr = m.group(2); + String dayStr = m.group(3); + + int year, month, day; String toParse; - if (year == null) { - Calendar now = Calendar.getInstance(); - int thisYear = now.get(Calendar.YEAR); - if (month == null) { - int thisMonth = now.get(Calendar.MONTH) + 1; - toParse = String.format(Locale.US, "%04d/%02d/%s", thisYear, thisMonth, dateString); + if (yearStr == null) { + SimpleDate today = SimpleDate.today(); + year = today.year; + if (monthStr == null) { + month = today.month; } - else toParse = String.format(Locale.US, "%04d/%s", thisYear, dateString); + else month = Integer.parseInt(monthStr); + } + else { + year = Integer.parseInt(yearStr); + assert monthStr != null; + month = Integer.parseInt(monthStr); } - else toParse = dateString; - return dateFormatter.get().parse(toParse); + assert dayStr != null; + day = Integer.parseInt(dayStr); + + return new SimpleDate(year, month, day); } public static Calendar parseLedgerDateAsCalendar(String dateString) throws ParseException { - Date date = parseLedgerDate(dateString); - Calendar calendar = Calendar.getInstance(); - calendar.setTime(date); - return calendar; + return parseLedgerDate(dateString).toCalendar(); } - public static Date parseIsoDate(String dateString) throws ParseException { - return isoDateFormatter.get().parse(dateString); + public static SimpleDate parseIsoDate(String dateString) throws ParseException { + return SimpleDate.fromDate(isoDateFormatter.get().parse(dateString)); } - public static String formatLedgerDate(Date date) { - return dateFormatter.get().format(date); + public static String formatLedgerDate(SimpleDate date) { + return dateFormatter.get().format(date.toDate()); } - public static String formatIsoDate(Date date) { - return isoDateFormatter.get().format(date); + public static String formatIsoDate(SimpleDate date) { + return isoDateFormatter.get().format(date.toDate()); } } \ No newline at end of file