source: josm/trunk/src/org/openstreetmap/josm/io/NoteImporter.java@ 12622

Last change on this file since 12622 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.9 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.IOException;
8import java.io.InputStream;
9import java.util.List;
10
11import org.openstreetmap.josm.Main;
12import org.openstreetmap.josm.actions.ExtensionFileFilter;
13import org.openstreetmap.josm.data.notes.Note;
14import org.openstreetmap.josm.gui.layer.NoteLayer;
15import org.openstreetmap.josm.gui.progress.ProgressMonitor;
16import org.openstreetmap.josm.tools.Logging;
17import org.xml.sax.SAXException;
18
19/**
20 * File importer that reads note dump files (*.osn, .osn.gz and .osn.bz2)
21 * @since 7538
22 */
23public class NoteImporter extends FileImporter {
24
25 private static final ExtensionFileFilter FILE_FILTER = ExtensionFileFilter.newFilterWithArchiveExtensions(
26 "osn", "osn", tr("Note Files"), true);
27
28 /** Create an importer for note dump files */
29 public NoteImporter() {
30 super(FILE_FILTER);
31 }
32
33 @Override
34 public void importData(final File file, ProgressMonitor progressMonitor) throws IOException {
35 if (Logging.isDebugEnabled()) {
36 Logging.debug("importing notes file {0}", file.getAbsolutePath());
37 }
38 try (InputStream is = Compression.getUncompressedFileInputStream(file)) {
39 final NoteLayer layer = loadLayer(is, file, file.getName(), progressMonitor);
40 if (!Main.getLayerManager().containsLayer(layer)) {
41 Main.getLayerManager().addLayer(layer);
42 }
43 } catch (SAXException e) {
44 Logging.error("error opening up notes file");
45 Logging.error(e);
46 throw new IOException(e.getMessage(), e);
47 }
48 }
49
50 /**
51 * Load note layer from InputStream.
52 * @param in input stream
53 * @param associatedFile filename of data (can be <code>null</code> if the stream does not come from a file)
54 * @param layerName name of generated layer
55 * @param progressMonitor handler for progress monitoring and canceling
56 * @return note layer
57 * @throws IOException if any I/O error occurs
58 * @throws SAXException if any SAX error occurs
59 * @since 9746
60 */
61 public NoteLayer loadLayer(InputStream in, final File associatedFile, final String layerName, ProgressMonitor progressMonitor)
62 throws SAXException, IOException {
63 final List<Note> fileNotes = new NoteReader(in).parse();
64 List<NoteLayer> noteLayers = null;
65 if (Main.map != null) {
66 noteLayers = Main.getLayerManager().getLayersOfType(NoteLayer.class);
67 }
68 final NoteLayer layer;
69 if (noteLayers != null && !noteLayers.isEmpty()) {
70 layer = noteLayers.get(0);
71 layer.getNoteData().addNotes(fileNotes);
72 } else {
73 layer = new NoteLayer(fileNotes, associatedFile != null ? associatedFile.getName() : tr("Notes"));
74 }
75 return layer;
76 }
77}
Note: See TracBrowser for help on using the repository browser.