source: josm/trunk/scripts/I18nSimilarStrings.java@ 14134

Last change on this file since 14134 was 14134, checked in by Don-vip, 7 years ago

see #15229 - deprecate Main*.undoRedo - make UndoRedoHandler a singleton

  • Property svn:eol-style set to native
File size: 2.2 KB
Line 
1import java.util.ArrayList;
2import java.util.Collections;
3import java.util.List;
4
5import org.openstreetmap.josm.Main;
6import org.openstreetmap.josm.data.Preferences;
7import org.openstreetmap.josm.data.preferences.JosmBaseDirectories;
8import org.openstreetmap.josm.data.preferences.JosmUrls;
9import org.openstreetmap.josm.data.validation.tests.SimilarNamedWays;
10import org.openstreetmap.josm.gui.MainApplicationTest;
11import org.openstreetmap.josm.plugins.PluginHandlerTestIT;
12import org.openstreetmap.josm.spi.preferences.Config;
13import org.openstreetmap.josm.tools.I18n;
14
15// License: GPL. For details, see LICENSE file.
16
17/**
18 * Finds similar strings in lang files to find potential duplicates in order to reduce translation workload.
19 */
20public final class I18nSimilarStrings {
21
22 /**
23 * Main.
24 * @param args not used
25 */
26 public static void main(String[] args) {
27 I18n.init();
28 Main.determinePlatformHook();
29 Config.setBaseDirectoriesProvider(JosmBaseDirectories.getInstance());
30 Config.setUrlsProvider(JosmUrls.getInstance());
31 Preferences pref = new Preferences();
32 Config.setPreferencesInstance(pref);
33 pref.init(false);
34 MainApplicationTest.initContentPane();
35 MainApplicationTest.initToolbar();
36 MainApplicationTest.initMainMenu();
37 PluginHandlerTestIT.loadAllPlugins();
38 List<String> strings = new ArrayList<>();
39 strings.addAll(I18n.getSingularTranslations().keySet());
40 strings.addAll(I18n.getPluralTranslations().keySet());
41 System.out.println("Loaded " + strings.size() + " strings");
42 strings.removeIf(s -> s.length() <= 5);
43 System.out.println("Kept " + strings.size() + " strings longer than 5 characters");
44 Collections.sort(strings);
45 for (int i = 0; i < strings.size(); i++) {
46 for (int j = i+1; j < strings.size(); j++) {
47 String a = strings.get(i);
48 String b = strings.get(j);
49 int d = SimilarNamedWays.getLevenshteinDistance(a, b);
50 if (d <= 2) {
51 System.err.println(": " + a + " <--> " + b);
52 }
53 }
54 }
55 System.out.println("Done!");
56 }
57}
Note: See TracBrowser for help on using the repository browser.