--- dao/DaoAdresseService/src/dk/daoas/daoadresseservice/AddressUtils.java 2015/02/26 13:42:10 2386 +++ dao/DaoAdresseService/src/dk/daoas/daoadresseservice/AddressUtils.java 2015/02/27 11:05:28 2401 @@ -20,20 +20,16 @@ } public static String vaskVejnavn(String indVejnavn) { - String out = indVejnavn.toLowerCase(); - out = out.replace(" ", ""); - out = out.replace(".", ""); - out = out.replace(",", ""); - out = out.replace("-", ""); - out = out.replace("/", ""); - out = out.replace("\\", ""); - out = out.replace("'", ""); - out = out.replace(";", ""); - out = out.replace(":", ""); - out = out.replace("´", ""); + StringBuilder sb = new StringBuilder(); + char chars[] = indVejnavn.toCharArray(); + for (char c: chars) { + if ( Character.isAlphabetic(c)) { + sb.append(Character.toLowerCase(c) ); + } + } - return out; + return sb.toString(); } public static String injectIntoBk(String bkrute, String injected) { @@ -72,7 +68,20 @@ delStreng.append( indAdresse.charAt(i) ); i++; } - result.vej = WordUtils.capitalize( delStreng.toString().trim() ); + + + result.vej = delStreng.toString().toLowerCase().trim(); + if ( result.vej.endsWith(".") || result.vej.endsWith(",")) { + result.vej = result.vej.substring(0, result.vej.length() - 1); + result.vej = result.vej.trim(); + } + + //special case - hvis strengen ender med ' nr' skal ' nr' fjernes + if ( result.vej.endsWith(" nr")) { + result.vej = result.vej.substring(0, result.vej.length() - 3); + } + + result.vej = WordUtils.capitalize( result.vej.trim() ); @@ -117,17 +126,26 @@ if (i>=len) //THN tilføjelse return result; - if (Character.isAlphabetic(indAdresse.charAt(i) )) { - if ( (i+1 == len || - (Character.isAlphabetic(indAdresse.charAt(i+1)) == false && indAdresse.charAt(i+1) != '.') - ) - ) { - result.litra = "" + indAdresse.charAt(i); - result.litra = result.litra.toUpperCase(); - i++; + if (Character.isAlphabetic(indAdresse.charAt(i) )) { + char current = Character.toUpperCase( indAdresse.charAt(i) ); + + if (current != 'Æ'&& current != 'Ø' && current != 'Å') { + if ( (i+1 == len || + (Character.isAlphabetic(indAdresse.charAt(i+1)) == false + /*&& indAdresse.charAt(i+1) != '.'*/) + ) + ) { + result.litra = "" + current; + i++; + } } } + // ignorer blanke og komma og punktum + while (i