Changeset 29706 in osm for applications/editors/josm


Ignore:
Timestamp:
2013-06-26T22:14:50+02:00 (12 years ago)
Author:
donvip
Message:

[josm_opendata] Update to JOSM 6031

Location:
applications/editors/josm/plugins/opendata
Files:
4 edited

Legend:

Unmodified
Added
Removed
  • applications/editors/josm/plugins/opendata/build.xml

    r29694 r29706  
    11<?xml version="1.0" encoding="utf-8"?>
    22<project name="opendata" default="dist" basedir=".">
    3     <property name="plugin.main.version" value="5874"/>
     3    <property name="plugin.main.version" value="6031"/>
    44    <property name="plugin.author" value="Don-vip"/>
    55    <property name="plugin.class" value="org.openstreetmap.josm.plugins.opendata.OdPlugin"/>
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/actions/DownloadDataTask.java

    r28696 r29706  
    7373                        }
    7474                }
    75                 for (String ext : new String[]{ZIP_EXT, CSV_EXT, KML_EXT, KMZ_EXT, XLS_EXT, ODS_EXT, SHP_EXT, MIF_EXT, TAB_EXT}) {
     75                for (String ext : NetworkReader.FILE_AND_ARCHIVE_READERS.keySet()) {
    7676                        if (Pattern.compile(".*\\."+ext, Pattern.CASE_INSENSITIVE).matcher(url).matches()) {
    7777                                return true;
     
    8181        }
    8282       
    83         protected class InternalDownloadTasK extends DownloadTask {
     83    @Override
     84    public String[] getPatterns() {
     85        String pattern = "";
     86        for (String ext : NetworkReader.FILE_AND_ARCHIVE_READERS.keySet()) {
     87            if (!pattern.isEmpty()) {
     88                pattern += "|";
     89            }
     90            pattern += "."+ext;
     91        }
     92        return new String[]{".*(" + pattern + ")"};
     93    }
     94
     95    @Override
     96    public String getTitle() {
     97        return tr("Download open data");
     98    }
     99
     100    protected class InternalDownloadTasK extends DownloadTask {
    84101
    85102                public InternalDownloadTasK(boolean newLayer, NetworkReader reader, ProgressMonitor progressMonitor) {
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/NetworkReader.java

    r29686 r29706  
    2020import java.io.File;
    2121import java.io.InputStream;
     22import java.util.HashMap;
     23import java.util.Map;
    2224import java.util.regex.Matcher;
    2325import java.util.regex.Pattern;
     
    5355        private File file;
    5456        private String filename;
    55        
     57   
     58    /**
     59     * File readers
     60     */
     61    public static final Map<String, Class<? extends AbstractReader>> FILE_READERS = new HashMap<String, Class<? extends AbstractReader>>();
     62    static {
     63        FILE_READERS.put(CSV_EXT, CsvReader.class);
     64        FILE_READERS.put(KML_EXT, KmlReader.class);
     65        FILE_READERS.put(KMZ_EXT, KmzReader.class);
     66        FILE_READERS.put(GML_EXT, GmlReader.class);
     67        FILE_READERS.put(XLS_EXT, XlsReader.class);
     68        FILE_READERS.put(ODS_EXT, OdsReader.class);
     69        FILE_READERS.put(SHP_EXT, ShpReader.class);
     70        FILE_READERS.put(MIF_EXT, MifReader.class);
     71        FILE_READERS.put(TAB_EXT, TabReader.class);
     72    }
     73   
     74    public static final Map<String, Class<? extends AbstractReader>> FILE_AND_ARCHIVE_READERS = new HashMap<String, Class<? extends AbstractReader>>(FILE_READERS);
     75    static {
     76        FILE_AND_ARCHIVE_READERS.put(ZIP_EXT, ZipReader.class);
     77        FILE_AND_ARCHIVE_READERS.put(SEVENZIP_EXT, SevenZipReader.class);
     78    }
     79
    5680    public NetworkReader(String url, AbstractDataSetHandler handler, boolean promptUser) {
    5781        CheckParameterUtil.ensureParameterNotNull(url, "url");
     
    76100                        if (m.matches()) {
    77101                                filename = m.group(1);
    78                                 return findReaderByExtension(filename.toLowerCase());
     102                                return findReaderByExtension(filename);
    79103                        }
    80104                }
     
    105129
    106130        private Class<? extends AbstractReader> findReaderByExtension(String filename) {
    107                 filename = filename.replace("\"", "");
    108         if (filename.endsWith("."+XLS_EXT)) {
    109                 return XlsReader.class;
    110         } else if (filename.endsWith("."+CSV_EXT)) {
    111                 return CsvReader.class;
    112         } else if (filename.endsWith("."+ODS_EXT)) {
    113                 return OdsReader.class;
    114         } else if (filename.endsWith("."+KML_EXT)) {
    115                 return KmlReader.class;
    116         } else if (filename.endsWith("."+KMZ_EXT)) {
    117                 return KmzReader.class;
    118         } else if (filename.endsWith("."+MIF_EXT)) {
    119                 return MifReader.class;
    120         } else if (filename.endsWith("."+SHP_EXT)) {
    121                 return ShpReader.class;
    122         } else if (filename.endsWith("."+TAB_EXT)) {
    123                 return TabReader.class;
    124         } else if (filename.endsWith("."+GML_EXT)) {
    125                 return GmlReader.class;
    126         } else if (filename.endsWith("."+ZIP_EXT)) {
    127                 return ZipReader.class;
    128         } else if (filename.endsWith("."+SEVENZIP_EXT)) {
    129             return SevenZipReader.class;
    130         } else {
    131                 return null;
    132         }
     131                filename = filename.replace("\"", "").toLowerCase();
     132                for (String ext : FILE_AND_ARCHIVE_READERS.keySet()) {
     133                    if (filename.endsWith("."+ext)) {
     134                        return FILE_AND_ARCHIVE_READERS.get(ext);
     135                    }
     136                }
     137                return null;
    133138        }
    134139
     
    146151            }
    147152            if (readerClass == null) {
    148                 readerClass = findReaderByExtension(url.toLowerCase());
     153                readerClass = findReaderByExtension(url);
    149154            }
    150155            if (readerClass == null) {
     
    153158            if (readerClass == null) {
    154159                        throw new OsmTransferException("Cannot find appropriate reader !");//TODO handler job ?
    155             } else if (findReaderByExtension(url.toLowerCase()) != null) {
     160            } else if (findReaderByExtension(url) != null) {
    156161                filename = url.substring(url.lastIndexOf('/')+1);
    157162            }
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/archive/ArchiveReader.java

    r29680 r29706  
    3636import org.openstreetmap.josm.plugins.opendata.core.gui.DialogPrompter;
    3737import org.openstreetmap.josm.plugins.opendata.core.io.NeptuneReader;
     38import org.openstreetmap.josm.plugins.opendata.core.io.NetworkReader;
    3839import org.openstreetmap.josm.plugins.opendata.core.io.geographic.GmlReader;
    3940import org.openstreetmap.josm.plugins.opendata.core.io.geographic.KmlReader;
     
    9697            }
    9798           
    98             if (file == null) {
    99                 return null;
    100             } else if (!file.exists()) {
    101                 Main.warn("File does not exist: "+file.getPath());
    102                 return null;
    103             } else {
    104                 DataSet from = null;
    105                 FileInputStream in = new FileInputStream(file);
    106                 ProgressMonitor instance = null;
    107                 if (progressMonitor != null) {
    108                     instance = progressMonitor.createSubTaskMonitor(ProgressMonitor.ALL_TICKS, false);
    109                 }
    110                 if (file.getName().toLowerCase().endsWith(CSV_EXT)) {
    111                     from = CsvReader.parseDataSet(in, handler, instance);
    112                 } else if (file.getName().toLowerCase().endsWith(KML_EXT)) {
    113                     from = KmlReader.parseDataSet(in, instance);
    114                 } else if (file.getName().toLowerCase().endsWith(KMZ_EXT)) {
    115                     from = KmzReader.parseDataSet(in, instance);
    116                 } else if (file.getName().toLowerCase().endsWith(XLS_EXT)) {
    117                     from = XlsReader.parseDataSet(in, handler, instance);
    118                 } else if (file.getName().toLowerCase().endsWith(ODS_EXT)) {
    119                     from = OdsReader.parseDataSet(in, handler, instance);
    120                 } else if (file.getName().toLowerCase().endsWith(SHP_EXT)) {
    121                     from = ShpReader.parseDataSet(in, file, handler, instance);
    122                 } else if (file.getName().toLowerCase().endsWith(MIF_EXT)) {
    123                     from = MifReader.parseDataSet(in, file, handler, instance);
    124                 } else if (file.getName().toLowerCase().endsWith(TAB_EXT)) {
    125                     from = TabReader.parseDataSet(in, file, handler, instance);
    126                 } else if (file.getName().toLowerCase().endsWith(GML_EXT)) {
    127                     from = GmlReader.parseDataSet(in, handler, instance);
    128                 } else if (file.getName().toLowerCase().endsWith(XML_EXT)) {
    129                     if (OdPlugin.getInstance().xmlImporter.acceptFile(file)) {
    130                         from = NeptuneReader.parseDataSet(in, handler, instance);
    131                     } else {
    132                         System.err.println("Unsupported XML file: "+file.getName());
    133                     }
    134                    
    135                 } else {
    136                     System.err.println("Unsupported file extension: "+file.getName());
    137                 }
    138                 if (from != null) {
    139                     ds = from;
    140                 }
     99            DataSet from = getDataForFile(progressMonitor);
     100            if (from != null) {
     101                ds = from;
    141102            }
    142103        } catch (IllegalArgumentException e) {
     
    152113    }
    153114
     115    protected DataSet getDataForFile(final ProgressMonitor progressMonitor)
     116            throws FileNotFoundException, IOException, XMLStreamException, FactoryConfigurationError, JAXBException {
     117        if (file == null) {
     118            return null;
     119        } else if (!file.exists()) {
     120            Main.warn("File does not exist: "+file.getPath());
     121            return null;
     122        } else {
     123            DataSet from = null;
     124            FileInputStream in = new FileInputStream(file);
     125            ProgressMonitor instance = null;
     126            if (progressMonitor != null) {
     127                instance = progressMonitor.createSubTaskMonitor(ProgressMonitor.ALL_TICKS, false);
     128            }
     129            if (file.getName().toLowerCase().endsWith(CSV_EXT)) {
     130                from = CsvReader.parseDataSet(in, handler, instance);
     131            } else if (file.getName().toLowerCase().endsWith(KML_EXT)) {
     132                from = KmlReader.parseDataSet(in, instance);
     133            } else if (file.getName().toLowerCase().endsWith(KMZ_EXT)) {
     134                from = KmzReader.parseDataSet(in, instance);
     135            } else if (file.getName().toLowerCase().endsWith(XLS_EXT)) {
     136                from = XlsReader.parseDataSet(in, handler, instance);
     137            } else if (file.getName().toLowerCase().endsWith(ODS_EXT)) {
     138                from = OdsReader.parseDataSet(in, handler, instance);
     139            } else if (file.getName().toLowerCase().endsWith(SHP_EXT)) {
     140                from = ShpReader.parseDataSet(in, file, handler, instance);
     141            } else if (file.getName().toLowerCase().endsWith(MIF_EXT)) {
     142                from = MifReader.parseDataSet(in, file, handler, instance);
     143            } else if (file.getName().toLowerCase().endsWith(TAB_EXT)) {
     144                from = TabReader.parseDataSet(in, file, handler, instance);
     145            } else if (file.getName().toLowerCase().endsWith(GML_EXT)) {
     146                from = GmlReader.parseDataSet(in, handler, instance);
     147            } else if (file.getName().toLowerCase().endsWith(XML_EXT)) {
     148                if (OdPlugin.getInstance().xmlImporter.acceptFile(file)) {
     149                    from = NeptuneReader.parseDataSet(in, handler, instance);
     150                } else {
     151                    System.err.println("Unsupported XML file: "+file.getName());
     152                }
     153               
     154            } else {
     155                System.err.println("Unsupported file extension: "+file.getName());
     156            }
     157            return from;
     158        }
     159    }
     160
    154161    protected final void lookForCandidate(String entryName, final List<File> candidates, File file) {
    155162        // Test file name to see if it may contain useful data
    156         for (String ext : new String[] {
    157                 CSV_EXT, KML_EXT, KMZ_EXT, XLS_EXT, ODS_EXT, SHP_EXT, MIF_EXT, TAB_EXT, GML_EXT
    158         }) {
     163        for (String ext : NetworkReader.FILE_READERS.keySet()) {
    159164            if (entryName.toLowerCase().endsWith("."+ext)) {
    160165                candidates.add(file);
Note: See TracChangeset for help on using the changeset viewer.