Changeset 33075 in osm for applications/editors/josm/plugins/wikipedia/src/org
- Timestamp:
- 2016-11-18T20:00:49+01:00 (8 years ago)
- Location:
- applications/editors/josm/plugins/wikipedia/src/org/wikipedia
- Files:
-
- 6 edited
Legend:
- Unmodified
- Added
- Removed
-
applications/editors/josm/plugins/wikipedia/src/org/wikipedia/WikipediaApp.java
r33074 r33075 44 44 public static final Pattern WIKIDATA_PATTERN = Pattern.compile("Q\\d+"); 45 45 private static final XPath X_PATH = XPath.getInstance(); 46 47 private WikipediaApp() { 46 private final String wikipediaLang; 47 48 private WikipediaApp(final String wikipediaLang) { 49 this.wikipediaLang = wikipediaLang; 50 } 51 52 public static WikipediaApp forLanguage(final String wikipediaLang) { 53 return new WikipediaApp(wikipediaLang); 48 54 } 49 55 … … 56 62 } 57 63 58 public staticString getSiteUrl(String wikipediaLang) {64 public String getSiteUrl() { 59 65 if ("wikidata".equals(wikipediaLang)) { 60 66 return "https://www.wikidata.org"; … … 64 70 } 65 71 66 public staticList<WikipediaEntry> getEntriesFromCoordinates(String wikipediaLang,LatLon min, LatLon max) {72 public List<WikipediaEntry> getEntriesFromCoordinates(LatLon min, LatLon max) { 67 73 try { 68 74 // construct url 69 final String url = getSiteUrl( wikipediaLang) + "/w/api.php"75 final String url = getSiteUrl() + "/w/api.php" 70 76 + "?action=query" 71 77 + "&list=geosearch" … … 120 126 } 121 127 122 public staticList<WikipediaEntry> getEntriesFromCategory(String wikipediaLang,String category, int depth) {128 public List<WikipediaEntry> getEntriesFromCategory(String category, int depth) { 123 129 try { 124 130 final String url = "https://tools.wmflabs.org/cats-php/" … … 145 151 } 146 152 147 public staticvoid updateWIWOSMStatus(String wikipediaLang,List<WikipediaEntry> entries) {153 public void updateWIWOSMStatus(List<WikipediaEntry> entries) { 148 154 if (entries.size() > 20) { 149 partitionList(entries, 20).forEach(chunk -> updateWIWOSMStatus( wikipediaLang,chunk));155 partitionList(entries, 20).forEach(chunk -> updateWIWOSMStatus(chunk)); 150 156 return; 151 157 } … … 179 185 } 180 186 181 public staticStream<String> getWikipediaArticles(finalString wikipediaLang,OsmPrimitive p) {187 public Stream<String> getWikipediaArticles(final OsmPrimitive p) { 182 188 if ("wikidata".equals(wikipediaLang)) { 183 189 return Stream.of(p.get("wikidata")).filter(Objects::nonNull); … … 194 200 * Returns a map mapping wikipedia articles to wikidata ids. 195 201 */ 196 public staticMap<String, String> getWikidataForArticles(String wikipediaLang, List<String> articles) {202 public Map<String, String> getWikidataForArticles(Collection<String> articles) { 197 203 return articles.stream() 198 204 .distinct() … … 216 222 .values() 217 223 .stream() 218 .flatMap(chunk -> getWikidataForArticles0( wikipediaLang,chunk).entrySet().stream())224 .flatMap(chunk -> getWikidataForArticles0(chunk).entrySet().stream()) 219 225 .collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue)); 220 226 } 221 227 222 private staticMap<String, String> getWikidataForArticles0(String wikipediaLang,List<String> articles) {228 private Map<String, String> getWikidataForArticles0(List<String> articles) { 223 229 if (articles.isEmpty()) { 224 230 return Collections.emptyMap(); … … 249 255 } 250 256 251 public staticList<String> getCategoriesForPrefix(final String wikipediaLang,final String prefix) {252 try { 253 final String url = getSiteUrl( wikipediaLang) + "/w/api.php"257 public List<String> getCategoriesForPrefix(final String prefix) { 258 try { 259 final String url = getSiteUrl() + "/w/api.php" 254 260 + "?action=query" 255 261 + "&list=prefixsearch" … … 334 340 } 335 341 336 public staticCollection<WikipediaEntry> getInterwikiArticles(String wikipediaLang,String article) {337 try { 338 final String url = getSiteUrl( wikipediaLang) + "/w/api.php" +342 public Collection<WikipediaEntry> getInterwikiArticles(String article) { 343 try { 344 final String url = getSiteUrl() + "/w/api.php" + 339 345 "?action=query" + 340 346 "&prop=langlinks" + … … 356 362 } 357 363 358 public staticLatLon getCoordinateForArticle(String wikipediaLang,String article) {359 try { 360 final String url = getSiteUrl( wikipediaLang) + "/w/api.php" +364 public LatLon getCoordinateForArticle(String article) { 365 try { 366 final String url = getSiteUrl() + "/w/api.php" + 361 367 "?action=query" + 362 368 "&prop=coordinates" + -
applications/editors/josm/plugins/wikipedia/src/org/wikipedia/actions/FetchWikidataAction.java
r32891 r33075 129 129 "Fetching {0} Wikidata ID for language ''{1}''", 130 130 "Fetching {0} Wikidata IDs for language ''{1}''", size, size, lang)); 131 final Map<String, String> wikidataByWikipedia = WikipediaApp.getWikidataForArticles( lang, new ArrayList<>(byArticle.keySet()));131 final Map<String, String> wikidataByWikipedia = WikipediaApp.forLanguage(lang).getWikidataForArticles(byArticle.keySet()); 132 132 ConditionalOptionPaneUtil.startBulkOperation(GuiUtils.PREF_OVERWRITE); 133 133 for (Map.Entry<String, Set<OsmPrimitive>> i : byArticle.entrySet()) { -
applications/editors/josm/plugins/wikipedia/src/org/wikipedia/actions/WikipediaAddNamesAction.java
r32891 r33075 31 31 final WikipediaEntry wp = WikipediaEntry.parseTag("wikipedia", getWikipediaValue()); 32 32 List<String[]> tags = new ArrayList<>(); 33 WikipediaApp.getInterwikiArticles( wp.lang,wp.article).stream()33 WikipediaApp.forLanguage(wp.lang).getInterwikiArticles(wp.article).stream() 34 34 .filter(this::useWikipediaLangArticle) 35 35 .map(i -> new String[]{"name:" + i.lang, i.article}) -
applications/editors/josm/plugins/wikipedia/src/org/wikipedia/data/WikipediaEntry.java
r32892 r33075 80 80 81 81 public String getBrowserUrl() { 82 return WikipediaApp.getSiteUrl( lang) + "/wiki/" + Utils.encodeUrl(article.replace(" ", "_"));82 return WikipediaApp.forLanguage(lang).getSiteUrl() + "/wiki/" + Utils.encodeUrl(article.replace(" ", "_")); 83 83 } 84 84 -
applications/editors/josm/plugins/wikipedia/src/org/wikipedia/gui/WikipediaCategorySearchDialog.java
r32887 r33075 58 58 final List<String> entries = query == null || query.isEmpty() 59 59 ? Collections.emptyList() 60 : WikipediaApp. getCategoriesForPrefix(WikipediaToggleDialog.wikipediaLang.get(),query);60 : WikipediaApp.forLanguage(WikipediaToggleDialog.wikipediaLang.get()).getCategoriesForPrefix(query); 61 61 GuiHelper.runInEDT(() -> lsResultModel.setItems(entries)); 62 62 }, 200, TimeUnit.MILLISECONDS); -
applications/editors/josm/plugins/wikipedia/src/org/wikipedia/gui/WikipediaToggleDialog.java
r33017 r33075 113 113 private void updateTitle() { 114 114 final String lang = getLanguageOfFirstItem(); 115 final String host = WikipediaApp.getSiteUrl( lang).split("/+")[1];115 final String host = WikipediaApp.forLanguage(lang).getSiteUrl().split("/+")[1]; 116 116 if (titleContext == null) { 117 117 setTitle(host); … … 155 155 @Override 156 156 List<WikipediaEntry> getEntries() { 157 return WikipediaApp. getEntriesFromCoordinates(158 wikidata ? "wikidata" : wikipediaLang.get(),min, max);157 return WikipediaApp.forLanguage(wikidata ? "wikidata" : wikipediaLang.get()) 158 .getEntriesFromCoordinates(min, max); 159 159 } 160 160 }.execute(); … … 175 175 publish(entries.toArray(new WikipediaEntry[entries.size()])); 176 176 WikipediaApp.partitionList(entries, 20).forEach(chunk -> { 177 WikipediaApp.updateWIWOSMStatus( chunk.get(0).lang,chunk);177 WikipediaApp.forLanguage(chunk.get(0).lang).updateWIWOSMStatus(chunk); 178 178 list.repaint(); 179 179 }); … … 217 217 @Override 218 218 List<WikipediaEntry> getEntries() { 219 return WikipediaApp. getEntriesFromCategory(220 wikipediaLang.get(),category, Main.pref.getInteger("wikipedia.depth", 3));219 return WikipediaApp.forLanguage(wikipediaLang.get()) 220 .getEntriesFromCategory(category, Main.pref.getInteger("wikipedia.depth", 3)); 221 221 } 222 222 }.execute(); … … 341 341 final LatLon latLon = entry.coordinate != null 342 342 ? entry.coordinate 343 : WikipediaApp.getCoordinateForArticle( entry.lang,entry.article);343 : WikipediaApp.forLanguage(entry.lang).getCoordinateForArticle(entry.article); 344 344 if (latLon == null) { 345 345 return; … … 354 354 if (Main.main != null && Main.getLayerManager().getEditDataSet() != null) { 355 355 Main.getLayerManager().getEditDataSet().allPrimitives().stream() 356 .flatMap(p -> WikipediaApp.getWikipediaArticles( language,p))356 .flatMap(p -> WikipediaApp.forLanguage(language).getWikipediaArticles(p)) 357 357 .forEach(articles::add); 358 358 }
Note:
See TracChangeset
for help on using the changeset viewer.