Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*
This file is part of the iText (R) project.
Copyright (c) 1998-2023 Apryse Group NV
Authors: Apryse Software.
This program is offered under a commercial and under the AGPL license.
For commercial licensing, contact us at https://itextpdf.com/sales. For AGPL licensing, see below.
AGPL licensing:
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see .
*/
package com.itextpdf.kernel.numbering;
/**
* This class can produce String combinations representing a roman number.
* The first roman numbers are: I, II, III, IV, V, VI, VII, VIII, IX, X
* See http://en.wikipedia.org/wiki/Roman_numerals
*/
public class RomanNumbering {
/**
* Array with Roman digits.
*/
private static final RomanDigit[] ROMAN_DIGITS = {
new RomanDigit('m', 1000, false),
new RomanDigit('d', 500, false),
new RomanDigit('c', 100, true),
new RomanDigit('l', 50, false),
new RomanDigit('x', 10, true),
new RomanDigit('v', 5, false),
new RomanDigit('i', 1, true)
};
/**
* Returns a lower case roman representation of an integer.
*
* @param number a number to be converted to roman notation
* @return a lower case roman representation of an integer
*/
public static String toRomanLowerCase(int number) {
return convert(number);
}
/**
* Returns an upper case roman representation of an integer.
*
* @param number a number to be converted to roman notation
* @return an upper case roman representation of an integer
*/
public static String toRomanUpperCase(int number) {
return convert(number).toUpperCase();
}
/**
* Returns a roman representation of an integer.
*
* @param number a number to be converted to roman notation
* @param upperCase true for upper case representation,
* false for lower case one
* @return a roman representation of an integer
*/
public static String toRoman(int number, boolean upperCase) {
return upperCase ? toRomanUpperCase(number) : toRomanLowerCase(number);
}
/**
* Returns a roman representation of an integer.
*
* @param index the original number
* @return the roman number representation (lower case)
*/
protected static String convert(int index) {
StringBuilder buf = new StringBuilder();
// lower than 0 ? Add minus
if (index < 0) {
buf.append('-');
index = -index;
}
if (index >= 4000) {
buf.append('|');
buf.append(convert(index / 1000));
buf.append('|');
// remainder
index = index - (index / 1000) * 1000;
}
// number between 1 and 3999
int pos = 0;
while (true) {
// loop over the array with values for m-d-c-l-x-v-i
RomanDigit dig = ROMAN_DIGITS[pos];
// adding as many digits as we can
while (index >= dig.value) {
buf.append(dig.digit);
index -= dig.value;
}
// we have the complete number
if (index <= 0) {
break;
}
// look for the next digit that can be used in a special way
int j = pos;
while (!ROMAN_DIGITS[++j].pre) ;
// does the special notation apply?
if (index + ROMAN_DIGITS[j].value >= dig.value) {
buf.append(ROMAN_DIGITS[j].digit).append(dig.digit);
index -= dig.value - ROMAN_DIGITS[j].value;
}
pos++;
}
return buf.toString();
}
/**
* Helper class for Roman Digits
*/
private static class RomanDigit {
/**
* part of a roman number
*/
public char digit;
/**
* value of the roman digit
*/
public int value;
/**
* can the digit be used as a prefix
*/
public boolean pre;
/**
* Constructs a roman digit
*
* @param digit the roman digit
* @param value the value
* @param pre can it be used as a prefix
*/
RomanDigit(char digit, int value, boolean pre) {
this.digit = digit;
this.value = value;
this.pre = pre;
}
}
}