All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.sf.saxon.option.local.Numberer_nl Maven / Gradle / Ivy

There is a newer version: 10.5
Show newest version
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// Copyright (c) 2013 Saxonica Limited.
// This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0.
// If a copy of the MPL was not distributed with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
// This Source Code Form is "Incompatible With Secondary Licenses", as defined by the Mozilla Public License, v. 2.0.
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

package net.sf.saxon.option.local;

import net.sf.saxon.expr.number.AbstractNumberer;

/**
 * Localization class for Dutch.
 * @author Karel Goossens
 *         BTR-Services Belgium.
 * Numberer class for the Dutch language.
 *
 * 

Modified 2009-07-27 by MHK to use initial capital letters in names of months, days, and numbers. * In response to email from Laurens Holst on saxon-help list: * "Although in Dutch we do not capitalise months by default, it still needs to be capitalised when it appears * at the start of a sentence, hence there is the problem."

* * @see http://woordenlijst.org/leidraad/6/9/#r6n * @see http://taaladvies.net/taal/advies/popup.php?id=88 * @see http://www.vlaanderen.be/servlet/Satellite?c=Page&cid=1120536021990&pagename=taaltelefoon%2FPage%2FHomePageMIN * */ public class Numberer_nl extends AbstractNumberer { private static final long serialVersionUID = 1L; private static String[] dutchOrdinalUnits = { "", "Eenste", "Tweede", "Derde", "Vierde", "Vijfde", "Zesde", "Zevende", "Achtste", "Negende", "Tiende", "Elfde ", "Twaalfde", "Dertiende" , "Veertiende", "Vijftiende", "Zestiende", "Zeventiende", "Achtiende", "Negentiende"}; private static String[] dutchOrdinalTens = { "", "Tiende", "Twintigste", "Dertigste", "Veertigste", "Vijftigste", "Zestigste", "Zeventigste", "Tachtigste", "Negentigste"}; private static String[] dutchUnits = { "", "Een", "Twee", "Drie", "Vier", "Vijf", "Zes", "Zeven", "Acht", "Negen", "Tien", "Elf", "Twaalf", "Dertien", "Veertien", "Vijftien", "Zestien", "Zeventien", "Achtien", "Negentien"}; private static String[] dutchTens = { "", "Tien", "Twintig", "Dertig", "Veertig", "Vijftig", "Zestig", "Zeventig", "Tachtig", "Negentig"}; /** * Show an ordinal number as dutch words in a requested case (for example, Twentyfirst) */ public String toOrdinalWords(String ordinalParam, long number, int wordCase) { String s; if(number==1000000000){ s="Miljardste"; } else if(number==1000000){ s="Miljoenste"; } else if(number==1000){ s="Duizendste"; } else if(number==100){ s="Honderste"; } else if (number >= 1000000000) { long rem = number % 1000000000; s = toWords(number / 1000000000) + " Miljard" + (rem==0 ? "" : (rem < 100 ? " en " : " ") + toOrdinalWords(ordinalParam, rem, wordCase)); } else if (number >= 1000000) { long rem = number % 1000000; s = toWords(number / 1000000) + " Miljoen" + (rem==0 ? "" : (rem < 100 ? " en " : " ") + toOrdinalWords(ordinalParam, rem, wordCase)); } else if (number >= 1000) { long rem = number % 1000; s = (number/1000==1?"":toWords(number / 1000)) + "Duizend" +" "+ toOrdinalWords(ordinalParam, rem, wordCase); } else if (number >= 100) { long rem = number % 100; s = (number/100==1?"":toWords(number / 100)) + "Honderd" + toOrdinalWords(ordinalParam, rem, wordCase); } else { if (number < 20) { s = dutchOrdinalUnits[(int)number]; } else { int rem = (int)(number % 10); if (rem==0) { s = dutchOrdinalTens[(int)number / 10]; } else { s = dutchUnits[rem]+(rem==2?"\u00ebn":"en")+dutchTens[(int)number / 10]+"ste"; } } } if (wordCase == UPPER_CASE) { return s.toUpperCase(); } else if (wordCase == LOWER_CASE) { return s.toLowerCase(); } else { return s; } } public String toWords(long number) { if (number >= 1000000000) { long rem = number % 1000000000; return toWords(number / 1000000000) + " Miljard" + (rem==0 ? "" : (rem < 100 ? "en" : " ") + toWords(rem)); } else if (number >= 1000000) { long rem = number % 1000000; return toWords(number / 1000000) + " Miljoen" + (rem==0 ? "" : (rem < 100 ? "en" : " ") + toWords(rem)); } else if (number >= 1000) { long rem = number % 1000; return (number/1000==1?"":toWords(number / 1000)) + "Duizend" + (rem==0 ? "" : (rem < 100 ? "en" : " ") + toWords(rem)); } else if (number >= 100) { long rem = number % 100; return (number/100==1?"":toWords(number / 100)) + "Honderd" + toWords(rem); } else { if (number < 20) { return dutchUnits[(int)number]; } int rem = (int)(number % 10); String tens = dutchTens[(int)number / 10]; if (rem == 0) { return tens; } else if (rem == 2) { return dutchUnits[rem] + "\u00ebn" + tens.toLowerCase(); } else { return dutchUnits[rem] + "en" + tens.toLowerCase(); } } } public String toWords(long number, int wordCase) { String s; if (number == 0) { s = "nul"; } else { s = toWords(number); } if (wordCase == UPPER_CASE) { return s.toUpperCase(); } else if (wordCase == LOWER_CASE) { return s.toLowerCase(); } else { return s; } } private static String[] dutchMonths = { "Januari", "Februari", "Maart", "April", "Mei", "Juni", "Juli", "Augustus", "September", "Oktober", "November", "December" }; /** * Get a month name or abbreviation * @param month The month number (1=January, 12=December) * @param minWidth The minimum number of characters * @param maxWidth The maximum number of characters */ //@Override public String monthName(int month, int minWidth, int maxWidth) { String name = dutchMonths[month-1]; if (maxWidth < 3) { maxWidth = 3; } if (name.length() > maxWidth) { name = name.substring(0, maxWidth); } while (name.length() < minWidth) { name = name + ' '; } return name; } /** * Get a day name or abbreviation * @param day The day of the week (1=Monday, 7=Sunday) * @param minWidth The minimum number of characters * @param maxWidth The maximum number of characters */ public String dayName(int day, int minWidth, int maxWidth) { String name = dutchDays[day-1]; if (maxWidth < 2) { maxWidth = 2; } if (name.length() > maxWidth) { name = dutchDayAbbreviations[day-1]; if (name.length() > maxWidth) { name = name.substring(0, maxWidth); } } while (name.length() < minWidth) { name = name + ' '; } if (minWidth==1 && maxWidth==2) { // special case name = name.substring(0, minUniqueDayLength[day-1]); } return name; } private static String[] dutchDays = { "Maandag", "Dinsdag", "Woensdag", "Donderdag", "Vrijdag", "Zaterdag", "Zondag" }; private static String[] dutchDayAbbreviations = { "Ma", "Di", "Woe", "Do", "Vrij", "Zat", "Zon" }; private static int[] minUniqueDayLength = { 1, 2, 1, 2, 1, 2, 2 }; /** * Get an am/pm indicator * @param minutes the minutes within the day * @param minWidth minimum width of output * @param maxWidth maximum width of output * @return the AM or PM indicator */ public String halfDayName(int minutes, int minWidth, int maxWidth) { String s; if (minutes < 12*60) { switch (maxWidth) { case 1: s = "v"; break; case 2: case 3: s = "vm"; break; default: s = "v.m."; } } else { switch (maxWidth) { case 1: s = "n"; break; case 2: case 3: s = "nm"; break; default: s = "n.m."; } } return s; } /** * Get the name for an era (e.g. "BC" or "AD") * * @param year the proleptic gregorian year, using "0" for the year before 1AD */ /*@NotNull*/ public String getEraName(int year) { return (year > 0 ? "n.C." : "v.C."); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy