source: josm/trunk/src/org/openstreetmap/josm/io/OsmChangeImporter.java@ 12623

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

see #15182 - deprecate all Main logging methods and introduce suitable replacements in Logging for most of them

  • Property svn:eol-style set to native
File size: 2.6 KB
Line 
1// License: GPL. For details, see LICENSE file.
2package org.openstreetmap.josm.io;
3
4import static org.openstreetmap.josm.tools.I18n.tr;
5
6import java.io.File;
7import java.io.FileNotFoundException;
8import java.io.IOException;
9import java.io.InputStream;
10
11import javax.swing.JOptionPane;
12
13import org.openstreetmap.josm.Main;
14import org.openstreetmap.josm.actions.ExtensionFileFilter;
15import org.openstreetmap.josm.data.osm.DataSet;
16import org.openstreetmap.josm.gui.layer.OsmDataLayer;
17import org.openstreetmap.josm.gui.progress.ProgressMonitor;
18import org.openstreetmap.josm.gui.util.GuiHelper;
19import org.openstreetmap.josm.tools.Logging;
20
21/**
22 * File importer that reads OSM change files (*.osc).
23 * @see <a href="http://wiki.openstreetmap.org/wiki/OsmChange">OsmChange</a>
24 */
25public class OsmChangeImporter extends FileImporter {
26
27 public static final ExtensionFileFilter FILE_FILTER = ExtensionFileFilter.newFilterWithArchiveExtensions(
28 "osc", "osc", tr("OsmChange File"), true);
29
30 /**
31 * Constructs a new {@code OsmChangeImporter}.
32 */
33 public OsmChangeImporter() {
34 super(FILE_FILTER);
35 }
36
37 public OsmChangeImporter(ExtensionFileFilter filter) {
38 super(filter);
39 }
40
41 @Override
42 public void importData(File file, ProgressMonitor progressMonitor) throws IOException, IllegalDataException {
43 try {
44 importData(Compression.getUncompressedFileInputStream(file), file, progressMonitor);
45 } catch (FileNotFoundException e) {
46 Logging.error(e);
47 throw new IOException(tr("File ''{0}'' does not exist.", file.getName()), e);
48 }
49 }
50
51 protected void importData(InputStream in, final File associatedFile, ProgressMonitor progressMonitor) throws IllegalDataException {
52 final DataSet dataSet = OsmChangeReader.parseDataSet(in, progressMonitor);
53 final OsmDataLayer layer = new OsmDataLayer(dataSet, associatedFile.getName(), associatedFile);
54 addDataLayer(dataSet, layer, associatedFile.getPath());
55 }
56
57 protected void addDataLayer(final DataSet dataSet, final OsmDataLayer layer, final String filePath) {
58 // FIXME: remove UI stuff from IO subsystem
59 //
60 GuiHelper.runInEDT(() -> {
61 if (dataSet.allPrimitives().isEmpty()) {
62 JOptionPane.showMessageDialog(
63 Main.parent,
64 tr("No data found in file {0}.", filePath),
65 tr("Open OsmChange file"),
66 JOptionPane.INFORMATION_MESSAGE);
67 }
68 Main.getLayerManager().addLayer(layer);
69 layer.onPostLoadFromFile();
70 });
71 }
72}
Note: See TracBrowser for help on using the repository browser.