--- 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:40:08 2403 @@ -19,21 +19,50 @@ } } + public static char fjernAccentTegn(char c) { + switch (c) { + case 'é': + return 'e'; + case 'è': + return 'e'; + + case 'û': + return 'u'; + case 'ü': + return 'u'; + + case 'ö': + return 'o'; + case 'ô': + return 'o'; + + case 'ä': + return 'a'; + case 'â': + return 'a'; + + case 'ñ': + return 'n'; + + default: + return c; + } + } + 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)) { + c = Character.toLowerCase(c); + c = fjernAccentTegn(c); + + sb.append( c ); + } + } - return out; + return sb.toString(); } public static String injectIntoBk(String bkrute, String injected) { @@ -72,7 +101,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 +159,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