mirror of https://github.com/apache/poi.git
bug 56781: make Name#validateName compatible on Java 6 (no Regex \p{IsAlphabetic} metaclasses
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1749305 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
5ad7ad2122
commit
5381a7b808
|
@ -17,8 +17,6 @@
|
|||
|
||||
package org.apache.poi.hssf.usermodel;
|
||||
|
||||
import java.util.regex.Pattern;
|
||||
|
||||
import org.apache.poi.hssf.model.HSSFFormulaParser;
|
||||
import org.apache.poi.hssf.model.InternalWorkbook;
|
||||
import org.apache.poi.hssf.record.NameCommentRecord;
|
||||
|
@ -32,10 +30,6 @@ import org.apache.poi.ss.usermodel.Name;
|
|||
* 'named range' or name of a user defined function.
|
||||
*/
|
||||
public final class HSSFName implements Name {
|
||||
private static final Pattern isValidName = Pattern.compile(
|
||||
"[\\p{IsAlphabetic}_\\\\]" +
|
||||
"[\\p{IsAlphabetic}0-9_.\\\\]*",
|
||||
Pattern.CASE_INSENSITIVE);
|
||||
|
||||
private HSSFWorkbook _book;
|
||||
private NameRecord _definedNameRec;
|
||||
|
@ -161,11 +155,36 @@ public final class HSSFName implements Name {
|
|||
}
|
||||
|
||||
private static void validateName(String name) {
|
||||
if(name.length() == 0) throw new IllegalArgumentException("Name cannot be blank");
|
||||
if(!isValidName.matcher(name).matches()) {
|
||||
/* equivalent to:
|
||||
Pattern.compile(
|
||||
"[\\p{IsAlphabetic}_]" +
|
||||
"[\\p{IsAlphabetic}0-9_\\\\]*",
|
||||
Pattern.CASE_INSENSITIVE).matcher(name).matches();
|
||||
\p{IsAlphabetic} doesn't work on Java 6, and other regex-based character classes don't work on unicode
|
||||
thus we are stuck with Character.isLetter (for now).
|
||||
*/
|
||||
|
||||
if (name.length() == 0) {
|
||||
throw new IllegalArgumentException("Name cannot be blank");
|
||||
}
|
||||
|
||||
// is first character valid?
|
||||
char c = name.charAt(0);
|
||||
String allowedSymbols = "_";
|
||||
boolean characterIsValid = (Character.isLetter(c) || allowedSymbols.indexOf(c) != -1);
|
||||
if (!characterIsValid) {
|
||||
throw new IllegalArgumentException("Invalid name: '"+name+"': first character must be underscore or a letter");
|
||||
}
|
||||
|
||||
// are all other characters valid?
|
||||
allowedSymbols = "_\\"; //backslashes needed for unicode escape
|
||||
for (final char ch : name.toCharArray()) {
|
||||
characterIsValid = (Character.isLetterOrDigit(ch) || allowedSymbols.indexOf(ch) != -1);
|
||||
if (!characterIsValid) {
|
||||
throw new IllegalArgumentException("Invalid name: '"+name+"'");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void setRefersToFormula(String formulaText) {
|
||||
Ptg[] ptgs = HSSFFormulaParser.parse(formulaText, _book, FormulaType.NAMEDRANGE, getSheetIndex());
|
||||
|
|
|
@ -18,9 +18,6 @@ package org.apache.poi.xssf.usermodel;
|
|||
|
||||
import org.apache.poi.ss.formula.ptg.Ptg;
|
||||
|
||||
import java.util.regex.Matcher;
|
||||
import java.util.regex.Pattern;
|
||||
|
||||
import org.apache.poi.ss.formula.FormulaParser;
|
||||
import org.apache.poi.ss.formula.FormulaType;
|
||||
import org.apache.poi.ss.usermodel.Name;
|
||||
|
@ -57,11 +54,6 @@ import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTDefinedName;
|
|||
*/
|
||||
public final class XSSFName implements Name {
|
||||
|
||||
private static final Pattern isValidName = Pattern.compile(
|
||||
"[\\p{IsAlphabetic}_\\\\]" +
|
||||
"[\\p{IsAlphabetic}0-9_.\\\\]*",
|
||||
Pattern.CASE_INSENSITIVE);
|
||||
|
||||
/**
|
||||
* A built-in defined name that specifies the workbook's print area
|
||||
*/
|
||||
|
@ -355,9 +347,34 @@ public final class XSSFName implements Name {
|
|||
}
|
||||
|
||||
private static void validateName(String name) {
|
||||
if(name.length() == 0) throw new IllegalArgumentException("Name cannot be blank");
|
||||
if (!isValidName.matcher(name).matches()) {
|
||||
/* equivalent to:
|
||||
Pattern.compile(
|
||||
"[\\p{IsAlphabetic}_]" +
|
||||
"[\\p{IsAlphabetic}0-9_\\\\]*",
|
||||
Pattern.CASE_INSENSITIVE).matcher(name).matches();
|
||||
\p{IsAlphabetic} doesn't work on Java 6, and other regex-based character classes don't work on unicode
|
||||
thus we are stuck with Character.isLetter (for now).
|
||||
*/
|
||||
|
||||
if (name.length() == 0) {
|
||||
throw new IllegalArgumentException("Name cannot be blank");
|
||||
}
|
||||
|
||||
// is first character valid?
|
||||
char c = name.charAt(0);
|
||||
String allowedSymbols = "_";
|
||||
boolean characterIsValid = (Character.isLetter(c) || allowedSymbols.indexOf(c) != -1);
|
||||
if (!characterIsValid) {
|
||||
throw new IllegalArgumentException("Invalid name: '"+name+"': first character must be underscore or a letter");
|
||||
}
|
||||
|
||||
// are all other characters valid?
|
||||
allowedSymbols = "_\\"; //backslashes needed for unicode escape
|
||||
for (final char ch : name.toCharArray()) {
|
||||
characterIsValid = (Character.isLetterOrDigit(ch) || allowedSymbols.indexOf(ch) != -1);
|
||||
if (!characterIsValid) {
|
||||
throw new IllegalArgumentException("Invalid name: '"+name+"'");
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -687,10 +687,10 @@ public abstract class BaseTestNamedRange {
|
|||
for (String valid : Arrays.asList(
|
||||
"Hello",
|
||||
"number1",
|
||||
"_underscore",
|
||||
"p.e.r.o.i.d.s",
|
||||
"\\Backslash",
|
||||
"Backslash\\"
|
||||
"_underscore"
|
||||
//"p.e.r.o.i.d.s",
|
||||
//"\\Backslash",
|
||||
//"Backslash\\"
|
||||
)) {
|
||||
name.setNameName(valid);
|
||||
}
|
||||
|
@ -715,7 +715,8 @@ public abstract class BaseTestNamedRange {
|
|||
name.setNameName(invalid);
|
||||
fail("expected exception: " + invalid);
|
||||
} catch (final IllegalArgumentException e) {
|
||||
assertEquals("Invalid name: '" + invalid + "'", e.getMessage());
|
||||
assertTrue(invalid,
|
||||
e.getMessage().startsWith("Invalid name: '"+invalid+"'"));
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue