Ignore:
Timestamp:
2014-10-15T09:44:47+02:00 (10 years ago)
Author:
donvip
Message:

[josm_opendata] replace tabs by spaces

Location:
applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata
Files:
102 edited

Legend:

Unmodified
Added
Removed
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/OdPlugin.java

    r30607 r30723  
    4848public final class OdPlugin extends Plugin {
    4949
    50         private static OdPlugin instance;
    51        
    52         public final XmlImporter xmlImporter = new XmlImporter();
    53        
    54         private final JMenu menu;
    55        
    56         private OdDialog dialog;
    57        
    58         public OdPlugin(PluginInformation info) {
    59                 super(info);
    60                 if (instance == null) {
    61                         instance = this;
    62                 } else {
    63                         throw new IllegalAccessError("Cannot instantiate plugin twice !");
    64                 }
     50    private static OdPlugin instance;
     51   
     52    public final XmlImporter xmlImporter = new XmlImporter();
     53   
     54    private final JMenu menu;
     55   
     56    private OdDialog dialog;
     57   
     58    public OdPlugin(PluginInformation info) {
     59        super(info);
     60        if (instance == null) {
     61            instance = this;
     62        } else {
     63            throw new IllegalAccessError("Cannot instantiate plugin twice !");
     64        }
    6565        // Allow JOSM to import more files
    66                 for (AbstractImporter importer : Arrays.asList(new AbstractImporter[]{
    67                                 new CsvImporter(), new OdsImporter(), new XlsImporter(), // Tabular file formats
    68                                 new KmlKmzImporter(), new ShpImporter(), new MifTabImporter(), new GmlImporter(), // Geographic file formats
    69                                 new ZipImporter(), // Zip archive containing any of the others
     66        for (AbstractImporter importer : Arrays.asList(new AbstractImporter[]{
     67                new CsvImporter(), new OdsImporter(), new XlsImporter(), // Tabular file formats
     68                new KmlKmzImporter(), new ShpImporter(), new MifTabImporter(), new GmlImporter(), // Geographic file formats
     69                new ZipImporter(), // Zip archive containing any of the others
    7070                new SevenZipImporter(), // 7Zip archive containing any of the others
    71                                 xmlImporter // Generic importer for XML files (currently used for Neptune files)
    72                 })) {
    73                         ExtensionFileFilter.importers.add(0, importer);
    74                 }
     71                xmlImporter // Generic importer for XML files (currently used for Neptune files)
     72        })) {
     73            ExtensionFileFilter.importers.add(0, importer);
     74        }
    7575        // Load modules
    7676        loadModules();
     
    8383        // Delete previous temp dirs if any (old plugin versions did not remove them correctly)
    8484        OdUtils.deletePreviousTempDirs();
    85         }
    86        
    87         public static final OdPlugin getInstance() {
    88                 return instance;
    89         }
    90        
    91         private JMenu getModuleMenu(Module module) {
    92                 String moduleName = module.getDisplayedName();
    93                 if (moduleName == null || moduleName.isEmpty()) {
    94                         moduleName = module.getModuleInformation().getName();
    95                 }
    96                 JMenu moduleMenu = new JMenu(moduleName);
    97                 moduleMenu.setIcon(module.getModuleInformation().getScaledIcon());
    98                 return moduleMenu;
    99         }
    100        
    101         private void buildMenu() {
     85    }
     86   
     87    public static final OdPlugin getInstance() {
     88        return instance;
     89    }
     90   
     91    private JMenu getModuleMenu(Module module) {
     92        String moduleName = module.getDisplayedName();
     93        if (moduleName == null || moduleName.isEmpty()) {
     94            moduleName = module.getModuleInformation().getName();
     95        }
     96        JMenu moduleMenu = new JMenu(moduleName);
     97        moduleMenu.setIcon(module.getModuleInformation().getScaledIcon());
     98        return moduleMenu;
     99    }
     100   
     101    private void buildMenu() {
    102102        for (Module module : ModuleHandler.moduleList) {
    103                 Map<DataSetCategory, JMenu> catMenus = new HashMap<>();
    104                 JMenu moduleMenu = null;
    105                 for (AbstractDataSetHandler handler: module.getNewlyInstanciatedHandlers()) {
    106                     URL dataURL = handler.getDataURL();
    107                     List<Pair<String, URL>> dataURLs = handler.getDataURLs();
    108                         if (dataURL != null || (dataURLs != null && !dataURLs.isEmpty())) {
    109                                 if (moduleMenu == null) {
    110                                         moduleMenu = getModuleMenu(module);
    111                                 }
    112                                 DataSetCategory cat = handler.getCategory();
    113                                 JMenu endMenu = null;
    114                                 if (cat != null) {
    115                                         if ((endMenu = catMenus.get(cat)) == null) {
    116                                                 catMenus.put(cat, endMenu = new JMenu(cat.getName()));
    117                                                 setMenuItemIcon(cat.getIcon(), endMenu);
    118                                                 moduleMenu.add(endMenu);
    119                                         }
    120                                 }
    121                                 if (endMenu == null) {
    122                                         endMenu = moduleMenu;
    123                                 }
    124                                 String handlerName = handler.getName();
    125                                 if (handlerName == null || handlerName.isEmpty()) {
    126                                         handlerName = handler.getClass().getName();
    127                                 }
    128                                 JMenuItem handlerItem = null;
    129                                 if (dataURL != null) {
    130                                     handlerItem = endMenu.add(new DownloadDataAction(module, handlerName, dataURL));
    131                                 } else if (dataURLs != null) {
    132                                         JMenu handlerMenu = new JMenu(handlerName);
    133                                         JMenuItem item = null;
    134                                         for (Pair<String, URL> pair : dataURLs) {
    135                                                 if (pair != null && pair.a != null && pair.b != null) {
    136                                                         item = handlerMenu.add(new DownloadDataAction(module, pair.a, pair.b));
    137                                                 }
    138                                         }
    139                                         if (item != null) {
    140                                                 MenuScroller.setScrollerFor(handlerMenu);
    141                                                 handlerItem = endMenu.add(handlerMenu);
    142                                         }
    143                                 }
    144                                 if (handlerItem != null) {
    145                                     setMenuItemIcon(handler.getMenuIcon(), handlerItem);
    146                                 }
    147                         }
    148                 }
    149                 if (moduleMenu != null) {
    150                         menu.add(moduleMenu);
    151                 }
     103            Map<DataSetCategory, JMenu> catMenus = new HashMap<>();
     104            JMenu moduleMenu = null;
     105            for (AbstractDataSetHandler handler: module.getNewlyInstanciatedHandlers()) {
     106                URL dataURL = handler.getDataURL();
     107                List<Pair<String, URL>> dataURLs = handler.getDataURLs();
     108                if (dataURL != null || (dataURLs != null && !dataURLs.isEmpty())) {
     109                    if (moduleMenu == null) {
     110                        moduleMenu = getModuleMenu(module);
     111                    }
     112                    DataSetCategory cat = handler.getCategory();
     113                    JMenu endMenu = null;
     114                    if (cat != null) {
     115                        if ((endMenu = catMenus.get(cat)) == null) {
     116                            catMenus.put(cat, endMenu = new JMenu(cat.getName()));
     117                            setMenuItemIcon(cat.getIcon(), endMenu);
     118                            moduleMenu.add(endMenu);
     119                        }
     120                    }
     121                    if (endMenu == null) {
     122                        endMenu = moduleMenu;
     123                    }
     124                    String handlerName = handler.getName();
     125                    if (handlerName == null || handlerName.isEmpty()) {
     126                        handlerName = handler.getClass().getName();
     127                    }
     128                    JMenuItem handlerItem = null;
     129                    if (dataURL != null) {
     130                        handlerItem = endMenu.add(new DownloadDataAction(module, handlerName, dataURL));
     131                    } else if (dataURLs != null) {
     132                        JMenu handlerMenu = new JMenu(handlerName);
     133                        JMenuItem item = null;
     134                        for (Pair<String, URL> pair : dataURLs) {
     135                            if (pair != null && pair.a != null && pair.b != null) {
     136                                item = handlerMenu.add(new DownloadDataAction(module, pair.a, pair.b));
     137                            }
     138                        }
     139                        if (item != null) {
     140                            MenuScroller.setScrollerFor(handlerMenu);
     141                            handlerItem = endMenu.add(handlerMenu);
     142                        }
     143                    }
     144                    if (handlerItem != null) {
     145                        setMenuItemIcon(handler.getMenuIcon(), handlerItem);
     146                    }
     147                }
     148            }
     149            if (moduleMenu != null) {
     150                menu.add(moduleMenu);
     151            }
    152152        }
    153153        menu.addSeparator();
    154154        MainMenu.add(menu, new OpenPreferencesActions());
    155         }
    156        
    157         private void setMenuItemIcon(ImageIcon icon, JMenuItem menuItem) {
     155    }
     156   
     157    private void setMenuItemIcon(ImageIcon icon, JMenuItem menuItem) {
    158158        if (icon != null) {
    159159            if (icon.getIconHeight() != 16 || icon.getIconWidth() != 16) {
     
    162162            menuItem.setIcon(icon);
    163163        }
    164         }
    165 
    166         @Override
    167         public void mapFrameInitialized(MapFrame oldFrame, MapFrame newFrame) {
    168                 if (newFrame != null) {
    169                         newFrame.addToggleDialog(dialog = new OdDialog());
    170                 } else {
    171                     dialog = null;
    172                 }
    173         }
    174        
     164    }
     165
     166    @Override
     167    public void mapFrameInitialized(MapFrame oldFrame, MapFrame newFrame) {
     168        if (newFrame != null) {
     169            newFrame.addToggleDialog(dialog = new OdDialog());
     170        } else {
     171            dialog = null;
     172        }
     173    }
     174   
    175175    @Override
    176176    public PreferenceSetting getPreferenceSetting() {
     
    185185
    186186        ModuleHandler.installDownloadedModules(true);
    187         ModuleHandler.loadModules(Main.parent, modulesToLoad, null);
     187        ModuleHandler.loadModules(Main.parent, modulesToLoad, null);
    188188    }
    189189   
    190190    private final File getSubDirectory(String name) {
    191         File dir = new File(getPluginDir()+File.separator+name);
     191        File dir = new File(getPluginDir()+File.separator+name);
    192192        if (!dir.exists()) {
    193193            dir.mkdirs();
     
    197197   
    198198    public final File getModulesDirectory() {
    199         return getSubDirectory("modules");
     199        return getSubDirectory("modules");
    200200    }
    201201
    202202    public final File getResourcesDirectory() {
    203         return getSubDirectory("resources");
     203        return getSubDirectory("resources");
    204204    }
    205205
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/OdConstants.java

    r30563 r30723  
    1010
    1111public abstract class OdConstants {
    12        
    13         /**
    14         * Encodings
    15         */
    16         public static final String UTF8 = "UTF-8";
    17         public static final String ISO8859_15 = "ISO-8859-15";
    18         public static final String CP850 = "Cp850";
     12   
     13    /**
     14    * Encodings
     15    */
     16    public static final String UTF8 = "UTF-8";
     17    public static final String ISO8859_15 = "ISO-8859-15";
     18    public static final String CP850 = "Cp850";
    1919    public static final String CP1251 = "Cp1251";
    20         public static final String CP1252 = "Cp1252";
    21         public static final String MAC_ROMAN = "MacRoman";
    22        
    23         /**
    24         * Patterns
    25         */
    26         public static final String PATTERN_LANG = "{lang}";
    27        
    28         /**
    29         * Preferences
    30         */
    31 /*      public static final String PREF_COORDINATES = "opendata.coordinates";
    32         public static final String VALUE_CC9ZONES = "cc9zones";
    33         public static final String VALUE_WGS84 = "wgs84";*/
     20    public static final String CP1252 = "Cp1252";
     21    public static final String MAC_ROMAN = "MacRoman";
     22   
     23    /**
     24    * Patterns
     25    */
     26    public static final String PATTERN_LANG = "{lang}";
     27   
     28    /**
     29    * Preferences
     30    */
     31/*    public static final String PREF_COORDINATES = "opendata.coordinates";
     32    public static final String VALUE_CC9ZONES = "cc9zones";
     33    public static final String VALUE_WGS84 = "wgs84";*/
    3434
    35         public static final String PREF_OAPI = "opendata.oapi";
     35    public static final String PREF_OAPI = "opendata.oapi";
    3636    public static final String DEFAULT_OAPI = "http://www.overpass-api.de/api/interpreter?";
    3737   
    38         public static final String PREF_XAPI = "opendata.xapi";
     38    public static final String PREF_XAPI = "opendata.xapi";
    3939    public static final String DEFAULT_XAPI = "http://www.overpass-api.de/api/xapi?";
    4040
    41         public static final String PREF_RAWDATA = "opendata.rawdata";
     41    public static final String PREF_RAWDATA = "opendata.rawdata";
    4242    public static final boolean DEFAULT_RAWDATA = false;
    4343
    44         public static final String PREF_MAXDISTANCE = "opendata.maxdistance";
     44    public static final String PREF_MAXDISTANCE = "opendata.maxdistance";
    4545    public static final double DEFAULT_MAXDISTANCE = 10;
    4646
     
    5858    public static final String PREF_CRS_COMPARISON_DEBUG = "opendata.crs.comparison_debug";
    5959
    60         /**
    61         * Icons
    62         */
    63         public static final String ICON_CORE_16 = "o16.png";
    64         public static final String ICON_CORE_24 = "o24.png";
    65         public static final String ICON_CORE_48 = "o48.png";
    66        
    67         public static final String ICON_OSM_16 = "osm16.png";
    68         public static final String ICON_OSM_24 = "osm24.png";
     60    /**
     61    * Icons
     62    */
     63    public static final String ICON_CORE_16 = "o16.png";
     64    public static final String ICON_CORE_24 = "o24.png";
     65    public static final String ICON_CORE_48 = "o48.png";
     66   
     67    public static final String ICON_OSM_16 = "osm16.png";
     68    public static final String ICON_OSM_24 = "osm24.png";
    6969
    70         public static final String ICON_AGREEMENT_24 = "agreement24.png";
    71         public static final String ICON_EMPTY_24 = "empty24.png";
     70    public static final String ICON_AGREEMENT_24 = "agreement24.png";
     71    public static final String ICON_EMPTY_24 = "empty24.png";
    7272
    73         public static final String ICON_LOOL_48 = "lool48.png";
     73    public static final String ICON_LOOL_48 = "lool48.png";
    7474
    7575    /**
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/actions/DownloadDataAction.java

    r30340 r30723  
    1414public class DownloadDataAction extends JosmAction {
    1515
    16         private final URL url;
    17        
    18         public DownloadDataAction(Module module, String name, URL url) {
    19                 super(false);
    20                 CheckParameterUtil.ensureParameterNotNull(name, "name");
    21                 CheckParameterUtil.ensureParameterNotNull(url, "url");
    22                 putValue(Action.NAME, name);
    23                 putValue("toolbar", ("opendata_download_"+module.getDisplayedName()+"_"+name).toLowerCase().replace(" ", "_"));
    24                 this.url = url;
    25         }
    26        
    27         @Override
    28         public void actionPerformed(ActionEvent e) {
    29                 Main.main.menu.openLocation.openUrl(true, url.toString());
    30         }
     16    private final URL url;
     17   
     18    public DownloadDataAction(Module module, String name, URL url) {
     19        super(false);
     20        CheckParameterUtil.ensureParameterNotNull(name, "name");
     21        CheckParameterUtil.ensureParameterNotNull(url, "url");
     22        putValue(Action.NAME, name);
     23        putValue("toolbar", ("opendata_download_"+module.getDisplayedName()+"_"+name).toLowerCase().replace(" ", "_"));
     24        this.url = url;
     25    }
     26   
     27    @Override
     28    public void actionPerformed(ActionEvent e) {
     29        Main.main.menu.openLocation.openUrl(true, url.toString());
     30    }
    3131}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/actions/DownloadDataTask.java

    r30607 r30723  
    2727public class DownloadDataTask extends DownloadOsmTask {
    2828
    29         private AbstractDataSetHandler handler;
    30        
    31         @Override
    32         public Future<?> download(boolean newLayer, Bounds downloadArea, ProgressMonitor progressMonitor) {
    33                 return null;
    34         }
     29    private AbstractDataSetHandler handler;
     30   
     31    @Override
     32    public Future<?> download(boolean newLayer, Bounds downloadArea, ProgressMonitor progressMonitor) {
     33        return null;
     34    }
    3535
    36         @Override
    37         public Future<?> loadUrl(boolean newLayer, String url, ProgressMonitor progressMonitor) {
     36    @Override
     37    public Future<?> loadUrl(boolean newLayer, String url, ProgressMonitor progressMonitor) {
    3838        downloadTask = new InternalDownloadTasK(newLayer, new NetworkReader(url, handler, true), progressMonitor);
    3939        currentBounds = null;
    4040        if (handler == null || !handler.hasLicenseToBeAccepted() || askLicenseAgreement(handler.getLicense())) {
    41                 return Main.worker.submit(downloadTask);
     41            return Main.worker.submit(downloadTask);
    4242        } else {
    43                 return null;
     43            return null;
    4444        }
    45         }
     45    }
    4646
    47         @Override
    48         public boolean acceptsUrl(String url) {
    49                 this.handler = null;
    50                 for (Module module : ModuleHandler.moduleList) {
    51                         for (AbstractDataSetHandler handler : module.getNewlyInstanciatedHandlers()) {
    52                                 if (handler.acceptsUrl(url)) {
    53                                         this.handler = handler;
    54                                         return true;
    55                                 }
    56                         }
    57                 }
    58                 for (String ext : NetworkReader.FILE_AND_ARCHIVE_READERS.keySet()) {
    59                         if (Pattern.compile(".*\\."+ext, Pattern.CASE_INSENSITIVE).matcher(url).matches()) {
    60                                 return true;
    61                         }
    62                 }
    63                 return false;
    64         }
    65        
     47    @Override
     48    public boolean acceptsUrl(String url) {
     49        this.handler = null;
     50        for (Module module : ModuleHandler.moduleList) {
     51            for (AbstractDataSetHandler handler : module.getNewlyInstanciatedHandlers()) {
     52                if (handler.acceptsUrl(url)) {
     53                    this.handler = handler;
     54                    return true;
     55                }
     56            }
     57        }
     58        for (String ext : NetworkReader.FILE_AND_ARCHIVE_READERS.keySet()) {
     59            if (Pattern.compile(".*\\."+ext, Pattern.CASE_INSENSITIVE).matcher(url).matches()) {
     60                return true;
     61            }
     62        }
     63        return false;
     64    }
     65   
    6666    @Override
    6767    public String[] getPatterns() {
     
    8383    protected class InternalDownloadTasK extends DownloadTask {
    8484
    85                 public InternalDownloadTasK(boolean newLayer, NetworkReader reader, ProgressMonitor progressMonitor) {
    86                         super(newLayer, reader, progressMonitor);
    87                 }
     85        public InternalDownloadTasK(boolean newLayer, NetworkReader reader, ProgressMonitor progressMonitor) {
     86            super(newLayer, reader, progressMonitor);
     87        }
    8888
    89                 @Override
    90                 protected OsmDataLayer createNewLayer(String layerName) {
     89        @Override
     90        protected OsmDataLayer createNewLayer(String layerName) {
    9191            File associatedFile = ((NetworkReader)reader).getReadFile();
    9292            String filename = ((NetworkReader)reader).getReadFileName();
    9393            if (layerName == null || layerName.isEmpty()) {
    94                 if (associatedFile != null) {
    95                         layerName = associatedFile.getName();
    96                 } else if (filename != null && !filename.isEmpty()) {
    97                         layerName = filename;
    98                 } else {
    99                         layerName = OsmDataLayer.createNewName();
    100                 }
     94                if (associatedFile != null) {
     95                    layerName = associatedFile.getName();
     96                } else if (filename != null && !filename.isEmpty()) {
     97                    layerName = filename;
     98                } else {
     99                    layerName = OsmDataLayer.createNewName();
     100                }
    101101            }
    102                 DataSetUpdater.updateDataSet(dataSet, handler, associatedFile);
    103                 return new OdDataLayer(dataSet, layerName, associatedFile, handler);
    104                 }
    105         }
    106        
     102            DataSetUpdater.updateDataSet(dataSet, handler, associatedFile);
     103            return new OdDataLayer(dataSet, layerName, associatedFile, handler);
     104        }
     105    }
     106   
    107107    /**
    108108     * returns true if the user accepts the license, false if they refuse
    109109     */
    110110    protected final boolean askLicenseAgreement(License license) {
    111         if (license == null || (license.getURL() == null && license.getSummaryURL() == null)) {
    112                 return true;
    113         }
    114         try {
    115                 return new AskLicenseAgreementDialog(license).showDialog().getValue() == 1;
    116                
    117                 } catch (IOException e) {
     111        if (license == null || (license.getURL() == null && license.getSummaryURL() == null)) {
     112            return true;
     113        }
     114        try {
     115            return new AskLicenseAgreementDialog(license).showDialog().getValue() == 1;
     116           
     117        } catch (IOException e) {
    118118            JOptionPane.showMessageDialog(Main.parent, tr("License URL not available: {0}", license.toString()));
    119119            return false;
    120                 }
     120        }
    121121    }
    122122}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/actions/OpenLinkAction.java

    r30563 r30723  
    2929    public void actionPerformed(ActionEvent e) {
    3030        try {
    31                 System.out.println("Opening "+url);
    32                         OpenBrowser.displayUrl(url.toURI());
    33                 } catch (URISyntaxException e1) {
    34                         try {
    35                                 System.err.println(e1.getLocalizedMessage());
    36                                 int index = e1.getIndex();
    37                                 if (index > -1) {
    38                                         String s = url.toString().substring(index, index+1);
    39                                         s = url.toString().replace(s, URLEncoder.encode(s, OdConstants.UTF8));
    40                                         URI uri = new URI(s);
    41                                 System.out.println("Opening "+uri);
    42                                         OpenBrowser.displayUrl(uri);
    43                                 }
    44                         } catch (Exception e2) {
    45                                 e2.printStackTrace();
    46                         }
    47                 }
     31            System.out.println("Opening "+url);
     32            OpenBrowser.displayUrl(url.toURI());
     33        } catch (URISyntaxException e1) {
     34            try {
     35                System.err.println(e1.getLocalizedMessage());
     36                int index = e1.getIndex();
     37                if (index > -1) {
     38                    String s = url.toString().substring(index, index+1);
     39                    s = url.toString().replace(s, URLEncoder.encode(s, OdConstants.UTF8));
     40                    URI uri = new URI(s);
     41                    System.out.println("Opening "+uri);
     42                    OpenBrowser.displayUrl(uri);
     43                }
     44            } catch (Exception e2) {
     45                e2.printStackTrace();
     46            }
     47        }
    4848    }
    4949}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/actions/OpenPreferencesActions.java

    r30563 r30723  
    1414
    1515public class OpenPreferencesActions extends JosmAction {
    16        
     16   
    1717    public OpenPreferencesActions() {
    18         super(false);
     18        super(false);
    1919        putValue(NAME, tr("OpenData preferences"));
    2020        putValue(SMALL_ICON, ImageProvider.get("dialogs", OdConstants.ICON_CORE_24));
    21                 putValue("toolbar", "opendata_open_preferences");
     21        putValue("toolbar", "opendata_open_preferences");
    2222    }
    2323   
    24         @Override
    25         public void actionPerformed(ActionEvent e) {
     24    @Override
     25    public void actionPerformed(ActionEvent e) {
    2626        final PreferenceDialog p = new PreferenceDialog(Main.parent);
    2727        p.selectPreferencesTabByClass(OdPreferenceSetting.class);
    2828        p.setVisible(true);
    29         }
     29    }
    3030}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/actions/ViewLicenseAction.java

    r30563 r30723  
    1616public class ViewLicenseAction extends JosmAction {
    1717
    18         private final License license;
    19        
    20         public ViewLicenseAction(License license, String title, String description) {
    21                 super(title, null, description, null, false);
    22                 CheckParameterUtil.ensureParameterNotNull(license, "license");
    23                 this.license = license;
     18    private final License license;
     19   
     20    public ViewLicenseAction(License license, String title, String description) {
     21        super(title, null, description, null, false);
     22        CheckParameterUtil.ensureParameterNotNull(license, "license");
     23        this.license = license;
    2424        putValue(Action.SMALL_ICON, OdUtils.getImageIcon(OdConstants.ICON_AGREEMENT_24));
    25         }
     25    }
    2626
    27         @Override
    28         public void actionPerformed(ActionEvent e) {
    29                 try {
    30                         new ViewLicenseDialog(license).showDialog();
    31                 } catch (IOException ex) {
    32                         ex.printStackTrace();
    33                 }
    34         }
     27    @Override
     28    public void actionPerformed(ActionEvent e) {
     29        try {
     30            new ViewLicenseDialog(license).showDialog();
     31        } catch (IOException ex) {
     32            ex.printStackTrace();
     33        }
     34    }
    3535}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/AbstractDataSetHandler.java

    r30583 r30723  
    3737
    3838public abstract class AbstractDataSetHandler {
    39        
    40         public abstract boolean acceptsFilename(String filename);
    41        
    42         public boolean acceptsFile(File file) {
    43                 return acceptsFilename(file.getName());
    44         }
    45        
    46         public abstract void updateDataSet(DataSet ds);
    47 
    48         public void checkDataSetSource(DataSet ds) {
    49                 if (ds != null) {
    50                         for (OsmPrimitive p : ds.allPrimitives()) {
    51                                 if (p.hasKeys() || p.getReferrers().isEmpty()) {
    52                                         if (getSource() != null && p.get("source") == null) {
    53                                                 p.put("source", getSource());
    54                                         }
    55                                         if (sourceDate != null && p.get("source:date") == null) {
    56                                                 p.put("source:date", sourceDate);
    57                                         }
    58                                 }
    59                         }
    60                 }
    61         }
    62        
    63         public void checkNames(DataSet ds) {
    64                 if (ds != null) {
    65                         for (OsmPrimitive p : ds.allPrimitives()) {
    66                                 if (p.get("name") != null) {
    67                                         p.put("name", NamesFrUtils.checkDictionary(p.get("name")));
    68                                 }
    69                         }
    70                 }
    71         }
    72 
    73         private String name;
    74         private DataSetCategory category;
    75         private String sourceDate;
    76         private File associatedFile;
    77         private ImageIcon menuIcon;
    78 
    79         public AbstractDataSetHandler() {
    80                 setShpHandler(new DefaultShpHandler());
    81                 setArchiveHandler(new DefaultArchiveHandler());
    82                 setCsvHandler(new DefaultCsvHandler());
    83                 setGmlHandler(new DefaultGmlHandler());
    84         }
    85        
    86         private final boolean acceptsFilename(String filename, String[] expected, String ... extensions ) {
    87                 if (filename != null) {
    88                         for (String name : expected) {
    89                                 for (String ext : extensions) {
    90                                         if (Pattern.compile(name+"\\."+ext, Pattern.CASE_INSENSITIVE).matcher(filename).matches()) {
    91                                         //if (filename.equalsIgnoreCase(name+"."+ext)) {
    92                                                 return true;
    93                                         }
    94                                 }
    95                         }
    96                 }
    97                 return false;
    98         }
    99        
    100         protected final boolean acceptsCsvFilename(String filename, String ... expected) {
    101                 return acceptsFilename(filename, expected, OdConstants.CSV_EXT);
    102         }
    103 
    104         protected final boolean acceptsXlsFilename(String filename, String ... expected) {
    105                 return acceptsFilename(filename, expected, OdConstants.XLS_EXT);
    106         }
    107 
    108         protected final boolean acceptsOdsFilename(String filename, String ... expected) {
    109                 return acceptsFilename(filename, expected, OdConstants.ODS_EXT);
    110         }
    111 
    112         protected final boolean acceptsShpFilename(String filename, String ... expected) {
    113                 return acceptsFilename(filename, expected, OdConstants.SHP_EXT);
    114         }
    115 
    116         protected final boolean acceptsMifFilename(String filename, String ... expected) {
    117                 return acceptsFilename(filename, expected, OdConstants.MIF_EXT);
    118         }
    119 
    120         protected final boolean acceptsMifTabFilename(String filename, String ... expected) {
    121                 return acceptsFilename(filename, expected, OdConstants.MIF_EXT, OdConstants.TAB_EXT);
    122         }
    123 
    124         protected final boolean acceptsShpMifFilename(String filename, String ... expected) {
    125                 return acceptsFilename(filename, expected, OdConstants.SHP_EXT, OdConstants.MIF_EXT);
    126         }
    127 
    128         protected final boolean acceptsKmlFilename(String filename, String ... expected) {
    129                 return acceptsFilename(filename, expected, OdConstants.KML_EXT);
    130         }
    131 
    132         protected final boolean acceptsKmzFilename(String filename, String ... expected) {
    133                 return acceptsFilename(filename, expected, OdConstants.KMZ_EXT);
    134         }
    135 
    136         protected final boolean acceptsKmzShpFilename(String filename, String ... expected) {
    137                 return acceptsFilename(filename, expected, OdConstants.KMZ_EXT, OdConstants.SHP_EXT);
    138         }
    139 
    140         protected final boolean acceptsKmzTabFilename(String filename, String ... expected) {
    141                 return acceptsFilename(filename, expected, OdConstants.KMZ_EXT, OdConstants.TAB_EXT);
    142         }
    143 
    144         protected final boolean acceptsZipFilename(String filename, String ... expected) {
    145                 return acceptsFilename(filename, expected, OdConstants.ZIP_EXT);
    146         }
     39   
     40    public abstract boolean acceptsFilename(String filename);
     41   
     42    public boolean acceptsFile(File file) {
     43        return acceptsFilename(file.getName());
     44    }
     45   
     46    public abstract void updateDataSet(DataSet ds);
     47
     48    public void checkDataSetSource(DataSet ds) {
     49        if (ds != null) {
     50            for (OsmPrimitive p : ds.allPrimitives()) {
     51                if (p.hasKeys() || p.getReferrers().isEmpty()) {
     52                    if (getSource() != null && p.get("source") == null) {
     53                        p.put("source", getSource());
     54                    }
     55                    if (sourceDate != null && p.get("source:date") == null) {
     56                        p.put("source:date", sourceDate);
     57                    }
     58                }
     59            }
     60        }
     61    }
     62   
     63    public void checkNames(DataSet ds) {
     64        if (ds != null) {
     65            for (OsmPrimitive p : ds.allPrimitives()) {
     66                if (p.get("name") != null) {
     67                    p.put("name", NamesFrUtils.checkDictionary(p.get("name")));
     68                }
     69            }
     70        }
     71    }
     72
     73    private String name;
     74    private DataSetCategory category;
     75    private String sourceDate;
     76    private File associatedFile;
     77    private ImageIcon menuIcon;
     78
     79    public AbstractDataSetHandler() {
     80        setShpHandler(new DefaultShpHandler());
     81        setArchiveHandler(new DefaultArchiveHandler());
     82        setCsvHandler(new DefaultCsvHandler());
     83        setGmlHandler(new DefaultGmlHandler());
     84    }
     85   
     86    private final boolean acceptsFilename(String filename, String[] expected, String ... extensions ) {
     87        if (filename != null) {
     88            for (String name : expected) {
     89                for (String ext : extensions) {
     90                    if (Pattern.compile(name+"\\."+ext, Pattern.CASE_INSENSITIVE).matcher(filename).matches()) {
     91                    //if (filename.equalsIgnoreCase(name+"."+ext)) {
     92                        return true;
     93                    }
     94                }
     95            }
     96        }
     97        return false;
     98    }
     99   
     100    protected final boolean acceptsCsvFilename(String filename, String ... expected) {
     101        return acceptsFilename(filename, expected, OdConstants.CSV_EXT);
     102    }
     103
     104    protected final boolean acceptsXlsFilename(String filename, String ... expected) {
     105        return acceptsFilename(filename, expected, OdConstants.XLS_EXT);
     106    }
     107
     108    protected final boolean acceptsOdsFilename(String filename, String ... expected) {
     109        return acceptsFilename(filename, expected, OdConstants.ODS_EXT);
     110    }
     111
     112    protected final boolean acceptsShpFilename(String filename, String ... expected) {
     113        return acceptsFilename(filename, expected, OdConstants.SHP_EXT);
     114    }
     115
     116    protected final boolean acceptsMifFilename(String filename, String ... expected) {
     117        return acceptsFilename(filename, expected, OdConstants.MIF_EXT);
     118    }
     119
     120    protected final boolean acceptsMifTabFilename(String filename, String ... expected) {
     121        return acceptsFilename(filename, expected, OdConstants.MIF_EXT, OdConstants.TAB_EXT);
     122    }
     123
     124    protected final boolean acceptsShpMifFilename(String filename, String ... expected) {
     125        return acceptsFilename(filename, expected, OdConstants.SHP_EXT, OdConstants.MIF_EXT);
     126    }
     127
     128    protected final boolean acceptsKmlFilename(String filename, String ... expected) {
     129        return acceptsFilename(filename, expected, OdConstants.KML_EXT);
     130    }
     131
     132    protected final boolean acceptsKmzFilename(String filename, String ... expected) {
     133        return acceptsFilename(filename, expected, OdConstants.KMZ_EXT);
     134    }
     135
     136    protected final boolean acceptsKmzShpFilename(String filename, String ... expected) {
     137        return acceptsFilename(filename, expected, OdConstants.KMZ_EXT, OdConstants.SHP_EXT);
     138    }
     139
     140    protected final boolean acceptsKmzTabFilename(String filename, String ... expected) {
     141        return acceptsFilename(filename, expected, OdConstants.KMZ_EXT, OdConstants.TAB_EXT);
     142    }
     143
     144    protected final boolean acceptsZipFilename(String filename, String ... expected) {
     145        return acceptsFilename(filename, expected, OdConstants.ZIP_EXT);
     146    }
    147147
    148148    protected final boolean accepts7ZipFilename(String filename, String ... expected) {
     
    150150    }
    151151
    152         protected final boolean acceptsCsvKmzFilename(String filename, String ... expected) {
    153                 return acceptsFilename(filename, expected, OdConstants.CSV_EXT, OdConstants.KMZ_EXT);
    154         }
    155 
    156         protected final boolean acceptsCsvKmzTabFilename(String filename, String ... expected) {
    157                 return acceptsFilename(filename, expected, OdConstants.CSV_EXT, OdConstants.KMZ_EXT, OdConstants.TAB_EXT);
    158         }
    159                
    160         protected final boolean acceptsCsvXlsFilename(String filename, String ... expected) {
    161                 return acceptsFilename(filename, expected, OdConstants.CSV_EXT, OdConstants.XLS_EXT);
    162         }
    163        
    164         // -------------------- License --------------------
    165        
    166         private License license;
    167        
    168         public License getLicense() {
    169                 return license;
    170         }
    171 
    172         public final void setLicense(License license) {
    173                 this.license = license;
    174         }
    175 
    176         // --------------------- URLs ---------------------
    177        
    178         private URL dataURL;
    179         private URL wikiURL;
    180         private URL localPortalURL;
    181         private URL nationalPortalURL;
    182        
    183         public URL getDataURL() {
    184                 return dataURL;
    185         }
    186 
    187         public final void setDataURL(URL dataURL) {
    188                 this.dataURL = dataURL;
    189         }
    190 
    191         public final void setDataURL(String dataURL) throws MalformedURLException {
    192                 setDataURL(new URL(dataURL));
    193         }
    194 
    195         public URL getWikiURL() {
    196                 return wikiURL;
    197         }
    198 
    199         public final void setWikiURL(URL wikiURL) {
    200                 this.wikiURL = wikiURL;
    201         }
    202 
    203         public final void setWikiURL(String wikiURL) throws MalformedURLException {
    204                 setWikiURL(new URL(wikiURL));
    205         }
    206 
    207         public URL getLocalPortalURL() {
    208                 return localPortalURL;
    209         }
    210 
    211         public final void setLocalPortalURL(URL localPortalURL) {
    212                 this.localPortalURL = localPortalURL;
    213         }
    214 
    215         public final void setLocalPortalURL(String localPortalURL) throws MalformedURLException {
    216                 setLocalPortalURL(new URL(localPortalURL));
    217         }
    218 
    219         public URL getNationalPortalURL() {
    220                 return nationalPortalURL;
    221         }
    222 
    223         public final void setNationalPortalURL(URL nationalPortalURL) {
    224                 this.nationalPortalURL = nationalPortalURL;
    225         }
    226 
    227         public final void setNationalPortalURL(String nationalPortalURL) throws MalformedURLException {
    228                 setNationalPortalURL(new URL(nationalPortalURL));
    229         }
    230 
    231         public List<Pair<String,URL>> getDataURLs() {return null;}
    232 
    233         public AbstractReader getReaderForUrl(String url) {return null;}
    234        
    235         private boolean hasLicenseToBeAccepted = true;
    236 
    237         public final boolean hasLicenseToBeAccepted() {
    238                 return hasLicenseToBeAccepted;
    239         }
    240 
    241         public final void setHasLicenseToBeAccepted(boolean hasLicenseToBeAccepted) {
    242                 this.hasLicenseToBeAccepted = hasLicenseToBeAccepted;
    243         }
    244 
    245         public final DataSetCategory getCategory() {
    246                 return category;
    247         }
    248 
    249         public final void setCategory(DataSetCategory category) {
    250                 this.category = category;
    251         }
    252 
    253         public final Collection<String> getOsmXapiRequests(Bounds bounds) {
    254                 return getOsmXapiRequests(
    255                                 LatLon.roundToOsmPrecisionStrict(bounds.getMin().lon())+","+
    256                                 LatLon.roundToOsmPrecisionStrict(bounds.getMin().lat())+","+
    257                                 LatLon.roundToOsmPrecisionStrict(bounds.getMax().lon())+","+
    258                                 LatLon.roundToOsmPrecisionStrict(bounds.getMax().lat()));
    259         }
    260        
    261         protected Collection<String> getOsmXapiRequests(String bbox) {return null;}
    262        
    263         public final String getOverpassApiRequest(Bounds bounds) {
    264                 return getOverpassApiRequest(
    265                                 "w=\""+LatLon.roundToOsmPrecisionStrict(bounds.getMin().lon())+"\" "+
    266                                 "s=\""+LatLon.roundToOsmPrecisionStrict(bounds.getMin().lat())+"\" "+
    267                                 "e=\""+LatLon.roundToOsmPrecisionStrict(bounds.getMax().lon())+"\" "+
    268                                 "n=\""+LatLon.roundToOsmPrecisionStrict(bounds.getMax().lat())+"\"");
    269         }
    270 
    271 
    272         protected String getOverpassApiRequest(String bbox) {return null;}
    273 
    274         public boolean equals(IPrimitive p1, IPrimitive p2) {return false;}
    275        
    276         public boolean isRelevant(IPrimitive p) {return false;}
    277        
    278         public final Collection<IPrimitive> extractRelevantPrimitives(DataSet ds) {
    279                 ArrayList<IPrimitive> result = new ArrayList<>();
    280                 for (IPrimitive p : ds.allPrimitives()) {
    281                         if (isRelevant(p)) {
    282                                 result.add(p);
    283                         }
    284                 }
    285                 return result;
    286         }
    287        
    288         public boolean isForbidden(IPrimitive p) {return false;}
    289        
    290         public boolean hasForbiddenTags() {return false;}
    291        
    292         public interface ValueReplacer {
    293                 public String replace(String value);
    294         }
    295        
    296         protected final void replace(IPrimitive p, String dataKey, String osmKey) {
    297                 addOrReplace(p, dataKey, osmKey, null, null, null, true);
    298         }
    299 
    300         protected final void replace(IPrimitive p, String dataKey, String osmKey, ValueReplacer replacer) {
    301                 addOrReplace(p, dataKey, osmKey, null, null, replacer, true);
    302         }
    303 
    304         protected final void replace(IPrimitive p, String dataKey, String osmKey, String[] dataValues, String[] osmValues) {
    305                 addOrReplace(p, dataKey, osmKey, dataValues, osmValues, null, true);
    306         }
    307        
    308         protected final void add(IPrimitive p, String dataKey, String osmKey, ValueReplacer replacer) {
    309                 addOrReplace(p, dataKey, osmKey, null, null, replacer, false);
    310         }
    311 
    312         protected final void add(IPrimitive p, String dataKey, String osmKey, String[] dataValues, String[] osmValues) {
    313                 addOrReplace(p, dataKey, osmKey, dataValues, osmValues, null, false);
    314         }
    315        
    316         private final void addOrReplace(IPrimitive p, String dataKey, String osmKey, String[] dataValues, String[] osmValues, ValueReplacer replacer, boolean replace) {
    317                 String value = p.get(dataKey);
    318                 if (value != null) {
    319                         int index = -1;
    320                         for (int i = 0; dataValues != null && index == -1 && i < dataValues.length; i++) {
    321                                 if (Pattern.compile(dataValues[i], Pattern.CASE_INSENSITIVE).matcher(value).matches()) {
    322                                         index = i;
    323                                 }
    324                                 /*if (value.equalsIgnoreCase(csvValues[i])) {
    325                                         index = i;
    326                                 }*/
    327                         }
    328                         if (index > -1 && osmValues != null) {
    329                                 doAddReplace(p, dataKey, osmKey, osmValues[index], replace);
    330                         } else if (replacer != null) {
    331                                 doAddReplace(p, dataKey, osmKey, replacer.replace(value), replace);
    332                         } else if (dataValues == null || osmValues == null) {
    333                                 doAddReplace(p, dataKey, osmKey, value, replace);
    334                         }
    335                 }
    336         }
    337        
    338         private final void doAddReplace(IPrimitive p, String dataKey, String osmKey, String osmValue, boolean replace) {
    339                 if (replace) {
    340                         p.remove(dataKey);
    341                 }
    342                 p.put(osmKey, osmValue);
    343         }
    344 
    345         public String getSource() {
    346                 return null;
    347         }
    348                
    349         public final String getSourceDate() {
    350                 return sourceDate;
    351         }
    352        
    353         public final void setSourceDate(String sourceDate) {
    354                 this.sourceDate = sourceDate;
    355         }
    356 
    357         public final String getName() {
    358                 return name;
    359         }
    360        
    361         public final void setName(String name) {
    362                 this.name = name;
    363         }
    364 
    365         public String getLocalPortalIconName() {
    366                 return OdConstants.ICON_CORE_24;
    367         }
    368                
    369         public String getNationalPortalIconName() {
    370                 return OdConstants.ICON_CORE_24;
    371         }
    372                
    373         public String getDataLayerIconName() {
    374                 return OdConstants.ICON_CORE_16;
    375         }
    376        
    377         public ExtendedSourceEntry getMapPaintStyle() {
    378                 return null;
    379         }
    380 
    381         public ExtendedSourceEntry getTaggingPreset() {
    382                 return null;
    383         }
    384 
    385         protected final ExtendedSourceEntry getMapPaintStyle(String displayName) {
    386                 return getMapPaintStyle(displayName, this.getClass().getSimpleName().replace("Handler", ""));
    387         }
    388 
    389         protected final ExtendedSourceEntry getMapPaintStyle(String displayName, String fileNameWithoutExtension) {
    390                 return new ExtendedSourceEntry(displayName,     OdConstants.PROTO_RSRC+//"/"+
    391                                 this.getClass().getPackage().getName().replace(".", "/")+"/"+
    392                                 fileNameWithoutExtension+"."+OdConstants.MAPCSS_EXT);
    393         }
    394        
     152    protected final boolean acceptsCsvKmzFilename(String filename, String ... expected) {
     153        return acceptsFilename(filename, expected, OdConstants.CSV_EXT, OdConstants.KMZ_EXT);
     154    }
     155
     156    protected final boolean acceptsCsvKmzTabFilename(String filename, String ... expected) {
     157        return acceptsFilename(filename, expected, OdConstants.CSV_EXT, OdConstants.KMZ_EXT, OdConstants.TAB_EXT);
     158    }
     159       
     160    protected final boolean acceptsCsvXlsFilename(String filename, String ... expected) {
     161        return acceptsFilename(filename, expected, OdConstants.CSV_EXT, OdConstants.XLS_EXT);
     162    }
     163   
     164    // -------------------- License --------------------
     165   
     166    private License license;
     167   
     168    public License getLicense() {
     169        return license;
     170    }
     171
     172    public final void setLicense(License license) {
     173        this.license = license;
     174    }
     175
     176    // --------------------- URLs ---------------------
     177   
     178    private URL dataURL;
     179    private URL wikiURL;
     180    private URL localPortalURL;
     181    private URL nationalPortalURL;
     182   
     183    public URL getDataURL() {
     184        return dataURL;
     185    }
     186
     187    public final void setDataURL(URL dataURL) {
     188        this.dataURL = dataURL;
     189    }
     190
     191    public final void setDataURL(String dataURL) throws MalformedURLException {
     192        setDataURL(new URL(dataURL));
     193    }
     194
     195    public URL getWikiURL() {
     196        return wikiURL;
     197    }
     198
     199    public final void setWikiURL(URL wikiURL) {
     200        this.wikiURL = wikiURL;
     201    }
     202
     203    public final void setWikiURL(String wikiURL) throws MalformedURLException {
     204        setWikiURL(new URL(wikiURL));
     205    }
     206
     207    public URL getLocalPortalURL() {
     208        return localPortalURL;
     209    }
     210
     211    public final void setLocalPortalURL(URL localPortalURL) {
     212        this.localPortalURL = localPortalURL;
     213    }
     214
     215    public final void setLocalPortalURL(String localPortalURL) throws MalformedURLException {
     216        setLocalPortalURL(new URL(localPortalURL));
     217    }
     218
     219    public URL getNationalPortalURL() {
     220        return nationalPortalURL;
     221    }
     222
     223    public final void setNationalPortalURL(URL nationalPortalURL) {
     224        this.nationalPortalURL = nationalPortalURL;
     225    }
     226
     227    public final void setNationalPortalURL(String nationalPortalURL) throws MalformedURLException {
     228        setNationalPortalURL(new URL(nationalPortalURL));
     229    }
     230
     231    public List<Pair<String,URL>> getDataURLs() {return null;}
     232
     233    public AbstractReader getReaderForUrl(String url) {return null;}
     234   
     235    private boolean hasLicenseToBeAccepted = true;
     236
     237    public final boolean hasLicenseToBeAccepted() {
     238        return hasLicenseToBeAccepted;
     239    }
     240
     241    public final void setHasLicenseToBeAccepted(boolean hasLicenseToBeAccepted) {
     242        this.hasLicenseToBeAccepted = hasLicenseToBeAccepted;
     243    }
     244
     245    public final DataSetCategory getCategory() {
     246        return category;
     247    }
     248
     249    public final void setCategory(DataSetCategory category) {
     250        this.category = category;
     251    }
     252
     253    public final Collection<String> getOsmXapiRequests(Bounds bounds) {
     254        return getOsmXapiRequests(
     255                LatLon.roundToOsmPrecisionStrict(bounds.getMin().lon())+","+
     256                LatLon.roundToOsmPrecisionStrict(bounds.getMin().lat())+","+
     257                LatLon.roundToOsmPrecisionStrict(bounds.getMax().lon())+","+
     258                LatLon.roundToOsmPrecisionStrict(bounds.getMax().lat()));
     259    }
     260   
     261    protected Collection<String> getOsmXapiRequests(String bbox) {return null;}
     262   
     263    public final String getOverpassApiRequest(Bounds bounds) {
     264        return getOverpassApiRequest(
     265                "w=\""+LatLon.roundToOsmPrecisionStrict(bounds.getMin().lon())+"\" "+
     266                "s=\""+LatLon.roundToOsmPrecisionStrict(bounds.getMin().lat())+"\" "+
     267                "e=\""+LatLon.roundToOsmPrecisionStrict(bounds.getMax().lon())+"\" "+
     268                "n=\""+LatLon.roundToOsmPrecisionStrict(bounds.getMax().lat())+"\"");
     269    }
     270
     271
     272    protected String getOverpassApiRequest(String bbox) {return null;}
     273
     274    public boolean equals(IPrimitive p1, IPrimitive p2) {return false;}
     275   
     276    public boolean isRelevant(IPrimitive p) {return false;}
     277   
     278    public final Collection<IPrimitive> extractRelevantPrimitives(DataSet ds) {
     279        ArrayList<IPrimitive> result = new ArrayList<>();
     280        for (IPrimitive p : ds.allPrimitives()) {
     281            if (isRelevant(p)) {
     282                result.add(p);
     283            }
     284        }
     285        return result;
     286    }
     287   
     288    public boolean isForbidden(IPrimitive p) {return false;}
     289   
     290    public boolean hasForbiddenTags() {return false;}
     291   
     292    public interface ValueReplacer {
     293        public String replace(String value);
     294    }
     295   
     296    protected final void replace(IPrimitive p, String dataKey, String osmKey) {
     297        addOrReplace(p, dataKey, osmKey, null, null, null, true);
     298    }
     299
     300    protected final void replace(IPrimitive p, String dataKey, String osmKey, ValueReplacer replacer) {
     301        addOrReplace(p, dataKey, osmKey, null, null, replacer, true);
     302    }
     303
     304    protected final void replace(IPrimitive p, String dataKey, String osmKey, String[] dataValues, String[] osmValues) {
     305        addOrReplace(p, dataKey, osmKey, dataValues, osmValues, null, true);
     306    }
     307   
     308    protected final void add(IPrimitive p, String dataKey, String osmKey, ValueReplacer replacer) {
     309        addOrReplace(p, dataKey, osmKey, null, null, replacer, false);
     310    }
     311
     312    protected final void add(IPrimitive p, String dataKey, String osmKey, String[] dataValues, String[] osmValues) {
     313        addOrReplace(p, dataKey, osmKey, dataValues, osmValues, null, false);
     314    }
     315   
     316    private final void addOrReplace(IPrimitive p, String dataKey, String osmKey, String[] dataValues, String[] osmValues, ValueReplacer replacer, boolean replace) {
     317        String value = p.get(dataKey);
     318        if (value != null) {
     319            int index = -1;
     320            for (int i = 0; dataValues != null && index == -1 && i < dataValues.length; i++) {
     321                if (Pattern.compile(dataValues[i], Pattern.CASE_INSENSITIVE).matcher(value).matches()) {
     322                    index = i;
     323                }
     324                /*if (value.equalsIgnoreCase(csvValues[i])) {
     325                    index = i;
     326                }*/
     327            }
     328            if (index > -1 && osmValues != null) {
     329                doAddReplace(p, dataKey, osmKey, osmValues[index], replace);
     330            } else if (replacer != null) {
     331                doAddReplace(p, dataKey, osmKey, replacer.replace(value), replace);
     332            } else if (dataValues == null || osmValues == null) {
     333                doAddReplace(p, dataKey, osmKey, value, replace);
     334            }
     335        }
     336    }
     337   
     338    private final void doAddReplace(IPrimitive p, String dataKey, String osmKey, String osmValue, boolean replace) {
     339        if (replace) {
     340            p.remove(dataKey);
     341        }
     342        p.put(osmKey, osmValue);
     343    }
     344
     345    public String getSource() {
     346        return null;
     347    }
     348       
     349    public final String getSourceDate() {
     350        return sourceDate;
     351    }
     352   
     353    public final void setSourceDate(String sourceDate) {
     354        this.sourceDate = sourceDate;
     355    }
     356
     357    public final String getName() {
     358        return name;
     359    }
     360   
     361    public final void setName(String name) {
     362        this.name = name;
     363    }
     364
     365    public String getLocalPortalIconName() {
     366        return OdConstants.ICON_CORE_24;
     367    }
     368       
     369    public String getNationalPortalIconName() {
     370        return OdConstants.ICON_CORE_24;
     371    }
     372       
     373    public String getDataLayerIconName() {
     374        return OdConstants.ICON_CORE_16;
     375    }
     376   
     377    public ExtendedSourceEntry getMapPaintStyle() {
     378        return null;
     379    }
     380
     381    public ExtendedSourceEntry getTaggingPreset() {
     382        return null;
     383    }
     384
     385    protected final ExtendedSourceEntry getMapPaintStyle(String displayName) {
     386        return getMapPaintStyle(displayName, this.getClass().getSimpleName().replace("Handler", ""));
     387    }
     388
     389    protected final ExtendedSourceEntry getMapPaintStyle(String displayName, String fileNameWithoutExtension) {
     390        return new ExtendedSourceEntry(displayName,    OdConstants.PROTO_RSRC+//"/"+
     391                this.getClass().getPackage().getName().replace(".", "/")+"/"+
     392                fileNameWithoutExtension+"."+OdConstants.MAPCSS_EXT);
     393    }
     394   
    395395    public final ImageIcon getMenuIcon() {
    396396        return menuIcon;
     
    405405    }
    406406
    407         public final void setAssociatedFile(File associatedFile) {
    408                 this.associatedFile = associatedFile;
    409         }
    410 
    411         public final File getAssociatedFile() {
    412                 return this.associatedFile;
    413         }
    414        
    415         public boolean acceptsUrl(String url) {
    416             URL dataURL = getDataURL();
    417                 if (dataURL != null && url.equals(dataURL.toString())) {
    418                         return true;
    419                 }
    420                 List<Pair<String, URL>> dataURLs = getDataURLs();
    421                 if (dataURLs != null) {
    422                         for (Pair<String, URL> pair : dataURLs) {
    423                                 if (pair.b != null && url.equals(pair.b.toString())) {
    424                                         return true;
    425                                 }
    426                         }
    427                 }
    428                 return false;
    429         }
    430        
    431         // --------- Shapefile handling ---------
    432        
    433         private ShpHandler shpHandler;
    434 
    435         public final void setShpHandler(ShpHandler handler) {
    436                 shpHandler = handler;
    437         }
    438        
    439         public final ShpHandler getShpHandler() {
    440                 return shpHandler;
    441         }
     407    public final void setAssociatedFile(File associatedFile) {
     408        this.associatedFile = associatedFile;
     409    }
     410
     411    public final File getAssociatedFile() {
     412        return this.associatedFile;
     413    }
     414   
     415    public boolean acceptsUrl(String url) {
     416        URL dataURL = getDataURL();
     417        if (dataURL != null && url.equals(dataURL.toString())) {
     418            return true;
     419        }
     420        List<Pair<String, URL>> dataURLs = getDataURLs();
     421        if (dataURLs != null) {
     422            for (Pair<String, URL> pair : dataURLs) {
     423                if (pair.b != null && url.equals(pair.b.toString())) {
     424                    return true;
     425                }
     426            }
     427        }
     428        return false;
     429    }
     430   
     431    // --------- Shapefile handling ---------
     432   
     433    private ShpHandler shpHandler;
     434
     435    public final void setShpHandler(ShpHandler handler) {
     436        shpHandler = handler;
     437    }
     438   
     439    public final ShpHandler getShpHandler() {
     440        return shpHandler;
     441    }
    442442
    443443    // --------- MIF handling ---------
     
    453453    }
    454454
    455         // --------- GML handling ---------
    456        
    457         private GmlHandler gmlHandler;
    458 
    459         public final void setGmlHandler(GmlHandler handler) {
    460                 gmlHandler = handler;
    461         }
    462        
    463         public final GmlHandler getGmlHandler() {
    464                 return gmlHandler;
    465         }
    466 
    467         // ------------ Archive handling ------------
    468        
    469         private ArchiveHandler archiveHandler;
    470 
    471         public final void setArchiveHandler(ArchiveHandler handler) {
    472                 archiveHandler = handler;
    473         }
    474        
    475         public ArchiveHandler getArchiveHandler() {
    476                 return archiveHandler;
    477         }
    478        
    479         // ------ Spreadsheet handling ----------
    480 
    481         private SpreadSheetHandler ssHandler;
    482 
    483         public final void setSpreadSheetHandler(SpreadSheetHandler handler) {
    484                 ssHandler = handler;
    485         }
    486        
    487         public final SpreadSheetHandler getSpreadSheetHandler() {
    488                 return ssHandler;
    489         }
    490 
    491         public final void setCsvHandler(CsvHandler handler) {
    492                 setSpreadSheetHandler(handler);
    493         }
    494        
    495         public final CsvHandler getCsvHandler() {
    496                 if (ssHandler instanceof CsvHandler) {
    497                         return (CsvHandler) ssHandler;
    498                 } else {
    499                         return null;
    500                 }
    501         }
    502        
    503         // Tools
    504 
    505         private final Collection<JosmAction> tools = new ArrayList<>();
    506        
    507         public final Collection<JosmAction> getTools() {
    508             return tools;
    509         }
    510        
    511         public final boolean addTool(JosmAction tool) {
     455    // --------- GML handling ---------
     456   
     457    private GmlHandler gmlHandler;
     458
     459    public final void setGmlHandler(GmlHandler handler) {
     460        gmlHandler = handler;
     461    }
     462   
     463    public final GmlHandler getGmlHandler() {
     464        return gmlHandler;
     465    }
     466
     467    // ------------ Archive handling ------------
     468   
     469    private ArchiveHandler archiveHandler;
     470
     471    public final void setArchiveHandler(ArchiveHandler handler) {
     472        archiveHandler = handler;
     473    }
     474   
     475    public ArchiveHandler getArchiveHandler() {
     476        return archiveHandler;
     477    }
     478   
     479    // ------ Spreadsheet handling ----------
     480
     481    private SpreadSheetHandler ssHandler;
     482
     483    public final void setSpreadSheetHandler(SpreadSheetHandler handler) {
     484        ssHandler = handler;
     485    }
     486   
     487    public final SpreadSheetHandler getSpreadSheetHandler() {
     488        return ssHandler;
     489    }
     490
     491    public final void setCsvHandler(CsvHandler handler) {
     492        setSpreadSheetHandler(handler);
     493    }
     494   
     495    public final CsvHandler getCsvHandler() {
     496        if (ssHandler instanceof CsvHandler) {
     497            return (CsvHandler) ssHandler;
     498        } else {
     499            return null;
     500        }
     501    }
     502   
     503    // Tools
     504
     505    private final Collection<JosmAction> tools = new ArrayList<>();
     506   
     507    public final Collection<JosmAction> getTools() {
     508        return tools;
     509    }
     510   
     511    public final boolean addTool(JosmAction tool) {
    512512        return tool != null ? tools.add(tool) : false;
    513         }
    514        
    515         public final boolean removeTool(JosmAction tool) {
    516             return tool != null ? tools.remove(tool) : false;
    517         }
     513    }
     514   
     515    public final boolean removeTool(JosmAction tool) {
     516        return tool != null ? tools.remove(tool) : false;
     517    }
    518518
    519519    public void notifyActive() {
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/DataSetCategory.java

    r30340 r30723  
    88public class DataSetCategory {
    99
    10         private final String name;
    11         private final ImageIcon icon;
    12        
    13         public DataSetCategory(String name, ImageIcon icon) {
    14                 this.name = name;
    15                 this.icon = icon;
    16         }
    17        
    18         public DataSetCategory(String name, String iconName) {
    19                 this(name, iconName != null && !iconName.isEmpty() ? OdUtils.getImageIcon(iconName, true) : null);
    20         }
     10    private final String name;
     11    private final ImageIcon icon;
     12   
     13    public DataSetCategory(String name, ImageIcon icon) {
     14        this.name = name;
     15        this.icon = icon;
     16    }
     17   
     18    public DataSetCategory(String name, String iconName) {
     19        this(name, iconName != null && !iconName.isEmpty() ? OdUtils.getImageIcon(iconName, true) : null);
     20    }
    2121
    22         public final String getName() {
    23                 return name;
    24         }
     22    public final String getName() {
     23        return name;
     24    }
    2525
    26         public final ImageIcon getIcon() {
    27                 return icon;
    28         }
     26    public final ImageIcon getIcon() {
     27        return icon;
     28    }
    2929}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/DataSetUpdater.java

    r30563 r30723  
    1616public abstract class DataSetUpdater {
    1717
    18         public static final void updateDataSet(DataSet dataSet, AbstractDataSetHandler handler, File associatedFile) {
    19                 if (dataSet != null && handler != null) {
    20                         if (associatedFile != null) {
    21                                 handler.setAssociatedFile(associatedFile);
    22                                 long lastmodified = associatedFile.lastModified();
    23                                 if (lastmodified > 0) {
    24                                         handler.setSourceDate(new SimpleDateFormat("yyyy-MM-dd").format(new Date(lastmodified)));
    25                                 }
    26                         }
    27                         if (!Main.pref.getBoolean(OdConstants.PREF_RAWDATA)) {
    28                                 handler.updateDataSet(dataSet);
    29                         }
    30                         handler.checkDataSetSource(dataSet);
    31                         handler.checkNames(dataSet);
    32                         // Replace multipolygons with single untagged member by their sole member
    33                         for (Relation r : dataSet.getRelations()) {
    34                             if (r.isMultipolygon() && r.getMembersCount() == 1) {
    35                                 OsmPrimitive outer = r.getMember(0).getMember();
    36                                 if (!outer.isTagged()) {
    37                                     r.remove("type");
    38                                     r.removeMember(0);
     18    public static final void updateDataSet(DataSet dataSet, AbstractDataSetHandler handler, File associatedFile) {
     19        if (dataSet != null && handler != null) {
     20            if (associatedFile != null) {
     21                handler.setAssociatedFile(associatedFile);
     22                long lastmodified = associatedFile.lastModified();
     23                if (lastmodified > 0) {
     24                    handler.setSourceDate(new SimpleDateFormat("yyyy-MM-dd").format(new Date(lastmodified)));
     25                }
     26            }
     27            if (!Main.pref.getBoolean(OdConstants.PREF_RAWDATA)) {
     28                handler.updateDataSet(dataSet);
     29            }
     30            handler.checkDataSetSource(dataSet);
     31            handler.checkNames(dataSet);
     32            // Replace multipolygons with single untagged member by their sole member
     33            for (Relation r : dataSet.getRelations()) {
     34                if (r.isMultipolygon() && r.getMembersCount() == 1) {
     35                    OsmPrimitive outer = r.getMember(0).getMember();
     36                    if (!outer.isTagged()) {
     37                        r.remove("type");
     38                        r.removeMember(0);
    3939                        outer.setKeys(r.getKeys());
    40                                     dataSet.removePrimitive(r);
    41                                 }
    42                             }
    43                         }
    44                         // Simplify ways geometries
    45                         for (Way w : dataSet.getWays()) {
    46                             SequenceCommand command = Main.main.menu.simplifyWay.simplifyWay(w, 0.25);
    47                             if (command != null) {
    48                                 Main.main.undoRedo.addNoRedraw(command);
    49                             }
    50                         }
    51                 }
    52         }
     40                        dataSet.removePrimitive(r);
     41                    }
     42                }
     43            }
     44            // Simplify ways geometries
     45            for (Way w : dataSet.getWays()) {
     46                SequenceCommand command = Main.main.menu.simplifyWay.simplifyWay(w, 0.25);
     47                if (command != null) {
     48                    Main.main.undoRedo.addNoRedraw(command);
     49                }
     50            }
     51        }
     52    }
    5353}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/NationalHandlers.java

    r30340 r30723  
    99public abstract class NationalHandlers {
    1010
    11         public static final GmlHandler[] DEFAULT_GML_HANDLERS = new GmlHandler[]{
    12                 new AustrianGmlHandler()
    13         };
     11    public static final GmlHandler[] DEFAULT_GML_HANDLERS = new GmlHandler[]{
     12        new AustrianGmlHandler()
     13    };
    1414
    15         public static final ShpHandler[] DEFAULT_SHP_HANDLERS = new ShpHandler[]{
    16                 new FrenchShpHandler()
    17         };
     15    public static final ShpHandler[] DEFAULT_SHP_HANDLERS = new ShpHandler[]{
     16        new FrenchShpHandler()
     17    };
    1818}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/SimpleDataSetHandler.java

    r30563 r30723  
    2424public abstract class SimpleDataSetHandler extends AbstractDataSetHandler {
    2525
    26         protected static final Projection wgs84 = OdConstants.PRJ_WGS84.getProjection();
    27 
    28         private final List<Tag> relevantTags = new ArrayList<>();
    29         private final List<Tag> forbiddenTags = new ArrayList<>();
    30        
    31         private final boolean relevantUnion;
    32        
    33         public SimpleDataSetHandler() {
    34                 this.relevantUnion = false;
    35         }
    36                        
    37         public SimpleDataSetHandler(String relevantTag) {
    38                 addRelevantTag(relevantTag);
    39                 this.relevantUnion = false;
     26    protected static final Projection wgs84 = OdConstants.PRJ_WGS84.getProjection();
     27
     28    private final List<Tag> relevantTags = new ArrayList<>();
     29    private final List<Tag> forbiddenTags = new ArrayList<>();
     30   
     31    private final boolean relevantUnion;
     32   
     33    public SimpleDataSetHandler() {
     34        this.relevantUnion = false;
     35    }
     36           
     37    public SimpleDataSetHandler(String relevantTag) {
     38        addRelevantTag(relevantTag);
     39        this.relevantUnion = false;
    4040        Tag tag;
    41                 String[] kv = relevantTag.split("=");
    42                 if (kv != null && kv.length == 2) {
    43                 tag = new Tag(kv[0], kv[1]);
    44                 } else {
    45                     tag = new Tag(relevantTag);
    46                 }
    47                 setMenuIcon(MapPaintStyles.getNodeIcon(tag));
    48         }
    49        
    50         public SimpleDataSetHandler(boolean relevantUnion, String ... relevantTags) {
    51                 addRelevantTag(relevantTags);
    52                 this.relevantUnion = relevantUnion;
    53         }
    54 
    55         public SimpleDataSetHandler(String ... relevantTags) {
    56                 this(false, relevantTags);
    57         }
    58 
    59         public SimpleDataSetHandler(Tag relevantTag) {
    60                 addRelevantTag(relevantTag);
    61                 this.relevantUnion = false;
    62         }
    63        
    64         public SimpleDataSetHandler(boolean relevantUnion, Tag ... relevantTags) {
    65                 addRelevantTag(relevantTags);
    66                 this.relevantUnion = relevantUnion;
    67         }
    68 
    69         public SimpleDataSetHandler(Tag ... relevantTags) {
    70                 this(false, relevantTags);
    71         }
    72 
    73         public void addRelevantTag(String ... relevantTags) {
    74                 addTags(this.relevantTags, relevantTags);
    75         }
    76 
    77         public void addRelevantTag(Tag ... relevantTags) {
    78                 addTags(this.relevantTags, relevantTags);
    79         }
    80 
    81         public void addForbiddenTag(String ... forbiddenTags) {
    82                 addTags(this.forbiddenTags, forbiddenTags);
    83         }
    84 
    85         public void addForbiddenTag(Tag ... forbiddenTags) {
    86                 addTags(this.forbiddenTags, forbiddenTags);
    87         }
    88        
    89         private final void addTags(final List<Tag> list, String ... tags) {
    90                 if (tags != null) {
    91                         for (String tag : tags) {
    92                                 if (tag != null) {
    93                                         if (tag.contains("=")) {
    94                                                 String[] tab = tag.split("=");
    95                                                 list.add(new Tag(tab[0], tab[1]));
    96                                         } else {
    97                                                 list.add(new Tag(tag));
    98                                         }
    99                                 }
    100                         }
    101                 }
    102         }
    103 
    104         private final void addTags(final List<Tag> list, Tag ... tags) {
    105                 if (tags != null) {
    106                         for (Tag tag : tags) {
    107                                 if (tag != null) {
    108                                         list.add(tag);
    109                                 }
    110                         }
    111                 }
    112         }
    113        
    114         @Override
    115         public boolean equals(IPrimitive p1, IPrimitive p2) {
    116                 for (Tag tag : this.relevantTags) {
    117                         if (!p1.get(tag.getKey()).equals(p2.get(tag.getKey()))) {
    118                                 return false;
    119                         }
    120                 }
    121                 return true;
    122         }
    123 
    124         @Override
    125         public boolean isRelevant(IPrimitive p) {
    126                 for (Tag tag : this.relevantTags) {
    127                         String value = p.get(tag.getKey());
    128                         if (value == null || (tag.getValue() != null && !tag.getValue().equals(value))) {
    129                                 return false;
    130                         }
    131                 }
    132                 if (isForbidden(p)) {
    133                         return false;
    134                 }
    135                 return true;
    136         }
    137        
    138         @Override
    139         public boolean isForbidden(IPrimitive p) {
    140                 for (Tag tag : this.forbiddenTags) {
    141                         String value = p.get(tag.getKey());
    142                         if (value != null && (tag.getValue() == null || tag.getValue().equals(value))) {
    143                                 return true;
    144                         }
    145                 }
    146                 return false;
    147         }
    148 
    149         @Override
    150         public boolean hasForbiddenTags() {
    151                 return !this.forbiddenTags.isEmpty();
    152         }
    153 
    154         protected final String[] getOverpassApiConditions() {
    155                 List<String> conditions = new ArrayList<>();
    156                 for (Tag tag : this.relevantTags) {
    157                         conditions.add(OverpassApi.hasKey(tag.getKey(), tag.getValue()));
    158                 }
    159                 return conditions.toArray(new String[0]);
    160         }
    161 
    162         protected String getOverpassApiQueries(String bbox, String ... conditions) {
    163                 String[] mpconditions = new String[conditions.length+1];
    164                 mpconditions[0] = OverpassApi.hasKey("type", "multipolygon");
    165                 for (int i=0; i<conditions.length; i++) {
    166                         mpconditions[i+1] = conditions[i];
    167                 }
    168                 return OverpassApi.query(bbox, NODE, conditions) + "\n" + // Nodes
    169                         OverpassApi.recurse(NODE_RELATION, RELATION_WAY, WAY_NODE) + "\n" +
    170                         OverpassApi.query(bbox, WAY, conditions) + "\n" + // Full ways and their full relations
    171                         OverpassApi.recurse(WAY_NODE, "nodes") + "\n" +
    172                         OverpassApi.recurse(WAY_RELATION, RELATION_WAY, WAY_NODE) + "\n" +
    173                         OverpassApi.query(bbox, RELATION, mpconditions) + "\n" + // Full multipolygons
    174                         OverpassApi.recurse(RELATION_WAY, WAY_NODE);
    175         }
    176        
    177         @Override
    178         protected String getOverpassApiRequest(String bbox) {
    179                 String result = "";
    180                 if (this.relevantUnion) {
    181                         for (Tag tag : this.relevantTags) {
    182                                 result += getOverpassApiQueries(bbox, OverpassApi.hasKey(tag.getKey(), tag.getValue()));
    183                         }
    184                         result = OverpassApi.union(result);
    185                 } else {
    186                         result = OverpassApi.union(getOverpassApiQueries(bbox, getOverpassApiConditions()));
    187                 }
    188                 return result + OverpassApi.print();
    189         }
    190 
    191         @Override
    192         protected Collection<String> getOsmXapiRequests(String bbox) {
    193                 String relevantTags = "";
    194                 for (Tag tag : this.relevantTags) {
    195                         relevantTags += "["+tag.getKey()+"="+(tag.getValue() == null ? "*" : tag.getValue())+"]";
    196                 }
    197                 String forbiddenTags = "";
    198                 for (Tag tag : this.forbiddenTags) {
    199                         forbiddenTags += "[not("+tag.getKey()+"="+(tag.getValue() == null ? "*" : tag.getValue())+")]";
    200                 }
    201                 return Collections.singleton("*[bbox="+bbox+"]"+relevantTags+forbiddenTags+"[@meta]");
    202         }
     41        String[] kv = relevantTag.split("=");
     42        if (kv != null && kv.length == 2) {
     43            tag = new Tag(kv[0], kv[1]);
     44        } else {
     45            tag = new Tag(relevantTag);
     46        }
     47        setMenuIcon(MapPaintStyles.getNodeIcon(tag));
     48    }
     49   
     50    public SimpleDataSetHandler(boolean relevantUnion, String ... relevantTags) {
     51        addRelevantTag(relevantTags);
     52        this.relevantUnion = relevantUnion;
     53    }
     54
     55    public SimpleDataSetHandler(String ... relevantTags) {
     56        this(false, relevantTags);
     57    }
     58
     59    public SimpleDataSetHandler(Tag relevantTag) {
     60        addRelevantTag(relevantTag);
     61        this.relevantUnion = false;
     62    }
     63   
     64    public SimpleDataSetHandler(boolean relevantUnion, Tag ... relevantTags) {
     65        addRelevantTag(relevantTags);
     66        this.relevantUnion = relevantUnion;
     67    }
     68
     69    public SimpleDataSetHandler(Tag ... relevantTags) {
     70        this(false, relevantTags);
     71    }
     72
     73    public void addRelevantTag(String ... relevantTags) {
     74        addTags(this.relevantTags, relevantTags);
     75    }
     76
     77    public void addRelevantTag(Tag ... relevantTags) {
     78        addTags(this.relevantTags, relevantTags);
     79    }
     80
     81    public void addForbiddenTag(String ... forbiddenTags) {
     82        addTags(this.forbiddenTags, forbiddenTags);
     83    }
     84
     85    public void addForbiddenTag(Tag ... forbiddenTags) {
     86        addTags(this.forbiddenTags, forbiddenTags);
     87    }
     88   
     89    private final void addTags(final List<Tag> list, String ... tags) {
     90        if (tags != null) {
     91            for (String tag : tags) {
     92                if (tag != null) {
     93                    if (tag.contains("=")) {
     94                        String[] tab = tag.split("=");
     95                        list.add(new Tag(tab[0], tab[1]));
     96                    } else {
     97                        list.add(new Tag(tag));
     98                    }
     99                }
     100            }
     101        }
     102    }
     103
     104    private final void addTags(final List<Tag> list, Tag ... tags) {
     105        if (tags != null) {
     106            for (Tag tag : tags) {
     107                if (tag != null) {
     108                    list.add(tag);
     109                }
     110            }
     111        }
     112    }
     113   
     114    @Override
     115    public boolean equals(IPrimitive p1, IPrimitive p2) {
     116        for (Tag tag : this.relevantTags) {
     117            if (!p1.get(tag.getKey()).equals(p2.get(tag.getKey()))) {
     118                return false;
     119            }
     120        }
     121        return true;
     122    }
     123
     124    @Override
     125    public boolean isRelevant(IPrimitive p) {
     126        for (Tag tag : this.relevantTags) {
     127            String value = p.get(tag.getKey());
     128            if (value == null || (tag.getValue() != null && !tag.getValue().equals(value))) {
     129                return false;
     130            }
     131        }
     132        if (isForbidden(p)) {
     133            return false;
     134        }
     135        return true;
     136    }
     137   
     138    @Override
     139    public boolean isForbidden(IPrimitive p) {
     140        for (Tag tag : this.forbiddenTags) {
     141            String value = p.get(tag.getKey());
     142            if (value != null && (tag.getValue() == null || tag.getValue().equals(value))) {
     143                return true;
     144            }
     145        }
     146        return false;
     147    }
     148
     149    @Override
     150    public boolean hasForbiddenTags() {
     151        return !this.forbiddenTags.isEmpty();
     152    }
     153
     154    protected final String[] getOverpassApiConditions() {
     155        List<String> conditions = new ArrayList<>();
     156        for (Tag tag : this.relevantTags) {
     157            conditions.add(OverpassApi.hasKey(tag.getKey(), tag.getValue()));
     158        }
     159        return conditions.toArray(new String[0]);
     160    }
     161
     162    protected String getOverpassApiQueries(String bbox, String ... conditions) {
     163        String[] mpconditions = new String[conditions.length+1];
     164        mpconditions[0] = OverpassApi.hasKey("type", "multipolygon");
     165        for (int i=0; i<conditions.length; i++) {
     166            mpconditions[i+1] = conditions[i];
     167        }
     168        return OverpassApi.query(bbox, NODE, conditions) + "\n" + // Nodes
     169            OverpassApi.recurse(NODE_RELATION, RELATION_WAY, WAY_NODE) + "\n" +
     170            OverpassApi.query(bbox, WAY, conditions) + "\n" + // Full ways and their full relations
     171            OverpassApi.recurse(WAY_NODE, "nodes") + "\n" +
     172            OverpassApi.recurse(WAY_RELATION, RELATION_WAY, WAY_NODE) + "\n" +
     173            OverpassApi.query(bbox, RELATION, mpconditions) + "\n" + // Full multipolygons
     174            OverpassApi.recurse(RELATION_WAY, WAY_NODE);
     175    }
     176   
     177    @Override
     178    protected String getOverpassApiRequest(String bbox) {
     179        String result = "";
     180        if (this.relevantUnion) {
     181            for (Tag tag : this.relevantTags) {
     182                result += getOverpassApiQueries(bbox, OverpassApi.hasKey(tag.getKey(), tag.getValue()));
     183            }
     184            result = OverpassApi.union(result);
     185        } else {
     186            result = OverpassApi.union(getOverpassApiQueries(bbox, getOverpassApiConditions()));
     187        }
     188        return result + OverpassApi.print();
     189    }
     190
     191    @Override
     192    protected Collection<String> getOsmXapiRequests(String bbox) {
     193        String relevantTags = "";
     194        for (Tag tag : this.relevantTags) {
     195            relevantTags += "["+tag.getKey()+"="+(tag.getValue() == null ? "*" : tag.getValue())+"]";
     196        }
     197        String forbiddenTags = "";
     198        for (Tag tag : this.forbiddenTags) {
     199            forbiddenTags += "[not("+tag.getKey()+"="+(tag.getValue() == null ? "*" : tag.getValue())+")]";
     200        }
     201        return Collections.singleton("*[bbox="+bbox+"]"+relevantTags+forbiddenTags+"[@meta]");
     202    }
    203203}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/WayCombiner.java

    r30532 r30723  
    2727// FIXME: Try to refactor CombineWayAction instead of using this class
    2828public class WayCombiner {
    29        
     29   
    3030    protected static Way getTargetWay(Collection<Way> combinedWays) {
    3131        // init with an arbitrary way
     
    155155        targetWay.cloneFrom(modifiedTargetWay);
    156156        /*for (Command c : dialog.buildResolutionCommands()) {
    157                 c.executeCommand();//FIXME
     157            c.executeCommand();//FIXME
    158158        }*/
    159159        //new DeleteCommand(deletedWays).executeCommand();
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/at/AustrianConstants.java

    r30563 r30723  
    55public interface AustrianConstants {
    66
    7         /**
    8         * Icon
    9         */
    10         public static final String ICON_AT_24 = "at24.png";
     7    /**
     8    * Icon
     9    */
     10    public static final String ICON_AT_24 = "at24.png";
    1111}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/at/AustrianGmlHandler.java

    r30340 r30723  
    1010public class AustrianGmlHandler extends DefaultGmlHandler {
    1111
    12         @Override
    13         public CoordinateReferenceSystem getCrsFor(String crsName)
    14                         throws NoSuchAuthorityCodeException, FactoryException {
    15                
    16                 // See http://www.esri-austria.at/downloads/coords_at.html
    17                
    18                 if (crsName != null && crsName.startsWith("AUT")) {
    19                         if (crsName.equalsIgnoreCase("AUT-GK28")) {             // Gauß-Krüger, Meridianstreifen M28
    20                                 return CRS.decode("EPSG:31281");
    21                        
    22                         } else if (crsName.equalsIgnoreCase("AUT-GK31")) {      // Gauß-Krüger, Meridianstreifen M31
    23                                 return CRS.decode("EPSG:31282");
    24                                
    25                         } else if (crsName.equalsIgnoreCase("AUT-GK34")) {      // Gauß-Krüger, Meridianstreifen M34
    26                                 return CRS.decode("EPSG:31283");
    27                                
    28                         } else if (crsName.equalsIgnoreCase("AUT-GK28-5")) {    // Gauß-Krüger, Meridianstreifen M28, ohne 5 Mio. im Hochwert
    29                                 return CRS.decode("EPSG:31251");
    30                                
    31                         } else if (crsName.equalsIgnoreCase("AUT-GK31-5")) {    // Gauß-Krüger, Meridianstreifen M31, ohne 5 Mio. im Hochwert
    32                                 return CRS.decode("EPSG:31252");
    33                                
    34                         } else if (crsName.equalsIgnoreCase("AUT-GK34-5")) {    // Gauß-Krüger, Meridianstreifen M34, ohne 5 Mio. im Hochwert
    35                                 return CRS.decode("EPSG:31253");
    36                                
    37                         } else if (crsName.equalsIgnoreCase("AUT-BM28")) {      // Bundesmeldenetz, Meridianstreifen M28
    38                                 return CRS.decode("EPSG:31288");
    39                                
    40                         } else if (crsName.equalsIgnoreCase("AUT-BM31")) {      // Bundesmeldenetz, Meridianstreifen M31
    41                                 return CRS.decode("EPSG:31289");
    42                                
    43                         } else if (crsName.equalsIgnoreCase("AUT-BM34")) {      // Bundesmeldenetz, Meridianstreifen M34
    44                                 return CRS.decode("EPSG:31290");
    45                                
    46                         } else if (crsName.equalsIgnoreCase("AUT-LM")) {        // Lambertsche Kegelprojektion (geogr. Breite des Koo.Ursprungs = 47°30')
    47                                 return CRS.decode("EPSG:31287");
    48                                
    49                         } else if (crsName.equalsIgnoreCase("AUT-LL-BESSEL")) { // Geographische Koordinaten auf dem Bessel-Ellipsoid, Längenzählung nach Greenwich
    50                                 // See http://josebatiz.com/granvision/Almap/Install/Data1/_B5694C166D6A4B5390B1E547C6A1FAF6
    51                                 // FIXME
    52                         }
    53                 }
    54                 return super.getCrsFor(crsName);
    55         }
     12    @Override
     13    public CoordinateReferenceSystem getCrsFor(String crsName)
     14            throws NoSuchAuthorityCodeException, FactoryException {
     15       
     16        // See http://www.esri-austria.at/downloads/coords_at.html
     17       
     18        if (crsName != null && crsName.startsWith("AUT")) {
     19            if (crsName.equalsIgnoreCase("AUT-GK28")) {             // Gauß-Krüger, Meridianstreifen M28
     20                return CRS.decode("EPSG:31281");
     21           
     22            } else if (crsName.equalsIgnoreCase("AUT-GK31")) {      // Gauß-Krüger, Meridianstreifen M31
     23                return CRS.decode("EPSG:31282");
     24               
     25            } else if (crsName.equalsIgnoreCase("AUT-GK34")) {      // Gauß-Krüger, Meridianstreifen M34
     26                return CRS.decode("EPSG:31283");
     27               
     28            } else if (crsName.equalsIgnoreCase("AUT-GK28-5")) {    // Gauß-Krüger, Meridianstreifen M28, ohne 5 Mio. im Hochwert
     29                return CRS.decode("EPSG:31251");
     30               
     31            } else if (crsName.equalsIgnoreCase("AUT-GK31-5")) {    // Gauß-Krüger, Meridianstreifen M31, ohne 5 Mio. im Hochwert
     32                return CRS.decode("EPSG:31252");
     33               
     34            } else if (crsName.equalsIgnoreCase("AUT-GK34-5")) {    // Gauß-Krüger, Meridianstreifen M34, ohne 5 Mio. im Hochwert
     35                return CRS.decode("EPSG:31253");
     36               
     37            } else if (crsName.equalsIgnoreCase("AUT-BM28")) {      // Bundesmeldenetz, Meridianstreifen M28
     38                return CRS.decode("EPSG:31288");
     39               
     40            } else if (crsName.equalsIgnoreCase("AUT-BM31")) {      // Bundesmeldenetz, Meridianstreifen M31
     41                return CRS.decode("EPSG:31289");
     42               
     43            } else if (crsName.equalsIgnoreCase("AUT-BM34")) {      // Bundesmeldenetz, Meridianstreifen M34
     44                return CRS.decode("EPSG:31290");
     45               
     46            } else if (crsName.equalsIgnoreCase("AUT-LM")) {        // Lambertsche Kegelprojektion (geogr. Breite des Koo.Ursprungs = 47°30')
     47                return CRS.decode("EPSG:31287");
     48               
     49            } else if (crsName.equalsIgnoreCase("AUT-LL-BESSEL")) { // Geographische Koordinaten auf dem Bessel-Ellipsoid, Längenzählung nach Greenwich
     50                // See http://josebatiz.com/granvision/Almap/Install/Data1/_B5694C166D6A4B5390B1E547C6A1FAF6
     51                // FIXME
     52            }
     53        }
     54        return super.getCrsFor(crsName);
     55    }
    5656}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/au/AustralianConstants.java

    r30563 r30723  
    55public interface AustralianConstants {
    66
    7         /**
    8         * Portal
    9         */
    10         public static final String AUSTRALIAN_PORTAL = "http://data.gov.au/dataset/";
    11        
    12         /**
    13         * Icon
    14         */
    15         public static final String ICON_AU_24 = "au24.png";
     7    /**
     8    * Portal
     9    */
     10    public static final String AUSTRALIAN_PORTAL = "http://data.gov.au/dataset/";
     11   
     12    /**
     13    * Icon
     14    */
     15    public static final String ICON_AU_24 = "au24.png";
    1616}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/be/BelgianConstants.java

    r30563 r30723  
    66public interface BelgianConstants {
    77
    8         /**
    9         * Portal
    10         */
    11         public static final String BELGIAN_PORTAL = "http://data.gov.be/"+OdConstants.PATTERN_LANG+"/dataset/";
    12        
    13         /**
    14         * Icon
    15         */
    16         public static final String ICON_BE_24 = "be24.png";
     8    /**
     9    * Portal
     10    */
     11    public static final String BELGIAN_PORTAL = "http://data.gov.be/"+OdConstants.PATTERN_LANG+"/dataset/";
     12   
     13    /**
     14    * Icon
     15    */
     16    public static final String ICON_BE_24 = "be24.png";
    1717}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/be/BelgianDataSetHandler.java

    r30563 r30723  
    1717public abstract class BelgianDataSetHandler extends SimpleDataSetHandler implements BelgianConstants {
    1818
    19         private Projection singleProjection;
     19    private Projection singleProjection;
    2020
    21         private String nationalPortalPathDe;
    22         private String nationalPortalPathEn;
    23         private String nationalPortalPathFr;
    24         private String nationalPortalPathNl;
     21    private String nationalPortalPathDe;
     22    private String nationalPortalPathEn;
     23    private String nationalPortalPathFr;
     24    private String nationalPortalPathNl;
    2525
    26         protected static final Projection lambert1972 = OdConstants.PRJ_LAMBERT_1972.getProjection();
    27         protected static final Projection lambert2008 = OdConstants.PRJ_LAMBERT_2008.getProjection();
    28        
    29         protected static final Projection[] projections = new Projection[]{
    30                 lambert1972,
    31                 lambert2008
    32         };
    33        
    34         protected class InternalCsvHandler extends DefaultCsvHandler {
    35                 /*@Override
    36                 public List<Projection> getSpreadSheetProjections() {
    37                         if (singleProjection != null) {
    38                                 return Arrays.asList(new Projection[]{singleProjection});
    39                         } else {
    40                                 return Arrays.asList(projections);
    41                         }
    42                 }*/
    43                
    44                 @Override
    45                 public LatLon getCoor(EastNorth en, String[] fields) {
    46                         if (singleProjection != null) {
    47                                 return singleProjection.eastNorth2latlon(en);
    48                         } else {
    49                                 return super.getCoor(en, fields);
    50                         }
    51                 }
    52         }
     26    protected static final Projection lambert1972 = OdConstants.PRJ_LAMBERT_1972.getProjection();
     27    protected static final Projection lambert2008 = OdConstants.PRJ_LAMBERT_2008.getProjection();
     28   
     29    protected static final Projection[] projections = new Projection[]{
     30        lambert1972,
     31        lambert2008
     32    };
     33   
     34    protected class InternalCsvHandler extends DefaultCsvHandler {
     35        /*@Override
     36        public List<Projection> getSpreadSheetProjections() {
     37            if (singleProjection != null) {
     38                return Arrays.asList(new Projection[]{singleProjection});
     39            } else {
     40                return Arrays.asList(projections);
     41            }
     42        }*/
     43       
     44        @Override
     45        public LatLon getCoor(EastNorth en, String[] fields) {
     46            if (singleProjection != null) {
     47                return singleProjection.eastNorth2latlon(en);
     48            } else {
     49                return super.getCoor(en, fields);
     50            }
     51        }
     52    }
    5353
    54         public BelgianDataSetHandler() {
    55                 init();
    56         }
     54    public BelgianDataSetHandler() {
     55        init();
     56    }
    5757
    58         public BelgianDataSetHandler(String relevantTag) {
    59                 super(relevantTag);
    60                 init();
    61         }
     58    public BelgianDataSetHandler(String relevantTag) {
     59        super(relevantTag);
     60        init();
     61    }
    6262
    63         public BelgianDataSetHandler(boolean relevantUnion, String[] relevantTags) {
    64                 super(relevantUnion, relevantTags);
    65                 init();
    66         }
     63    public BelgianDataSetHandler(boolean relevantUnion, String[] relevantTags) {
     64        super(relevantUnion, relevantTags);
     65        init();
     66    }
    6767
    68         public BelgianDataSetHandler(boolean relevantUnion, Tag[] relevantTags) {
    69                 super(relevantUnion, relevantTags);
    70                 init();
    71         }
    72        
    73         private void init() {
    74                 setCsvHandler(new InternalCsvHandler());
    75         }
     68    public BelgianDataSetHandler(boolean relevantUnion, Tag[] relevantTags) {
     69        super(relevantUnion, relevantTags);
     70        init();
     71    }
     72   
     73    private void init() {
     74        setCsvHandler(new InternalCsvHandler());
     75    }
    7676
    77         protected final void setNationalPortalPath(String nationalPortalPathDe, String nationalPortalPathEn, String nationalPortalPathFr, String nationalPortalPathNl) {
    78                 this.nationalPortalPathDe = nationalPortalPathDe;
    79                 this.nationalPortalPathEn = nationalPortalPathEn;
    80                 this.nationalPortalPathFr = nationalPortalPathFr;
    81                 this.nationalPortalPathNl = nationalPortalPathNl;
    82         }
     77    protected final void setNationalPortalPath(String nationalPortalPathDe, String nationalPortalPathEn, String nationalPortalPathFr, String nationalPortalPathNl) {
     78        this.nationalPortalPathDe = nationalPortalPathDe;
     79        this.nationalPortalPathEn = nationalPortalPathEn;
     80        this.nationalPortalPathFr = nationalPortalPathFr;
     81        this.nationalPortalPathNl = nationalPortalPathNl;
     82    }
    8383
    84         protected final void setSingleProjection(Projection singleProjection) {
    85                 this.singleProjection = singleProjection;
    86                 getCsvHandler().setHandlesProjection(singleProjection != null);
    87         }
     84    protected final void setSingleProjection(Projection singleProjection) {
     85        this.singleProjection = singleProjection;
     86        getCsvHandler().setHandlesProjection(singleProjection != null);
     87    }
    8888
    89         @Override
    90         public URL getNationalPortalURL() {
    91                 try {
    92                         String nationalPortalPath = "";
    93                         String lang = Main.pref.get("language");
    94                         if (lang == null || lang.isEmpty()) {
    95                                 lang = Locale.getDefault().toString();
    96                         }
    97                                
    98                         if (lang.startsWith("de") && nationalPortalPathDe != null) {
    99                                 nationalPortalPath = nationalPortalPathDe;
    100                         } else if (lang.startsWith("fr") && nationalPortalPathFr != null) {
    101                                 nationalPortalPath = nationalPortalPathFr;
    102                         } else if (lang.startsWith("nl") && nationalPortalPathNl != null) {
    103                                 nationalPortalPath = nationalPortalPathNl;
    104                         } else {
    105                                 nationalPortalPath = nationalPortalPathEn;
    106                         }
    107                         return new URL(BELGIAN_PORTAL.replace(OdConstants.PATTERN_LANG, lang.substring(0, 2))+nationalPortalPath);//FIXME
    108                 } catch (MalformedURLException e) {
    109                         e.printStackTrace();
    110                 }
    111                 return null;
    112         }
     89    @Override
     90    public URL getNationalPortalURL() {
     91        try {
     92            String nationalPortalPath = "";
     93            String lang = Main.pref.get("language");
     94            if (lang == null || lang.isEmpty()) {
     95                lang = Locale.getDefault().toString();
     96            }
     97               
     98            if (lang.startsWith("de") && nationalPortalPathDe != null) {
     99                nationalPortalPath = nationalPortalPathDe;
     100            } else if (lang.startsWith("fr") && nationalPortalPathFr != null) {
     101                nationalPortalPath = nationalPortalPathFr;
     102            } else if (lang.startsWith("nl") && nationalPortalPathNl != null) {
     103                nationalPortalPath = nationalPortalPathNl;
     104            } else {
     105                nationalPortalPath = nationalPortalPathEn;
     106            }
     107            return new URL(BELGIAN_PORTAL.replace(OdConstants.PATTERN_LANG, lang.substring(0, 2))+nationalPortalPath);//FIXME
     108        } catch (MalformedURLException e) {
     109            e.printStackTrace();
     110        }
     111        return null;
     112    }
    113113
    114         @Override
    115         public String getLocalPortalIconName() {
    116                 return ICON_BE_24;
    117         }
     114    @Override
     115    public String getLocalPortalIconName() {
     116        return ICON_BE_24;
     117    }
    118118
    119         @Override
    120         public String getNationalPortalIconName() {
    121                 return ICON_BE_24;
    122         }
     119    @Override
     120    public String getNationalPortalIconName() {
     121        return ICON_BE_24;
     122    }
    123123}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/ca/CanadianConstants.java

    r30563 r30723  
    55public interface CanadianConstants {
    66
    7         /**
    8         * Portal
    9         */
    10         public static final String CANADIAN_PORTAL = "http://www.data.gc.ca/geo/";
    11        
    12         /**
    13         * Icon
    14         */
    15         public static final String ICON_CA_24 = "ca24.png";
     7    /**
     8    * Portal
     9    */
     10    public static final String CANADIAN_PORTAL = "http://www.data.gc.ca/geo/";
     11   
     12    /**
     13    * Icon
     14    */
     15    public static final String ICON_CA_24 = "ca24.png";
    1616}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/cl/ChileanConstants.java

    r30563 r30723  
    55public interface ChileanConstants {
    66
    7         /**
    8         * Portal
    9         */
    10         public static final String CHILEAN_PORTAL = "http://datos.gob.cl/datasets/";
    11        
    12         /**
    13         * Icon
    14         */
    15         public static final String ICON_CL_24 = "cl24.png";
     7    /**
     8    * Portal
     9    */
     10    public static final String CHILEAN_PORTAL = "http://datos.gob.cl/datasets/";
     11   
     12    /**
     13    * Icon
     14    */
     15    public static final String ICON_CL_24 = "cl24.png";
    1616}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/es/SpanishConstants.java

    r30563 r30723  
    55public interface SpanishConstants {
    66
    7         /**
    8         * Portal
    9         */
    10         public static final String SPANISH_PORTAL = "http://datos.gob.es/datos/";
    11        
    12         /**
    13         * Icon
    14         */
    15         public static final String ICON_ES_24 = "es24.png";
     7    /**
     8    * Portal
     9    */
     10    public static final String SPANISH_PORTAL = "http://datos.gob.es/datos/";
     11   
     12    /**
     13    * Icon
     14    */
     15    public static final String ICON_ES_24 = "es24.png";
    1616}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/fr/FrenchAdministrativeUnit.java

    r30340 r30723  
    33
    44public abstract class FrenchAdministrativeUnit {
    5         private final String code;
    6         private final String name;
    7        
    8         private FrenchAdministrativeUnit(String code, String name) {
    9                 this.code = code;
    10                 this.name = name;
    11         }
     5    private final String code;
     6    private final String name;
     7   
     8    private FrenchAdministrativeUnit(String code, String name) {
     9        this.code = code;
     10        this.name = name;
     11    }
    1212
    13         public final String getCode() {
    14                 return code;
    15         }
     13    public final String getCode() {
     14        return code;
     15    }
    1616
    17         public final String getName() {
    18                 return name;
    19         }
    20        
    21         public static final class FrenchDepartment extends FrenchAdministrativeUnit {
    22                 private FrenchDepartment(String code, String name) {
    23                         super(code, name);
    24                 }
    25         }
    26        
    27         public static final class FrenchRegion extends FrenchAdministrativeUnit {
    28                 private FrenchRegion(String code, String name) {
    29                         super(code, name);
    30                 }
    31         }
     17    public final String getName() {
     18        return name;
     19    }
     20   
     21    public static final class FrenchDepartment extends FrenchAdministrativeUnit {
     22        private FrenchDepartment(String code, String name) {
     23            super(code, name);
     24        }
     25    }
     26   
     27    public static final class FrenchRegion extends FrenchAdministrativeUnit {
     28        private FrenchRegion(String code, String name) {
     29            super(code, name);
     30        }
     31    }
    3232
    33         public static final FrenchDepartment[] allDepartments = new FrenchDepartment[] {
    34                 new FrenchDepartment("001", "Ain"),
    35                 new FrenchDepartment("002", "Aisne"),
    36                 new FrenchDepartment("003", "Allier"),
    37                 new FrenchDepartment("004", "Alpes-de-Haute-Provence"),
    38                 new FrenchDepartment("005", "Hautes-Alpes"),
    39                 new FrenchDepartment("006", "Alpes-Maritimes"),
    40                 new FrenchDepartment("007", "Ardèche"),
    41                 new FrenchDepartment("008", "Ardennes"),
    42                 new FrenchDepartment("009", "Ariège"),
    43                 new FrenchDepartment("010", "Aube"),
    44                 new FrenchDepartment("011", "Aude"),
    45                 new FrenchDepartment("012", "Aveyron"),
    46                 new FrenchDepartment("013", "Bouches-du-Rhône"),
    47                 new FrenchDepartment("014", "Calvados"),
    48                 new FrenchDepartment("015", "Cantal"),
    49                 new FrenchDepartment("016", "Charente"),
    50                 new FrenchDepartment("017", "Charente-Maritime"),
    51                 new FrenchDepartment("018", "Cher"),
    52                 new FrenchDepartment("019", "Corrèze"),
    53                 new FrenchDepartment("02A", "Corse-du-Sud"),
    54                 new FrenchDepartment("02B", "Haute-Corse"),
    55                 new FrenchDepartment("021", "Côte-d'Or"),
    56                 new FrenchDepartment("022", "Côtes-d'Armor"),
    57                 new FrenchDepartment("023", "Creuse"),
    58                 new FrenchDepartment("024", "Dordogne"),
    59                 new FrenchDepartment("025", "Doubs"),
    60                 new FrenchDepartment("026", "Drôme"),
    61                 new FrenchDepartment("027", "Eure"),
    62                 new FrenchDepartment("028", "Eure-et-Loir"),
    63                 new FrenchDepartment("029", "Finistère"),
    64                 new FrenchDepartment("030", "Gard"),
    65                 new FrenchDepartment("031", "Haute-Garonne"),
    66                 new FrenchDepartment("032", "Gers"),
    67                 new FrenchDepartment("033", "Gironde"),
    68                 new FrenchDepartment("034", "Hérault"),
    69                 new FrenchDepartment("035", "Ille-et-Vilaine"),
    70                 new FrenchDepartment("036", "Indre"),
    71                 new FrenchDepartment("037", "Indre-et-Loire"),
    72                 new FrenchDepartment("038", "Isère"),
    73                 new FrenchDepartment("039", "Jura"),
    74                 new FrenchDepartment("040", "Landes"),
    75                 new FrenchDepartment("041", "Loir-et-Cher"),
    76                 new FrenchDepartment("042", "Loire"),
    77                 new FrenchDepartment("043", "Haute-Loire"),
    78                 new FrenchDepartment("044", "Loire-Atlantique"),
    79                 new FrenchDepartment("045", "Loiret"),
    80                 new FrenchDepartment("046", "Lot"),
    81                 new FrenchDepartment("047", "Lot-et-Garonne"),
    82                 new FrenchDepartment("048", "Lozère"),
    83                 new FrenchDepartment("049", "Maine-et-Loire"),
    84                 new FrenchDepartment("050", "Manche"),
    85                 new FrenchDepartment("051", "Marne"),
    86                 new FrenchDepartment("052", "Haute-Marne"),
    87                 new FrenchDepartment("053", "Mayenne"),
    88                 new FrenchDepartment("054", "Meurthe-et-Moselle"),
    89                 new FrenchDepartment("055", "Meuse"),
    90                 new FrenchDepartment("056", "Morbihan"),
    91                 new FrenchDepartment("057", "Moselle"),
    92                 new FrenchDepartment("058", "Nièvre"),
    93                 new FrenchDepartment("059", "Nord"),
    94                 new FrenchDepartment("060", "Oise"),
    95                 new FrenchDepartment("061", "Orne"),
    96                 new FrenchDepartment("062", "Pas-de-Calais"),
    97                 new FrenchDepartment("063", "Puy-de-Dôme"),
    98                 new FrenchDepartment("064", "Pyrénées-Atlantiques"),
    99                 new FrenchDepartment("065", "Hautes-Pyrénées"),
    100                 new FrenchDepartment("066", "Pyrénées-Orientales"),
    101                 new FrenchDepartment("067", "Bas-Rhin"),
    102                 new FrenchDepartment("068", "Haut-Rhin"),
    103                 new FrenchDepartment("069", "Rhône"),
    104                 new FrenchDepartment("070", "Haute-Saône"),
    105                 new FrenchDepartment("071", "Saône-et-Loire"),
    106                 new FrenchDepartment("072", "Sarthe"),
    107                 new FrenchDepartment("073", "Savoie"),
    108                 new FrenchDepartment("074", "Haute-Savoie"),
    109                 new FrenchDepartment("075", "Paris"),
    110                 new FrenchDepartment("076", "Seine-Maritime"),
    111                 new FrenchDepartment("077", "Seine-et-Marne"),
    112                 new FrenchDepartment("078", "Yvelines"),
    113                 new FrenchDepartment("079", "Deux-Sèvres"),
    114                 new FrenchDepartment("080", "Somme"),
    115                 new FrenchDepartment("081", "Tarn"),
    116                 new FrenchDepartment("082", "Tarn-et-Garonne"),
    117                 new FrenchDepartment("083", "Var"),
    118                 new FrenchDepartment("084", "Vaucluse"),
    119                 new FrenchDepartment("085", "Vendée"),
    120                 new FrenchDepartment("086", "Vienne"),
    121                 new FrenchDepartment("087", "Haute-Vienne"),
    122                 new FrenchDepartment("088", "Vosges"),
    123                 new FrenchDepartment("089", "Yonne"),
    124                 new FrenchDepartment("090", "Territoire de Belfort"),
    125                 new FrenchDepartment("091", "Essonne"),
    126                 new FrenchDepartment("092", "Hauts-de-Seine"),
    127                 new FrenchDepartment("093", "Seine-Saint-Denis"),
    128                 new FrenchDepartment("094", "Val-de-Marne"),
    129                 new FrenchDepartment("095", "Val-d'Oise"),
    130                 new FrenchDepartment("971", "Guadeloupe"),
    131                 new FrenchDepartment("972", "Martinique"),
    132                 new FrenchDepartment("973", "Guyane"),
    133                 new FrenchDepartment("974", "La Réunion"),
    134                 new FrenchDepartment("976", "Mayotte"),
    135         };
     33    public static final FrenchDepartment[] allDepartments = new FrenchDepartment[] {
     34        new FrenchDepartment("001", "Ain"),
     35        new FrenchDepartment("002", "Aisne"),
     36        new FrenchDepartment("003", "Allier"),
     37        new FrenchDepartment("004", "Alpes-de-Haute-Provence"),
     38        new FrenchDepartment("005", "Hautes-Alpes"),
     39        new FrenchDepartment("006", "Alpes-Maritimes"),
     40        new FrenchDepartment("007", "Ardèche"),
     41        new FrenchDepartment("008", "Ardennes"),
     42        new FrenchDepartment("009", "Ariège"),
     43        new FrenchDepartment("010", "Aube"),
     44        new FrenchDepartment("011", "Aude"),
     45        new FrenchDepartment("012", "Aveyron"),
     46        new FrenchDepartment("013", "Bouches-du-Rhône"),
     47        new FrenchDepartment("014", "Calvados"),
     48        new FrenchDepartment("015", "Cantal"),
     49        new FrenchDepartment("016", "Charente"),
     50        new FrenchDepartment("017", "Charente-Maritime"),
     51        new FrenchDepartment("018", "Cher"),
     52        new FrenchDepartment("019", "Corrèze"),
     53        new FrenchDepartment("02A", "Corse-du-Sud"),
     54        new FrenchDepartment("02B", "Haute-Corse"),
     55        new FrenchDepartment("021", "Côte-d'Or"),
     56        new FrenchDepartment("022", "Côtes-d'Armor"),
     57        new FrenchDepartment("023", "Creuse"),
     58        new FrenchDepartment("024", "Dordogne"),
     59        new FrenchDepartment("025", "Doubs"),
     60        new FrenchDepartment("026", "Drôme"),
     61        new FrenchDepartment("027", "Eure"),
     62        new FrenchDepartment("028", "Eure-et-Loir"),
     63        new FrenchDepartment("029", "Finistère"),
     64        new FrenchDepartment("030", "Gard"),
     65        new FrenchDepartment("031", "Haute-Garonne"),
     66        new FrenchDepartment("032", "Gers"),
     67        new FrenchDepartment("033", "Gironde"),
     68        new FrenchDepartment("034", "Hérault"),
     69        new FrenchDepartment("035", "Ille-et-Vilaine"),
     70        new FrenchDepartment("036", "Indre"),
     71        new FrenchDepartment("037", "Indre-et-Loire"),
     72        new FrenchDepartment("038", "Isère"),
     73        new FrenchDepartment("039", "Jura"),
     74        new FrenchDepartment("040", "Landes"),
     75        new FrenchDepartment("041", "Loir-et-Cher"),
     76        new FrenchDepartment("042", "Loire"),
     77        new FrenchDepartment("043", "Haute-Loire"),
     78        new FrenchDepartment("044", "Loire-Atlantique"),
     79        new FrenchDepartment("045", "Loiret"),
     80        new FrenchDepartment("046", "Lot"),
     81        new FrenchDepartment("047", "Lot-et-Garonne"),
     82        new FrenchDepartment("048", "Lozère"),
     83        new FrenchDepartment("049", "Maine-et-Loire"),
     84        new FrenchDepartment("050", "Manche"),
     85        new FrenchDepartment("051", "Marne"),
     86        new FrenchDepartment("052", "Haute-Marne"),
     87        new FrenchDepartment("053", "Mayenne"),
     88        new FrenchDepartment("054", "Meurthe-et-Moselle"),
     89        new FrenchDepartment("055", "Meuse"),
     90        new FrenchDepartment("056", "Morbihan"),
     91        new FrenchDepartment("057", "Moselle"),
     92        new FrenchDepartment("058", "Nièvre"),
     93        new FrenchDepartment("059", "Nord"),
     94        new FrenchDepartment("060", "Oise"),
     95        new FrenchDepartment("061", "Orne"),
     96        new FrenchDepartment("062", "Pas-de-Calais"),
     97        new FrenchDepartment("063", "Puy-de-Dôme"),
     98        new FrenchDepartment("064", "Pyrénées-Atlantiques"),
     99        new FrenchDepartment("065", "Hautes-Pyrénées"),
     100        new FrenchDepartment("066", "Pyrénées-Orientales"),
     101        new FrenchDepartment("067", "Bas-Rhin"),
     102        new FrenchDepartment("068", "Haut-Rhin"),
     103        new FrenchDepartment("069", "Rhône"),
     104        new FrenchDepartment("070", "Haute-Saône"),
     105        new FrenchDepartment("071", "Saône-et-Loire"),
     106        new FrenchDepartment("072", "Sarthe"),
     107        new FrenchDepartment("073", "Savoie"),
     108        new FrenchDepartment("074", "Haute-Savoie"),
     109        new FrenchDepartment("075", "Paris"),
     110        new FrenchDepartment("076", "Seine-Maritime"),
     111        new FrenchDepartment("077", "Seine-et-Marne"),
     112        new FrenchDepartment("078", "Yvelines"),
     113        new FrenchDepartment("079", "Deux-Sèvres"),
     114        new FrenchDepartment("080", "Somme"),
     115        new FrenchDepartment("081", "Tarn"),
     116        new FrenchDepartment("082", "Tarn-et-Garonne"),
     117        new FrenchDepartment("083", "Var"),
     118        new FrenchDepartment("084", "Vaucluse"),
     119        new FrenchDepartment("085", "Vendée"),
     120        new FrenchDepartment("086", "Vienne"),
     121        new FrenchDepartment("087", "Haute-Vienne"),
     122        new FrenchDepartment("088", "Vosges"),
     123        new FrenchDepartment("089", "Yonne"),
     124        new FrenchDepartment("090", "Territoire de Belfort"),
     125        new FrenchDepartment("091", "Essonne"),
     126        new FrenchDepartment("092", "Hauts-de-Seine"),
     127        new FrenchDepartment("093", "Seine-Saint-Denis"),
     128        new FrenchDepartment("094", "Val-de-Marne"),
     129        new FrenchDepartment("095", "Val-d'Oise"),
     130        new FrenchDepartment("971", "Guadeloupe"),
     131        new FrenchDepartment("972", "Martinique"),
     132        new FrenchDepartment("973", "Guyane"),
     133        new FrenchDepartment("974", "La Réunion"),
     134        new FrenchDepartment("976", "Mayotte"),
     135    };
    136136
    137         public static final FrenchRegion[] allRegions = new FrenchRegion[] {
    138                 new FrenchRegion("42", "Alsace"),
    139                 new FrenchRegion("72", "Aquitaine"),
    140                 new FrenchRegion("83", "Auvergne"),
    141                 new FrenchRegion("25", "Basse-Normandie"),
    142                 new FrenchRegion("26", "Bourgogne"),
    143                 new FrenchRegion("53", "Bretagne"),
    144                 new FrenchRegion("24", "Centre"),
    145                 new FrenchRegion("21", "Champagne-Ardenne"),
    146                 new FrenchRegion("94", "Corse"),
    147                 new FrenchRegion("43", "Franche-Comté"),
    148                 new FrenchRegion("23", "Haute-Normandie"),
    149                 new FrenchRegion("11", "Île-de-France"),
    150                 new FrenchRegion("91", "Languedoc-Roussillon"),
    151                 new FrenchRegion("74", "Limousin"),
    152                 new FrenchRegion("41", "Lorraine"),
    153                 new FrenchRegion("73", "Midi-Pyrénées"),
    154                 new FrenchRegion("31", "Nord-Pas-de-Calais"),
    155                 new FrenchRegion("52", "Pays de la Loire"),
    156                 new FrenchRegion("22", "Picardie"),
    157                 new FrenchRegion("54", "Poitou-Charentes"),
    158                 new FrenchRegion("93", "Provence-Alpes-Côte d'Azur"),
    159                 new FrenchRegion("82", "Rhône-Alpes"),
    160                 new FrenchRegion("01", "Guadeloupe"),
    161                 new FrenchRegion("02", "Martinique"),
    162                 new FrenchRegion("03", "Guyane"),
    163                 new FrenchRegion("04", "La Réunion"),
    164                 new FrenchRegion("05", "Mayotte")
    165         };
     137    public static final FrenchRegion[] allRegions = new FrenchRegion[] {
     138        new FrenchRegion("42", "Alsace"),
     139        new FrenchRegion("72", "Aquitaine"),
     140        new FrenchRegion("83", "Auvergne"),
     141        new FrenchRegion("25", "Basse-Normandie"),
     142        new FrenchRegion("26", "Bourgogne"),
     143        new FrenchRegion("53", "Bretagne"),
     144        new FrenchRegion("24", "Centre"),
     145        new FrenchRegion("21", "Champagne-Ardenne"),
     146        new FrenchRegion("94", "Corse"),
     147        new FrenchRegion("43", "Franche-Comté"),
     148        new FrenchRegion("23", "Haute-Normandie"),
     149        new FrenchRegion("11", "Île-de-France"),
     150        new FrenchRegion("91", "Languedoc-Roussillon"),
     151        new FrenchRegion("74", "Limousin"),
     152        new FrenchRegion("41", "Lorraine"),
     153        new FrenchRegion("73", "Midi-Pyrénées"),
     154        new FrenchRegion("31", "Nord-Pas-de-Calais"),
     155        new FrenchRegion("52", "Pays de la Loire"),
     156        new FrenchRegion("22", "Picardie"),
     157        new FrenchRegion("54", "Poitou-Charentes"),
     158        new FrenchRegion("93", "Provence-Alpes-Côte d'Azur"),
     159        new FrenchRegion("82", "Rhône-Alpes"),
     160        new FrenchRegion("01", "Guadeloupe"),
     161        new FrenchRegion("02", "Martinique"),
     162        new FrenchRegion("03", "Guyane"),
     163        new FrenchRegion("04", "La Réunion"),
     164        new FrenchRegion("05", "Mayotte")
     165    };
    166166}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/fr/FrenchConstants.java

    r30563 r30723  
    55public interface FrenchConstants {
    66
    7         /**
    8         * Portal
    9         */
    10         public static final String FRENCH_PORTAL = "http://www.data.gouv.fr/";
    11        
    12         /**
    13         * Icon
    14         */
    15         public static final String ICON_FR_24 = "fr24.png";
    16        
    17         /**
    18         * NEPTUNE XML Schema
    19         */
    20         public static final String NEPTUNE_XSD = "/resources/neptune/neptune.xsd";
     7    /**
     8    * Portal
     9    */
     10    public static final String FRENCH_PORTAL = "http://www.data.gouv.fr/";
     11   
     12    /**
     13    * Icon
     14    */
     15    public static final String ICON_FR_24 = "fr24.png";
     16   
     17    /**
     18    * NEPTUNE XML Schema
     19    */
     20    public static final String NEPTUNE_XSD = "/resources/neptune/neptune.xsd";
    2121}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/fr/FrenchDataSetHandler.java

    r30563 r30723  
    2121public abstract class FrenchDataSetHandler extends SimpleDataSetHandler implements FrenchConstants {
    2222
    23         private Projection singleProjection;
    24 
    25         private String nationalPortalPath;
    26 
    27         protected static final Projection lambert93 = OdConstants.PRJ_LAMBERT_93.getProjection(); // France metropolitaine
    28         protected static final Projection utm20 = Projections.getProjectionByCode("EPSG:32620"); // UTM 20 N - Guadeloupe, Martinique
    29         protected static final Projection utm22 = Projections.getProjectionByCode("EPSG:32622"); // UTM 22 N - Guyane
    30         protected static final Projection utm38 = Projections.getProjectionByCode("EPSG:32738"); // UTM 38 S - Mayotte
    31         protected static final Projection utm40 = Projections.getProjectionByCode("EPSG:32740"); // UTM 40 S - Reunion
    32        
    33         protected static final Projection[] lambert4Zones = new Projection[4];
    34         static {
    35                 for (int i=0; i<lambert4Zones.length; i++) {
    36                         lambert4Zones[i] = Projections.getProjectionByCode("EPSG:"+Integer.toString(27561+i));
    37                 }
    38         }
    39 
    40         protected static final Projection[] projections = new Projection[]{
    41                 lambert93, // France metropolitaine
    42                 utm20, // Guadeloupe, Martinique
    43                 utm22, // Guyane
    44                 utm38, // Mayotte
    45                 utm40, // Reunion
    46         };
    47        
    48         protected class InternalCsvHandler extends DefaultCsvHandler {
    49                 /*@Override
    50                 public List<Projection> getSpreadSheetProjections() {
    51                         if (singleProjection != null) {
    52                                 return Arrays.asList(new Projection[]{singleProjection});
    53                         } else {
    54                                 return Arrays.asList(projections);
    55                         }
    56                 }*/
    57                
    58                 @Override
    59                 public LatLon getCoor(EastNorth en, String[] fields) {
    60                         if (singleProjection != null) {
    61                                 return singleProjection.eastNorth2latlon(en);
    62                         } else {
    63                                 return super.getCoor(en, fields);
    64                         }
    65                 }
    66 
    67                 @Override
    68                 public boolean handlesProjection() {
    69                         return singleProjection != null;
    70                 }
    71         }
    72 
    73         public FrenchDataSetHandler() {
    74                 init();
    75         }
    76 
    77         public FrenchDataSetHandler(String relevantTag) {
    78                 super(relevantTag);
    79                 init();
    80         }
    81 
    82         public FrenchDataSetHandler(boolean relevantUnion, String[] relevantTags) {
    83                 super(relevantUnion, relevantTags);
    84                 init();
    85         }
    86 
    87         public FrenchDataSetHandler(boolean relevantUnion, Tag[] relevantTags) {
    88                 super(relevantUnion, relevantTags);
    89                 init();
    90         }
    91        
    92         private void init() {
    93                 setShpHandler(new FrenchShpHandler());
    94                 setCsvHandler(new InternalCsvHandler());
    95         }
    96 
    97         protected final void setNationalPortalPath(String nationalPortalPath) {
    98                 this.nationalPortalPath = nationalPortalPath;
    99         }
    100 
    101         protected final void setSingleProjection(Projection singleProjection) {
    102                 this.singleProjection = singleProjection;
    103         }
    104 
    105         @Override
    106         public URL getNationalPortalURL() {
    107                 try {
    108                         if (nationalPortalPath != null && !nationalPortalPath.isEmpty()) {
    109                                 return new URL(FRENCH_PORTAL + "donnees/view/" + nationalPortalPath);
    110                         }
    111                 } catch (MalformedURLException e) {
    112                         e.printStackTrace();
    113                 }
    114                 return null;
    115         }
    116 
    117         @Override
    118         public String getLocalPortalIconName() {
    119                 return ICON_FR_24;
    120         }
    121 
    122         @Override
    123         public String getNationalPortalIconName() {
    124                 return ICON_FR_24;
    125         }
    126        
    127         protected static final LatLon getLatLonByDptCode(EastNorth en, String dpt, boolean useCC9) {
    128                 if (dpt.equals("971") || dpt.equals("972") || dpt.equals("977") || dpt.equals("978")) { // Antilles
    129                         return utm20.eastNorth2latlon(en);
    130                 } else if (dpt.equals("973")) { // Guyane
    131                         return utm22.eastNorth2latlon(en);
    132                 } else if (dpt.equals("974")) { // La Réunion
    133                         return utm40.eastNorth2latlon(en);
    134                 } else if (dpt.equals("976") || dpt.equals("985")) { // 985 = ancien code de Mayotte ? (présent dans geofla)
    135                         return utm38.eastNorth2latlon(en);
    136                 } else if (!useCC9) {
    137                         return lambert93.eastNorth2latlon(en);
    138                 } else if (dpt.endsWith("2A") || dpt.endsWith("2B") || dpt.endsWith("20")) {
    139                         return lambertCC9Zones[0].eastNorth2latlon(en);
    140                 } else if (dpt.endsWith("64") || dpt.endsWith("65") || dpt.endsWith("31") || dpt.endsWith("09") || dpt.endsWith("11") || dpt.endsWith("66") || dpt.endsWith("34") || dpt.endsWith("83")) {
    141                         return lambertCC9Zones[1].eastNorth2latlon(en);
    142                 } else if (dpt.endsWith("40") || dpt.endsWith("32") || dpt.endsWith("47") || dpt.endsWith("82") || dpt.endsWith("81") || dpt.endsWith("12") || dpt.endsWith("48") || dpt.endsWith("30") || dpt.endsWith("13") || dpt.endsWith("84") || dpt.endsWith("04") || dpt.endsWith("06")) {
    143                         return lambertCC9Zones[2].eastNorth2latlon(en);
    144                 } else if (dpt.endsWith("33") || dpt.endsWith("24") || dpt.endsWith("46") || dpt.endsWith("19") || dpt.endsWith("15") || dpt.endsWith("43") || dpt.endsWith("07") || dpt.endsWith("26") || dpt.endsWith("05") || dpt.endsWith("38") || dpt.endsWith("73")) {
    145                         return lambertCC9Zones[3].eastNorth2latlon(en);
    146                 } else if (dpt.endsWith("17") || dpt.endsWith("16") || dpt.endsWith("87") || dpt.endsWith("23") || dpt.endsWith("63") || dpt.endsWith("03") || dpt.endsWith("42") || dpt.endsWith("69") || dpt.endsWith("01") || dpt.endsWith("74")) {
    147                         return lambertCC9Zones[4].eastNorth2latlon(en);
    148                 } else if (dpt.endsWith("44") || dpt.endsWith("85") || dpt.endsWith("49") || dpt.endsWith("79") || dpt.endsWith("37") || dpt.endsWith("86") || dpt.endsWith("36") || dpt.endsWith("18") || dpt.endsWith("58") || dpt.endsWith("71") || dpt.endsWith("21") || dpt.endsWith("39") || dpt.endsWith("25")) {
    149                         return lambertCC9Zones[5].eastNorth2latlon(en);
    150                 } else if (dpt.endsWith("29") || dpt.endsWith("56") || dpt.endsWith("22") || dpt.endsWith("35") || dpt.endsWith("53") || dpt.endsWith("72") || dpt.endsWith("41") || dpt.endsWith("28") || dpt.endsWith("45") || dpt.endsWith("89") || dpt.endsWith("10") || dpt.endsWith("52") || dpt.endsWith("70") || dpt.endsWith("88") || dpt.endsWith("68") || dpt.endsWith("90")) {
    151                         return lambertCC9Zones[6].eastNorth2latlon(en);
    152                 } else if (dpt.endsWith("50") || dpt.endsWith("14") || dpt.endsWith("61") || dpt.endsWith("27") || dpt.endsWith("60") || dpt.endsWith("95") || dpt.endsWith("78") || dpt.endsWith("91") || dpt.endsWith("92") || dpt.endsWith("93") || dpt.endsWith("94") || dpt.endsWith("75") || dpt.endsWith("77") || dpt.endsWith("60") || dpt.endsWith("02") || dpt.endsWith("51") || dpt.endsWith("55") || dpt.endsWith("54") || dpt.endsWith("57") || dpt.endsWith("67")) {
    153                         return lambertCC9Zones[7].eastNorth2latlon(en);
    154                 } else if (dpt.endsWith("76") || dpt.endsWith("80") || dpt.endsWith("62") || dpt.endsWith("59") || dpt.endsWith("08")) {
    155                         return lambertCC9Zones[8].eastNorth2latlon(en);
    156                 } else {
    157                         throw new IllegalArgumentException("Unsupported department code: "+dpt);
    158                 }
    159         }
    160 
    161         private void replaceFaxPhone(OsmPrimitive p, String dataKey, String osmKey) {
    162                 String phone = p.get(dataKey);
    163                 if (phone != null) {
    164                         p.put(osmKey, phone.replace(" ", "").replace(".", "").replaceFirst("0", "+33"));
    165                         p.remove(dataKey);
    166                 }
    167         }
    168 
    169         protected void replaceFax(OsmPrimitive p, String dataKey) {
    170                 replaceFaxPhone(p, dataKey, "contact:fax");
    171         }
    172        
    173         protected void replacePhone(OsmPrimitive p, String dataKey) {
    174                 replaceFaxPhone(p, dataKey, "contact:phone");
    175         }
    176        
    177         private static final String dayFr = "L|Lu|M|Ma|Me|J|Je|V|Ve|S|Sa|D|Di";
    178         private static final String dayEn = "Mo|Mo|Tu|Tu|We|Th|Th|Fr|Fr|Sa|Sa|Su|Su";
    179        
    180         private static final String[] dayFrSplit = dayFr.split("\\|");
    181         private static final String[] dayEnSplit = dayEn.split("\\|");
    182        
    183         protected void replaceOpeningHours(OsmPrimitive p, String dataKey) {
    184                 String hours = p.get(dataKey);
    185                 if (hours != null) {
    186                         hours = hours.replace("h", ":").replace(": ", ":00 ");
    187                         hours = hours.replace(" - ", "-").replace(" au ", "-").replace(" à ", "-");
    188                         hours = hours.replace(" et ", ",").replace("/", ",");
    189                         hours = hours.replace(" (sf vacances)", "; PH off");
    190                         if (hours.endsWith(":")) {
    191                                 hours += "00";
    192                         }
    193                         String dayGroup = "("+dayFr+")";
    194                         String dayNcGroup = "(?:"+dayFr+")";
    195                         // FIXME: this doesn't work yet
    196                         for (String sep : new String[]{"-",","}) {
    197                                 boolean finished = false;
    198                                 while (!finished) {
    199                                         Matcher m = Pattern.compile(".*("+dayNcGroup+"(?:"+sep+dayNcGroup+")+).*").matcher(hours);
    200                                         if (m.matches()) {
    201                                                 String range = m.group(1);
    202                                                 Matcher m2 = Pattern.compile(dayGroup+"(?:"+sep+dayGroup+")+").matcher(range);
    203                                                 if (m2.matches()) {
    204                                                         String replacement = "";
    205                                                         for (int i=0; i<m2.groupCount(); i++) {
    206                                                                 if (i > 0) {
    207                                                                         replacement += sep;
    208                                                                 }
    209                                                                 replacement += getEnDay(m2.group(i+1));
    210                                                         }
    211                                                         hours = hours.replace(range, replacement);
    212                                                 }
    213                                         } else {
    214                                                 finished = true;
    215                                         }
    216                                 }
    217                         }
    218                         p.put("opening_hours", hours);
    219                         p.remove(dataKey);
    220                 }
    221         }
    222        
    223         private String getEnDay(String frDay) {
    224                 for (int i=0; i<dayFrSplit.length; i++) {
    225                         if (dayFrSplit[i].equals(frDay)) {
    226                                 return dayEnSplit[i];
    227                         }
    228                 }
    229                 return "";
    230         }
     23    private Projection singleProjection;
     24
     25    private String nationalPortalPath;
     26
     27    protected static final Projection lambert93 = OdConstants.PRJ_LAMBERT_93.getProjection(); // France metropolitaine
     28    protected static final Projection utm20 = Projections.getProjectionByCode("EPSG:32620"); // UTM 20 N - Guadeloupe, Martinique
     29    protected static final Projection utm22 = Projections.getProjectionByCode("EPSG:32622"); // UTM 22 N - Guyane
     30    protected static final Projection utm38 = Projections.getProjectionByCode("EPSG:32738"); // UTM 38 S - Mayotte
     31    protected static final Projection utm40 = Projections.getProjectionByCode("EPSG:32740"); // UTM 40 S - Reunion
     32   
     33    protected static final Projection[] lambert4Zones = new Projection[4];
     34    static {
     35        for (int i=0; i<lambert4Zones.length; i++) {
     36            lambert4Zones[i] = Projections.getProjectionByCode("EPSG:"+Integer.toString(27561+i));
     37        }
     38    }
     39
     40    protected static final Projection[] projections = new Projection[]{
     41        lambert93, // France metropolitaine
     42        utm20, // Guadeloupe, Martinique
     43        utm22, // Guyane
     44        utm38, // Mayotte
     45        utm40, // Reunion
     46    };
     47   
     48    protected class InternalCsvHandler extends DefaultCsvHandler {
     49        /*@Override
     50        public List<Projection> getSpreadSheetProjections() {
     51            if (singleProjection != null) {
     52                return Arrays.asList(new Projection[]{singleProjection});
     53            } else {
     54                return Arrays.asList(projections);
     55            }
     56        }*/
     57       
     58        @Override
     59        public LatLon getCoor(EastNorth en, String[] fields) {
     60            if (singleProjection != null) {
     61                return singleProjection.eastNorth2latlon(en);
     62            } else {
     63                return super.getCoor(en, fields);
     64            }
     65        }
     66
     67        @Override
     68        public boolean handlesProjection() {
     69            return singleProjection != null;
     70        }
     71    }
     72
     73    public FrenchDataSetHandler() {
     74        init();
     75    }
     76
     77    public FrenchDataSetHandler(String relevantTag) {
     78        super(relevantTag);
     79        init();
     80    }
     81
     82    public FrenchDataSetHandler(boolean relevantUnion, String[] relevantTags) {
     83        super(relevantUnion, relevantTags);
     84        init();
     85    }
     86
     87    public FrenchDataSetHandler(boolean relevantUnion, Tag[] relevantTags) {
     88        super(relevantUnion, relevantTags);
     89        init();
     90    }
     91   
     92    private void init() {
     93        setShpHandler(new FrenchShpHandler());
     94        setCsvHandler(new InternalCsvHandler());
     95    }
     96
     97    protected final void setNationalPortalPath(String nationalPortalPath) {
     98        this.nationalPortalPath = nationalPortalPath;
     99    }
     100
     101    protected final void setSingleProjection(Projection singleProjection) {
     102        this.singleProjection = singleProjection;
     103    }
     104
     105    @Override
     106    public URL getNationalPortalURL() {
     107        try {
     108            if (nationalPortalPath != null && !nationalPortalPath.isEmpty()) {
     109                return new URL(FRENCH_PORTAL + "donnees/view/" + nationalPortalPath);
     110            }
     111        } catch (MalformedURLException e) {
     112            e.printStackTrace();
     113        }
     114        return null;
     115    }
     116
     117    @Override
     118    public String getLocalPortalIconName() {
     119        return ICON_FR_24;
     120    }
     121
     122    @Override
     123    public String getNationalPortalIconName() {
     124        return ICON_FR_24;
     125    }
     126   
     127    protected static final LatLon getLatLonByDptCode(EastNorth en, String dpt, boolean useCC9) {
     128        if (dpt.equals("971") || dpt.equals("972") || dpt.equals("977") || dpt.equals("978")) {    // Antilles
     129            return utm20.eastNorth2latlon(en);
     130        } else if (dpt.equals("973")) {    // Guyane
     131            return utm22.eastNorth2latlon(en);
     132        } else if (dpt.equals("974")) {    // La Réunion
     133            return utm40.eastNorth2latlon(en);
     134        } else if (dpt.equals("976") || dpt.equals("985")) { // 985 = ancien code de Mayotte ? (présent dans geofla)
     135            return utm38.eastNorth2latlon(en);
     136        } else if (!useCC9) {
     137            return lambert93.eastNorth2latlon(en);
     138        } else if (dpt.endsWith("2A") || dpt.endsWith("2B") || dpt.endsWith("20")) {
     139            return lambertCC9Zones[0].eastNorth2latlon(en);
     140        } else if (dpt.endsWith("64") || dpt.endsWith("65") || dpt.endsWith("31") || dpt.endsWith("09") || dpt.endsWith("11") || dpt.endsWith("66") || dpt.endsWith("34") || dpt.endsWith("83")) {
     141            return lambertCC9Zones[1].eastNorth2latlon(en);
     142        } else if (dpt.endsWith("40") || dpt.endsWith("32") || dpt.endsWith("47") || dpt.endsWith("82") || dpt.endsWith("81") || dpt.endsWith("12") || dpt.endsWith("48") || dpt.endsWith("30") || dpt.endsWith("13") || dpt.endsWith("84") || dpt.endsWith("04") || dpt.endsWith("06")) {
     143            return lambertCC9Zones[2].eastNorth2latlon(en);
     144        } else if (dpt.endsWith("33") || dpt.endsWith("24") || dpt.endsWith("46") || dpt.endsWith("19") || dpt.endsWith("15") || dpt.endsWith("43") || dpt.endsWith("07") || dpt.endsWith("26") || dpt.endsWith("05") || dpt.endsWith("38") || dpt.endsWith("73")) {
     145            return lambertCC9Zones[3].eastNorth2latlon(en);
     146        } else if (dpt.endsWith("17") || dpt.endsWith("16") || dpt.endsWith("87") || dpt.endsWith("23") || dpt.endsWith("63") || dpt.endsWith("03") || dpt.endsWith("42") || dpt.endsWith("69") || dpt.endsWith("01") || dpt.endsWith("74")) {
     147            return lambertCC9Zones[4].eastNorth2latlon(en);
     148        } else if (dpt.endsWith("44") || dpt.endsWith("85") || dpt.endsWith("49") || dpt.endsWith("79") || dpt.endsWith("37") || dpt.endsWith("86") || dpt.endsWith("36") || dpt.endsWith("18") || dpt.endsWith("58") || dpt.endsWith("71") || dpt.endsWith("21") || dpt.endsWith("39") || dpt.endsWith("25")) {
     149            return lambertCC9Zones[5].eastNorth2latlon(en);
     150        } else if (dpt.endsWith("29") || dpt.endsWith("56") || dpt.endsWith("22") || dpt.endsWith("35") || dpt.endsWith("53") || dpt.endsWith("72") || dpt.endsWith("41") || dpt.endsWith("28") || dpt.endsWith("45") || dpt.endsWith("89") || dpt.endsWith("10") || dpt.endsWith("52") || dpt.endsWith("70") || dpt.endsWith("88") || dpt.endsWith("68") || dpt.endsWith("90")) {
     151            return lambertCC9Zones[6].eastNorth2latlon(en);
     152        } else if (dpt.endsWith("50") || dpt.endsWith("14") || dpt.endsWith("61") || dpt.endsWith("27") || dpt.endsWith("60") || dpt.endsWith("95") || dpt.endsWith("78") || dpt.endsWith("91") || dpt.endsWith("92") || dpt.endsWith("93") || dpt.endsWith("94") || dpt.endsWith("75") || dpt.endsWith("77") || dpt.endsWith("60") || dpt.endsWith("02") || dpt.endsWith("51") || dpt.endsWith("55") || dpt.endsWith("54") || dpt.endsWith("57") || dpt.endsWith("67")) {
     153            return lambertCC9Zones[7].eastNorth2latlon(en);
     154        } else if (dpt.endsWith("76") || dpt.endsWith("80") || dpt.endsWith("62") || dpt.endsWith("59") || dpt.endsWith("08")) {
     155            return lambertCC9Zones[8].eastNorth2latlon(en);
     156        } else {
     157            throw new IllegalArgumentException("Unsupported department code: "+dpt);
     158        }
     159    }
     160
     161    private void replaceFaxPhone(OsmPrimitive p, String dataKey, String osmKey) {
     162        String phone = p.get(dataKey);
     163        if (phone != null) {
     164            p.put(osmKey, phone.replace(" ", "").replace(".", "").replaceFirst("0", "+33"));
     165            p.remove(dataKey);
     166        }
     167    }
     168
     169    protected void replaceFax(OsmPrimitive p, String dataKey) {
     170        replaceFaxPhone(p, dataKey, "contact:fax");
     171    }
     172   
     173    protected void replacePhone(OsmPrimitive p, String dataKey) {
     174        replaceFaxPhone(p, dataKey, "contact:phone");
     175    }
     176   
     177    private static final String dayFr = "L|Lu|M|Ma|Me|J|Je|V|Ve|S|Sa|D|Di";
     178    private static final String dayEn = "Mo|Mo|Tu|Tu|We|Th|Th|Fr|Fr|Sa|Sa|Su|Su";
     179   
     180    private static final String[] dayFrSplit = dayFr.split("\\|");
     181    private static final String[] dayEnSplit = dayEn.split("\\|");
     182   
     183    protected void replaceOpeningHours(OsmPrimitive p, String dataKey) {
     184        String hours = p.get(dataKey);
     185        if (hours != null) {
     186            hours = hours.replace("h", ":").replace(": ", ":00 ");
     187            hours = hours.replace(" - ", "-").replace(" au ", "-").replace(" à ", "-");
     188            hours = hours.replace(" et ", ",").replace("/", ",");
     189            hours = hours.replace(" (sf vacances)", "; PH off");
     190            if (hours.endsWith(":")) {
     191                hours += "00";
     192            }
     193            String dayGroup = "("+dayFr+")";
     194            String dayNcGroup = "(?:"+dayFr+")";
     195            // FIXME: this doesn't work yet
     196            for (String sep : new String[]{"-",","}) {
     197                boolean finished = false;
     198                while (!finished) {
     199                    Matcher m = Pattern.compile(".*("+dayNcGroup+"(?:"+sep+dayNcGroup+")+).*").matcher(hours);
     200                    if (m.matches()) {
     201                        String range = m.group(1);
     202                        Matcher m2 = Pattern.compile(dayGroup+"(?:"+sep+dayGroup+")+").matcher(range);
     203                        if (m2.matches()) {
     204                            String replacement = "";
     205                            for (int i=0; i<m2.groupCount(); i++) {
     206                                if (i > 0) {
     207                                    replacement += sep;
     208                                }
     209                                replacement += getEnDay(m2.group(i+1));
     210                            }
     211                            hours = hours.replace(range, replacement);
     212                        }
     213                    } else {
     214                        finished = true;
     215                    }
     216                }
     217            }
     218            p.put("opening_hours", hours);
     219            p.remove(dataKey);
     220        }
     221    }
     222   
     223    private String getEnDay(String frDay) {
     224        for (int i=0; i<dayFrSplit.length; i++) {
     225            if (dayFrSplit[i].equals(frDay)) {
     226                return dayEnSplit[i];
     227            }
     228        }
     229        return "";
     230    }
    231231}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/fr/FrenchShpHandler.java

    r30340 r30723  
    1515public class FrenchShpHandler extends DefaultShpHandler {
    1616
    17         @Override
    18         public CoordinateReferenceSystem getCrsFor(String crsName) throws NoSuchAuthorityCodeException, FactoryException {
    19                 if (crsName.equalsIgnoreCase("RGM04")) {
    20                         return CRS.decode("EPSG:4471");
    21                 } else if (crsName.equalsIgnoreCase("RGFG95_UTM_Zone_22N")) {
    22                         return CRS.decode("EPSG:2972");
    23                 } else {
    24                         return super.getCrsFor(crsName);
    25                 }
    26         }
     17    @Override
     18    public CoordinateReferenceSystem getCrsFor(String crsName) throws NoSuchAuthorityCodeException, FactoryException {
     19        if (crsName.equalsIgnoreCase("RGM04")) {
     20            return CRS.decode("EPSG:4471");
     21        } else if (crsName.equalsIgnoreCase("RGFG95_UTM_Zone_22N")) {
     22            return CRS.decode("EPSG:2972");
     23        } else {
     24            return super.getCrsFor(crsName);
     25        }
     26    }
    2727
    28         @Override
    29         public MathTransform findMathTransform(CoordinateReferenceSystem sourceCRS, CoordinateReferenceSystem targetCRS, boolean lenient)
    30                         throws FactoryException {
    31                 if (sourceCRS.getName().getCode().equalsIgnoreCase("Lambert I Nord")) {
    32                         if (sourceCRS instanceof ProjectedCRS) {
    33                                 GeodeticDatum datum = ((ProjectedCRS) sourceCRS).getDatum();
    34                                 if (datum.getPrimeMeridian().getGreenwichLongitude() > 0.0 && ((ProjectedCRS) sourceCRS).getConversionFromBase().getMathTransform() instanceof LambertConformal2SP) {
    35                                         LambertConformal2SP lambert = (LambertConformal2SP) ((ProjectedCRS) sourceCRS).getConversionFromBase().getMathTransform();
    36                                         Double falseNorthing = get(lambert.getParameterValues(), AbstractProvider.FALSE_NORTHING);
    37                                         Double centralmeridian = get(lambert.getParameterValues(), AbstractProvider.CENTRAL_MERIDIAN);
    38                                         if (centralmeridian.equals(0.0)) {
    39                                                 if (falseNorthing.equals(200000.0)) {
    40                                                         return CRS.findMathTransform(CRS.decode("EPSG:27561"), targetCRS, lenient);
    41                                                 } else if (falseNorthing.equals(1200000.0)) {
    42                                                         return CRS.findMathTransform(CRS.decode("EPSG:27571"), targetCRS, lenient);
    43                                                 }
    44                                         }
    45                                 }
    46                         }
    47                 }
    48                 return super.findMathTransform(sourceCRS, targetCRS, lenient);
    49         }
     28    @Override
     29    public MathTransform findMathTransform(CoordinateReferenceSystem sourceCRS, CoordinateReferenceSystem targetCRS, boolean lenient)
     30            throws FactoryException {
     31        if (sourceCRS.getName().getCode().equalsIgnoreCase("Lambert I Nord")) {
     32            if (sourceCRS instanceof ProjectedCRS) {
     33                GeodeticDatum datum = ((ProjectedCRS) sourceCRS).getDatum();
     34                if (datum.getPrimeMeridian().getGreenwichLongitude() > 0.0 && ((ProjectedCRS) sourceCRS).getConversionFromBase().getMathTransform() instanceof LambertConformal2SP) {
     35                    LambertConformal2SP lambert = (LambertConformal2SP) ((ProjectedCRS) sourceCRS).getConversionFromBase().getMathTransform();
     36                    Double falseNorthing = get(lambert.getParameterValues(), AbstractProvider.FALSE_NORTHING);
     37                    Double centralmeridian = get(lambert.getParameterValues(), AbstractProvider.CENTRAL_MERIDIAN);
     38                    if (centralmeridian.equals(0.0)) {
     39                        if (falseNorthing.equals(200000.0)) {
     40                            return CRS.findMathTransform(CRS.decode("EPSG:27561"), targetCRS, lenient);
     41                        } else if (falseNorthing.equals(1200000.0)) {
     42                            return CRS.findMathTransform(CRS.decode("EPSG:27571"), targetCRS, lenient);
     43                        }
     44                    }
     45                }
     46            }
     47        }
     48        return super.findMathTransform(sourceCRS, targetCRS, lenient);
     49    }
    5050}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/it/ItalianConstants.java

    r30563 r30723  
    55public interface ItalianConstants {
    66
    7         /**
    8         * Portal
    9         */
    10         public static final String ITALIAN_PORTAL = "http://www.dati.gov.it/content/";
    11        
    12         /**
    13         * Icon
    14         */
    15         public static final String ICON_IT_24 = "it24.png";
     7    /**
     8    * Portal
     9    */
     10    public static final String ITALIAN_PORTAL = "http://www.dati.gov.it/content/";
     11   
     12    /**
     13    * Icon
     14    */
     15    public static final String ICON_IT_24 = "it24.png";
    1616}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/ke/KenyanConstants.java

    r30563 r30723  
    55public interface KenyanConstants {
    66
    7         /**
    8         * Portal
    9         */
    10         public static final String KENYAN_PORTAL = "https://opendata.go.ke/";
    11        
    12         /**
    13         * Icon
    14         */
    15         public static final String ICON_KE_24 = "ke24.png";
     7    /**
     8    * Portal
     9    */
     10    public static final String KENYAN_PORTAL = "https://opendata.go.ke/";
     11   
     12    /**
     13    * Icon
     14    */
     15    public static final String ICON_KE_24 = "ke24.png";
    1616}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/nl/DutchConstants.java

    r30563 r30723  
    55public interface DutchConstants {
    66
    7         /**
    8         * Portal
    9         */
    10         public static final String NORWEGIAN_PORTAL = "http://data.overheid.nl/package/";
    11        
    12         /**
    13         * Icon
    14         */
    15         public static final String ICON_NL_24 = "nl24.png";
     7    /**
     8    * Portal
     9    */
     10    public static final String NORWEGIAN_PORTAL = "http://data.overheid.nl/package/";
     11   
     12    /**
     13    * Icon
     14    */
     15    public static final String ICON_NL_24 = "nl24.png";
    1616}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/no/NorwegianConstants.java

    r30563 r30723  
    55public interface NorwegianConstants {
    66
    7         /**
    8         * Portal
    9         */
    10         public static final String NORWEGIAN_PORTAL = "http://data.norge.no/data/";
    11        
    12         /**
    13         * Icon
    14         */
    15         public static final String ICON_NO_24 = "no24.png";
     7    /**
     8    * Portal
     9    */
     10    public static final String NORWEGIAN_PORTAL = "http://data.norge.no/data/";
     11   
     12    /**
     13    * Icon
     14    */
     15    public static final String ICON_NO_24 = "no24.png";
    1616}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/nz/NewZealanderConstants.java

    r30563 r30723  
    55public interface NewZealanderConstants {
    66
    7         /**
    8         * Portal
    9         */
    10         public static final String NEW_ZEALANDER_PORTAL = "http://data.govt.nz/dataset/";
    11        
    12         /**
    13         * Icon
    14         */
    15         public static final String ICON_NZ_24 = "nz24.png";
     7    /**
     8    * Portal
     9    */
     10    public static final String NEW_ZEALANDER_PORTAL = "http://data.govt.nz/dataset/";
     11   
     12    /**
     13    * Icon
     14    */
     15    public static final String ICON_NZ_24 = "nz24.png";
    1616}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/pt/PortugueseConstants.java

    r30563 r30723  
    55public interface PortugueseConstants {
    66
    7         /**
    8         * Portal
    9         */
    10         public static final String PORTUGUESE_PORTAL = "http://www.dados.gov.pt/PT/CatalogoDados/Dados.aspx?name=";
    11        
    12         /**
    13         * Icon
    14         */
    15         public static final String ICON_PT_24 = "pt24.png";
     7    /**
     8    * Portal
     9    */
     10    public static final String PORTUGUESE_PORTAL = "http://www.dados.gov.pt/PT/CatalogoDados/Dados.aspx?name=";
     11   
     12    /**
     13    * Icon
     14    */
     15    public static final String ICON_PT_24 = "pt24.png";
    1616}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/uk/BritishConstants.java

    r30563 r30723  
    55public interface BritishConstants {
    66
    7         /**
    8         * Portal
    9         */
    10         public static final String BRITISH_PORTAL = "http://data.gov.uk/dataset/";
    11        
    12         /**
    13         * Icon
    14         */
    15         public static final String ICON_UK_24 = "uk24.png";
     7    /**
     8    * Portal
     9    */
     10    public static final String BRITISH_PORTAL = "http://data.gov.uk/dataset/";
     11   
     12    /**
     13    * Icon
     14    */
     15    public static final String ICON_UK_24 = "uk24.png";
    1616}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/datasets/us/AmericanConstants.java

    r30563 r30723  
    55public interface AmericanConstants {
    66
    7         /**
    8         * Portal
    9         */
    10         public static final String AMERICAN_PORTAL = "http://explore.data.gov/";
    11        
    12         /**
    13         * Icon
    14         */
    15         public static final String ICON_US_24 = "us24.png";
     7    /**
     8    * Portal
     9    */
     10    public static final String AMERICAN_PORTAL = "http://explore.data.gov/";
     11   
     12    /**
     13    * Icon
     14    */
     15    public static final String ICON_US_24 = "us24.png";
    1616}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/gui/AskLicenseAgreementDialog.java

    r30340 r30723  
    1010
    1111public class AskLicenseAgreementDialog extends ViewLicenseDialog {
    12        
    13         public AskLicenseAgreementDialog(License license) throws IOException {
    14                 super(license, Main.parent, tr("License Agreement"), new String[] {tr("Accept"), "", tr("Refuse")});
    15                
     12   
     13    public AskLicenseAgreementDialog(License license) throws IOException {
     14        super(license, Main.parent, tr("License Agreement"), new String[] {tr("Accept"), "", tr("Refuse")});
     15       
    1616        setToolTipTexts(new String[] {
    1717                tr("I understand and accept these terms and conditions"),
    1818                tr("View the full text of this license"),
    1919                tr("I refuse these terms and conditions. Cancel download.")});
    20         }
     20    }
    2121}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/gui/DialogPrompter.java

    r30563 r30723  
    99
    1010public class DialogPrompter <T extends ExtendedDialog> implements Runnable {
    11        
    12         private T dialog;
    13         private int value = -1;
     11   
     12    private T dialog;
     13    private int value = -1;
    1414
    15         protected T buildDialog() {return null;} // To be overriden if needed
    16        
    17         public DialogPrompter() {
    18                 this(null);
    19         }
    20        
    21         public DialogPrompter(T dialog) {
    22                 this.dialog = dialog;
    23         }
    24        
    25         public final T getDialog() {
    26                 return dialog;
    27         }
    28        
    29         @Override
    30         public final void run() {
    31                 if (dialog == null) {
    32                         dialog = buildDialog();
    33                 }
    34                 if (dialog != null) {
    35                         value = dialog.showDialog().getValue();
    36                 }
    37         }
    38        
    39         public final DialogPrompter<T> promptInEdt() {
    40                 if (SwingUtilities.isEventDispatchThread()) {
    41                         run();
    42                 } else {
    43                         try {
    44                                 SwingUtilities.invokeAndWait(this);
    45                         } catch (InterruptedException e) {
    46                                 e.printStackTrace();
    47                         } catch (InvocationTargetException e) {
    48                                 e.printStackTrace();
    49                         }
    50                 }
    51                 return this;
    52         }
     15    protected T buildDialog() {return null;} // To be overriden if needed
     16   
     17    public DialogPrompter() {
     18        this(null);
     19    }
     20   
     21    public DialogPrompter(T dialog) {
     22        this.dialog = dialog;
     23    }
     24   
     25    public final T getDialog() {
     26        return dialog;
     27    }
     28   
     29    @Override
     30    public final void run() {
     31        if (dialog == null) {
     32            dialog = buildDialog();
     33        }
     34        if (dialog != null) {
     35            value = dialog.showDialog().getValue();
     36        }
     37    }
     38   
     39    public final DialogPrompter<T> promptInEdt() {
     40        if (SwingUtilities.isEventDispatchThread()) {
     41            run();
     42        } else {
     43            try {
     44                SwingUtilities.invokeAndWait(this);
     45            } catch (InterruptedException e) {
     46                e.printStackTrace();
     47            } catch (InvocationTargetException e) {
     48                e.printStackTrace();
     49            }
     50        }
     51        return this;
     52    }
    5353
    54         public final int getValue() {
    55                 return value;
    56         }
     54    public final int getValue() {
     55        return value;
     56    }
    5757}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/gui/ModulePreference.java

    r30563 r30723  
    527527    }
    528528
    529         @Override
    530         public boolean isExpert() {
    531                 return false;
    532         }
    533 
    534         @Override
    535         public TabPreferenceSetting getTabPreferenceSetting(PreferenceTabbedPane gui) {
    536                 return gui.getSetting(OdPreferenceSetting.class);
    537         }
     529    @Override
     530    public boolean isExpert() {
     531        return false;
     532    }
     533
     534    @Override
     535    public TabPreferenceSetting getTabPreferenceSetting(PreferenceTabbedPane gui) {
     536        return gui.getSetting(OdPreferenceSetting.class);
     537    }
    538538}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/gui/ModulePreferencesModel.java

    r30563 r30723  
    2929
    3030    protected Collection<String> getModules(Collection<String> def) {
    31         return Main.pref.getCollection(OdConstants.PREF_MODULES, def);
     31        return Main.pref.getCollection(OdConstants.PREF_MODULES, def);
    3232    }
    3333   
    3434    public ModulePreferencesModel() {
    35         currentActiveModules = new HashSet<>();
    36         currentActiveModules.addAll(getModules(currentActiveModules));
     35        currentActiveModules = new HashSet<>();
     36        currentActiveModules.addAll(getModules(currentActiveModules));
    3737    }
    3838
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/gui/OdDialog.java

    r30563 r30723  
    4646   
    4747    private class DownloadAction extends JosmAction {
    48                 public DownloadAction() {
    49                         super(marktr("Download"), "download", tr("Download OSM data corresponding to the current data set."), null, false);
    50                 }
    51                 @Override
    52                 public void actionPerformed(ActionEvent e) {
    53                         if (Main.main.getEditLayer() instanceof OdLayer) {
    54                                 dataLayer.downloadOsmData();
    55                                 diffButton.setEnabled(dataLayer.osmLayer != null);
    56                         }
    57                 }
     48        public DownloadAction() {
     49            super(marktr("Download"), "download", tr("Download OSM data corresponding to the current data set."), null, false);
     50        }
     51        @Override
     52        public void actionPerformed(ActionEvent e) {
     53            if (Main.main.getEditLayer() instanceof OdLayer) {
     54                dataLayer.downloadOsmData();
     55                diffButton.setEnabled(dataLayer.osmLayer != null);
     56            }
     57        }
    5858    }
    5959
    6060    private class SelectAction extends JosmAction {
    61                 public SelectAction() {
    62                         super(marktr("Select"), "dialogs/select", tr("Set the selected elements on the map to the selected items in the list above."), null, false);
    63                 }
    64                 @Override
    65                 public void actionPerformed(ActionEvent e) {
    66                         // TODO
    67                 }
     61        public SelectAction() {
     62            super(marktr("Select"), "dialogs/select", tr("Set the selected elements on the map to the selected items in the list above."), null, false);
     63        }
     64        @Override
     65        public void actionPerformed(ActionEvent e) {
     66            // TODO
     67        }
    6868    }
    6969
    7070    private class DiffAction extends JosmAction {
    71                 public DiffAction() {
    72                         super(marktr("Diff"), "dialogs/diff", tr("Perform diff between current data set and existing OSM data."), null, false);
    73                 }
    74                 @Override
    75                 public void actionPerformed(ActionEvent e) {
    76                         if (Main.main.getEditLayer() instanceof OdLayer) {
    77                                 dataLayer.makeDiff();
    78                         }
    79                 }
     71        public DiffAction() {
     72            super(marktr("Diff"), "dialogs/diff", tr("Perform diff between current data set and existing OSM data."), null, false);
     73        }
     74        @Override
     75        public void actionPerformed(ActionEvent e) {
     76            if (Main.main.getEditLayer() instanceof OdLayer) {
     77                dataLayer.makeDiff();
     78            }
     79        }
    8080    }
    8181   
     
    9090    }
    9191
    92         public OdDialog() {
    93                 super("OpenData", OdConstants.ICON_CORE_24, tr("Open the OpenData window."),
    94                                 Shortcut.registerShortcut("subwindow:opendata", tr("Toggle: {0}", "OpenData"),
    95                                                 KeyEvent.VK_A, Shortcut.ALT_CTRL_SHIFT), 150, false, OdPreferenceSetting.class);
    96                
    97                 this.buttons = Arrays.asList(new SideButton[] {
    98                                 /*selectButton =*/ new SideButton(new SelectAction()),
    99                                 downloadButton = new SideButton(new DownloadAction()),
    100                                 diffButton = new SideButton(new DiffAction()),
    101                                 toolsButton = new SideButton(new ToolsAction())
     92    public OdDialog() {
     93        super("OpenData", OdConstants.ICON_CORE_24, tr("Open the OpenData window."),
     94                Shortcut.registerShortcut("subwindow:opendata", tr("Toggle: {0}", "OpenData"),
     95                        KeyEvent.VK_A, Shortcut.ALT_CTRL_SHIFT), 150, false, OdPreferenceSetting.class);
     96       
     97        this.buttons = Arrays.asList(new SideButton[] {
     98                /*selectButton =*/ new SideButton(new SelectAction()),
     99                downloadButton = new SideButton(new DownloadAction()),
     100                diffButton = new SideButton(new DiffAction()),
     101                toolsButton = new SideButton(new ToolsAction())
    102102        });
    103                
    104                 this.toolsButton.addMouseListener(new MouseAdapter() {
    105                     @Override
    106                     public void mousePressed(MouseEvent e) {
    107                     if (Main.main.getEditLayer() instanceof OdLayer) {
     103       
     104        this.toolsButton.addMouseListener(new MouseAdapter() {
     105            @Override
     106            public void mousePressed(MouseEvent e) {
     107                if (Main.main.getEditLayer() instanceof OdLayer) {
    108108                    JPopupMenu popup = new JPopupMenu();
    109                         for (JosmAction tool : dataLayer.handler.getTools()) {
    110                             popup.add(tool);
    111                         }
     109                    for (JosmAction tool : dataLayer.handler.getTools()) {
     110                        popup.add(tool);
     111                    }
    112112                    popup.show(e.getComponent(), e.getX(), e.getY());
    113                     }
    114                     }
     113                }
     114            }
    115115        });
    116                
    117                 disableAllButtons();
    118                
    119                 this.treeModel = new DefaultTreeModel(null); // TODO: treeNode
    120                 this.dataLayer = null;
    121                
    122                 createLayout(new JTree(treeModel), true, buttons);
    123                
    124                 MapView.addEditLayerChangeListener(this);
    125         }
    126        
    127         private void disableAllButtons() {
    128                 for (SideButton button : buttons) {
    129                         button.setEnabled(false);
    130                 }
    131         }
     116       
     117        disableAllButtons();
     118       
     119        this.treeModel = new DefaultTreeModel(null); // TODO: treeNode
     120        this.dataLayer = null;
     121       
     122        createLayout(new JTree(treeModel), true, buttons);
     123       
     124        MapView.addEditLayerChangeListener(this);
     125    }
     126   
     127    private void disableAllButtons() {
     128        for (SideButton button : buttons) {
     129            button.setEnabled(false);
     130        }
     131    }
    132132
    133         @Override
    134         public void editLayerChanged(OsmDataLayer oldLayer, OsmDataLayer newLayer) {
    135                 activeLayerChange(oldLayer, newLayer);
    136         }
     133    @Override
     134    public void editLayerChanged(OsmDataLayer oldLayer, OsmDataLayer newLayer) {
     135        activeLayerChange(oldLayer, newLayer);
     136    }
    137137
    138         @Override
    139         public void activeLayerChange(Layer oldLayer, Layer newLayer) {
    140                 if (newLayer instanceof OdLayer) {
    141                         dataLayer = ((OdLayer) newLayer).getDataLayer();
    142                 } else {
    143                         dataLayer = null;
    144                 }
    145                
    146                 if (dataLayer != null) {
    147                         if (dataLayer.osmLayer == null) {
    148                                 downloadButton.setEnabled(true);
    149                         } else if (dataLayer.diffLayer == null) {
    150                                 diffButton.setEnabled(true);
    151                         }
    152                         toolsButton.setEnabled(dataLayer.handler != null && !dataLayer.handler.getTools().isEmpty());
    153                 } else {
    154                         disableAllButtons();
    155                 }
    156         }
     138    @Override
     139    public void activeLayerChange(Layer oldLayer, Layer newLayer) {
     140        if (newLayer instanceof OdLayer) {
     141            dataLayer = ((OdLayer) newLayer).getDataLayer();
     142        } else {
     143            dataLayer = null;
     144        }
     145       
     146        if (dataLayer != null) {
     147            if (dataLayer.osmLayer == null) {
     148                downloadButton.setEnabled(true);
     149            } else if (dataLayer.diffLayer == null) {
     150                diffButton.setEnabled(true);
     151            }
     152            toolsButton.setEnabled(dataLayer.handler != null && !dataLayer.handler.getTools().isEmpty());
     153        } else {
     154            disableAllButtons();
     155        }
     156    }
    157157
    158         @Override
    159         public void layerAdded(Layer newLayer) {
    160         }
     158    @Override
     159    public void layerAdded(Layer newLayer) {
     160    }
    161161
    162         @Override
    163         public void layerRemoved(Layer oldLayer) {
    164         }
     162    @Override
     163    public void layerRemoved(Layer oldLayer) {
     164    }
    165165
    166166    @Override
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/gui/OdPreferenceSetting.java

    r30563 r30723  
    4646
    4747    public OdPreferenceSetting() {
    48         super(OdConstants.ICON_CORE_48, tr("OpenData Preferences"),
     48        super(OdConstants.ICON_CORE_48, tr("OpenData Preferences"),
    4949                tr("A special handler for various Open Data portals<br/><br/>"+
    5050                        "Please read the Terms and Conditions of Use of each portal<br/>"+
     
    6666     * @param sites the site URLs
    6767     */
    68         public static void setModuleSites(List<String> sites) {
    69                 Main.pref.putCollection(OdConstants.PREF_MODULES_SITES, sites);
     68    public static void setModuleSites(List<String> sites) {
     69        Main.pref.putCollection(OdConstants.PREF_MODULES_SITES, sites);
    7070    }
    7171   
     
    8181    }
    8282
    83         protected JPanel createGeneralSettings() {
     83    protected JPanel createGeneralSettings() {
    8484        JPanel general = new JPanel(new GridBagLayout());
    8585        general.setBorder(BorderFactory.createEmptyBorder(0,0,0,0));
     
    104104        String currentCoordinates = Main.pref.get(PREF_COORDINATES, VALUE_CC9ZONES);
    105105        if (currentCoordinates.equals(VALUE_WGS84))
    106                 rbWGS84.setSelected(true);
     106            rbWGS84.setSelected(true);
    107107        else
    108                 rbCC43.setSelected(true);
     108            rbCC43.setSelected(true);
    109109        p.add(rbCC43, GBC.std().insets(5, 0, 5, 0));
    110110        p.add(rbWGS84, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 5, 0, 5));*/
     
    132132    @Override
    133133    public boolean ok() {
    134         boolean result = modulePref.ok();
    135                 //Main.pref.put(PREF_COORDINATES, rbWGS84.isSelected() ? VALUE_WGS84 : VALUE_CC9ZONES);
    136                 Main.pref.put(OdConstants.PREF_OAPI, oapi.getText());
    137                 Main.pref.put(OdConstants.PREF_XAPI, xapi.getText());
    138                 Main.pref.put(OdConstants.PREF_RAWDATA, rawData.isSelected());
     134        boolean result = modulePref.ok();
     135           //Main.pref.put(PREF_COORDINATES, rbWGS84.isSelected() ? VALUE_WGS84 : VALUE_CC9ZONES);
     136           Main.pref.put(OdConstants.PREF_OAPI, oapi.getText());
     137           Main.pref.put(OdConstants.PREF_XAPI, xapi.getText());
     138           Main.pref.put(OdConstants.PREF_RAWDATA, rawData.isSelected());
    139139       
    140140        // create a task for downloading modules if the user has activated, yet not downloaded,
     
    146146            task = new ModuleDownloadTask(masterPanel, toDownload, tr("Download modules"));
    147147        } else {
    148                 task = null;
     148            task = null;
    149149        }
    150150       
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/gui/ProjectionChooser.java

    r30583 r30723  
    6565    private static final GBC projSubPrefPanelGBC = GBC.std().fill(GBC.BOTH).weight(1.0, 1.0);
    6666
    67         public ProjectionChooser(Component parent) {
    68                 this(parent, tr("Projection method"), new String[] {tr("OK"), tr("Cancel")});
    69         }
    70        
    71         protected ProjectionChooser(Component parent, String title, String[] buttonTexts) {
    72                 super(parent, title, buttonTexts);
    73                 setMinimumSize(new Dimension(600, 200));
    74                 addGui();
    75         }
    76        
    77         public void addGui() {
     67    public ProjectionChooser(Component parent) {
     68        this(parent, tr("Projection method"), new String[] {tr("OK"), tr("Cancel")});
     69    }
     70   
     71    protected ProjectionChooser(Component parent, String title, String[] buttonTexts) {
     72        super(parent, title, buttonTexts);
     73        setMinimumSize(new Dimension(600, 200));
     74        addGui();
     75    }
     76   
     77    public void addGui() {
    7878        projPanel.setBorder(BorderFactory.createEmptyBorder( 0, 0, 0, 0 ));
    7979        projPanel.setLayout(new GridBagLayout());
     
    101101        });
    102102        setContent(projPanel);
    103         }
    104        
    105         private void selectedProjectionChanged(final ProjectionChoice pc) {
     103    }
     104   
     105    private void selectedProjectionChanged(final ProjectionChoice pc) {
    106106        // Don't try to update if we're still starting up
    107107        int size = projPanel.getComponentCount();
     
    124124        updateMeta(pc);
    125125    }
    126        
     126   
    127127    private void updateMeta(ProjectionChoice pc) {
    128128        pc.setPreferences(pc.getPreferences(projSubPrefPanel));
     
    148148
    149149    public Projection getProjection() {
    150                 ProjectionChoice pc = (ProjectionChoice) projectionCombo.getSelectedItem();
    151                 if (pc != null) {
    152                     Main.info("Chosen projection: "+pc+" ("+pc.getProjection()+")");
    153                     return pc.getProjection();
    154                 } else {
    155                     return null;
    156                 }
    157         }
     150        ProjectionChoice pc = (ProjectionChoice) projectionCombo.getSelectedItem();
     151        if (pc != null) {
     152            Main.info("Chosen projection: "+pc+" ("+pc.getProjection()+")");
     153            return pc.getProjection();
     154        } else {
     155            return null;
     156        }
     157    }
    158158}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/gui/ViewLicenseDialog.java

    r30340 r30723  
    2121public class ViewLicenseDialog extends ExtendedDialog {
    2222
    23         private final License license;
    24         private final JEditorPane htmlPane;
    25         private boolean summary;
    26        
    27         public ViewLicenseDialog(License license) throws IOException {
    28                 this(license, Main.parent, tr("License"), new String[] {tr("OK"), "", tr("Cancel")});
    29         }
     23    private final License license;
     24    private final JEditorPane htmlPane;
     25    private boolean summary;
     26   
     27    public ViewLicenseDialog(License license) throws IOException {
     28        this(license, Main.parent, tr("License"), new String[] {tr("OK"), "", tr("Cancel")});
     29    }
    3030
    31         public ViewLicenseDialog(License license, Component parent, String title, String[] buttonTexts) throws IOException {
    32                 super(parent, title, buttonTexts);
    33                
    34                 this.license = license;
    35                 this.htmlPane = new JEditorPane();
    36                 htmlPane.setEditable(false);
    37                 if (license.getSummaryURL() != null) {
    38                         htmlPane.setPage(license.getSummaryURL());
    39                         summary = true;
    40                 } else {
    41                         htmlPane.setPage(license.getURL());
    42                         summary = false;
    43                 }
    44                 JScrollPane scrollPane = new JScrollPane(htmlPane);
    45                 scrollPane.setPreferredSize(new Dimension(800, 600));
     31    public ViewLicenseDialog(License license, Component parent, String title, String[] buttonTexts) throws IOException {
     32        super(parent, title, buttonTexts);
     33       
     34        this.license = license;
     35        this.htmlPane = new JEditorPane();
     36        htmlPane.setEditable(false);
     37        if (license.getSummaryURL() != null) {
     38            htmlPane.setPage(license.getSummaryURL());
     39            summary = true;
     40        } else {
     41            htmlPane.setPage(license.getURL());
     42            summary = false;
     43        }
     44        JScrollPane scrollPane = new JScrollPane(htmlPane);
     45        scrollPane.setPreferredSize(new Dimension(800, 600));
    4646       
    4747        setButtonIcons(new Icon[] {
     
    5555                null});
    5656        if (license.getIcon() != null) {
    57                 setIcon(license.getIcon());
     57            setIcon(license.getIcon());
    5858        } else {
    59                 setIcon(JOptionPane.INFORMATION_MESSAGE);
     59            setIcon(JOptionPane.INFORMATION_MESSAGE);
    6060        }
    6161        setCancelButton(3);
    6262        setMinimumSize(new Dimension(300, 200));
    6363        setContent(scrollPane, false);
    64         }
     64    }
    6565
    66         @Override
    67         protected void buttonAction(int buttonIndex, ActionEvent evt) {
    68                 if (buttonIndex == 1) {
    69                         try {
    70                                 if (summary) {
    71                                         buttons.get(1).setText(tr("View summary"));
    72                                         htmlPane.setPage(license.getURL());
    73                                 } else {
    74                                         buttons.get(1).setText(tr("View full text"));
    75                                         htmlPane.setPage(license.getSummaryURL());
    76                                 }
    77                         } catch (IOException e) {
    78                                 e.printStackTrace();
    79                         }
    80                         summary = !summary;
    81                 } else {
    82                         super.buttonAction(buttonIndex, evt);
    83                 }
    84         }
     66    @Override
     67    protected void buttonAction(int buttonIndex, ActionEvent evt) {
     68        if (buttonIndex == 1) {
     69            try {
     70                if (summary) {
     71                    buttons.get(1).setText(tr("View summary"));
     72                    htmlPane.setPage(license.getURL());
     73                } else {
     74                    buttons.get(1).setText(tr("View full text"));
     75                    htmlPane.setPage(license.getSummaryURL());
     76                }
     77            } catch (IOException e) {
     78                e.printStackTrace();
     79            }
     80            summary = !summary;
     81        } else {
     82            super.buttonAction(buttonIndex, evt);
     83        }
     84    }
    8585
    86         @Override
    87         public void setupDialog() {
    88                 super.setupDialog();
    89                 buttons.get(1).setEnabled(license.getSummaryURL() != null && license.getURL() != null);
    90                 if (summary) {
    91                         buttons.get(1).setText(tr("View full text"));
    92                 } else {
    93                         buttons.get(1).setText(tr("View summary"));
    94                 }
    95         }
     86    @Override
     87    public void setupDialog() {
     88        super.setupDialog();
     89        buttons.get(1).setEnabled(license.getSummaryURL() != null && license.getURL() != null);
     90        if (summary) {
     91            buttons.get(1).setText(tr("View full text"));
     92        } else {
     93            buttons.get(1).setText(tr("View summary"));
     94        }
     95    }
    9696}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/AbstractImporter.java

    r30573 r30723  
    2424
    2525public abstract class AbstractImporter extends OsmImporter {
    26        
    27         protected AbstractDataSetHandler handler;
    28        
    29         protected File file;
    30        
     26   
     27    protected AbstractDataSetHandler handler;
     28   
     29    protected File file;
     30   
    3131    public AbstractImporter(ExtensionFileFilter filter) {
    3232        super(filter);
     
    3434   
    3535    protected final AbstractDataSetHandler findDataSetHandler(File file) {
    36         for (Module module : ModuleHandler.moduleList) {
    37                         for (AbstractDataSetHandler dsh : module.getNewlyInstanciatedHandlers()) {
    38                                 if (dsh.acceptsFile(file)) {
    39                                         return dsh;
    40                                 }
    41                         }
    42                 }
    43         return null;
     36        for (Module module : ModuleHandler.moduleList) {
     37            for (AbstractDataSetHandler dsh : module.getNewlyInstanciatedHandlers()) {
     38                if (dsh.acceptsFile(file)) {
     39                    return dsh;
     40                }
     41            }
     42        }
     43        return null;
    4444    }
    4545
    46         @Override
    47         public void importData(File file, ProgressMonitor progressMonitor)
    48                         throws IOException, IllegalDataException {
    49                 if (file != null) {
    50                         this.file = file;
    51                         this.handler = findDataSetHandler(file);
    52                 }
    53                 // Do not call super.importData because Compression.getUncompressedFileInputStream skips the first entry
     46    @Override
     47    public void importData(File file, ProgressMonitor progressMonitor)
     48            throws IOException, IllegalDataException {
     49        if (file != null) {
     50            this.file = file;
     51            this.handler = findDataSetHandler(file);
     52        }
     53        // Do not call super.importData because Compression.getUncompressedFileInputStream skips the first entry
    5454        try (InputStream in = new FileInputStream(file)) {
    5555            importData(in, file, progressMonitor);
     
    5858            throw new IOException(tr("File ''{0}'' does not exist.", file.getName()), e);
    5959        }
    60         }
     60    }
    6161
    62         @Override
    63         protected OsmDataLayer createLayer(DataSet dataSet, File associatedFile, String layerName) {
    64                 DataSetUpdater.updateDataSet(dataSet, handler, associatedFile);
    65                 return new OdDataLayer(dataSet, layerName, associatedFile, handler);
    66         }
     62    @Override
     63    protected OsmDataLayer createLayer(DataSet dataSet, File associatedFile, String layerName) {
     64        DataSetUpdater.updateDataSet(dataSet, handler, associatedFile);
     65        return new OdDataLayer(dataSet, layerName, associatedFile, handler);
     66    }
    6767}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/LambertCC9ZonesProjectionPatterns.java

    r30340 r30723  
    1010
    1111public class LambertCC9ZonesProjectionPatterns extends ProjectionPatterns {
    12        
    13         public static final Projection[] lambertCC9Zones = new Projection[9];
    14         static {
    15                 for (int i=0; i<lambertCC9Zones.length; i++) {
    16                         lambertCC9Zones[i] = Projections.getProjectionByCode("EPSG:"+Integer.toString(3942+i));
    17                 }
    18         }
     12   
     13    public static final Projection[] lambertCC9Zones = new Projection[9];
     14    static {
     15        for (int i=0; i<lambertCC9Zones.length; i++) {
     16            lambertCC9Zones[i] = Projections.getProjectionByCode("EPSG:"+Integer.toString(3942+i));
     17        }
     18    }
    1919
    20         public LambertCC9ZonesProjectionPatterns(String proj) {
    21                 super(proj);
    22         }
     20    public LambertCC9ZonesProjectionPatterns(String proj) {
     21        super(proj);
     22    }
    2323
    24         @Override
    25         public Projection getProjection(String xFieldName, String yFieldName) {
     24    @Override
     25    public Projection getProjection(String xFieldName, String yFieldName) {
    2626
    27                 Matcher mx = getXPattern().matcher(xFieldName);
    28                 Matcher my = getYPattern().matcher(yFieldName);
    29                 mx.find();
    30                 my.find();
    31                 String ccx = mx.group(1);
    32                 String ccy = mx.group(1);
    33                 if (!ccx.equals(ccy)) {
    34                         throw new IllegalArgumentException(tr("''Lambert CC 9 zones'' coordinates found with different zone codes for X and Y: "+xFieldName+", "+yFieldName));
    35                 }
    36                 return lambertCC9Zones[Integer.parseInt(ccx)-42];
    37         }
     27        Matcher mx = getXPattern().matcher(xFieldName);
     28        Matcher my = getYPattern().matcher(yFieldName);
     29        mx.find();
     30        my.find();
     31        String ccx = mx.group(1);
     32        String ccy = mx.group(1);
     33        if (!ccx.equals(ccy)) {
     34            throw new IllegalArgumentException(tr("''Lambert CC 9 zones'' coordinates found with different zone codes for X and Y: "+xFieldName+", "+yFieldName));
     35        }
     36        return lambertCC9Zones[Integer.parseInt(ccx)-42];
     37    }
    3838}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/NeptuneReader.java

    r30568 r30723  
    5858public class NeptuneReader extends AbstractReader implements FrenchConstants {
    5959
    60         public static final String OSM_PUBLIC_TRANSPORT = "public_transport";
    61         public static final String OSM_STOP = "stop";
    62         public static final String OSM_STOP_AREA = "stop_area";
    63         public static final String OSM_STOP_POSITION = "stop_position";
    64         public static final String OSM_PLATFORM = "platform";
    65         public static final String OSM_STATION = "station";
    66         public static final String OSM_NETWORK = "network";
    67         public static final String OSM_ROUTE = "route";
    68         public static final String OSM_ROUTE_MASTER = "route_master";
    69 
    70         public static final String OSM_TRAIN = "train";
    71         public static final String OSM_SUBWAY = "subway";
    72         public static final String OSM_MONORAIL = "monorail";
    73         public static final String OSM_TRAM = "tram";
    74         public static final String OSM_BUS = "bus";
    75         public static final String OSM_TROLLEYBUS = "trolleybus";
    76         public static final String OSM_AERIALWAY = "aerialway";
    77         public static final String OSM_FERRY = "ferry";
    78 
    79         private static final List<URL> schemas = new ArrayList<>();
    80         static {
    81                 schemas.add(NeptuneReader.class.getResource(NEPTUNE_XSD));
    82         }
    83        
    84         private ChouettePTNetworkType root;
    85        
    86         private final Map<String, OsmPrimitive> tridentObjects = new HashMap<>();
    87        
    88         public static final boolean acceptsXmlNeptuneFile(File file) {
    89                 return acceptsXmlNeptuneFile(file, null);
    90         }
    91 
    92         public static final boolean acceptsXmlNeptuneFile(File file, URL schemaURL) {
    93                
    94                 if (schemaURL == null) {
    95                         schemaURL = schemas.get(0);
    96                 }
    97                
    98                 try {
    99                         FileInputStream in = new FileInputStream(file);
    100                         Source xmlFile = new StreamSource(in);
    101                         try {
    102                                 SchemaFactory schemaFactory = SchemaFactory.newInstance(XMLConstants.W3C_XML_SCHEMA_NS_URI);
    103                                 Schema schema = schemaFactory.newSchema(schemaURL);
    104                                 Validator validator = schema.newValidator();
    105                                 validator.validate(xmlFile);
    106                                 Main.info(xmlFile.getSystemId() + " is valid");
    107                                 return true;
    108                         } catch (SAXException e) {
    109                                 Main.error(xmlFile.getSystemId() + " is NOT valid");
    110                                 Main.error("Reason: " + e.getLocalizedMessage());
    111                         } catch (IOException e) {
    112                             Main.error(xmlFile.getSystemId() + " is NOT valid");
    113                             Main.error("Reason: " + e.getLocalizedMessage());
    114                         } finally {
    115                                 try {
    116                                         in.close();
    117                                 } catch (IOException e) {
    118                                         // Ignore exception
    119                                 }
    120                         }
    121                 } catch (FileNotFoundException e) {
    122                     Main.error(e.getMessage());
    123                 }
    124                
    125                 return false;
    126         }
    127        
    128         public static DataSet parseDataSet(InputStream in, AbstractDataSetHandler handler, ProgressMonitor instance) throws JAXBException {
    129                 return new NeptuneReader().parse(in, instance);
    130         }
    131 
    132         protected static final <T> T unmarshal(Class<T> docClass, InputStream inputStream) throws JAXBException {
    133                 String packageName = docClass.getPackage().getName();
    134                 JAXBContext jc = JAXBContext.newInstance(packageName, NeptuneReader.class.getClassLoader());
    135                 Unmarshaller u = jc.createUnmarshaller();
    136                 @SuppressWarnings("unchecked")
     60    public static final String OSM_PUBLIC_TRANSPORT = "public_transport";
     61    public static final String OSM_STOP = "stop";
     62    public static final String OSM_STOP_AREA = "stop_area";
     63    public static final String OSM_STOP_POSITION = "stop_position";
     64    public static final String OSM_PLATFORM = "platform";
     65    public static final String OSM_STATION = "station";
     66    public static final String OSM_NETWORK = "network";
     67    public static final String OSM_ROUTE = "route";
     68    public static final String OSM_ROUTE_MASTER = "route_master";
     69
     70    public static final String OSM_TRAIN = "train";
     71    public static final String OSM_SUBWAY = "subway";
     72    public static final String OSM_MONORAIL = "monorail";
     73    public static final String OSM_TRAM = "tram";
     74    public static final String OSM_BUS = "bus";
     75    public static final String OSM_TROLLEYBUS = "trolleybus";
     76    public static final String OSM_AERIALWAY = "aerialway";
     77    public static final String OSM_FERRY = "ferry";
     78
     79    private static final List<URL> schemas = new ArrayList<>();
     80    static {
     81        schemas.add(NeptuneReader.class.getResource(NEPTUNE_XSD));
     82    }
     83   
     84    private ChouettePTNetworkType root;
     85   
     86    private final Map<String, OsmPrimitive> tridentObjects = new HashMap<>();
     87   
     88    public static final boolean acceptsXmlNeptuneFile(File file) {
     89        return acceptsXmlNeptuneFile(file, null);
     90    }
     91
     92    public static final boolean acceptsXmlNeptuneFile(File file, URL schemaURL) {
     93       
     94        if (schemaURL == null) {
     95            schemaURL = schemas.get(0);
     96        }
     97       
     98        try {
     99            FileInputStream in = new FileInputStream(file);
     100            Source xmlFile = new StreamSource(in);
     101            try {
     102                SchemaFactory schemaFactory = SchemaFactory.newInstance(XMLConstants.W3C_XML_SCHEMA_NS_URI);
     103                Schema schema = schemaFactory.newSchema(schemaURL);
     104                Validator validator = schema.newValidator();
     105                validator.validate(xmlFile);
     106                Main.info(xmlFile.getSystemId() + " is valid");
     107                return true;
     108            } catch (SAXException e) {
     109                Main.error(xmlFile.getSystemId() + " is NOT valid");
     110                Main.error("Reason: " + e.getLocalizedMessage());
     111            } catch (IOException e) {
     112                Main.error(xmlFile.getSystemId() + " is NOT valid");
     113                Main.error("Reason: " + e.getLocalizedMessage());
     114            } finally {
     115                try {
     116                    in.close();
     117                } catch (IOException e) {
     118                    // Ignore exception
     119                }
     120            }
     121        } catch (FileNotFoundException e) {
     122            Main.error(e.getMessage());
     123        }
     124       
     125        return false;
     126    }
     127   
     128    public static DataSet parseDataSet(InputStream in, AbstractDataSetHandler handler, ProgressMonitor instance) throws JAXBException {
     129        return new NeptuneReader().parse(in, instance);
     130    }
     131
     132    protected static final <T> T unmarshal(Class<T> docClass, InputStream inputStream) throws JAXBException {
     133        String packageName = docClass.getPackage().getName();
     134        JAXBContext jc = JAXBContext.newInstance(packageName, NeptuneReader.class.getClassLoader());
     135        Unmarshaller u = jc.createUnmarshaller();
     136        @SuppressWarnings("unchecked")
    137137        JAXBElement<T> doc = (JAXBElement<T>)u.unmarshal(inputStream);
    138                 return doc.getValue();
    139         }
    140        
    141         private final void linkTridentObjectToOsmPrimitive(TridentObjectType object, OsmPrimitive p) {
    142                 p.put("ref:neptune", object.getObjectId());
    143                 if (tridentObjects.put(object.getObjectId(), p) != null) {
    144                         System.err.println("Trident object duplicated !!! : "+object.getObjectId());
    145                 }
    146         }
    147 
    148         protected Node createNode(LatLon latlon){
    149                 Node n = new Node(latlon);
    150                 ds.addPrimitive(n);
    151                 return n;
    152         }
    153        
    154         private Node createPlatform(StopPointType stop) {
    155                 Node n = createNode(createLatLon(stop));
    156                 n.put(OSM_PUBLIC_TRANSPORT, OSM_PLATFORM);
    157                 linkTridentObjectToOsmPrimitive(stop, n);
    158                 n.put("name", stop.getName());
    159                 return n;
    160         }
    161         /*
    162         private Node createStopPosition(StopPointType stop) {
    163                 Node n = createNode(createLatLon(stop));
    164                 n.put(OSM_PUBLIC_TRANSPORT, OSM_STOP_POSITION);
    165                 linkTridentObjectToOsmPrimitive(stop, n);
    166                 n.put("name", stop.getName());
    167                 return n;
    168         }
     138        return doc.getValue();
     139    }
     140   
     141    private final void linkTridentObjectToOsmPrimitive(TridentObjectType object, OsmPrimitive p) {
     142        p.put("ref:neptune", object.getObjectId());
     143        if (tridentObjects.put(object.getObjectId(), p) != null) {
     144            System.err.println("Trident object duplicated !!! : "+object.getObjectId());
     145        }
     146    }
     147
     148    protected Node createNode(LatLon latlon){
     149        Node n = new Node(latlon);
     150        ds.addPrimitive(n);
     151        return n;
     152    }
     153   
     154    private Node createPlatform(StopPointType stop) {
     155        Node n = createNode(createLatLon(stop));
     156        n.put(OSM_PUBLIC_TRANSPORT, OSM_PLATFORM);
     157        linkTridentObjectToOsmPrimitive(stop, n);
     158        n.put("name", stop.getName());
     159        return n;
     160    }
     161    /*
     162    private Node createStopPosition(StopPointType stop) {
     163        Node n = createNode(createLatLon(stop));
     164        n.put(OSM_PUBLIC_TRANSPORT, OSM_STOP_POSITION);
     165        linkTridentObjectToOsmPrimitive(stop, n);
     166        n.put("name", stop.getName());
     167        return n;
     168    }
    169169*/
    170         protected Relation createRelation(String type){
    171                 Relation r = new Relation();
    172                 r.put("type", type);
    173                 ds.addPrimitive(r);
    174                 return r;
    175         }
    176 
    177         protected Relation createPtRelation(String pt, TridentObjectType object){
    178                 Relation r = createRelation(OSM_PUBLIC_TRANSPORT);
    179                 r.put(OSM_PUBLIC_TRANSPORT, pt);
    180                 linkTridentObjectToOsmPrimitive(object, r);
    181                 return r;
    182         }
    183        
    184         protected Relation createNetwork(PTNetworkType network) {
    185                 Relation r = createRelation(OSM_NETWORK);
    186                 linkTridentObjectToOsmPrimitive(network, r);
    187                 r.put("name", network.getName());
    188                 return r;
    189         }
    190        
    191         protected Relation createRouteMaster(LineType line) {
    192                 Relation r = createPtRelation(OSM_ROUTE_MASTER, line);
    193                 switch (line.getTransportModeName()) {
    194                 case BUS:
    195                         r.put(OSM_ROUTE_MASTER, OSM_BUS); break;
    196                 case AIR:
    197                         r.put(OSM_ROUTE_MASTER, OSM_AERIALWAY); break;
    198                 case FERRY:
    199                         r.put(OSM_ROUTE_MASTER, OSM_FERRY); break;
    200                 case METRO:
    201                         r.put(OSM_ROUTE_MASTER, OSM_SUBWAY); break;
    202                 case TRAIN:
    203                         r.put(OSM_ROUTE_MASTER, OSM_TRAIN); break;
    204                 case TRAMWAY:
    205                         r.put(OSM_ROUTE_MASTER, OSM_TRAM); break;
    206                 case TROLLEYBUS:
    207                         r.put(OSM_ROUTE_MASTER, OSM_TROLLEYBUS); break;
    208                 default:
    209                         System.err.println("Unsupported transport mode: "+line.getTransportModeName());
    210                 }
    211                 r.put("ref", line.getNumber());
    212                 r.put("name", line.getTransportModeName().value()+" "+line.getNumber()+": "+line.getName());
    213                 return r;
    214         }
    215 
    216         private Relation createRoute(ChouetteRoute route) {
    217                 Relation r = createPtRelation(OSM_ROUTE, route);
    218                 r.put("name", route.getName());
    219                 return r;
    220         }
    221        
    222         protected Relation createStopArea(StopAreaType sa) {
    223                 Relation r = createPtRelation(OSM_STOP_AREA, sa);
    224                 r.put("name", sa.getName());
    225                 return r;
    226         }
    227        
    228         protected LatLon createLatLon(PointType point) {
    229                 return new LatLon(point.getLatitude().doubleValue(), point.getLongitude().doubleValue());
    230         }
    231        
    232         protected final <T extends TridentObjectType> T findTridentObject(List<T> list, String id) {
    233                 for (T object : list) {
    234                         if (object.getObjectId().equals(id)) {
    235                                 return object;
    236                         }
    237                 }
    238                 return null;
    239         }
    240        
    241         protected StopPoint findStopPoint(String id) {
    242                 return findTridentObject(root.getChouetteLineDescription().getStopPoint(), id);
    243         }
    244 
    245         protected StopArea findStopArea(String id) {
    246                 return findTridentObject(root.getChouetteArea().getStopArea(), id);
    247         }
    248 
    249         protected AreaCentroid findAreaCentroid(String id) {
    250                 return findTridentObject(root.getChouetteArea().getAreaCentroid(), id);
    251         }
    252 
    253         protected PTLinkType findPtLink(String id) {
    254                 return findTridentObject(root.getChouetteLineDescription().getPtLink(), id);
    255         }
    256 
    257         protected static final boolean isNullLatLon(LatLon ll) {
    258                 return ll.lat() == 0.0 && ll.lon() == 0.0;
    259         }
    260 
    261         private DataSet parse(InputStream in, ProgressMonitor instance) throws JAXBException {
    262                 root = unmarshal(ChouettePTNetworkType.class, in);
    263 
    264                 Relation network = createNetwork(root.getPTNetwork());
    265 
    266                 // Parsing Stop areas
    267                 for (StopArea sa : root.getChouetteArea().getStopArea()) {
    268                         if (sa.getStopAreaExtension().getAreaType().equals(ChouetteAreaType.COMMERCIAL_STOP_POINT)) {
    269                                 Relation stopArea = createStopArea(sa);
    270                                 stopArea.put("name", sa.getName());
    271                                 for (String childId : sa.getContains()) {
    272                                         if (childId.contains("StopArea")) {
    273                                                 StopArea child = findStopArea(childId);
    274                                                 if (child == null) {
    275                                                         System.err.println("Cannot find StopArea: "+childId);
    276                                                 } else {
    277                                                         if (child.getStopAreaExtension().getAreaType().equals(ChouetteAreaType.BOARDING_POSITION)) {
    278                                                                 for (String grandchildId : child.getContains()) {
    279                                                                         if (grandchildId.contains("StopPoint")) {
    280                                                                                 StopPoint grandchild = findStopPoint(grandchildId);
    281                                                                                 if (grandchild == null) {
    282                                                                                         System.err.println("Cannot find StopPoint: "+grandchildId);
    283                                                                                 } else {
    284                                                                                         if (grandchild.getLongLatType().equals(LongLatTypeType.WGS_84)) {
    285                                                                                                 Node platform = createPlatform(grandchild);
    286                                                                                                 stopArea.addMember(new RelationMember(OSM_PLATFORM, platform));
    287                                                                                         } else {
    288                                                                                                 System.err.println("Unsupported long/lat type: "+grandchild.getLongLatType());
    289                                                                                         }
    290                                                                                 }
    291                                                                         } else {
    292                                                                                 System.err.println("Unsupported grandchild: "+grandchildId);
    293                                                                         }
    294                                                                 }
    295                                                                 String centroidId = child.getCentroidOfArea();
    296                                                                 AreaCentroid areaCentroid = findAreaCentroid(centroidId);
    297                                                                 if (areaCentroid == null) {
    298                                                                         System.err.println("Cannot find AreaCentroid: "+centroidId);
    299                                                                 } else if (!areaCentroid.getLongLatType().equals(LongLatTypeType.WGS_84)) {
    300                                                                         System.err.println("Unsupported long/lat type: "+areaCentroid.getLongLatType());
    301                                                                 } else {
    302                                                                         for (RelationMember member : stopArea.getMembers()) {
    303                                                                                 // Fix stop coordinates if needed
    304                                                                                 if (member.getRole().equals(OSM_PLATFORM) && isNullLatLon(member.getNode().getCoor())) {
    305                                                                                         member.getNode().setCoor(createLatLon(areaCentroid));
    306                                                                                 }
    307                                                                         }
    308                                                                 }
    309                                                         } else {
    310                                                                 System.err.println("Unsupported child type: "+child.getStopAreaExtension().getAreaType());
    311                                                         }
    312                                                 }
    313                                                
    314                                         } else if (childId.contains("StopPoint")) {
    315                                                 StopPoint child = findStopPoint(childId);
    316                                                 if (child == null) {
    317                                                         System.err.println("Cannot find StopPoint: "+childId);
    318                                                 } else {
    319                                                         // TODO
    320                                                         Main.info("TODO: handle StopPoint "+childId);
    321                                                 }
    322 
    323                                         } else {
    324                                                 Main.warn("Unsupported child: "+childId);
    325                                         }
    326                                 }
    327                         } else if (sa.getStopAreaExtension().getAreaType().equals(ChouetteAreaType.BOARDING_POSITION)) {
    328                                 //Main.info("skipping StopArea with type "+sa.getStopAreaExtension().getAreaType()+": "+sa.getObjectId());
    329                         } else {
    330                             Main.warn("Unsupported StopArea type: "+sa.getStopAreaExtension().getAreaType());
    331                         }
    332                 }
    333 
    334                 Relation routeMaster = createRouteMaster(root.getChouetteLineDescription().getLine());
    335                 network.addMember(new RelationMember(null, routeMaster));
    336 
    337                 for (ChouetteRoute cr : root.getChouetteLineDescription().getChouetteRoute()) {
    338                         Relation route = createRoute(cr);
    339                         routeMaster.addMember(new RelationMember(null, route));
    340                         for (String id : cr.getPtLinkId()) {
    341                                 PTLinkType ptlink = findPtLink(id);
    342                                 if (ptlink == null) {
    343                                         System.err.println("Cannot find PTLinkType: "+id);
    344                                 } else {
    345                                         /*StopPoint start = findStopPoint(ptlink.getStartOfLink());
    346                                         StopPoint end = findStopPoint(ptlink.getEndOfLink());*/
    347                                         OsmPrimitive start = tridentObjects.get(ptlink.getStartOfLink());
    348                                         OsmPrimitive end = tridentObjects.get(ptlink.getEndOfLink());
    349                                         if (start == null) {
    350                                                 System.err.println("Cannot find start StopPoint: "+ptlink.getStartOfLink());
    351                                         } else if (start.get(OSM_PUBLIC_TRANSPORT).equals(OSM_STOP) || start.get(OSM_PUBLIC_TRANSPORT).equals(OSM_PLATFORM)) {
    352                                                 addStopToRoute(route, start);
    353                                         }
    354                                        
    355                                         if (end == null) {
    356                                                 System.err.println("Cannot find end StopPoint: "+ptlink.getEndOfLink());
    357                                         } else if (end.get(OSM_PUBLIC_TRANSPORT).equals(OSM_STOP) || end.get(OSM_PUBLIC_TRANSPORT).equals(OSM_PLATFORM)) {
    358                                                 addStopToRoute(route, end);
    359                                         }
    360                                 }
    361                         }
    362                 }
    363                
    364                 return ds;
    365         }
    366                
    367         private static final boolean addStopToRoute(Relation route, OsmPrimitive stop) {
    368                 if (route.getMembersCount() == 0 || !route.getMember(route.getMembersCount()-1).getMember().equals(stop) ) {
    369                         route.addMember(new RelationMember(stop.get(OSM_PUBLIC_TRANSPORT), stop));
    370                         return true;
    371                 } else {
    372                         return false;
    373                 }
    374         }
    375 
    376         public static List<URL> getSchemas() {
    377                 return schemas;
    378         }
    379 
    380         public static void registerSchema(URL resource) {
    381                 if (resource != null && !schemas.contains(resource)) {
    382                         schemas.add(resource);
    383                 }
    384         }
     170    protected Relation createRelation(String type){
     171        Relation r = new Relation();
     172        r.put("type", type);
     173        ds.addPrimitive(r);
     174        return r;
     175    }
     176
     177    protected Relation createPtRelation(String pt, TridentObjectType object){
     178        Relation r = createRelation(OSM_PUBLIC_TRANSPORT);
     179        r.put(OSM_PUBLIC_TRANSPORT, pt);
     180        linkTridentObjectToOsmPrimitive(object, r);
     181        return r;
     182    }
     183   
     184    protected Relation createNetwork(PTNetworkType network) {
     185        Relation r = createRelation(OSM_NETWORK);
     186        linkTridentObjectToOsmPrimitive(network, r);
     187        r.put("name", network.getName());
     188        return r;
     189    }
     190   
     191    protected Relation createRouteMaster(LineType line) {
     192        Relation r = createPtRelation(OSM_ROUTE_MASTER, line);
     193        switch (line.getTransportModeName()) {
     194        case BUS:
     195            r.put(OSM_ROUTE_MASTER, OSM_BUS); break;
     196        case AIR:
     197            r.put(OSM_ROUTE_MASTER, OSM_AERIALWAY); break;
     198        case FERRY:
     199            r.put(OSM_ROUTE_MASTER, OSM_FERRY); break;
     200        case METRO:
     201            r.put(OSM_ROUTE_MASTER, OSM_SUBWAY); break;
     202        case TRAIN:
     203            r.put(OSM_ROUTE_MASTER, OSM_TRAIN); break;
     204        case TRAMWAY:
     205            r.put(OSM_ROUTE_MASTER, OSM_TRAM); break;
     206        case TROLLEYBUS:
     207            r.put(OSM_ROUTE_MASTER, OSM_TROLLEYBUS); break;
     208        default:
     209            System.err.println("Unsupported transport mode: "+line.getTransportModeName());
     210        }
     211        r.put("ref", line.getNumber());
     212        r.put("name", line.getTransportModeName().value()+" "+line.getNumber()+": "+line.getName());
     213        return r;
     214    }
     215
     216    private Relation createRoute(ChouetteRoute route) {
     217        Relation r = createPtRelation(OSM_ROUTE, route);
     218        r.put("name", route.getName());
     219        return r;
     220    }
     221   
     222    protected Relation createStopArea(StopAreaType sa) {
     223        Relation r = createPtRelation(OSM_STOP_AREA, sa);
     224        r.put("name", sa.getName());
     225        return r;
     226    }
     227   
     228    protected LatLon createLatLon(PointType point) {
     229        return new LatLon(point.getLatitude().doubleValue(), point.getLongitude().doubleValue());
     230    }
     231   
     232    protected final <T extends TridentObjectType> T findTridentObject(List<T> list, String id) {
     233        for (T object : list) {
     234            if (object.getObjectId().equals(id)) {
     235                return object;
     236            }
     237        }
     238        return null;
     239    }
     240   
     241    protected StopPoint findStopPoint(String id) {
     242        return findTridentObject(root.getChouetteLineDescription().getStopPoint(), id);
     243    }
     244
     245    protected StopArea findStopArea(String id) {
     246        return findTridentObject(root.getChouetteArea().getStopArea(), id);
     247    }
     248
     249    protected AreaCentroid findAreaCentroid(String id) {
     250        return findTridentObject(root.getChouetteArea().getAreaCentroid(), id);
     251    }
     252
     253    protected PTLinkType findPtLink(String id) {
     254        return findTridentObject(root.getChouetteLineDescription().getPtLink(), id);
     255    }
     256
     257    protected static final boolean isNullLatLon(LatLon ll) {
     258        return ll.lat() == 0.0 && ll.lon() == 0.0;
     259    }
     260
     261    private DataSet parse(InputStream in, ProgressMonitor instance) throws JAXBException {
     262        root = unmarshal(ChouettePTNetworkType.class, in);
     263
     264        Relation network = createNetwork(root.getPTNetwork());
     265
     266        // Parsing Stop areas
     267        for (StopArea sa : root.getChouetteArea().getStopArea()) {
     268            if (sa.getStopAreaExtension().getAreaType().equals(ChouetteAreaType.COMMERCIAL_STOP_POINT)) {
     269                Relation stopArea = createStopArea(sa);
     270                stopArea.put("name", sa.getName());
     271                for (String childId : sa.getContains()) {
     272                    if (childId.contains("StopArea")) {
     273                        StopArea child = findStopArea(childId);
     274                        if (child == null) {
     275                            System.err.println("Cannot find StopArea: "+childId);
     276                        } else {
     277                            if (child.getStopAreaExtension().getAreaType().equals(ChouetteAreaType.BOARDING_POSITION)) {
     278                                for (String grandchildId : child.getContains()) {
     279                                    if (grandchildId.contains("StopPoint")) {
     280                                        StopPoint grandchild = findStopPoint(grandchildId);
     281                                        if (grandchild == null) {
     282                                            System.err.println("Cannot find StopPoint: "+grandchildId);
     283                                        } else {
     284                                            if (grandchild.getLongLatType().equals(LongLatTypeType.WGS_84)) {
     285                                                Node platform = createPlatform(grandchild);
     286                                                stopArea.addMember(new RelationMember(OSM_PLATFORM, platform));
     287                                            } else {
     288                                                System.err.println("Unsupported long/lat type: "+grandchild.getLongLatType());
     289                                            }
     290                                        }
     291                                    } else {
     292                                        System.err.println("Unsupported grandchild: "+grandchildId);
     293                                    }
     294                                }
     295                                String centroidId = child.getCentroidOfArea();
     296                                AreaCentroid areaCentroid = findAreaCentroid(centroidId);
     297                                if (areaCentroid == null) {
     298                                    System.err.println("Cannot find AreaCentroid: "+centroidId);
     299                                } else if (!areaCentroid.getLongLatType().equals(LongLatTypeType.WGS_84)) {
     300                                    System.err.println("Unsupported long/lat type: "+areaCentroid.getLongLatType());
     301                                } else {
     302                                    for (RelationMember member : stopArea.getMembers()) {
     303                                        // Fix stop coordinates if needed
     304                                        if (member.getRole().equals(OSM_PLATFORM) && isNullLatLon(member.getNode().getCoor())) {
     305                                            member.getNode().setCoor(createLatLon(areaCentroid));
     306                                        }
     307                                    }
     308                                }
     309                            } else {
     310                                System.err.println("Unsupported child type: "+child.getStopAreaExtension().getAreaType());
     311                            }
     312                        }
     313                       
     314                    } else if (childId.contains("StopPoint")) {
     315                        StopPoint child = findStopPoint(childId);
     316                        if (child == null) {
     317                            System.err.println("Cannot find StopPoint: "+childId);
     318                        } else {
     319                            // TODO
     320                            Main.info("TODO: handle StopPoint "+childId);
     321                        }
     322
     323                    } else {
     324                        Main.warn("Unsupported child: "+childId);
     325                    }
     326                }
     327            } else if (sa.getStopAreaExtension().getAreaType().equals(ChouetteAreaType.BOARDING_POSITION)) {
     328                //Main.info("skipping StopArea with type "+sa.getStopAreaExtension().getAreaType()+": "+sa.getObjectId());
     329            } else {
     330                Main.warn("Unsupported StopArea type: "+sa.getStopAreaExtension().getAreaType());
     331            }
     332        }
     333
     334        Relation routeMaster = createRouteMaster(root.getChouetteLineDescription().getLine());
     335        network.addMember(new RelationMember(null, routeMaster));
     336
     337        for (ChouetteRoute cr : root.getChouetteLineDescription().getChouetteRoute()) {
     338            Relation route = createRoute(cr);
     339            routeMaster.addMember(new RelationMember(null, route));
     340            for (String id : cr.getPtLinkId()) {
     341                PTLinkType ptlink = findPtLink(id);
     342                if (ptlink == null) {
     343                    System.err.println("Cannot find PTLinkType: "+id);
     344                } else {
     345                    /*StopPoint start = findStopPoint(ptlink.getStartOfLink());
     346                    StopPoint end = findStopPoint(ptlink.getEndOfLink());*/
     347                    OsmPrimitive start = tridentObjects.get(ptlink.getStartOfLink());
     348                    OsmPrimitive end = tridentObjects.get(ptlink.getEndOfLink());
     349                    if (start == null) {
     350                        System.err.println("Cannot find start StopPoint: "+ptlink.getStartOfLink());
     351                    } else if (start.get(OSM_PUBLIC_TRANSPORT).equals(OSM_STOP) || start.get(OSM_PUBLIC_TRANSPORT).equals(OSM_PLATFORM)) {
     352                        addStopToRoute(route, start);
     353                    }
     354                   
     355                    if (end == null) {
     356                        System.err.println("Cannot find end StopPoint: "+ptlink.getEndOfLink());
     357                    } else if (end.get(OSM_PUBLIC_TRANSPORT).equals(OSM_STOP) || end.get(OSM_PUBLIC_TRANSPORT).equals(OSM_PLATFORM)) {
     358                        addStopToRoute(route, end);
     359                    }
     360                }
     361            }
     362        }
     363       
     364        return ds;
     365    }
     366       
     367    private static final boolean addStopToRoute(Relation route, OsmPrimitive stop) {
     368        if (route.getMembersCount() == 0 || !route.getMember(route.getMembersCount()-1).getMember().equals(stop) ) {
     369            route.addMember(new RelationMember(stop.get(OSM_PUBLIC_TRANSPORT), stop));
     370            return true;
     371        } else {
     372            return false;
     373        }
     374    }
     375
     376    public static List<URL> getSchemas() {
     377        return schemas;
     378    }
     379
     380    public static void registerSchema(URL resource) {
     381        if (resource != null && !schemas.contains(resource)) {
     382            schemas.add(resource);
     383        }
     384    }
    385385}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/NetworkReader.java

    r30563 r30723  
    3434public class NetworkReader extends OsmServerReader {
    3535
    36         private final String url;
    37         private final AbstractDataSetHandler handler;
    38         private Class<? extends AbstractReader> readerClass;
    39         private final boolean promptUser;
     36    private final String url;
     37    private final AbstractDataSetHandler handler;
     38    private Class<? extends AbstractReader> readerClass;
     39    private final boolean promptUser;
    4040
    41         private File file;
    42         private String filename;
     41    private File file;
     42    private String filename;
    4343   
    4444    /**
     
    6666    public NetworkReader(String url, AbstractDataSetHandler handler, boolean promptUser) {
    6767        CheckParameterUtil.ensureParameterNotNull(url, "url");
    68         this.url = url;
     68        this.url = url;
    6969        this.handler = handler;
    7070        this.readerClass = null;
     
    7272    }
    7373   
    74         public final File getReadFile() {
    75                 return file;
    76         }
     74    public final File getReadFile() {
     75        return file;
     76    }
    7777
    78         public final String getReadFileName() {
    79                 return filename;
    80         }
     78    public final String getReadFileName() {
     79        return filename;
     80    }
    8181
    82         private Class<? extends AbstractReader> findReaderByAttachment() {
    83                 String cdisp = this.activeConnection.getHeaderField("Content-disposition");
    84                 if (cdisp != null) {
    85                         Matcher m = Pattern.compile("attachment;.?filename=(.*)").matcher(cdisp);
    86                         if (m.matches()) {
    87                                 filename = m.group(1);
    88                                 return findReaderByExtension(filename);
    89                         }
    90                 }
    91                 return null;
    92         }
     82    private Class<? extends AbstractReader> findReaderByAttachment() {
     83        String cdisp = this.activeConnection.getHeaderField("Content-disposition");
     84        if (cdisp != null) {
     85            Matcher m = Pattern.compile("attachment;.?filename=(.*)").matcher(cdisp);
     86            if (m.matches()) {
     87                filename = m.group(1);
     88                return findReaderByExtension(filename);
     89            }
     90        }
     91        return null;
     92    }
    9393
    94         private Class<? extends AbstractReader> findReaderByContentType() {
    95         String contentType = this.activeConnection.getContentType();
    96         if (contentType.startsWith("application/zip")) {
    97                 return ZipReader.class;
     94    private Class<? extends AbstractReader> findReaderByContentType() {
     95        String contentType = this.activeConnection.getContentType();
     96        if (contentType.startsWith("application/zip")) {
     97            return ZipReader.class;
    9898        } else if (contentType.startsWith("application/x-7z-compressed")) {
    9999            return SevenZipReader.class;
    100         } else if (contentType.startsWith("application/vnd.ms-excel")) {
    101                 return XlsReader.class;
    102         } else if (contentType.startsWith("application/octet-stream")) {
    103                 //return OdsReader.class;//FIXME, can be anything
    104         } else if (contentType.startsWith("text/csv")) {
    105                 return CsvReader.class;
    106         } else if (contentType.startsWith("text/plain")) {//TODO: extract charset
    107                 return CsvReader.class;
    108         } else if (contentType.startsWith("tdyn/html")) {
    109                 //return CsvReader.class;//FIXME, can also be .tar.gz
    110         } else {
    111                 System.err.println("Unsupported content type: "+contentType);
    112         }
    113         return null;
    114         }
     100        } else if (contentType.startsWith("application/vnd.ms-excel")) {
     101            return XlsReader.class;
     102        } else if (contentType.startsWith("application/octet-stream")) {
     103            //return OdsReader.class;//FIXME, can be anything
     104        } else if (contentType.startsWith("text/csv")) {
     105            return CsvReader.class;
     106        } else if (contentType.startsWith("text/plain")) {//TODO: extract charset
     107            return CsvReader.class;
     108        } else if (contentType.startsWith("tdyn/html")) {
     109            //return CsvReader.class;//FIXME, can also be .tar.gz
     110        } else {
     111            System.err.println("Unsupported content type: "+contentType);
     112        }
     113        return null;
     114    }
    115115
    116         private Class<? extends AbstractReader> findReaderByExtension(String filename) {
    117                 filename = filename.replace("\"", "").toLowerCase();
    118                 for (String ext : FILE_AND_ARCHIVE_READERS.keySet()) {
    119                     if (filename.endsWith("."+ext)) {
    120                         return FILE_AND_ARCHIVE_READERS.get(ext);
    121                     }
    122                 }
    123                 return null;
    124         }
     116    private Class<? extends AbstractReader> findReaderByExtension(String filename) {
     117        filename = filename.replace("\"", "").toLowerCase();
     118        for (String ext : FILE_AND_ARCHIVE_READERS.keySet()) {
     119            if (filename.endsWith("."+ext)) {
     120                return FILE_AND_ARCHIVE_READERS.get(ext);
     121            }
     122        }
     123        return null;
     124    }
    125125
    126         @Override
    127         public DataSet parseOsm(ProgressMonitor progressMonitor) throws OsmTransferException {
     126    @Override
     127    public DataSet parseOsm(ProgressMonitor progressMonitor) throws OsmTransferException {
    128128        InputStream in = null;
    129129        ProgressMonitor instance = null;
    130130        try {
    131                 in = getInputStreamRaw(url, progressMonitor);
     131            in = getInputStreamRaw(url, progressMonitor);
    132132            if (in == null)
    133133                return null;
    134134            progressMonitor.subTask(tr("Downloading data..."));
    135135            if (readerClass == null) {
    136                 readerClass = findReaderByAttachment();
     136                readerClass = findReaderByAttachment();
    137137            }
    138138            if (readerClass == null) {
     
    140140            }
    141141            if (readerClass == null) {
    142                 readerClass = findReaderByContentType();
     142                readerClass = findReaderByContentType();
    143143            }
    144144            if (readerClass == null) {
    145                         throw new OsmTransferException("Cannot find appropriate reader !");//TODO handler job ?
     145                   throw new OsmTransferException("Cannot find appropriate reader !");//TODO handler job ?
    146146            } else if (findReaderByExtension(url) != null) {
    147                 filename = url.substring(url.lastIndexOf('/')+1);
     147                filename = url.substring(url.lastIndexOf('/')+1);
    148148            }
    149149            instance = progressMonitor.createSubTaskMonitor(ProgressMonitor.ALL_TICKS, false);
    150150            if (readerClass.equals(ZipReader.class) || readerClass.equals(SevenZipReader.class)) {
    151                 ArchiveReader zipReader = readerClass.equals(ZipReader.class)
    152                         ? new ZipReader(in, handler, promptUser) : new SevenZipReader(in, handler, promptUser);
    153                 DataSet ds = zipReader.parseDoc(instance);
    154                 file = zipReader.getReadFile();
    155                 return ds;
     151                ArchiveReader zipReader = readerClass.equals(ZipReader.class)
     152                        ? new ZipReader(in, handler, promptUser) : new SevenZipReader(in, handler, promptUser);
     153                DataSet ds = zipReader.parseDoc(instance);
     154                file = zipReader.getReadFile();
     155                return ds;
    156156            } else if (readerClass.equals(KmlReader.class)) {
    157                 return KmlReader.parseDataSet(in, instance);
     157                return KmlReader.parseDataSet(in, instance);
    158158            } else if (readerClass.equals(KmzReader.class)) {
    159                 return KmzReader.parseDataSet(in, instance);
     159                return KmzReader.parseDataSet(in, instance);
    160160            } else if (readerClass.equals(MifReader.class)) {
    161                 return MifReader.parseDataSet(in, null, handler, instance);
     161                return MifReader.parseDataSet(in, null, handler, instance);
    162162            } else if (readerClass.equals(ShpReader.class)) {
    163                 return ShpReader.parseDataSet(in, null, handler, instance);
     163                return ShpReader.parseDataSet(in, null, handler, instance);
    164164            } else if (readerClass.equals(TabReader.class)) {
    165                 return TabReader.parseDataSet(in, null, handler, instance);
     165                return TabReader.parseDataSet(in, null, handler, instance);
    166166            } else if (readerClass.equals(CsvReader.class)) {
    167                 return CsvReader.parseDataSet(in, handler, instance);
     167                return CsvReader.parseDataSet(in, handler, instance);
    168168            } else if (readerClass.equals(OdsReader.class)) {
    169                 return OdsReader.parseDataSet(in, handler, instance);
     169                return OdsReader.parseDataSet(in, handler, instance);
    170170            } else if (readerClass.equals(XlsReader.class)) {
    171                 return XlsReader.parseDataSet(in, handler, instance);
     171                return XlsReader.parseDataSet(in, handler, instance);
    172172            } else if (readerClass.equals(GmlReader.class)) {
    173                 return GmlReader.parseDataSet(in, handler, instance);
     173                return GmlReader.parseDataSet(in, handler, instance);
    174174            } else {
    175                 throw new IllegalArgumentException("Unsupported reader class: "+readerClass.getName());
     175                throw new IllegalArgumentException("Unsupported reader class: "+readerClass.getName());
    176176            }
    177177        } catch (OsmTransferException e) {
     
    190190            } catch (Exception e) {/* ignore it */}
    191191        }
    192         }
     192    }
    193193}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/OsmDownloader.java

    r30568 r30723  
    1010
    1111public class OsmDownloader {
    12        
    13         public static final void downloadOapi(String oapiReq) {
    14                 if (oapiReq != null) {
    15                         try {
    16                                 String oapiServer = Main.pref.get(OdConstants.PREF_OAPI, OdConstants.DEFAULT_OAPI);
    17                                 Main.info(oapiReq);
    18                                 String oapiReqEnc = URLEncoder.encode(oapiReq, OdConstants.UTF8);
    19                                 Main.main.menu.openLocation.openUrl(false, oapiServer+"data="+oapiReqEnc);
    20                         } catch (UnsupportedEncodingException e) {
    21                                 e.printStackTrace();
    22                         }
    23                 }
    24         }
    25        
    26         public static final void downloadXapi(Collection<String> xapiReqs) {
    27                 if (xapiReqs != null) {
    28                         String xapiServer = Main.pref.get(OdConstants.PREF_XAPI, OdConstants.DEFAULT_XAPI);
    29                         for (String xapiReq : xapiReqs) {
    30                                 Main.main.menu.openLocation.openUrl(false, xapiServer+xapiReq);
    31                         }
    32                 }
    33         }
     12   
     13    public static final void downloadOapi(String oapiReq) {
     14        if (oapiReq != null) {
     15            try {
     16                String oapiServer = Main.pref.get(OdConstants.PREF_OAPI, OdConstants.DEFAULT_OAPI);
     17                Main.info(oapiReq);
     18                String oapiReqEnc = URLEncoder.encode(oapiReq, OdConstants.UTF8);
     19                Main.main.menu.openLocation.openUrl(false, oapiServer+"data="+oapiReqEnc);
     20            } catch (UnsupportedEncodingException e) {
     21                e.printStackTrace();
     22            }
     23        }
     24    }
     25   
     26    public static final void downloadXapi(Collection<String> xapiReqs) {
     27        if (xapiReqs != null) {
     28            String xapiServer = Main.pref.get(OdConstants.PREF_XAPI, OdConstants.DEFAULT_XAPI);
     29            for (String xapiReq : xapiReqs) {
     30                Main.main.menu.openLocation.openUrl(false, xapiServer+xapiReq);
     31            }
     32        }
     33    }
    3434}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/OverpassApi.java

    r30340 r30723  
    44public abstract class OverpassApi {
    55
    6         public enum OaQueryType {
    7                 NODE ("node"),
    8                 WAY ("way"),
    9                 RELATION ("relation");
    10                 @Override
    11                 public String toString() { return this.value; }
    12                 private OaQueryType(final String value) { this.value = value; }
    13                 private final String value;
    14         }
     6    public enum OaQueryType {
     7        NODE ("node"),
     8        WAY ("way"),
     9        RELATION ("relation");
     10        @Override
     11        public String toString() { return this.value; }
     12        private OaQueryType(final String value) { this.value = value; }
     13        private final String value;
     14    }
    1515
    16         public enum OaRecurseType {
    17                 RELATION_RELATION ("relation-relation"),
    18                 RELATION_BACKWARDS ("relation-backwards"),
    19                 RELATION_WAY ("relation-way"),
    20                 RELATION_NODE ("relation-node"),
    21                 WAY_NODE ("way-node"),
    22                 WAY_RELATION ("way-relation"),
    23                 NODE_RELATION ("node-relation"),
    24                 NODE_WAY ("node-way");
    25                 @Override
    26                 public String toString() { return this.value; }
    27                 private OaRecurseType(final String value) { this.value = value; }
    28                 private final String value;
    29         }
    30        
    31         public static final String union(String ... queries) {
    32                 String result = "<union>\n";
    33                 for (String query : queries) {
    34                         if (query != null) {
    35                                 result += query + "\n";
    36                         }
    37                 }
    38                 result += "</union>";
    39                 return result;
    40         }
    41        
    42         public static final String query(String bbox, OaQueryType type, String ... conditions) {
    43                 String result = "<query type=\""+type+"\" >\n";
    44                 if (bbox != null) {
    45                         result += "<bbox-query "+bbox+"/>\n";
    46                 }
    47                 for (String condition : conditions) {
    48                         if (condition != null) {
    49                                 result += condition + "\n";
    50                         }
    51                 }
    52                 result += "</query>";
    53                 return result;
    54         }
     16    public enum OaRecurseType {
     17        RELATION_RELATION ("relation-relation"),
     18        RELATION_BACKWARDS ("relation-backwards"),
     19        RELATION_WAY ("relation-way"),
     20        RELATION_NODE ("relation-node"),
     21        WAY_NODE ("way-node"),
     22        WAY_RELATION ("way-relation"),
     23        NODE_RELATION ("node-relation"),
     24        NODE_WAY ("node-way");
     25        @Override
     26        public String toString() { return this.value; }
     27        private OaRecurseType(final String value) { this.value = value; }
     28        private final String value;
     29    }
     30   
     31    public static final String union(String ... queries) {
     32        String result = "<union>\n";
     33        for (String query : queries) {
     34            if (query != null) {
     35                result += query + "\n";
     36            }
     37        }
     38        result += "</union>";
     39        return result;
     40    }
     41   
     42    public static final String query(String bbox, OaQueryType type, String ... conditions) {
     43        String result = "<query type=\""+type+"\" >\n";
     44        if (bbox != null) {
     45            result += "<bbox-query "+bbox+"/>\n";
     46        }
     47        for (String condition : conditions) {
     48            if (condition != null) {
     49                result += condition + "\n";
     50            }
     51        }
     52        result += "</query>";
     53        return result;
     54    }
    5555
    56         public static final String recurse(OaRecurseType type, String into) {
    57                 return "<recurse type=\""+type+"\" into=\""+into+"\"/>\n";
    58         }
     56    public static final String recurse(OaRecurseType type, String into) {
     57        return "<recurse type=\""+type+"\" into=\""+into+"\"/>\n";
     58    }
    5959
    60         public static final String recurse(OaRecurseType ... types) {
    61                 String result = "";
    62                 for (OaRecurseType type : types) {
    63                         result += "<recurse type=\""+type+"\"/>\n";
    64                 }
    65                 return result;
    66         }
    67        
    68         public static final String print() {
    69                 return "<print mode=\"meta\"/>";
    70         }
    71        
    72         public static final String hasKey(String key) {
    73                 return hasKey(key, null);
    74         }
     60    public static final String recurse(OaRecurseType ... types) {
     61        String result = "";
     62        for (OaRecurseType type : types) {
     63            result += "<recurse type=\""+type+"\"/>\n";
     64        }
     65        return result;
     66    }
     67   
     68    public static final String print() {
     69        return "<print mode=\"meta\"/>";
     70    }
     71   
     72    public static final String hasKey(String key) {
     73        return hasKey(key, null);
     74    }
    7575
    76         public static final String hasKey(String key, String value) {
    77                 return "<has-kv k=\""+key+"\" "+(value != null && !value.isEmpty() ? "v=\""+value+"\"" : "")+" />";
    78         }
     76    public static final String hasKey(String key, String value) {
     77        return "<has-kv k=\""+key+"\" "+(value != null && !value.isEmpty() ? "v=\""+value+"\"" : "")+" />";
     78    }
    7979}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/ProjectionPatterns.java

    r30563 r30723  
    99public class ProjectionPatterns {
    1010
    11         private final Pattern xPattern;
    12         private final Pattern yPattern;
    13         private final Projection projection;
    14        
    15         public ProjectionPatterns(Pattern xPattern, Pattern yPattern, Projection projection) {
    16                 this.xPattern = xPattern;
    17                 this.yPattern = yPattern;
    18                 this.projection = projection;
    19                 OdConstants.PROJECTIONS.add(this);
    20         }
     11    private final Pattern xPattern;
     12    private final Pattern yPattern;
     13    private final Projection projection;
     14   
     15    public ProjectionPatterns(Pattern xPattern, Pattern yPattern, Projection projection) {
     16        this.xPattern = xPattern;
     17        this.yPattern = yPattern;
     18        this.projection = projection;
     19        OdConstants.PROJECTIONS.add(this);
     20    }
    2121
    22         public ProjectionPatterns(Pattern xPattern, Pattern yPattern) {
    23                 this(xPattern, yPattern, null);
    24         }
     22    public ProjectionPatterns(Pattern xPattern, Pattern yPattern) {
     23        this(xPattern, yPattern, null);
     24    }
    2525
    26         public ProjectionPatterns(String proj, Projection projection) {
    27                 this(getCoordinatePattern(OdConstants.X_STRING, proj), getCoordinatePattern(OdConstants.Y_STRING, proj), projection);
    28         }
     26    public ProjectionPatterns(String proj, Projection projection) {
     27        this(getCoordinatePattern(OdConstants.X_STRING, proj), getCoordinatePattern(OdConstants.Y_STRING, proj), projection);
     28    }
    2929
    30         public ProjectionPatterns(String proj) {
    31                 this(getCoordinatePattern(OdConstants.X_STRING, proj), getCoordinatePattern(OdConstants.Y_STRING, proj), null);
    32         }
    33        
    34         public final Pattern getXPattern() {
    35                 return xPattern;
    36         }
    37        
    38         public final Pattern getYPattern() {
    39                 return yPattern;
    40         }
     30    public ProjectionPatterns(String proj) {
     31        this(getCoordinatePattern(OdConstants.X_STRING, proj), getCoordinatePattern(OdConstants.Y_STRING, proj), null);
     32    }
     33   
     34    public final Pattern getXPattern() {
     35        return xPattern;
     36    }
     37   
     38    public final Pattern getYPattern() {
     39        return yPattern;
     40    }
    4141
    42         public Projection getProjection(String xFieldName, String yFieldName) {
    43                 return getProjection();
    44         }
     42    public Projection getProjection(String xFieldName, String yFieldName) {
     43        return getProjection();
     44    }
    4545
    46         public final Projection getProjection() {
    47                 return projection;
    48         }
     46    public final Projection getProjection() {
     47        return projection;
     48    }
    4949
    50         public static final Pattern getCoordinatePattern(String coor, String proj) {
    51                 if (proj != null && !proj.isEmpty()) {
    52                         return Pattern.compile("(?:.*(?:"+coor+").*(?:"+proj+").*)|(?:.*("+proj+").*(?:"+coor+").*)", Pattern.CASE_INSENSITIVE);
    53                 } else {
    54                         return Pattern.compile(coor, Pattern.CASE_INSENSITIVE);
    55                 }
     50    public static final Pattern getCoordinatePattern(String coor, String proj) {
     51        if (proj != null && !proj.isEmpty()) {
     52            return Pattern.compile("(?:.*(?:"+coor+").*(?:"+proj+").*)|(?:.*("+proj+").*(?:"+coor+").*)", Pattern.CASE_INSENSITIVE);
     53        } else {
     54            return Pattern.compile(coor, Pattern.CASE_INSENSITIVE);
     55        }
    5656    }
    5757
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/XmlImporter.java

    r30563 r30723  
    2121            OdConstants.XML_EXT, OdConstants.XML_EXT, tr("OpenData XML files") + " (*."+OdConstants.XML_EXT+")");
    2222
    23         public XmlImporter() {
    24                 super(XML_FILE_FILTER);
    25         }
    26        
    27         @Override
    28         public boolean acceptFile(File pathname) {
    29                 if (super.acceptFile(pathname)) {
    30                         for (URL schemaURL : NeptuneReader.getSchemas()) {
    31                                 if (NeptuneReader.acceptsXmlNeptuneFile(pathname, schemaURL)) {
    32                                         return true;
    33                                 }
    34                         }
    35                 }
    36                 return false;
    37         }
     23    public XmlImporter() {
     24        super(XML_FILE_FILTER);
     25    }
     26   
     27    @Override
     28    public boolean acceptFile(File pathname) {
     29        if (super.acceptFile(pathname)) {
     30            for (URL schemaURL : NeptuneReader.getSchemas()) {
     31                if (NeptuneReader.acceptsXmlNeptuneFile(pathname, schemaURL)) {
     32                    return true;
     33                }
     34            }
     35        }
     36        return false;
     37    }
    3838
    39         @Override
    40         protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
    41                         throws IllegalDataException {
    42                 try {
    43                         return NeptuneReader.parseDataSet(in, handler, instance);
    44                 } catch (JAXBException e) {
    45                         throw new IllegalDataException(e);
    46                 }
    47         }
     39    @Override
     40    protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
     41            throws IllegalDataException {
     42        try {
     43            return NeptuneReader.parseDataSet(in, handler, instance);
     44        } catch (JAXBException e) {
     45            throw new IllegalDataException(e);
     46        }
     47    }
    4848}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/archive/ArchiveHandler.java

    r30340 r30723  
    66public interface ArchiveHandler {
    77
    8         public void notifyTempFileWritten(File file);
     8    public void notifyTempFileWritten(File file);
    99
    10         public boolean skipXsdValidation();
     10    public boolean skipXsdValidation();
    1111
    12         public void setSkipXsdValidation(boolean skip);
     12    public void setSkipXsdValidation(boolean skip);
    1313}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/archive/CandidateChooser.java

    r30532 r30723  
    2929    private final JComboBox<File> fileCombo;
    3030
    31         public CandidateChooser(Component parent, List<File> candidates) {
    32                 this(parent, tr("File to load"), new String[] {tr("OK"), tr("Cancel")}, candidates);
    33         }
    34        
    35         private class Renderer extends DefaultListCellRenderer {
     31    public CandidateChooser(Component parent, List<File> candidates) {
     32        this(parent, tr("File to load"), new String[] {tr("OK"), tr("Cancel")}, candidates);
     33    }
     34   
     35    private class Renderer extends DefaultListCellRenderer {
    3636
    37                 @Override
    38                 public Component getListCellRendererComponent(JList<?> list, Object value,
    39                                 int index, boolean isSelected, boolean cellHasFocus) {
    40                         super.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
    41                         if (value instanceof File) {
    42                                 setText(((File)value).getName());
    43                         }
    44                         return this;
    45                 }
    46         }
    47        
    48         protected CandidateChooser(Component parent, String title, String[] buttonTexts, List<File> candidates) {
    49                 super(parent, title, buttonTexts);
    50                 this.fileCombo = new JComboBox<>(candidates.toArray(new File[0]));
    51                 this.fileCombo.setRenderer(new Renderer());
    52                 addGui(candidates);
    53         }
    54        
    55         public void addGui(List<File> candidates) {
     37        @Override
     38        public Component getListCellRendererComponent(JList<?> list, Object value,
     39                int index, boolean isSelected, boolean cellHasFocus) {
     40            super.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
     41            if (value instanceof File) {
     42                setText(((File)value).getName());
     43            }
     44            return this;
     45        }
     46    }
     47   
     48    protected CandidateChooser(Component parent, String title, String[] buttonTexts, List<File> candidates) {
     49        super(parent, title, buttonTexts);
     50        this.fileCombo = new JComboBox<>(candidates.toArray(new File[0]));
     51        this.fileCombo.setRenderer(new Renderer());
     52        addGui(candidates);
     53    }
     54   
     55    public void addGui(List<File> candidates) {
    5656        projPanel.setBorder(BorderFactory.createEmptyBorder( 0, 0, 0, 0 ));
    5757        projPanel.setLayout(new GridBagLayout());
     
    5959        projPanel.add(GBC.glue(5,0), GBC.std().fill(GBC.HORIZONTAL));
    6060        /*for (File file : candidates) {
    61                 JCheckBox cbox = new JCheckBox(file.getName());
    62                 checkBoxes.put(cbox, file);
    63                 projPanel.add(cbox, GBC.eop().fill(GBC.HORIZONTAL).insets(0,5,5,5));
     61            JCheckBox cbox = new JCheckBox(file.getName());
     62            checkBoxes.put(cbox, file);
     63            projPanel.add(cbox, GBC.eop().fill(GBC.HORIZONTAL).insets(0,5,5,5));
    6464        }*/
    6565        projPanel.add(fileCombo, GBC.eop().fill(GBC.HORIZONTAL).insets(0,5,5,5));
    6666        setContent(projPanel);
    67         }
    68        
    69         /*public List<File> getSelectedFiles() {
    70                 List<File> result = new ArrayList<File>();
    71                 for (JCheckBox cbox : checkBoxes.keySet()) {
    72                         if (cbox.isSelected()) {
    73                                 result.add(checkBoxes.get(cbox));
    74                         }
    75                 }
    76                 return result;
    77         }*/
    78        
    79         public File getSelectedFile() {
    80                 return (File) fileCombo.getSelectedItem();
    81         }
     67    }
     68   
     69    /*public List<File> getSelectedFiles() {
     70        List<File> result = new ArrayList<File>();
     71        for (JCheckBox cbox : checkBoxes.keySet()) {
     72            if (cbox.isSelected()) {
     73                result.add(checkBoxes.get(cbox));
     74            }
     75        }
     76        return result;
     77    }*/
     78   
     79    public File getSelectedFile() {
     80        return (File) fileCombo.getSelectedItem();
     81    }
    8282}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/archive/DefaultArchiveHandler.java

    r30340 r30723  
    66public class DefaultArchiveHandler implements ArchiveHandler {
    77
    8         private boolean skipXsdValidation = false;
    9        
    10         @Override
    11         public final void setSkipXsdValidation(boolean skip) {
    12                 skipXsdValidation = skip;
    13         }
    14        
    15         @Override
    16         public boolean skipXsdValidation() {
    17                 return skipXsdValidation;
    18         }
    19        
    20         @Override
    21         public void notifyTempFileWritten(File file) {
    22                 // Do nothing, let subclass override this method if they need it
    23         }
     8    private boolean skipXsdValidation = false;
     9   
     10    @Override
     11    public final void setSkipXsdValidation(boolean skip) {
     12        skipXsdValidation = skip;
     13    }
     14   
     15    @Override
     16    public boolean skipXsdValidation() {
     17        return skipXsdValidation;
     18    }
     19   
     20    @Override
     21    public void notifyTempFileWritten(File file) {
     22        // Do nothing, let subclass override this method if they need it
     23    }
    2424}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/archive/SevenZipImporter.java

    r30563 r30723  
    1818            OdConstants.SEVENZIP_EXT, OdConstants.SEVENZIP_EXT, tr("7Zip Files") + " (*."+OdConstants.SEVENZIP_EXT+")");
    1919
    20         public SevenZipImporter() {
    21                 super(SEVENZIP_FILE_FILTER);
    22         }
     20    public SevenZipImporter() {
     21        super(SEVENZIP_FILE_FILTER);
     22    }
    2323
    24         @Override
    25         protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
    26                         throws IllegalDataException {
    27                 try {
    28                         return SevenZipReader.parseDataSet(in, handler, instance, true);
    29                 } catch (Exception e) {
    30                         throw new IllegalDataException(e);
    31                 }
    32         }
     24    @Override
     25    protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
     26            throws IllegalDataException {
     27        try {
     28            return SevenZipReader.parseDataSet(in, handler, instance, true);
     29        } catch (Exception e) {
     30            throw new IllegalDataException(e);
     31        }
     32    }
    3333}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/archive/ZipImporter.java

    r30563 r30723  
    1919            OdConstants.ZIP_EXT, OdConstants.ZIP_EXT, tr("Zip Files") + " (*."+OdConstants.ZIP_EXT+")");
    2020
    21         public ZipImporter() {
    22                 super(ZIP_FILE_FILTER);
    23         }
     21    public ZipImporter() {
     22        super(ZIP_FILE_FILTER);
     23    }
    2424
    25         @Override
    26         protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
    27                         throws IllegalDataException {
    28                 try {
    29                         return ZipReader.parseDataSet(in, handler, instance, true);
    30                 } catch (Exception e) {
    31                         throw new IllegalDataException(e);
    32                 }
    33         }
     25    @Override
     26    protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
     27            throws IllegalDataException {
     28        try {
     29            return ZipReader.parseDataSet(in, handler, instance, true);
     30        } catch (Exception e) {
     31            throw new IllegalDataException(e);
     32        }
     33    }
    3434
    3535    @Override
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/archive/ZipReader.java

    r30573 r30723  
    2525public class ZipReader extends ArchiveReader {
    2626
    27         private final ZipInputStream zis;
    28        
    29         private ZipEntry entry;
    30        
     27    private final ZipInputStream zis;
     28   
     29    private ZipEntry entry;
     30   
    3131    public ZipReader(InputStream in, AbstractDataSetHandler handler, boolean promptUser) {
    3232        super(handler, handler != null ? handler.getArchiveHandler() : null, promptUser);
     
    3434    }
    3535
    36         public static DataSet parseDataSet(InputStream in, AbstractDataSetHandler handler, ProgressMonitor instance, boolean promptUser)
    37                 throws IOException, XMLStreamException, FactoryConfigurationError, JAXBException {
    38                 return new ZipReader(in, handler, promptUser).parseDoc(instance);
    39         }
     36    public static DataSet parseDataSet(InputStream in, AbstractDataSetHandler handler, ProgressMonitor instance, boolean promptUser)
     37            throws IOException, XMLStreamException, FactoryConfigurationError, JAXBException {
     38        return new ZipReader(in, handler, promptUser).parseDoc(instance);
     39    }
    4040
    4141    public static Map<File, DataSet> parseDataSets(InputStream in, AbstractDataSetHandler handler, ProgressMonitor instance, boolean promptUser)
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/AbstractMapInfoReader.java

    r30576 r30723  
    1717public abstract class AbstractMapInfoReader extends AbstractReader {
    1818
    19         protected static final String VERSION_1 = "1";
    20         protected static final String VERSION_2 = "2";
    21         protected static final String VERSION_300 = "300";
    22         protected static final String VERSION_450 = "450";
     19    protected static final String VERSION_1 = "1";
     20    protected static final String VERSION_2 = "2";
     21    protected static final String VERSION_300 = "300";
     22    protected static final String VERSION_450 = "450";
    2323
    24         protected static final String CHARSET_WINDOWS_LATIN    = "WindowsLatin1";
     24    protected static final String CHARSET_WINDOWS_LATIN    = "WindowsLatin1";
    2525    protected static final String CHARSET_WINDOWS_CYRILLIC = "WindowsCyrillic";
    26         protected static final String CHARSET_NEUTRAL = "Neutral";
    27         protected static final String CHARSET_MAC     = "MacRoman";
    28        
    29         protected BufferedReader headerReader;
     26    protected static final String CHARSET_NEUTRAL = "Neutral";
     27    protected static final String CHARSET_MAC     = "MacRoman";
     28   
     29    protected BufferedReader headerReader;
    3030
    31         protected String line;
    32         protected int lineNum = 0;
     31    protected String line;
     32    protected int lineNum = 0;
    3333
    34         protected String version;
     34    protected String version;
    3535
    36         // Columns
    37         protected int numcolumns = -1;
    38         protected List<String> columns;
     36    // Columns
     37    protected int numcolumns = -1;
     38    protected List<String> columns;
    3939
    40         protected final File getDataFile(File headerFile, String extension) {
    41                 String filename = headerFile.getName().substring(0, headerFile.getName().lastIndexOf('.'));
    42                 File dataFile = new File(headerFile.getParent() + File.separator + filename + extension.toUpperCase());
    43                 if (!dataFile.exists()) {
    44                         dataFile = new File(headerFile.getParent() + File.separator + filename + extension.toLowerCase());
    45                 }
    46                 return dataFile;
    47         }
    48        
    49         protected final BufferedReader getDataReader(File headerFile, String extension, Charset charset) throws IOException {
    50                 File dataFile = getDataFile(headerFile, extension);
    51                 return dataFile.exists() ? Files.newBufferedReader(dataFile.toPath(), charset) : null;
    52         }
     40    protected final File getDataFile(File headerFile, String extension) {
     41        String filename = headerFile.getName().substring(0, headerFile.getName().lastIndexOf('.'));
     42        File dataFile = new File(headerFile.getParent() + File.separator + filename + extension.toUpperCase());
     43        if (!dataFile.exists()) {
     44            dataFile = new File(headerFile.getParent() + File.separator + filename + extension.toLowerCase());
     45        }
     46        return dataFile;
     47    }
     48   
     49    protected final BufferedReader getDataReader(File headerFile, String extension, Charset charset) throws IOException {
     50        File dataFile = getDataFile(headerFile, extension);
     51        return dataFile.exists() ? Files.newBufferedReader(dataFile.toPath(), charset) : null;
     52    }
    5353
    54         protected Charset parseCharset(String[] words) throws IllegalCharsetNameException, UnsupportedCharsetException {
    55                 return parseCharset(words, 1);
    56         }
     54    protected Charset parseCharset(String[] words) throws IllegalCharsetNameException, UnsupportedCharsetException {
     55        return parseCharset(words, 1);
     56    }
    5757
    58         protected Charset parseCharset(String[] words, int index) throws IllegalCharsetNameException, UnsupportedCharsetException {
    59                 words[index] = words[index].replace("\"", "");
    60                 if (words[index].equalsIgnoreCase(CHARSET_WINDOWS_LATIN)) {
    61                         return Charset.forName(OdConstants.CP1252);
     58    protected Charset parseCharset(String[] words, int index) throws IllegalCharsetNameException, UnsupportedCharsetException {
     59        words[index] = words[index].replace("\"", "");
     60        if (words[index].equalsIgnoreCase(CHARSET_WINDOWS_LATIN)) {
     61            return Charset.forName(OdConstants.CP1252);
    6262        } else if (words[index].equalsIgnoreCase(CHARSET_WINDOWS_CYRILLIC)) {
    6363            return Charset.forName(OdConstants.CP1251);
    64                 } else if (words[index].equalsIgnoreCase(CHARSET_NEUTRAL)) {
    65                         return Charset.forName(OdConstants.ISO8859_15);
    66                 } else if (words[index].equalsIgnoreCase(CHARSET_MAC)) {
    67                         return Charset.forName(OdConstants.MAC_ROMAN);
    68                 } else {
    69                         System.err.println("Line "+lineNum+". Unknown charset detected: "+line);
    70                         return Charset.forName(words[index]);
    71                 }
    72         }
     64        } else if (words[index].equalsIgnoreCase(CHARSET_NEUTRAL)) {
     65            return Charset.forName(OdConstants.ISO8859_15);
     66        } else if (words[index].equalsIgnoreCase(CHARSET_MAC)) {
     67            return Charset.forName(OdConstants.MAC_ROMAN);
     68        } else {
     69            System.err.println("Line "+lineNum+". Unknown charset detected: "+line);
     70            return Charset.forName(words[index]);
     71        }
     72    }
    7373
    74         protected void parseVersion(String[] words) {
    75                 version = words[1];
    76         }
    77        
    78         protected void parseColumns(String[] words) {
    79                 columns = new ArrayList<>();
    80                 numcolumns = Integer.parseInt(words[1]);
    81         }
     74    protected void parseVersion(String[] words) {
     75        version = words[1];
     76    }
     77   
     78    protected void parseColumns(String[] words) {
     79        columns = new ArrayList<>();
     80        numcolumns = Integer.parseInt(words[1]);
     81    }
    8282
    83         protected final void parseHeader() throws IOException {
    84                 while ((line = headerReader.readLine()) != null) {
    85                         lineNum++;
    86                         while (line.contains("  ")) {
    87                                 line = line.replace("  ", " ");
    88                         }
    89                         String [] words = line.isEmpty() ? null : line.trim().split(" ");
    90                         if (words != null && words.length > 0) {
    91                                 parseHeaderLine(words);
    92                         }
    93                 }
    94         }
    95        
    96         protected abstract void parseHeaderLine(String[] words) throws IOException;
     83    protected final void parseHeader() throws IOException {
     84        while ((line = headerReader.readLine()) != null) {
     85            lineNum++;
     86            while (line.contains("  ")) {
     87                line = line.replace("  ", " ");
     88            }
     89            String [] words = line.isEmpty() ? null : line.trim().split(" ");
     90            if (words != null && words.length > 0) {
     91                parseHeaderLine(words);
     92            }
     93        }
     94    }
     95   
     96    protected abstract void parseHeaderLine(String[] words) throws IOException;
    9797}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/DefaultGeographicHandler.java

    r30340 r30723  
    99public abstract class DefaultGeographicHandler implements GeographicHandler {
    1010
    11         private boolean useNodeMap = true;
    12         private boolean checkNodeProximity = false;
    13         private boolean preferMultipolygonToSimpleWay = false;
     11    private boolean useNodeMap = true;
     12    private boolean checkNodeProximity = false;
     13    private boolean preferMultipolygonToSimpleWay = false;
    1414
    15         @Override
    16         public boolean preferMultipolygonToSimpleWay() {
    17                 return preferMultipolygonToSimpleWay;
    18         }
     15    @Override
     16    public boolean preferMultipolygonToSimpleWay() {
     17        return preferMultipolygonToSimpleWay;
     18    }
    1919
    20         @Override
    21         public void setPreferMultipolygonToSimpleWay(boolean prefer) {
    22                 preferMultipolygonToSimpleWay = prefer;
    23         }
     20    @Override
     21    public void setPreferMultipolygonToSimpleWay(boolean prefer) {
     22        preferMultipolygonToSimpleWay = prefer;
     23    }
    2424
    25         @Override
    26         public boolean checkNodeProximity() {
    27                 return checkNodeProximity;
    28         }
     25    @Override
     26    public boolean checkNodeProximity() {
     27        return checkNodeProximity;
     28    }
    2929
    30         @Override
    31         public void setCheckNodeProximity(boolean check) {
    32                 checkNodeProximity = check;
    33         }
     30    @Override
     31    public void setCheckNodeProximity(boolean check) {
     32        checkNodeProximity = check;
     33    }
    3434
    35         @Override
    36         public void setUseNodeMap(boolean use) {
    37                 useNodeMap = use;
    38         }
     35    @Override
     36    public void setUseNodeMap(boolean use) {
     37        useNodeMap = use;
     38    }
    3939
    40         @Override
    41         public boolean useNodeMap() {
    42                 return useNodeMap;
    43         }
     40    @Override
     41    public boolean useNodeMap() {
     42        return useNodeMap;
     43    }
    4444
    45         @Override
    46         public CoordinateReferenceSystem getCrsFor(String crsName) throws NoSuchAuthorityCodeException, FactoryException {
    47                 if (crsName.equalsIgnoreCase("GCS_ETRS_1989")) {
    48                         return CRS.decode("EPSG:4258");
    49                 }
    50                 return null;
    51         }
     45    @Override
     46    public CoordinateReferenceSystem getCrsFor(String crsName) throws NoSuchAuthorityCodeException, FactoryException {
     47        if (crsName.equalsIgnoreCase("GCS_ETRS_1989")) {
     48            return CRS.decode("EPSG:4258");
     49        }
     50        return null;
     51    }
    5252}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/DefaultGmlHandler.java

    r30340 r30723  
    99public class DefaultGmlHandler extends DefaultGeographicHandler implements GmlHandler {
    1010
    11         @Override
    12         public MathTransform findMathTransform(CoordinateReferenceSystem sourceCRS, CoordinateReferenceSystem targetCRS, boolean lenient)
    13                         throws FactoryException {
    14                 return CRS.findMathTransform(sourceCRS, targetCRS, lenient);
    15         }
     11    @Override
     12    public MathTransform findMathTransform(CoordinateReferenceSystem sourceCRS, CoordinateReferenceSystem targetCRS, boolean lenient)
     13            throws FactoryException {
     14        return CRS.findMathTransform(sourceCRS, targetCRS, lenient);
     15    }
    1616}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/DefaultShpHandler.java

    r30568 r30723  
    3737public class DefaultShpHandler extends DefaultGeographicHandler implements ShpHandler {
    3838
    39         private static final List<Pair<org.opengis.referencing.datum.Ellipsoid, Ellipsoid>>
    40                 ellipsoids = new ArrayList<>();
    41         static {
    42                 ellipsoids.add(new Pair<org.opengis.referencing.datum.Ellipsoid, Ellipsoid>(DefaultEllipsoid.GRS80, Ellipsoid.GRS80));
    43                 ellipsoids.add(new Pair<org.opengis.referencing.datum.Ellipsoid, Ellipsoid>(DefaultEllipsoid.WGS84, Ellipsoid.WGS84));
    44         }
    45        
    46         protected static final Double get(ParameterValueGroup values, ParameterDescriptor<?> desc) {
    47                 return (Double) values.parameter(desc.getName().getCode()).getValue();
    48         }
    49        
    50         private static final boolean equals(Double a, Double b) {
    51                 boolean res = Math.abs(a - b) <= Main.pref.getDouble(OdConstants.PREF_CRS_COMPARISON_TOLERANCE, OdConstants.DEFAULT_CRS_COMPARISON_TOLERANCE);
    52                 if (Main.pref.getBoolean(OdConstants.PREF_CRS_COMPARISON_DEBUG, false)) {
    53                         Main.debug("Comparing "+a+" and "+b+" -> "+res);
    54                 }
    55                 return res;
    56         }
    57        
    58         private Charset dbfCharset = null;
     39    private static final List<Pair<org.opengis.referencing.datum.Ellipsoid, Ellipsoid>>
     40        ellipsoids = new ArrayList<>();
     41    static {
     42        ellipsoids.add(new Pair<org.opengis.referencing.datum.Ellipsoid, Ellipsoid>(DefaultEllipsoid.GRS80, Ellipsoid.GRS80));
     43        ellipsoids.add(new Pair<org.opengis.referencing.datum.Ellipsoid, Ellipsoid>(DefaultEllipsoid.WGS84, Ellipsoid.WGS84));
     44    }
     45   
     46    protected static final Double get(ParameterValueGroup values, ParameterDescriptor<?> desc) {
     47        return (Double) values.parameter(desc.getName().getCode()).getValue();
     48    }
     49   
     50    private static final boolean equals(Double a, Double b) {
     51        boolean res = Math.abs(a - b) <= Main.pref.getDouble(OdConstants.PREF_CRS_COMPARISON_TOLERANCE, OdConstants.DEFAULT_CRS_COMPARISON_TOLERANCE);
     52        if (Main.pref.getBoolean(OdConstants.PREF_CRS_COMPARISON_DEBUG, false)) {
     53            Main.debug("Comparing "+a+" and "+b+" -> "+res);
     54        }
     55        return res;
     56    }
     57   
     58    private Charset dbfCharset = null;
    5959
    60         @Override
    61         public MathTransform findMathTransform(CoordinateReferenceSystem sourceCRS, CoordinateReferenceSystem targetCRS, boolean lenient)
    62                         throws FactoryException {
    63                 if (getCrsFor(sourceCRS.getName().getCode()) != null) {
    64                         return CRS.findMathTransform(getCrsFor(sourceCRS.getName().getCode()), targetCRS, lenient);
    65                 } else if (sourceCRS instanceof AbstractDerivedCRS && sourceCRS.getName().getCode().equalsIgnoreCase("Lambert_Conformal_Conic")) {
    66                         List<MathTransform> result = new ArrayList<>();
    67                         AbstractDerivedCRS crs = (AbstractDerivedCRS) sourceCRS;
    68                         MathTransform transform = crs.getConversionFromBase().getMathTransform();
    69                         if (transform instanceof LambertConformal && crs.getDatum() instanceof GeodeticDatum) {
    70                                 LambertConformal lambert = (LambertConformal) transform;
    71                                 GeodeticDatum geo = (GeodeticDatum) crs.getDatum();
    72                                 for (ProjectionChoice choice : ProjectionPreference.getProjectionChoices()) {
    73                                         Projection p = choice.getProjection();
    74                                         if (p instanceof AbstractProjection) {
    75                                                 AbstractProjection ap = (AbstractProjection) p;
    76                                                 if (ap.getProj() instanceof LambertConformalConic) {
    77                                                         for (Pair<org.opengis.referencing.datum.Ellipsoid, Ellipsoid> pair : ellipsoids) {
    78                                                                 if (pair.a.equals(geo.getEllipsoid()) && pair.b.equals(ap.getEllipsoid())) {
    79                                                                         boolean ok = true;
    80                                                                         ParameterValueGroup values = lambert.getParameterValues();
    81                                                                         Parameters params = ((LambertConformalConic) ap.getProj()).getParameters();
    82                                                                        
    83                                                                         ok = ok ? equals(get(values, AbstractProvider.LATITUDE_OF_ORIGIN), params.latitudeOrigin) : ok;
    84                                                                         ok = ok ? equals(get(values, AbstractProvider.CENTRAL_MERIDIAN), ap.getCentralMeridian()) : ok;
    85                                                                         ok = ok ? equals(get(values, AbstractProvider.SCALE_FACTOR), ap.getScaleFactor()) : ok;
    86                                                                         ok = ok ? equals(get(values, AbstractProvider.FALSE_EASTING), ap.getFalseEasting()) : ok;
    87                                                                         ok = ok ? equals(get(values, AbstractProvider.FALSE_NORTHING), ap.getFalseNorthing()) : ok;
    88                                                                        
    89                                                                         if (lambert instanceof LambertConformal2SP && params instanceof Parameters2SP) {
    90                                                                                 Parameters2SP param = (Parameters2SP) params;
    91                                                                                 ok = ok ? equals(Math.min(get(values, AbstractProvider.STANDARD_PARALLEL_1),get(values, AbstractProvider.STANDARD_PARALLEL_2)),
    92                                                                                                                 Math.min(param.standardParallel1, param.standardParallel2)) : ok;
    93                                                                                 ok = ok ? equals(Math.max(get(values, AbstractProvider.STANDARD_PARALLEL_1), get(values, AbstractProvider.STANDARD_PARALLEL_2)),
    94                                                                                                          Math.max(param.standardParallel1, param.standardParallel2)) : ok;
    95                                                                                
    96                                                                         } else if (!(lambert instanceof LambertConformal1SP && params instanceof Parameters1SP)) {
    97                                                                                 ok = false;
    98                                                                         }
     60    @Override
     61    public MathTransform findMathTransform(CoordinateReferenceSystem sourceCRS, CoordinateReferenceSystem targetCRS, boolean lenient)
     62            throws FactoryException {
     63        if (getCrsFor(sourceCRS.getName().getCode()) != null) {
     64            return CRS.findMathTransform(getCrsFor(sourceCRS.getName().getCode()), targetCRS, lenient);
     65        } else if (sourceCRS instanceof AbstractDerivedCRS && sourceCRS.getName().getCode().equalsIgnoreCase("Lambert_Conformal_Conic")) {
     66            List<MathTransform> result = new ArrayList<>();
     67            AbstractDerivedCRS crs = (AbstractDerivedCRS) sourceCRS;
     68            MathTransform transform = crs.getConversionFromBase().getMathTransform();
     69            if (transform instanceof LambertConformal && crs.getDatum() instanceof GeodeticDatum) {
     70                LambertConformal lambert = (LambertConformal) transform;
     71                GeodeticDatum geo = (GeodeticDatum) crs.getDatum();
     72                for (ProjectionChoice choice : ProjectionPreference.getProjectionChoices()) {
     73                    Projection p = choice.getProjection();
     74                    if (p instanceof AbstractProjection) {
     75                        AbstractProjection ap = (AbstractProjection) p;
     76                        if (ap.getProj() instanceof LambertConformalConic) {
     77                            for (Pair<org.opengis.referencing.datum.Ellipsoid, Ellipsoid> pair : ellipsoids) {
     78                                if (pair.a.equals(geo.getEllipsoid()) && pair.b.equals(ap.getEllipsoid())) {
     79                                    boolean ok = true;
     80                                    ParameterValueGroup values = lambert.getParameterValues();
     81                                    Parameters params = ((LambertConformalConic) ap.getProj()).getParameters();
     82                                   
     83                                    ok = ok ? equals(get(values, AbstractProvider.LATITUDE_OF_ORIGIN), params.latitudeOrigin) : ok;
     84                                    ok = ok ? equals(get(values, AbstractProvider.CENTRAL_MERIDIAN), ap.getCentralMeridian()) : ok;
     85                                    ok = ok ? equals(get(values, AbstractProvider.SCALE_FACTOR), ap.getScaleFactor()) : ok;
     86                                    ok = ok ? equals(get(values, AbstractProvider.FALSE_EASTING), ap.getFalseEasting()) : ok;
     87                                    ok = ok ? equals(get(values, AbstractProvider.FALSE_NORTHING), ap.getFalseNorthing()) : ok;
     88                                   
     89                                    if (lambert instanceof LambertConformal2SP && params instanceof Parameters2SP) {
     90                                        Parameters2SP param = (Parameters2SP) params;
     91                                        ok = ok ? equals(Math.min(get(values, AbstractProvider.STANDARD_PARALLEL_1),get(values, AbstractProvider.STANDARD_PARALLEL_2)),
     92                                                        Math.min(param.standardParallel1, param.standardParallel2)) : ok;
     93                                        ok = ok ? equals(Math.max(get(values, AbstractProvider.STANDARD_PARALLEL_1), get(values, AbstractProvider.STANDARD_PARALLEL_2)),
     94                                                         Math.max(param.standardParallel1, param.standardParallel2)) : ok;
     95                                       
     96                                    } else if (!(lambert instanceof LambertConformal1SP && params instanceof Parameters1SP)) {
     97                                        ok = false;
     98                                    }
    9999
    100                                                                         if (ok) {
    101                                                                                 try {
    102                                                                                         result.add(CRS.findMathTransform(CRS.decode(p.toCode()), targetCRS, lenient));
    103                                                                                 } catch (FactoryException e) {
    104                                                                                         System.err.println(e.getMessage());
    105                                                                                 }
    106                                                                         }
    107                                                                 }
    108                                                         }
    109                                                 }
    110                                         }
    111                                 }
    112                         }
    113                         if (!result.isEmpty()) {
    114                                 if (result.size() > 1) {
    115                                         System.err.println("Found multiple projections !"); // TODO: something
    116                                 }
    117                                 return result.get(0);
    118                         }
    119                 }
    120                 return null;
    121         }
     100                                    if (ok) {
     101                                        try {
     102                                            result.add(CRS.findMathTransform(CRS.decode(p.toCode()), targetCRS, lenient));
     103                                        } catch (FactoryException e) {
     104                                            System.err.println(e.getMessage());
     105                                        }
     106                                    }
     107                                }
     108                            }
     109                        }
     110                    }
     111                }
     112            }
     113            if (!result.isEmpty()) {
     114                if (result.size() > 1) {
     115                    System.err.println("Found multiple projections !"); // TODO: something
     116                }
     117                return result.get(0);
     118            }
     119        }
     120        return null;
     121    }
    122122
    123         @Override
    124         public void notifyFeatureParsed(Object feature, DataSet result, Set<OsmPrimitive> featurePrimitives) {
    125                 // To be overriden by modules handlers
    126         }
     123    @Override
     124    public void notifyFeatureParsed(Object feature, DataSet result, Set<OsmPrimitive> featurePrimitives) {
     125        // To be overriden by modules handlers
     126    }
    127127
    128         @Override
    129         public void setDbfCharset(Charset charset) {
    130                 dbfCharset = charset;
    131         }
    132        
    133         @Override
    134         public Charset getDbfCharset() {
    135                 return dbfCharset;
    136         }
     128    @Override
     129    public void setDbfCharset(Charset charset) {
     130        dbfCharset = charset;
     131    }
     132   
     133    @Override
     134    public Charset getDbfCharset() {
     135        return dbfCharset;
     136    }
    137137}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/GeoCrsException.java

    r30340 r30723  
    44public class GeoCrsException extends Exception {
    55
    6         public GeoCrsException() {
    7                 super();
    8         }
     6    public GeoCrsException() {
     7        super();
     8    }
    99
    10         public GeoCrsException(String message, Throwable cause) {
    11                 super(message, cause);
    12         }
     10    public GeoCrsException(String message, Throwable cause) {
     11        super(message, cause);
     12    }
    1313
    14         public GeoCrsException(String message) {
    15                 super(message);
    16         }
     14    public GeoCrsException(String message) {
     15        super(message);
     16    }
    1717
    18         public GeoCrsException(Throwable cause) {
    19                 super(cause);
    20         }
     18    public GeoCrsException(Throwable cause) {
     19        super(cause);
     20    }
    2121}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/GeoMathTransformException.java

    r30340 r30723  
    44public class GeoMathTransformException extends Exception {
    55
    6         public GeoMathTransformException() {
    7                 super();
    8         }
     6    public GeoMathTransformException() {
     7        super();
     8    }
    99
    10         public GeoMathTransformException(String message, Throwable cause) {
    11                 super(message, cause);
    12         }
     10    public GeoMathTransformException(String message, Throwable cause) {
     11        super(message, cause);
     12    }
    1313
    14         public GeoMathTransformException(String message) {
    15                 super(message);
    16         }
     14    public GeoMathTransformException(String message) {
     15        super(message);
     16    }
    1717
    18         public GeoMathTransformException(Throwable cause) {
    19                 super(cause);
    20         }
     18    public GeoMathTransformException(Throwable cause) {
     19        super(cause);
     20    }
    2121}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/GeographicHandler.java

    r30340 r30723  
    88
    99public interface GeographicHandler {
    10        
    11         public void setPreferMultipolygonToSimpleWay(boolean prefer);
     10   
     11    public void setPreferMultipolygonToSimpleWay(boolean prefer);
    1212
    13         public boolean preferMultipolygonToSimpleWay();
     13    public boolean preferMultipolygonToSimpleWay();
    1414
    15         public void setCheckNodeProximity(boolean check);
    16        
    17         public boolean checkNodeProximity();
    18        
    19         public void setUseNodeMap(boolean use);
    20        
    21         public boolean useNodeMap();
    22        
    23         public CoordinateReferenceSystem getCrsFor(String crsName) throws NoSuchAuthorityCodeException, FactoryException;
     15    public void setCheckNodeProximity(boolean check);
     16   
     17    public boolean checkNodeProximity();
     18   
     19    public void setUseNodeMap(boolean use);
     20   
     21    public boolean useNodeMap();
     22   
     23    public CoordinateReferenceSystem getCrsFor(String crsName) throws NoSuchAuthorityCodeException, FactoryException;
    2424
    25         public MathTransform findMathTransform(CoordinateReferenceSystem sourceCRS, CoordinateReferenceSystem targetCRS, boolean lenient) throws FactoryException;
     25    public MathTransform findMathTransform(CoordinateReferenceSystem sourceCRS, CoordinateReferenceSystem targetCRS, boolean lenient) throws FactoryException;
    2626}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/GeographicReader.java

    r30568 r30723  
    5454public abstract class GeographicReader extends AbstractReader {
    5555
    56         protected static CoordinateReferenceSystem wgs84;
    57         static {
    58                 try {
    59                         wgs84 = CRS.decode("EPSG:4326");
    60                 } catch (NoSuchAuthorityCodeException e) {
    61                         e.printStackTrace();
    62                 } catch (FactoryException e) {
    63                         e.printStackTrace();
    64                 }
    65         }
    66        
    67         private final GeographicHandler handler;
    68         private final GeographicHandler[] defaultHandlers;
    69        
    70         protected final Map<LatLon, Node> nodes;
    71 
    72         protected CoordinateReferenceSystem crs;
    73         protected MathTransform transform;
    74 
    75         public GeographicReader(GeographicHandler handler, GeographicHandler[] defaultHandlers) {
    76                 this.nodes = new HashMap<>();
    77                 this.handler = handler;
    78                 this.defaultHandlers = defaultHandlers;
    79         }
    80        
    81         protected Node getNode(Point p, LatLon key) {
    82                 Node n = nodes.get(key);
    83                 if (n == null && handler != null && handler.checkNodeProximity()) {
    84                         LatLon ll = new LatLon(p.getY(), p.getX());
    85                         for (Node node : nodes.values()) {
    86                                 if (node.getCoor().equalsEpsilon(ll)) {
    87                                         return node;
    88                                 }
    89                         }
    90                 }
    91                 return n;
    92         }
    93 
    94         protected Node createOrGetNode(Point p) throws MismatchedDimensionException, TransformException {
    95                 return createOrGetNode(p, null);
    96         }
    97 
    98         protected Node createOrGetNode(Point p, String ele) throws MismatchedDimensionException, TransformException {
    99                 Point p2 = (Point) JTS.transform(p, transform);
    100                 LatLon key = new LatLon(p2.getY(), p2.getX());
    101                 Node n = getNode(p2, key);
    102                 if (n == null) {
    103                         n = new Node(key);
    104                         if (ele != null) {
    105                                 n.put("ele", ele);
    106                         }
    107                         if (handler == null || handler.useNodeMap()) {
    108                                 nodes.put(key, n);
    109                         }
    110                         ds.addPrimitive(n);
    111                 } else if (n.getDataSet() == null) {
    112                     // handler may have removed the node from DataSet (see Paris public light handler for example)
    113                     ds.addPrimitive(n);
    114                 }
    115                 return n;
    116         }
    117        
     56    protected static CoordinateReferenceSystem wgs84;
     57    static {
     58        try {
     59            wgs84 = CRS.decode("EPSG:4326");
     60        } catch (NoSuchAuthorityCodeException e) {
     61            e.printStackTrace();
     62        } catch (FactoryException e) {
     63            e.printStackTrace();
     64        }
     65    }
     66   
     67    private final GeographicHandler handler;
     68    private final GeographicHandler[] defaultHandlers;
     69   
     70    protected final Map<LatLon, Node> nodes;
     71
     72    protected CoordinateReferenceSystem crs;
     73    protected MathTransform transform;
     74
     75    public GeographicReader(GeographicHandler handler, GeographicHandler[] defaultHandlers) {
     76        this.nodes = new HashMap<>();
     77        this.handler = handler;
     78        this.defaultHandlers = defaultHandlers;
     79    }
     80   
     81    protected Node getNode(Point p, LatLon key) {
     82        Node n = nodes.get(key);
     83        if (n == null && handler != null && handler.checkNodeProximity()) {
     84            LatLon ll = new LatLon(p.getY(), p.getX());
     85            for (Node node : nodes.values()) {
     86                if (node.getCoor().equalsEpsilon(ll)) {
     87                    return node;
     88                }
     89            }
     90        }
     91        return n;
     92    }
     93
     94    protected Node createOrGetNode(Point p) throws MismatchedDimensionException, TransformException {
     95        return createOrGetNode(p, null);
     96    }
     97
     98    protected Node createOrGetNode(Point p, String ele) throws MismatchedDimensionException, TransformException {
     99        Point p2 = (Point) JTS.transform(p, transform);
     100        LatLon key = new LatLon(p2.getY(), p2.getX());
     101        Node n = getNode(p2, key);
     102        if (n == null) {
     103            n = new Node(key);
     104            if (ele != null) {
     105                n.put("ele", ele);
     106            }
     107            if (handler == null || handler.useNodeMap()) {
     108                nodes.put(key, n);
     109            }
     110            ds.addPrimitive(n);
     111        } else if (n.getDataSet() == null) {
     112            // handler may have removed the node from DataSet (see Paris public light handler for example)
     113            ds.addPrimitive(n);
     114        }
     115        return n;
     116    }
     117   
    118118        protected Node createOrGetEmptyNode(Point p) throws MismatchedDimensionException, TransformException {
    119119                Point p2 = (Point) JTS.transform(p, transform);
     
    136136        }
    137137       
    138         protected <T extends OsmPrimitive> T addOsmPrimitive(T p) {
    139                 ds.addPrimitive(p);
    140                 return p;
    141         }
    142 
    143         protected final Way createWay() {
    144                 return addOsmPrimitive(new Way());
    145         }
    146 
    147         protected final Way createWay(LineString ls) {
    148                 Way w = createWay();
    149                 if (ls != null) {
    150                         for (int i=0; i<ls.getNumPoints(); i++) {
    151                                 try {
    152                                         w.addNode(createOrGetNode(ls.getPointN(i)));
    153                                 } catch (Exception e) {
    154                                         System.err.println(e.getMessage());
    155                                 }
    156                         }
    157                 }
    158                 return w;
    159         }
    160 
    161         protected final Relation createMultipolygon() {
    162                 Relation r = new Relation();
    163                 r.put("type", "multipolygon");
    164                 return addOsmPrimitive(r);
    165         }
    166 
    167         protected final void addWayToMp(Relation r, String role, Way w) {
    168                 r.addMember(new RelationMember(role, w));
    169         }
    170        
     138    protected <T extends OsmPrimitive> T addOsmPrimitive(T p) {
     139        ds.addPrimitive(p);
     140        return p;
     141    }
     142
     143    protected final Way createWay() {
     144        return addOsmPrimitive(new Way());
     145    }
     146
     147    protected final Way createWay(LineString ls) {
     148        Way w = createWay();
     149        if (ls != null) {
     150            for (int i=0; i<ls.getNumPoints(); i++) {
     151                try {
     152                    w.addNode(createOrGetNode(ls.getPointN(i)));
     153                } catch (Exception e) {
     154                    System.err.println(e.getMessage());
     155                }
     156            }
     157        }
     158        return w;
     159    }
     160
     161    protected final Relation createMultipolygon() {
     162        Relation r = new Relation();
     163        r.put("type", "multipolygon");
     164        return addOsmPrimitive(r);
     165    }
     166
     167    protected final void addWayToMp(Relation r, String role, Way w) {
     168        r.addMember(new RelationMember(role, w));
     169    }
     170   
    171171    /**
    172172     * returns true if the user wants to cancel, false if they
     
    174174     */
    175175    protected static final boolean warnLenientMethod(final Component parent, final CoordinateReferenceSystem crs) {
    176         return new DialogPrompter<ExtendedDialog>() {
    177                         @Override
    178                         protected ExtendedDialog buildDialog() {
    179                         final ExtendedDialog dlg = new ExtendedDialog(parent,
    180                                 tr("Cannot transform to WGS84"),
    181                                 new String[] {tr("Cancel"), tr("Continue")});
    182                         dlg.setContent("<html>" +
    183                                 tr("JOSM was unable to find a strict mathematical transformation between ''{0}'' and WGS84.<br /><br />"+
    184                                         "Do you want to try a <i>lenient</i> method, which will perform a non-precise transformation (<b>with location errors up to 1 km</b>) ?<br/><br/>"+
    185                                         "If so, <b>do NOT upload</b> such data to OSM !", crs.getName())+
    186                                 "</html>");
    187                         dlg.setButtonIcons(new Icon[] {
    188                                 ImageProvider.get("cancel"),
    189                                 ImageProvider.overlay(
    190                                         ImageProvider.get("ok"),
    191                                         new ImageIcon(ImageProvider.get("warning-small").getImage().getScaledInstance(10 , 10, Image.SCALE_SMOOTH)),
    192                                         ImageProvider.OverlayPosition.SOUTHEAST)});
    193                         dlg.setToolTipTexts(new String[] {
    194                                 tr("Cancel"),
    195                                 tr("Try lenient method")});
    196                         dlg.setIcon(JOptionPane.WARNING_MESSAGE);
    197                         dlg.setCancelButton(1);
    198                         return dlg;
    199                         }
    200                 }.promptInEdt().getValue() != 2;
    201     }
    202    
    203         private static final void compareDebug(CoordinateReferenceSystem crs1, CoordinateReferenceSystem crs2) {
    204                 Main.debug("-- COMPARING "+crs1.getName()+" WITH "+crs2.getName()+" --");
    205                 compareDebug("class", crs1.getClass(), crs2.getClass());
    206                 CoordinateSystem cs1 = crs1.getCoordinateSystem();
    207                 CoordinateSystem cs2 = crs2.getCoordinateSystem();
    208                 if (!compareDebug("cs", cs1, cs2)) {
    209                         Integer dim1 = cs1.getDimension();
    210                         Integer dim2 = cs2.getDimension();
    211                         if (compareDebug("cs.dim", dim1, dim2)) {
    212                                 for (int i = 0; i<dim1; i++) {
    213                                         compareDebug("cs.axis"+i, cs1.getAxis(i), cs1.getAxis(i));
    214                                 }
    215                         }
    216                 }
    217                 if (crs1 instanceof AbstractSingleCRS) {
    218                         Datum datum1 = ((AbstractSingleCRS) crs1).getDatum();
    219                         Datum datum2 = ((AbstractSingleCRS) crs2).getDatum();
    220                         if (!compareDebug("datum", datum1, datum2)) {
    221                                 AbstractIdentifiedObject adatum1 = (AbstractIdentifiedObject) datum1;
    222                                 AbstractIdentifiedObject adatum2 = (AbstractIdentifiedObject) datum2;
    223                                 compareDebug("datum.name1", adatum1.nameMatches(adatum2.getName().getCode()), adatum1.getName(), adatum2.getName());
    224                                 compareDebug("datum.name2", adatum2.nameMatches(adatum1.getName().getCode()), adatum2.getName(), adatum1.getName());
    225                         }
    226                         if (crs1 instanceof AbstractDerivedCRS) {
    227                                 AbstractDerivedCRS adcrs1 = (AbstractDerivedCRS) crs1;
    228                                 AbstractDerivedCRS adcrs2 = (AbstractDerivedCRS) crs2;
    229                                 compareDebug("baseCRS", adcrs1.getBaseCRS(), adcrs2.getBaseCRS());
    230                                 compareDebug("conversionFromBase", adcrs1.getConversionFromBase(), adcrs2.getConversionFromBase());
    231                         }
    232                 }
    233                 Main.debug("-- COMPARING FINISHED --");
    234         }
    235        
    236         private static final boolean compareDebug(String text, Object o1, Object o2) {
    237                 return compareDebug(text, o1.equals(o2), o1, o2);
    238         }
    239        
    240         private static final boolean compareDebug(String text, IdentifiedObject o1, IdentifiedObject o2) {
    241                 return compareDebug(text, (AbstractIdentifiedObject)o1, (AbstractIdentifiedObject)o2);
    242         }
    243        
    244         private static final boolean compareDebug(String text, AbstractIdentifiedObject o1, AbstractIdentifiedObject o2) {
    245                 return compareDebug(text, o1.equals(o2, false), o1, o2);
    246         }
    247 
    248         private static final boolean compareDebug(String text, boolean result, Object o1, Object o2) {
    249             Main.debug(text + ": " + result + "("+o1+", "+o2+")");
    250                 return result;
    251         }
    252        
    253         protected void findMathTransform(Component parent, boolean findSimiliarCrs) throws FactoryException, UserCancelException, GeoMathTransformException {
    254                 try {
    255                         transform = CRS.findMathTransform(crs, wgs84);
    256                 } catch (OperationNotFoundException e) {
    257                         Main.info(crs.getName()+": "+e.getMessage()); // Bursa wolf parameters required.
    258                        
    259                         if (findSimiliarCrs) {
    260                                 List<CoordinateReferenceSystem> candidates = new ArrayList<>();
    261                                
    262                                 // Find matching CRS with Bursa Wolf parameters in EPSG database
    263                                 for (String code : CRS.getAuthorityFactory(false).getAuthorityCodes(ProjectedCRS.class)) {
    264                                     try {
    265                                         CoordinateReferenceSystem candidate = CRS.decode(code);
    266                                         if (candidate instanceof AbstractCRS && crs instanceof AbstractIdentifiedObject) {
    267                                                
    268                                                 Hints.putSystemDefault(Hints.COMPARISON_TOLERANCE,
    269                                                                 Main.pref.getDouble(OdConstants.PREF_CRS_COMPARISON_TOLERANCE, OdConstants.DEFAULT_CRS_COMPARISON_TOLERANCE));
    270                                                 if (((AbstractCRS)candidate).equals((AbstractIdentifiedObject)crs, false)) {
    271                                                         Main.info("Found a potential CRS: "+candidate.getName());
    272                                                         candidates.add(candidate);
    273                                                 } else if (Main.pref.getBoolean(OdConstants.PREF_CRS_COMPARISON_DEBUG, false)) {
    274                                                         compareDebug(crs, candidate);
    275                                                 }
    276                                                 Hints.removeSystemDefault(Hints.COMPARISON_TOLERANCE);
    277                                         }
    278                                     } catch (FactoryException ex) {
    279                                         // Silently ignore exceptions
    280                                         //System.err.println("Warning: cannot decode "+code+". "+ex.getMessage());
    281                                     }
    282                                 }
    283                                
    284                                 if (candidates.size() > 1) {
    285                                         Main.warn("Found several potential CRS: "+Arrays.toString(candidates.toArray()));
    286                                         // TODO: ask user which one to use
    287                                 }
    288                                
    289                                 if (candidates.size() > 0) {
    290                                         CoordinateReferenceSystem newCRS = candidates.get(0);
    291                                         try {
    292                                                 transform = CRS.findMathTransform(newCRS, wgs84, false);
    293                                         } catch (OperationNotFoundException ex) {
    294                                                 System.err.println(newCRS.getName()+": "+e.getMessage());
    295                                         }
    296                                 }
    297                         }
    298                        
    299                         if (transform == null) {
    300                                 if (handler != null) {
    301                                         // ask handler if it can provide a math transform
    302                                         try {
    303                                                 transform = handler.findMathTransform(crs, wgs84, false);
    304                                         } catch (OperationNotFoundException ex) {
    305                                             Main.warn(crs.getName()+": "+ex.getMessage()); // Bursa wolf parameters required.
    306                                         }
    307                                 } else {
    308                                         // ask default known handlers
    309                                         for (GeographicHandler geoHandler : defaultHandlers) {
    310                                                 try {
    311                                                         if ((transform = geoHandler.findMathTransform(crs, wgs84, false)) != null) {
    312                                                                 break;
    313                                                         }
    314                                                 } catch (OperationNotFoundException ex) {
    315                                                     Main.warn(crs.getName()+": "+ex.getMessage()); // Bursa wolf parameters required.
    316                                                 }
    317                                         }
    318                                 }
    319                                 if (transform == null) {
    320                                         // ask user before trying lenient method, unless in headless mode (unit tests)
    321                                         if (!GraphicsEnvironment.isHeadless() && warnLenientMethod(parent, crs)) {
    322                                                 // User canceled
    323                                                 throw new UserCancelException();
    324                                         }
    325                                         Main.info("Searching for a lenient math transform.");
    326                                         transform = CRS.findMathTransform(crs, wgs84, true);
    327                                 }
    328                         }
    329                 }
    330                 if (transform == null) {
    331                         throw new GeoMathTransformException("Unable to find math transform !");
    332                 }
    333         }
     176        return new DialogPrompter<ExtendedDialog>() {
     177            @Override
     178            protected ExtendedDialog buildDialog() {
     179                final ExtendedDialog dlg = new ExtendedDialog(parent,
     180                        tr("Cannot transform to WGS84"),
     181                        new String[] {tr("Cancel"), tr("Continue")});
     182                dlg.setContent("<html>" +
     183                        tr("JOSM was unable to find a strict mathematical transformation between ''{0}'' and WGS84.<br /><br />"+
     184                                "Do you want to try a <i>lenient</i> method, which will perform a non-precise transformation (<b>with location errors up to 1 km</b>) ?<br/><br/>"+
     185                                "If so, <b>do NOT upload</b> such data to OSM !", crs.getName())+
     186                        "</html>");
     187                dlg.setButtonIcons(new Icon[] {
     188                        ImageProvider.get("cancel"),
     189                        ImageProvider.overlay(
     190                                ImageProvider.get("ok"),
     191                                new ImageIcon(ImageProvider.get("warning-small").getImage().getScaledInstance(10 , 10, Image.SCALE_SMOOTH)),
     192                                ImageProvider.OverlayPosition.SOUTHEAST)});
     193                dlg.setToolTipTexts(new String[] {
     194                        tr("Cancel"),
     195                        tr("Try lenient method")});
     196                dlg.setIcon(JOptionPane.WARNING_MESSAGE);
     197                dlg.setCancelButton(1);
     198                return dlg;
     199            }
     200        }.promptInEdt().getValue() != 2;
     201    }
     202   
     203    private static final void compareDebug(CoordinateReferenceSystem crs1, CoordinateReferenceSystem crs2) {
     204        Main.debug("-- COMPARING "+crs1.getName()+" WITH "+crs2.getName()+" --");
     205        compareDebug("class", crs1.getClass(), crs2.getClass());
     206        CoordinateSystem cs1 = crs1.getCoordinateSystem();
     207        CoordinateSystem cs2 = crs2.getCoordinateSystem();
     208        if (!compareDebug("cs", cs1, cs2)) {
     209            Integer dim1 = cs1.getDimension();
     210            Integer dim2 = cs2.getDimension();
     211            if (compareDebug("cs.dim", dim1, dim2)) {
     212                for (int i = 0; i<dim1; i++) {
     213                    compareDebug("cs.axis"+i, cs1.getAxis(i), cs1.getAxis(i));
     214                }
     215            }
     216        }
     217        if (crs1 instanceof AbstractSingleCRS) {
     218            Datum datum1 = ((AbstractSingleCRS) crs1).getDatum();
     219            Datum datum2 = ((AbstractSingleCRS) crs2).getDatum();
     220            if (!compareDebug("datum", datum1, datum2)) {
     221                AbstractIdentifiedObject adatum1 = (AbstractIdentifiedObject) datum1;
     222                AbstractIdentifiedObject adatum2 = (AbstractIdentifiedObject) datum2;
     223                compareDebug("datum.name1", adatum1.nameMatches(adatum2.getName().getCode()), adatum1.getName(), adatum2.getName());
     224                compareDebug("datum.name2", adatum2.nameMatches(adatum1.getName().getCode()), adatum2.getName(), adatum1.getName());
     225            }
     226            if (crs1 instanceof AbstractDerivedCRS) {
     227                AbstractDerivedCRS adcrs1 = (AbstractDerivedCRS) crs1;
     228                AbstractDerivedCRS adcrs2 = (AbstractDerivedCRS) crs2;
     229                compareDebug("baseCRS", adcrs1.getBaseCRS(), adcrs2.getBaseCRS());
     230                compareDebug("conversionFromBase", adcrs1.getConversionFromBase(), adcrs2.getConversionFromBase());
     231            }
     232        }
     233        Main.debug("-- COMPARING FINISHED --");
     234    }
     235   
     236    private static final boolean compareDebug(String text, Object o1, Object o2) {
     237        return compareDebug(text, o1.equals(o2), o1, o2);
     238    }
     239   
     240    private static final boolean compareDebug(String text, IdentifiedObject o1, IdentifiedObject o2) {
     241        return compareDebug(text, (AbstractIdentifiedObject)o1, (AbstractIdentifiedObject)o2);
     242    }
     243   
     244    private static final boolean compareDebug(String text, AbstractIdentifiedObject o1, AbstractIdentifiedObject o2) {
     245        return compareDebug(text, o1.equals(o2, false), o1, o2);
     246    }
     247
     248    private static final boolean compareDebug(String text, boolean result, Object o1, Object o2) {
     249        Main.debug(text + ": " + result + "("+o1+", "+o2+")");
     250        return result;
     251    }
     252   
     253    protected void findMathTransform(Component parent, boolean findSimiliarCrs) throws FactoryException, UserCancelException, GeoMathTransformException {
     254        try {
     255            transform = CRS.findMathTransform(crs, wgs84);
     256        } catch (OperationNotFoundException e) {
     257            Main.info(crs.getName()+": "+e.getMessage()); // Bursa wolf parameters required.
     258           
     259            if (findSimiliarCrs) {
     260                List<CoordinateReferenceSystem> candidates = new ArrayList<>();
     261               
     262                // Find matching CRS with Bursa Wolf parameters in EPSG database
     263                for (String code : CRS.getAuthorityFactory(false).getAuthorityCodes(ProjectedCRS.class)) {
     264                    try {
     265                        CoordinateReferenceSystem candidate = CRS.decode(code);
     266                        if (candidate instanceof AbstractCRS && crs instanceof AbstractIdentifiedObject) {
     267                           
     268                            Hints.putSystemDefault(Hints.COMPARISON_TOLERANCE,
     269                                    Main.pref.getDouble(OdConstants.PREF_CRS_COMPARISON_TOLERANCE, OdConstants.DEFAULT_CRS_COMPARISON_TOLERANCE));
     270                            if (((AbstractCRS)candidate).equals((AbstractIdentifiedObject)crs, false)) {
     271                                Main.info("Found a potential CRS: "+candidate.getName());
     272                                candidates.add(candidate);
     273                            } else if (Main.pref.getBoolean(OdConstants.PREF_CRS_COMPARISON_DEBUG, false)) {
     274                                compareDebug(crs, candidate);
     275                            }
     276                            Hints.removeSystemDefault(Hints.COMPARISON_TOLERANCE);
     277                        }
     278                    } catch (FactoryException ex) {
     279                        // Silently ignore exceptions
     280                        //System.err.println("Warning: cannot decode "+code+". "+ex.getMessage());
     281                    }
     282                }
     283               
     284                if (candidates.size() > 1) {
     285                    Main.warn("Found several potential CRS: "+Arrays.toString(candidates.toArray()));
     286                    // TODO: ask user which one to use
     287                }
     288               
     289                if (candidates.size() > 0) {
     290                    CoordinateReferenceSystem newCRS = candidates.get(0);
     291                    try {
     292                        transform = CRS.findMathTransform(newCRS, wgs84, false);
     293                    } catch (OperationNotFoundException ex) {
     294                        System.err.println(newCRS.getName()+": "+e.getMessage());
     295                    }
     296                }
     297            }
     298           
     299            if (transform == null) {
     300                if (handler != null) {
     301                    // ask handler if it can provide a math transform
     302                    try {
     303                        transform = handler.findMathTransform(crs, wgs84, false);
     304                    } catch (OperationNotFoundException ex) {
     305                        Main.warn(crs.getName()+": "+ex.getMessage()); // Bursa wolf parameters required.
     306                    }
     307                } else {
     308                    // ask default known handlers
     309                    for (GeographicHandler geoHandler : defaultHandlers) {
     310                        try {
     311                            if ((transform = geoHandler.findMathTransform(crs, wgs84, false)) != null) {
     312                                break;
     313                            }
     314                        } catch (OperationNotFoundException ex) {
     315                            Main.warn(crs.getName()+": "+ex.getMessage()); // Bursa wolf parameters required.
     316                        }
     317                    }
     318                }
     319                if (transform == null) {
     320                    // ask user before trying lenient method, unless in headless mode (unit tests)
     321                    if (!GraphicsEnvironment.isHeadless() && warnLenientMethod(parent, crs)) {
     322                        // User canceled
     323                        throw new UserCancelException();
     324                    }
     325                    Main.info("Searching for a lenient math transform.");
     326                    transform = CRS.findMathTransform(crs, wgs84, true);
     327                }
     328            }
     329        }
     330        if (transform == null) {
     331            throw new GeoMathTransformException("Unable to find math transform !");
     332        }
     333    }
    334334}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/GmlImporter.java

    r30563 r30723  
    1414
    1515public class GmlImporter extends AbstractImporter {
    16        
     16   
    1717    public static final ExtensionFileFilter GML_FILE_FILTER = new ExtensionFileFilter(
    1818            OdConstants.GML_EXT, OdConstants.GML_EXT, tr("GML files") + " (*."+OdConstants.GML_EXT+")");
     
    2222    }
    2323
    24         @Override
    25         protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
    26                         throws IllegalDataException {
    27                 try {
    28                         return GmlReader.parseDataSet(in, handler, instance);
    29                 } catch (Exception e) {
    30                         throw new IllegalDataException(e);
    31                 }
    32         }
     24    @Override
     25    protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
     26            throws IllegalDataException {
     27        try {
     28            return GmlReader.parseDataSet(in, handler, instance);
     29        } catch (Exception e) {
     30            throw new IllegalDataException(e);
     31        }
     32    }
    3333}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/GmlReader.java

    r30568 r30723  
    4848    public static final String GML_POS_LIST = "posList";
    4949
    50         private final GeometryFactory geometryFactory = new GeometryFactory();
     50    private final GeometryFactory geometryFactory = new GeometryFactory();
    5151   
    5252    private final GmlHandler gmlHandler;
    53        
     53   
    5454    private XMLStreamReader parser;
    5555   
     
    5757   
    5858    private final class CrsData {
    59         public CoordinateReferenceSystem crs;
    60         public MathTransform transform;
    61         public int dim;
    62                 public CrsData(CoordinateReferenceSystem crs, MathTransform transform, int dim) {
    63                         this.crs = crs;
    64                         this.transform = transform;
    65                         this.dim = dim;
    66                 }
     59        public CoordinateReferenceSystem crs;
     60        public MathTransform transform;
     61        public int dim;
     62        public CrsData(CoordinateReferenceSystem crs, MathTransform transform, int dim) {
     63            this.crs = crs;
     64            this.transform = transform;
     65            this.dim = dim;
     66        }
    6767    }
    6868
     
    7070   
    7171    public GmlReader(XMLStreamReader parser, GmlHandler handler) {
    72                 super(handler, NationalHandlers.DEFAULT_GML_HANDLERS);
     72        super(handler, NationalHandlers.DEFAULT_GML_HANDLERS);
    7373        this.parser = parser;
    7474        this.gmlHandler = handler;
    7575    }
    7676
    77         public static DataSet parseDataSet(InputStream in, AbstractDataSetHandler handler, ProgressMonitor instance) throws IOException, XMLStreamException {
     77    public static DataSet parseDataSet(InputStream in, AbstractDataSetHandler handler, ProgressMonitor instance) throws IOException, XMLStreamException {
    7878        InputStreamReader ir = UTFInputStreamReader.create(in, OdConstants.UTF8);
    7979        XMLStreamReader parser = XMLInputFactory.newInstance().createXMLStreamReader(ir);
    8080        try {
    81                 return new GmlReader(parser, handler != null ? handler.getGmlHandler() : null).parseDoc(instance);
     81            return new GmlReader(parser, handler != null ? handler.getGmlHandler() : null).parseDoc(instance);
    8282        } catch (Exception e) {
    83                 throw new IOException(e);
     83            throw new IOException(e);
    8484        }
    85         }
    86        
    87         private final boolean isElement(String element) {
    88                 return parser.getLocalName().matches("(gml:)?"+element);
    89         }
     85    }
     86   
     87    private final boolean isElement(String element) {
     88        return parser.getLocalName().matches("(gml:)?"+element);
     89    }
    9090
    91         private DataSet parseDoc(ProgressMonitor instance) throws XMLStreamException, GeoCrsException, FactoryException, GeoMathTransformException, MismatchedDimensionException, TransformException {
    92                 Component parent = instance != null ? instance.getWindowParent() : Main.parent;
    93                 while (parser.hasNext()) {
     91    private DataSet parseDoc(ProgressMonitor instance) throws XMLStreamException, GeoCrsException, FactoryException, GeoMathTransformException, MismatchedDimensionException, TransformException {
     92        Component parent = instance != null ? instance.getWindowParent() : Main.parent;
     93        while (parser.hasNext()) {
    9494            int event = parser.next();
    9595            if (event == XMLStreamConstants.START_ELEMENT) {
    9696                if (isElement(GML_FEATURE_MEMBER)) {
    97                         try {
    98                                                 parseFeatureMember(parent);
    99                                         } catch (UserCancelException e) {
    100                                                 return ds;
    101                                         }
     97                    try {
     98                        parseFeatureMember(parent);
     99                    } catch (UserCancelException e) {
     100                        return ds;
     101                    }
    102102                }
    103103            }
    104                 }
    105                 return ds;
    106         }
    107        
    108         private void findCRS(String srs) throws NoSuchAuthorityCodeException, FactoryException {
    109                 Main.info("Finding CRS for "+srs);
    110                 if (gmlHandler != null) {
    111                         crs = gmlHandler.getCrsFor(srs);
    112                 } else {
    113                         for (GmlHandler h : NationalHandlers.DEFAULT_GML_HANDLERS) {
    114                                 if ((crs = h.getCrsFor(srs)) != null) {
    115                                         return;
    116                                 }
    117                         }
    118                 }
    119         }
    120        
    121         private void parseSrs(Component parent) throws GeoCrsException, FactoryException, UserCancelException, GeoMathTransformException {
    122                 String srs = parser.getAttributeValue(null, GML_SRS_NAME);
    123                 dim = Integer.parseInt(parser.getAttributeValue(null, GML_SRS_DIMENSION));
    124                 CrsData crsData = crsDataMap.get(srs);
    125                 if (crsData == null) {
    126                         try {
    127                         findCRS(srs);
    128                         } catch (NoSuchAuthorityCodeException e) {
    129                                 e.printStackTrace();
    130                         } catch (FactoryException e) {
    131                                 e.printStackTrace();
    132                         }
    133                         if (crs == null) {
    134                                 throw new GeoCrsException("Unable to detect CRS for srs '"+srs+"' !");
    135                         } else {
    136                                 findMathTransform(parent, false);
    137                         }
    138                         crsDataMap.put(srs, new CrsData(crs, transform, dim));
    139                 } else {
    140                         crs = crsData.crs;
    141                         transform = crsData.transform;
    142                         dim = crsData.dim;
    143                 }
    144         }
    145        
    146         private void parseFeatureMember(Component parent) throws XMLStreamException, GeoCrsException, FactoryException, UserCancelException, GeoMathTransformException, MismatchedDimensionException, TransformException {
    147                 List<OsmPrimitive> list = new ArrayList<>();
    148                 Way way = null;
    149                 Node node = null;
    150                 Map<String, String> tags = new HashMap<>();
    151                 while (parser.hasNext()) {
     104        }
     105        return ds;
     106    }
     107   
     108    private void findCRS(String srs) throws NoSuchAuthorityCodeException, FactoryException {
     109        Main.info("Finding CRS for "+srs);
     110        if (gmlHandler != null) {
     111            crs = gmlHandler.getCrsFor(srs);
     112        } else {
     113            for (GmlHandler h : NationalHandlers.DEFAULT_GML_HANDLERS) {
     114                if ((crs = h.getCrsFor(srs)) != null) {
     115                    return;
     116                }
     117            }
     118        }
     119    }
     120   
     121    private void parseSrs(Component parent) throws GeoCrsException, FactoryException, UserCancelException, GeoMathTransformException {
     122        String srs = parser.getAttributeValue(null, GML_SRS_NAME);
     123        dim = Integer.parseInt(parser.getAttributeValue(null, GML_SRS_DIMENSION));
     124        CrsData crsData = crsDataMap.get(srs);
     125        if (crsData == null) {
     126            try {
     127                findCRS(srs);
     128            } catch (NoSuchAuthorityCodeException e) {
     129                e.printStackTrace();
     130            } catch (FactoryException e) {
     131                e.printStackTrace();
     132            }
     133            if (crs == null) {
     134                throw new GeoCrsException("Unable to detect CRS for srs '"+srs+"' !");
     135            } else {
     136                findMathTransform(parent, false);
     137            }
     138            crsDataMap.put(srs, new CrsData(crs, transform, dim));
     139        } else {
     140            crs = crsData.crs;
     141            transform = crsData.transform;
     142            dim = crsData.dim;
     143        }
     144    }
     145   
     146    private void parseFeatureMember(Component parent) throws XMLStreamException, GeoCrsException, FactoryException, UserCancelException, GeoMathTransformException, MismatchedDimensionException, TransformException {
     147        List<OsmPrimitive> list = new ArrayList<>();
     148        Way way = null;
     149        Node node = null;
     150        Map<String, String> tags = new HashMap<>();
     151        while (parser.hasNext()) {
    152152            int event = parser.next();
    153153            if (event == XMLStreamConstants.START_ELEMENT) {
    154                 if (isElement(GML_LINE_STRING)) {
    155                         list.add(way = createWay());
    156                         parseSrs(parent);
    157                 } else if (isElement(GML_LINEAR_RING)) {
    158                         list.add(way = createWay());
    159                 } else if (isElement(GML_SURFACE)) {
    160                         parseSrs(parent);
    161                 } else if (isElement(GML_POS_LIST)) {
    162                         String[] tab = parser.getElementText().split(" ");
    163                         for (int i = 0; i < tab.length; i += dim) {
    164                                 Point p = geometryFactory.createPoint(new Coordinate(Double.valueOf(tab[i]), Double.valueOf(tab[i+1])));
    165                                 node = createOrGetNode(p, dim > 2 && !tab[i+2].equals("0") ? tab[i+2] : null);
    166                                 if (way != null) {
    167                                         way.addNode(node);
    168                                 }
    169                         }
    170                 }
     154                if (isElement(GML_LINE_STRING)) {
     155                    list.add(way = createWay());
     156                    parseSrs(parent);
     157                } else if (isElement(GML_LINEAR_RING)) {
     158                    list.add(way = createWay());
     159                } else if (isElement(GML_SURFACE)) {
     160                    parseSrs(parent);
     161                } else if (isElement(GML_POS_LIST)) {
     162                    String[] tab = parser.getElementText().split(" ");
     163                    for (int i = 0; i < tab.length; i += dim) {
     164                        Point p = geometryFactory.createPoint(new Coordinate(Double.valueOf(tab[i]), Double.valueOf(tab[i+1])));
     165                        node = createOrGetNode(p, dim > 2 && !tab[i+2].equals("0") ? tab[i+2] : null);
     166                        if (way != null) {
     167                            way.addNode(node);
     168                        }
     169                    }
     170                }
    171171            } else if (event == XMLStreamConstants.END_ELEMENT) {
    172172                if (isElement(GML_FEATURE_MEMBER)) {
    173                         break;
     173                    break;
    174174                }
    175175            }
    176                 }
    177                 for (OsmPrimitive p : list) {
    178                         for (String key : tags.keySet()) {
    179                                 p.put(key, tags.get(key));
    180                         }
    181                 }
    182         }
     176        }
     177        for (OsmPrimitive p : list) {
     178            for (String key : tags.keySet()) {
     179                p.put(key, tags.get(key));
     180            }
     181        }
     182    }
    183183}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/KmlKmzImporter.java

    r30563 r30723  
    1414
    1515public class KmlKmzImporter extends AbstractImporter {
    16        
     16   
    1717    public static final ExtensionFileFilter KML_KMZ_FILE_FILTER = new ExtensionFileFilter(
    1818            OdConstants.KML_EXT+","+OdConstants.KMZ_EXT, OdConstants.KMZ_EXT, tr("KML/KMZ files") + " (*."+OdConstants.KML_EXT+",*."+OdConstants.KMZ_EXT+")");
     
    2222    }
    2323
    24         @Override
    25         protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
    26                         throws IllegalDataException {
    27                 try {
    28                         if (file.getName().toLowerCase().endsWith(OdConstants.KML_EXT)) {
    29                                 return KmlReader.parseDataSet(in, instance);
    30                         } else {
    31                                 return KmzReader.parseDataSet(in, instance);
    32                         }
    33                 } catch (Exception e) {
    34                         throw new IllegalDataException(e);
    35                 }
    36         }
     24    @Override
     25    protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
     26            throws IllegalDataException {
     27        try {
     28            if (file.getName().toLowerCase().endsWith(OdConstants.KML_EXT)) {
     29                return KmlReader.parseDataSet(in, instance);
     30            } else {
     31                return KmzReader.parseDataSet(in, instance);
     32            }
     33        } catch (Exception e) {
     34            throw new IllegalDataException(e);
     35        }
     36    }
    3737}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/KmlReader.java

    r30563 r30723  
    3232
    3333    public static final String KML_PLACEMARK   = "Placemark";
    34     public static final String KML_NAME        = "name";
     34    public static final String KML_NAME           = "name";
    3535    public static final String KML_COLOR       = "color";
    3636    public static final String KML_SIMPLE_DATA = "SimpleData";
     
    5151    }
    5252
    53         public static DataSet parseDataSet(InputStream in, ProgressMonitor instance) throws IOException, XMLStreamException, FactoryConfigurationError {
     53    public static DataSet parseDataSet(InputStream in, ProgressMonitor instance) throws IOException, XMLStreamException, FactoryConfigurationError {
    5454        InputStreamReader ir = UTFInputStreamReader.create(in);
    5555        XMLStreamReader parser = XMLInputFactory.newInstance().createXMLStreamReader(ir);
    56             //XMLStreamReader parser = XMLInputFactory.newInstance().createXMLStreamReader(in, UTF8);
     56        //XMLStreamReader parser = XMLInputFactory.newInstance().createXMLStreamReader(in, UTF8);
    5757        return new KmlReader(parser).parseDoc();
    58         }
     58    }
    5959
    60         private DataSet parseDoc() throws XMLStreamException {
    61                 DataSet ds = new DataSet();
    62                 while (parser.hasNext()) {
     60    private DataSet parseDoc() throws XMLStreamException {
     61        DataSet ds = new DataSet();
     62        while (parser.hasNext()) {
    6363            int event = parser.next();
    6464            if (event == XMLStreamConstants.START_ELEMENT) {
    6565                if (parser.getLocalName().equals(KML_PLACEMARK)) {
    66                         parsePlaceMark(ds);
     66                    parsePlaceMark(ds);
    6767                }
    6868            }
    69                 }
    70                 return ds;
    71         }
    72        
    73         private static boolean keyIsIgnored(String key) {
    74                 for (ProjectionPatterns pp : OdConstants.PROJECTIONS) {
    75                         if (pp.getXPattern().matcher(key).matches() || pp.getYPattern().matcher(key).matches()) {
    76                                 return true;
    77                         }
    78                 }
    79                 return false;
    80         }
    81        
    82         private void parsePlaceMark(DataSet ds) throws XMLStreamException {
    83                 List<OsmPrimitive> list = new ArrayList<>();
    84                 Way way = null;
    85                 Node node = null;
    86                 Relation relation = null;
    87                 String role = "";
    88                 Map<String, String> tags = new HashMap<>();
    89                 while (parser.hasNext()) {
     69        }
     70        return ds;
     71    }
     72   
     73    private static boolean keyIsIgnored(String key) {
     74        for (ProjectionPatterns pp : OdConstants.PROJECTIONS) {
     75            if (pp.getXPattern().matcher(key).matches() || pp.getYPattern().matcher(key).matches()) {
     76                return true;
     77            }
     78        }
     79        return false;
     80    }
     81   
     82    private void parsePlaceMark(DataSet ds) throws XMLStreamException {
     83        List<OsmPrimitive> list = new ArrayList<>();
     84        Way way = null;
     85        Node node = null;
     86        Relation relation = null;
     87        String role = "";
     88        Map<String, String> tags = new HashMap<>();
     89        while (parser.hasNext()) {
    9090            int event = parser.next();
    9191            if (event == XMLStreamConstants.START_ELEMENT) {
    92                 if (parser.getLocalName().equals(KML_COLOR)) {
    93                         String s = parser.getElementText();
    94                         // KML color format is aabbggrr, convert it to OSM (web) format: #rrggbb
    95                         String rgbColor = '#'+s.substring(6,8)+s.substring(4,6)+s.substring(2,4);
    96                         tags.put(KML_COLOR, rgbColor);
    97                 } else if (parser.getLocalName().equals(KML_NAME)) {
    98                         tags.put(KML_NAME, parser.getElementText());
    99                 } else if (parser.getLocalName().equals(KML_SIMPLE_DATA)) {
    100                         String key = parser.getAttributeValue(null, "name");
    101                         if (!keyIsIgnored(key)) {
    102                                 tags.put(key, parser.getElementText());
    103                         }
    104                 } else if (parser.getLocalName().equals(KML_POLYGON)) {
    105                         ds.addPrimitive(relation = new Relation());
    106                         relation.put("type", "multipolygon");
    107                         list.add(relation);
    108                 } else if (parser.getLocalName().equals(KML_OUTER_BOUND)) {
    109                         role = "outer";
    110                 } else if (parser.getLocalName().equals(KML_INNER_BOUND)) {
    111                         role = "inner";
    112                 } else if (parser.getLocalName().equals(KML_LINEAR_RING)) {
    113                         if (relation != null) {
    114                                 ds.addPrimitive(way = new Way());
    115                                 relation.addMember(new RelationMember(role, way));
    116                         }
    117                 } else if (parser.getLocalName().equals(KML_LINE_STRING)) {
    118                         ds.addPrimitive(way = new Way());
    119                         list.add(way);
    120                 } else if (parser.getLocalName().equals(KML_COORDINATES)) {
    121                         String[] tab = parser.getElementText().trim().split("\\s");
    122                         for (int i = 0; i < tab.length; i ++) {
    123                                 String[] values = tab[i].split(",");
    124                                 if (values.length >= 2) {
    125                                         LatLon ll = new LatLon(Double.valueOf(values[1]), Double.valueOf(values[0])).getRoundedToOsmPrecisionStrict();
    126                                         node = nodes.get(ll);
    127                                         if (node == null) {
    128                                                 ds.addPrimitive(node = new Node(ll));
    129                                                 nodes.put(ll, node);
    130                                                 if (values.length > 2 && !values[2].equals("0")) {
    131                                                         node.put("ele", values[2]);
    132                                                 }
    133                                         }
    134                                         if (way != null) {
    135                                                 way.addNode(node);
    136                                         }
    137                                 }
    138                         }
    139                 }
     92                if (parser.getLocalName().equals(KML_COLOR)) {
     93                    String s = parser.getElementText();
     94                    // KML color format is aabbggrr, convert it to OSM (web) format: #rrggbb
     95                    String rgbColor = '#'+s.substring(6,8)+s.substring(4,6)+s.substring(2,4);
     96                    tags.put(KML_COLOR, rgbColor);
     97                } else if (parser.getLocalName().equals(KML_NAME)) {
     98                    tags.put(KML_NAME, parser.getElementText());
     99                } else if (parser.getLocalName().equals(KML_SIMPLE_DATA)) {
     100                    String key = parser.getAttributeValue(null, "name");
     101                    if (!keyIsIgnored(key)) {
     102                        tags.put(key, parser.getElementText());
     103                    }
     104                } else if (parser.getLocalName().equals(KML_POLYGON)) {
     105                    ds.addPrimitive(relation = new Relation());
     106                    relation.put("type", "multipolygon");
     107                    list.add(relation);
     108                } else if (parser.getLocalName().equals(KML_OUTER_BOUND)) {
     109                    role = "outer";
     110                } else if (parser.getLocalName().equals(KML_INNER_BOUND)) {
     111                    role = "inner";
     112                } else if (parser.getLocalName().equals(KML_LINEAR_RING)) {
     113                    if (relation != null) {
     114                        ds.addPrimitive(way = new Way());
     115                        relation.addMember(new RelationMember(role, way));
     116                    }
     117                } else if (parser.getLocalName().equals(KML_LINE_STRING)) {
     118                    ds.addPrimitive(way = new Way());
     119                    list.add(way);
     120                } else if (parser.getLocalName().equals(KML_COORDINATES)) {
     121                    String[] tab = parser.getElementText().trim().split("\\s");
     122                    for (int i = 0; i < tab.length; i ++) {
     123                        String[] values = tab[i].split(",");
     124                        if (values.length >= 2) {
     125                            LatLon ll = new LatLon(Double.valueOf(values[1]), Double.valueOf(values[0])).getRoundedToOsmPrecisionStrict();
     126                            node = nodes.get(ll);
     127                            if (node == null) {
     128                                ds.addPrimitive(node = new Node(ll));
     129                                nodes.put(ll, node);
     130                                if (values.length > 2 && !values[2].equals("0")) {
     131                                    node.put("ele", values[2]);
     132                                }
     133                            }
     134                            if (way != null) {
     135                                way.addNode(node);
     136                            }
     137                        }
     138                    }
     139                }
    140140            } else if (event == XMLStreamConstants.END_ELEMENT) {
    141141                if (parser.getLocalName().equals(KML_PLACEMARK)) {
    142                         break;
     142                    break;
    143143                } else if (parser.getLocalName().equals(KML_POINT)) {
    144                         list.add(node);
     144                    list.add(node);
    145145                }
    146146            }
    147                 }
    148                 for (OsmPrimitive p : list) {
    149                         for (String key : tags.keySet()) {
    150                                 p.put(key, tags.get(key));
    151                         }
    152                 }
    153         }
     147        }
     148        for (OsmPrimitive p : list) {
     149            for (String key : tags.keySet()) {
     150                p.put(key, tags.get(key));
     151            }
     152        }
     153    }
    154154}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/KmzReader.java

    r30563 r30723  
    1919public class KmzReader extends AbstractReader {
    2020
    21         private ZipInputStream zis;
     21    private ZipInputStream zis;
    2222   
    2323    public KmzReader(ZipInputStream zis) {
     
    2525    }
    2626
    27         public static DataSet parseDataSet(InputStream in, ProgressMonitor instance) throws IOException, XMLStreamException, FactoryConfigurationError {
    28                 return new KmzReader(new ZipInputStream(in)).parseDoc(instance);
    29         }
     27    public static DataSet parseDataSet(InputStream in, ProgressMonitor instance) throws IOException, XMLStreamException, FactoryConfigurationError {
     28        return new KmzReader(new ZipInputStream(in)).parseDoc(instance);
     29    }
    3030
    31         private DataSet parseDoc(ProgressMonitor instance) throws IOException, XMLStreamException, FactoryConfigurationError  {
    32             ZipEntry entry;
    33             do {
    34                 entry = zis.getNextEntry();
    35                 if (entry == null) {
    36                     Main.warn("No KML file found");
    37                     return null;
    38                 }
    39             } while (!entry.getName().toLowerCase().endsWith(".kml"));
    40                 long size = entry.getSize();
    41                 byte[] buffer;
    42                 if (size > 0) {
     31    private DataSet parseDoc(ProgressMonitor instance) throws IOException, XMLStreamException, FactoryConfigurationError  {
     32        ZipEntry entry;
     33        do {
     34            entry = zis.getNextEntry();
     35            if (entry == null) {
     36                Main.warn("No KML file found");
     37                return null;
     38            }
     39        } while (!entry.getName().toLowerCase().endsWith(".kml"));
     40        long size = entry.getSize();
     41        byte[] buffer;
     42        if (size > 0) {
    4343            buffer = new byte[(int) size];
    4444            int off = 0;
     
    5959            buffer = out.toByteArray();
    6060        }
    61            
    62                 return KmlReader.parseDataSet(new ByteArrayInputStream(buffer), instance);
    63         }
     61       
     62        return KmlReader.parseDataSet(new ByteArrayInputStream(buffer), instance);
     63    }
    6464}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/MifDatum.java

    r30573 r30723  
    1111 */
    1212public enum MifDatum {
    13         Adindan(1, "Ethiopia, Mali, Senegal, Sudan", Clarke_1880),
    14         Afgooye(2, "Somalia", Krassovsky),
    15         Ain_el_Abd_1970(3, "Bahrain Island", International),
    16         Anna_1_Astro_1965(4, "Cocos Islands", Australian_National),
    17         Arc_1950(5, "Botswana, Lesotho, Malawi, Swaziland, Zaire, Zambia, Zimbabwe", Clarke_1880),
    18         Arc_1960(6, "Kenya, Tanzania", Clarke_1880),
    19         Ascension_Island_1958(7, "Ascension Island", International),
    20         Astro_Beacon_E(8, "Iwo Jima Island", International),
    21         Astro_B4_Sorol_Atoll(9, "Tern Island", International),
    22         Astro_DOS_71_4(10, "St. Helena Island", International),
    23         Astronomic_Station_1952(11, "Marcus Island", International),
    24         Australian_Geodetic_1966_AGD_66(12, "Australia and Tasmania Island", Australian_National),
    25         Australian_Geodetic_1984_AGD_84(13, "Australia and Tasmania Island", Australian_National),
    26         Belgium(110, "Belgium", International),
    27         Bellevue_IGN(14, "Efate and Erromango Islands", International),
    28         Bermuda_1957(15, "Bermuda Islands", Clarke_1866),
    29         Bogota_Observatory(16, "Colombia", International),
    30         Campo_Inchauspe(17, "Argentina", International),
     13    Adindan(1, "Ethiopia, Mali, Senegal, Sudan", Clarke_1880),
     14    Afgooye(2, "Somalia", Krassovsky),
     15    Ain_el_Abd_1970(3, "Bahrain Island", International),
     16    Anna_1_Astro_1965(4, "Cocos Islands", Australian_National),
     17    Arc_1950(5, "Botswana, Lesotho, Malawi, Swaziland, Zaire, Zambia, Zimbabwe", Clarke_1880),
     18    Arc_1960(6, "Kenya, Tanzania", Clarke_1880),
     19    Ascension_Island_1958(7, "Ascension Island", International),
     20    Astro_Beacon_E(8, "Iwo Jima Island", International),
     21    Astro_B4_Sorol_Atoll(9, "Tern Island", International),
     22    Astro_DOS_71_4(10, "St. Helena Island", International),
     23    Astronomic_Station_1952(11, "Marcus Island", International),
     24    Australian_Geodetic_1966_AGD_66(12, "Australia and Tasmania Island", Australian_National),
     25    Australian_Geodetic_1984_AGD_84(13, "Australia and Tasmania Island", Australian_National),
     26    Belgium(110, "Belgium", International),
     27    Bellevue_IGN(14, "Efate and Erromango Islands", International),
     28    Bermuda_1957(15, "Bermuda Islands", Clarke_1866),
     29    Bogota_Observatory(16, "Colombia", International),
     30    Campo_Inchauspe(17, "Argentina", International),
    3131    Canton_Astro_1966(18, "Phoenix Islands", International),
    3232    Cape(19, "South Africa", Clarke_1880),
     
    4040    DOS_1968(26, "Gizo Island (New Georgia Islands)", International),
    4141    Easter_Island_1967(27, "Easter Island", International),
    42         European_1950_ED_50(28, "Austria, Belgium, Denmark, Finland, France, Germany, Gibraltar, Greece, Italy, Luxembourg, Netherlands, Norway, Portugal, Spain, Sweden, Switzerland", International),
    43         European_1979_ED_79(29, "Austria, Finland, Netherlands, Norway, Spain, Sweden, Switzerland", International),
    44         European_1987_ED_87(108, "Europe", International),
    45         Gandajika_Base(30, "Republic of Maldives", International),
    46         Geodetic_Datum_1949(31, "New Zealand", International),
    47         Geodetic_Reference_System_1967_GRS_67(32, "Worldwide", GRS_67),
    48         Geodetic_Reference_System_1980_GRS_80(33, "Worldwide", GRS_80),
    49         Guam_1963(34, "Guam Island", Clarke_1866),
    50         GUX_1_Astro(35, "Guadalcanal Island", International),
    51         Hito_XVIII_1963(36, "South Chile (near 53°S)", International),
    52         Hjorsey_1955(37, "Iceland", International),
    53         Hong_Kong_1963(38, "Hong Kong", International),
    54         Hu_Tzu_Shan(39, "Taiwan", International),
    55         Indian_40(40, "Thailand and Vietnam", Everest),
    56         Indian_41(41, "Bangladesh, India, Nepal", Everest),
    57         Ireland_1965(42, "Ireland", Modified_Airy),
    58         ISTS_073_Astro_1969(43, "Diego Garcia", International),
    59         Johnston_Island_1961(44, "Johnston Island", International),
    60         Kandawala(45, "Sri Lanka", Everest),
    61         Kerguelen_Island(46, "Kerguelen Island", International),
    62         Kertau_1948(47, "West Malaysia and Singapore", Modified_Everest),
    63         LC_5_Astro(48, "Cayman Brac Island", Clarke_1866),
    64         Liberia_1964(49, "Liberia", Clarke_1880),
    65         Lisboa_DLx(113, "Portugal", International),
    66         Luzon_50(50, "Philippines (excluding Mindanao Island)", Clarke_1866),
    67         Luzon_51(51, "Mindanao Island", Clarke_1866),
     42    European_1950_ED_50(28, "Austria, Belgium, Denmark, Finland, France, Germany, Gibraltar, Greece, Italy, Luxembourg, Netherlands, Norway, Portugal, Spain, Sweden, Switzerland", International),
     43    European_1979_ED_79(29, "Austria, Finland, Netherlands, Norway, Spain, Sweden, Switzerland", International),
     44    European_1987_ED_87(108, "Europe", International),
     45    Gandajika_Base(30, "Republic of Maldives", International),
     46    Geodetic_Datum_1949(31, "New Zealand", International),
     47    Geodetic_Reference_System_1967_GRS_67(32, "Worldwide", GRS_67),
     48    Geodetic_Reference_System_1980_GRS_80(33, "Worldwide", GRS_80),
     49    Guam_1963(34, "Guam Island", Clarke_1866),
     50    GUX_1_Astro(35, "Guadalcanal Island", International),
     51    Hito_XVIII_1963(36, "South Chile (near 53°S)", International),
     52    Hjorsey_1955(37, "Iceland", International),
     53    Hong_Kong_1963(38, "Hong Kong", International),
     54    Hu_Tzu_Shan(39, "Taiwan", International),
     55    Indian_40(40, "Thailand and Vietnam", Everest),
     56    Indian_41(41, "Bangladesh, India, Nepal", Everest),
     57    Ireland_1965(42, "Ireland", Modified_Airy),
     58    ISTS_073_Astro_1969(43, "Diego Garcia", International),
     59    Johnston_Island_1961(44, "Johnston Island", International),
     60    Kandawala(45, "Sri Lanka", Everest),
     61    Kerguelen_Island(46, "Kerguelen Island", International),
     62    Kertau_1948(47, "West Malaysia and Singapore", Modified_Everest),
     63    LC_5_Astro(48, "Cayman Brac Island", Clarke_1866),
     64    Liberia_1964(49, "Liberia", Clarke_1880),
     65    Lisboa_DLx(113, "Portugal", International),
     66    Luzon_50(50, "Philippines (excluding Mindanao Island)", Clarke_1866),
     67    Luzon_51(51, "Mindanao Island", Clarke_1866),
    6868    Mahe_1971(52, "Mahe Island", Clarke_1880),
    6969    Marco_Astro(53, "Salvage Islands", International),
     
    7878    Naparima_BWI(61, "Trinidad and Tobago", International),
    7979    Netherlands(109, "Netherlands", Bessel),
    80         North_American_1927_NAD_27_CONTINENTAL(62, "Continental US", Clarke_1866),
    81         North_American_1927_NAD_27_ALASKA(63, "Alaska", Clarke_1866),
    82         North_American_1927_NAD_27_BAHAMAS(64, "Bahamas (excluding San Salvador Island)", Clarke_1866),
    83         North_American_1927_NAD_27_SAN_SALVADOR(65, "San Salvador Island", Clarke_1866),
    84         North_American_1927_NAD_27_CANADA(66, "Canada (including Newfoundland Island)", Clarke_1866),
    85         North_American_1927_NAD_27_CANAL_ZONE(67, "Canal Zone", Clarke_1866),
    86         North_American_1927_NAD_27_CARIBBEAN(68, "Caribbean (Turks and Caicos Islands)", Clarke_1866),
    87         North_American_1927_NAD_27_CENTRAL_AMERICA(69, "Central America (Belize, Costa Rica, El Salvador, Guatemala, Honduras, Nicaragua)", Clarke_1866),
    88         North_American_1927_NAD_27_CUBA(70, "Cuba", Clarke_1866),
    89         North_American_1927_NAD_27_GREENLAND(71, "Greenland (Hayes Peninsula)", Clarke_1866),
    90         North_American_1927_NAD_27_MEXICO(72, "Mexico", Clarke_1866),
    91         North_American_1927_NAD_27_MICHIGAN(73, "Michigan (used only for State Plane Coordinate System 1927)", Modified_Clarke_1866),
    92         North_American_1983_NAD_83(74, "Alaska, Canada, Central America, Continental US, Mexico", GRS_80),
    93         Nouvelle_Triangulation_Francaise_NTF(107, "France", Clarke_1880),
    94         Nouvelle_Triangulation_Francaise_NTF_Greenwich_Prime_Meridian(1002, "France", Clarke_1880),
    95         NWGL_10(111, "Worldwide", WGS_72),
     80    North_American_1927_NAD_27_CONTINENTAL(62, "Continental US", Clarke_1866),
     81    North_American_1927_NAD_27_ALASKA(63, "Alaska", Clarke_1866),
     82    North_American_1927_NAD_27_BAHAMAS(64, "Bahamas (excluding San Salvador Island)", Clarke_1866),
     83    North_American_1927_NAD_27_SAN_SALVADOR(65, "San Salvador Island", Clarke_1866),
     84    North_American_1927_NAD_27_CANADA(66, "Canada (including Newfoundland Island)", Clarke_1866),
     85    North_American_1927_NAD_27_CANAL_ZONE(67, "Canal Zone", Clarke_1866),
     86    North_American_1927_NAD_27_CARIBBEAN(68, "Caribbean (Turks and Caicos Islands)", Clarke_1866),
     87    North_American_1927_NAD_27_CENTRAL_AMERICA(69, "Central America (Belize, Costa Rica, El Salvador, Guatemala, Honduras, Nicaragua)", Clarke_1866),
     88    North_American_1927_NAD_27_CUBA(70, "Cuba", Clarke_1866),
     89    North_American_1927_NAD_27_GREENLAND(71, "Greenland (Hayes Peninsula)", Clarke_1866),
     90    North_American_1927_NAD_27_MEXICO(72, "Mexico", Clarke_1866),
     91    North_American_1927_NAD_27_MICHIGAN(73, "Michigan (used only for State Plane Coordinate System 1927)", Modified_Clarke_1866),
     92    North_American_1983_NAD_83(74, "Alaska, Canada, Central America, Continental US, Mexico", GRS_80),
     93    Nouvelle_Triangulation_Francaise_NTF(107, "France", Clarke_1880),
     94    Nouvelle_Triangulation_Francaise_NTF_Greenwich_Prime_Meridian(1002, "France", Clarke_1880),
     95    NWGL_10(111, "Worldwide", WGS_72),
    9696    Observatorio_1966(75, "Corvo and Flores Islands (Azores)", International),
    9797    Old_Egyptian(76, "Egypt", Helmert_1906),
     
    125125    Tristan_Astro_1968(98, "Tristan da Cunha", International),
    126126    Viti_Levu_1916(99, "Viti Levu Island (Fiji Islands)", Clarke_1880),
    127         Wake_Eniwetok_1960(100, "", Hough),
    128         World_Geodetic_System_1960_WGS_60(101, "", WGS_60),
    129         World_Geodetic_System_1966_WGS_66(102, "", WGS_66),
    130         World_Geodetic_System_1972_WGS_72(103, "", WGS_72),
    131         World_Geodetic_System_1984_WGS_84(104, "", WGS_84),
    132         Yacare(105, "", International),
    133         Zanderij(106, "", International),
    134         Custom(999, null, null);
    135        
    136         private final Integer code;
     127    Wake_Eniwetok_1960(100, "", Hough),
     128    World_Geodetic_System_1960_WGS_60(101, "", WGS_60),
     129    World_Geodetic_System_1966_WGS_66(102, "", WGS_66),
     130    World_Geodetic_System_1972_WGS_72(103, "", WGS_72),
     131    World_Geodetic_System_1984_WGS_84(104, "", WGS_84),
     132    Yacare(105, "", International),
     133    Zanderij(106, "", International),
     134    Custom(999, null, null);
     135   
     136    private final Integer code;
    137137    private final String area;
    138         private final MifEllipsoid ellipsoid;
    139         private MifDatum(Integer code, String area, MifEllipsoid ellipsoid) {
    140                 this.code = code;
    141                 this.area = area;
    142                 this.ellipsoid = ellipsoid;
    143         }
    144         public final Integer getCode() {
    145                 return code;
    146         }
     138    private final MifEllipsoid ellipsoid;
     139    private MifDatum(Integer code, String area, MifEllipsoid ellipsoid) {
     140        this.code = code;
     141        this.area = area;
     142        this.ellipsoid = ellipsoid;
     143    }
     144    public final Integer getCode() {
     145        return code;
     146    }
    147147    public final String getArea() {
    148148        return area;
    149149    }
    150         public final MifEllipsoid getEllipsoid() {
    151                 return ellipsoid;
    152         }
    153         public static MifDatum forCode(Integer code) {
    154                 for (MifDatum p : values()) {
    155                         if (p.getCode().equals(code)) {
    156                                 return p;
    157                         }
    158                 }
    159                 return null;
    160         }
     150    public final MifEllipsoid getEllipsoid() {
     151        return ellipsoid;
     152    }
     153    public static MifDatum forCode(Integer code) {
     154        for (MifDatum p : values()) {
     155            if (p.getCode().equals(code)) {
     156                return p;
     157            }
     158        }
     159        return null;
     160    }
    161161}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/MifEllipsoid.java

    r30573 r30723  
    99 */
    1010public enum MifEllipsoid {
    11         Airy,
    12         Modified_Airy,
    13         Australian_National,
    14         Bessel,
    15         Bessel_1841,
    16         Clarke_1866,
    17         Modified_Clarke_1866,
    18         Clarke_1880,
    19         Modified_Clarke_1880,
    20         Everest,
    21         Modified_Fischer_1960,
    22         Helmert_1906,
    23         Hough,
    24         Modified_Everest,
    25         GRS_67,
    26         GRS_80,
    27         International,
    28         Krassovsky,
    29         South_American_1969,
    30         WGS_60,
    31         WGS_66,
    32         WGS_72,
    33         WGS_84
     11    Airy,
     12    Modified_Airy,
     13    Australian_National,
     14    Bessel,
     15    Bessel_1841,
     16    Clarke_1866,
     17    Modified_Clarke_1866,
     18    Clarke_1880,
     19    Modified_Clarke_1880,
     20    Everest,
     21    Modified_Fischer_1960,
     22    Helmert_1906,
     23    Hough,
     24    Modified_Everest,
     25    GRS_67,
     26    GRS_80,
     27    International,
     28    Krassovsky,
     29    South_American_1969,
     30    WGS_60,
     31    WGS_66,
     32    WGS_72,
     33    WGS_84
    3434}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/MifProjection.java

    r30573 r30723  
    99 */
    1010public enum MifProjection {
    11         Albers_Equal_Area_Conic(9, "aea"),
    12         Azimuthal_Equidistant_polar_aspect_only(5, "aeqd"),
    13         Cylindrical_Equal_Area(2, "cea"),
    14         Eckert_IV(14, "eck4"),
    15         Eckert_VI(15, "eck6"),
    16         Equidistant_Conic_also_known_as_Simple_Conic(6, "eqdc"),
    17         Gall(17, "gall"),
    18         Hotine_Oblique_Mercator(7, "omerc"),
    19         Lambert_Azimuthal_Equal_Area_polar_aspect_only(4, "laea"),
    20         Lambert_Conformal_Conic(3, "lcc"),
    21         Lambert_Conformal_Conic_modified_for_Belgium_1972(19, "lcca"),
    22         Longitude_Latitude(1, "lonlat"),
    23         Mercator(10, "merc"),
    24         Miller_Cylindrical(11, "mill"),
    25         New_Zealand_Map_Grid(18, "nzmg"),
    26         Mollweide(13, "moll"),
    27         Polyconic(27, "poly"),
    28         Regional_Mercator(26, "merc"),
    29         Robinson(12, "robin"),
    30         Sinusoidal(16, "sinu"),
    31         Stereographic(20, "stere"),
    32         Swiss_Oblique_Mercator(25, "somerc"),
    33         Transverse_Mercator_also_known_as_Gauss_Kruger(8, "tmerc"),
    34         Transverse_Mercator_modified_for_Danish_System_34_Jylland_Fyn(21, "tmerc"),
    35         Transverse_Mercator_modified_for_Sjaelland(22, "tmerc"),
    36         Transverse_Mercator_modified_for_Danish_System_45_Bornholm(23, "tmerc"),
    37         Transverse_Mercator_modified_for_Finnish_KKJ(24, "tmerc");
    38        
    39         private final Integer code;
    40         private final String proj4id;
    41        
    42         private MifProjection(Integer code, String proj4id) {
    43                 this.code = code;
    44                 this.proj4id = proj4id;
    45         }
    46        
    47         public final Integer getCode() {
    48                 return code;
    49         }
     11    Albers_Equal_Area_Conic(9, "aea"),
     12    Azimuthal_Equidistant_polar_aspect_only(5, "aeqd"),
     13    Cylindrical_Equal_Area(2, "cea"),
     14    Eckert_IV(14, "eck4"),
     15    Eckert_VI(15, "eck6"),
     16    Equidistant_Conic_also_known_as_Simple_Conic(6, "eqdc"),
     17    Gall(17, "gall"),
     18    Hotine_Oblique_Mercator(7, "omerc"),
     19    Lambert_Azimuthal_Equal_Area_polar_aspect_only(4, "laea"),
     20    Lambert_Conformal_Conic(3, "lcc"),
     21    Lambert_Conformal_Conic_modified_for_Belgium_1972(19, "lcca"),
     22    Longitude_Latitude(1, "lonlat"),
     23    Mercator(10, "merc"),
     24    Miller_Cylindrical(11, "mill"),
     25    New_Zealand_Map_Grid(18, "nzmg"),
     26    Mollweide(13, "moll"),
     27    Polyconic(27, "poly"),
     28    Regional_Mercator(26, "merc"),
     29    Robinson(12, "robin"),
     30    Sinusoidal(16, "sinu"),
     31    Stereographic(20, "stere"),
     32    Swiss_Oblique_Mercator(25, "somerc"),
     33    Transverse_Mercator_also_known_as_Gauss_Kruger(8, "tmerc"),
     34    Transverse_Mercator_modified_for_Danish_System_34_Jylland_Fyn(21, "tmerc"),
     35    Transverse_Mercator_modified_for_Sjaelland(22, "tmerc"),
     36    Transverse_Mercator_modified_for_Danish_System_45_Bornholm(23, "tmerc"),
     37    Transverse_Mercator_modified_for_Finnish_KKJ(24, "tmerc");
    5038   
    51         /**
     39    private final Integer code;
     40    private final String proj4id;
     41   
     42    private MifProjection(Integer code, String proj4id) {
     43        this.code = code;
     44        this.proj4id = proj4id;
     45    }
     46   
     47    public final Integer getCode() {
     48        return code;
     49    }
     50   
     51    /**
    5252     * Replies the Proj.4 identifier.
    5353     *
     
    5959    }
    6060   
    61         public static MifProjection forCode(Integer code) {
    62                 for (MifProjection p : values()) {
    63                         if (p.getCode().equals(code)) {
    64                                 return p;
    65                         }
    66                 }
    67                 return null;
    68         }
     61    public static MifProjection forCode(Integer code) {
     62        for (MifProjection p : values()) {
     63            if (p.getCode().equals(code)) {
     64                return p;
     65            }
     66        }
     67        return null;
     68    }
    6969}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/MifTabImporter.java

    r30563 r30723  
    1515
    1616public class MifTabImporter extends AbstractImporter {
    17        
     17   
    1818    public static final ExtensionFileFilter MIF_TAB_FILE_FILTER = new ExtensionFileFilter(
    1919            OdConstants.MIF_EXT+","+OdConstants.TAB_EXT, OdConstants.MIF_EXT, tr("MapInfo files") + " (*."+OdConstants.MIF_EXT+",*."+OdConstants.TAB_EXT+")");
     
    2323    }
    2424
    25         @Override
    26         protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
    27                         throws IllegalDataException {
    28                 try {
    29                         if (file.getName().toLowerCase().endsWith(OdConstants.MIF_EXT)) {
    30                                 return MifReader.parseDataSet(in, file, handler, instance);
    31                         } else {
    32                                 return TabReader.parseDataSet(in, file, handler, instance);
    33                         }
    34                 } catch (IOException e) {
    35                         throw new IllegalDataException(e);
    36                 }
    37         }
     25    @Override
     26    protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
     27            throws IllegalDataException {
     28        try {
     29            if (file.getName().toLowerCase().endsWith(OdConstants.MIF_EXT)) {
     30                return MifReader.parseDataSet(in, file, handler, instance);
     31            } else {
     32                return TabReader.parseDataSet(in, file, handler, instance);
     33            }
     34        } catch (IOException e) {
     35            throw new IllegalDataException(e);
     36        }
     37    }
    3838}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/MifUnit.java

    r30573 r30723  
    99 */
    1010public enum MifUnit {
    11         Centimeters(6),
    12         Chains(31),
    13         Feet(3),
    14         Inches(2),
    15         Kilometers(1),
    16         Links(30),
    17         Meters(7),
    18         Miles(0),
    19         Millimeters(5),
    20         Nautical_Miles(9),
    21         Rods(32),
    22         US_Survey_Feet(8),
    23         Yards(4);
    24                
    25         private final Integer code;
    26         private MifUnit(Integer code) {
    27                 this.code = code;
    28         }
    29         public final Integer getCode() {
    30                 return code;
    31         }
    32         public static MifUnit forCode(Integer code) {
    33                 for (MifUnit p : values()) {
    34                         if (p.getCode().equals(code)) {
    35                                 return p;
    36                         }
    37                 }
    38                 return null;
    39         }
     11    Centimeters(6),
     12    Chains(31),
     13    Feet(3),
     14    Inches(2),
     15    Kilometers(1),
     16    Links(30),
     17    Meters(7),
     18    Miles(0),
     19    Millimeters(5),
     20    Nautical_Miles(9),
     21    Rods(32),
     22    US_Survey_Feet(8),
     23    Yards(4);
     24       
     25    private final Integer code;
     26    private MifUnit(Integer code) {
     27        this.code = code;
     28    }
     29    public final Integer getCode() {
     30        return code;
     31    }
     32    public static MifUnit forCode(Integer code) {
     33        for (MifUnit p : values()) {
     34            if (p.getCode().equals(code)) {
     35                return p;
     36            }
     37        }
     38        return null;
     39    }
    4040}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/ShpHandler.java

    r30340 r30723  
    1010public interface ShpHandler extends GeographicHandler {
    1111
    12         public void notifyFeatureParsed(Object feature, DataSet result, Set<OsmPrimitive> featurePrimitives);
     12    public void notifyFeatureParsed(Object feature, DataSet result, Set<OsmPrimitive> featurePrimitives);
    1313
    14         public void setDbfCharset(Charset charset);
    15        
    16         public Charset getDbfCharset();
     14    public void setDbfCharset(Charset charset);
     15   
     16    public Charset getDbfCharset();
    1717}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/ShpImporter.java

    r30563 r30723  
    1515
    1616public class ShpImporter extends AbstractImporter {
    17        
     17   
    1818    public static final ExtensionFileFilter SHP_FILE_FILTER = new ExtensionFileFilter(
    1919            OdConstants.SHP_EXT, OdConstants.SHP_EXT, tr("Shapefiles") + " (*."+OdConstants.SHP_EXT+")");
     
    2323    }
    2424
    25         @Override
    26         protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
    27                         throws IllegalDataException {
    28                 try {
    29                         return ShpReader.parseDataSet(in, file, handler, instance);
    30                 } catch (IOException e) {
    31                         throw new IllegalDataException(e);
    32                 }
    33         }
     25    @Override
     26    protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
     27            throws IllegalDataException {
     28        try {
     29            return ShpReader.parseDataSet(in, file, handler, instance);
     30        } catch (IOException e) {
     31            throw new IllegalDataException(e);
     32        }
     33    }
    3434}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/ShpReader.java

    r30568 r30723  
    5757public class ShpReader extends GeographicReader {
    5858
    59         private final ShpHandler handler;
    60         private final Set<OsmPrimitive> featurePrimitives = new HashSet<>();
    61        
    62         public ShpReader(ShpHandler handler) {
    63                 super(handler, NationalHandlers.DEFAULT_SHP_HANDLERS);
    64                 this.handler = handler;
    65         }
    66 
    67         public static DataSet parseDataSet(InputStream in, File file,
    68                         AbstractDataSetHandler handler, ProgressMonitor instance) throws IOException {
    69                 if (in != null) {
    70                         in.close();
    71                 }
    72                 try {
    73                         return new ShpReader(handler != null ? handler.getShpHandler() : null).parse(file, instance);
    74                 } catch (IOException e) {
    75                         throw e;
    76                 } catch (Throwable t) {
    77                         throw new IOException(t);
    78                 }
    79         }
    80        
    81         private void parseFeature(Feature feature, final Component parent)
    82                         throws UserCancelException, GeoMathTransformException, FactoryException, GeoCrsException, MismatchedDimensionException, TransformException {
    83                 featurePrimitives.clear();
    84                 GeometryAttribute geometry = feature.getDefaultGeometryProperty();
    85                 if (geometry != null) {
    86 
    87                         GeometryDescriptor desc = geometry.getDescriptor();
    88                        
    89                         if (crs == null) {
    90                         if (desc != null && desc.getCoordinateReferenceSystem() != null) {
    91                                 crs = desc.getCoordinateReferenceSystem();
    92                         } else if (!GraphicsEnvironment.isHeadless()) {
    93                             GuiHelper.runInEDTAndWait(new Runnable() {
     59    private final ShpHandler handler;
     60    private final Set<OsmPrimitive> featurePrimitives = new HashSet<>();
     61   
     62    public ShpReader(ShpHandler handler) {
     63        super(handler, NationalHandlers.DEFAULT_SHP_HANDLERS);
     64        this.handler = handler;
     65    }
     66
     67    public static DataSet parseDataSet(InputStream in, File file,
     68            AbstractDataSetHandler handler, ProgressMonitor instance) throws IOException {
     69        if (in != null) {
     70            in.close();
     71        }
     72        try {
     73            return new ShpReader(handler != null ? handler.getShpHandler() : null).parse(file, instance);
     74        } catch (IOException e) {
     75            throw e;
     76        } catch (Throwable t) {
     77            throw new IOException(t);
     78        }
     79    }
     80   
     81    private void parseFeature(Feature feature, final Component parent)
     82            throws UserCancelException, GeoMathTransformException, FactoryException, GeoCrsException, MismatchedDimensionException, TransformException {
     83        featurePrimitives.clear();
     84        GeometryAttribute geometry = feature.getDefaultGeometryProperty();
     85        if (geometry != null) {
     86
     87            GeometryDescriptor desc = geometry.getDescriptor();
     88           
     89            if (crs == null) {
     90                if (desc != null && desc.getCoordinateReferenceSystem() != null) {
     91                    crs = desc.getCoordinateReferenceSystem();
     92                } else if (!GraphicsEnvironment.isHeadless()) {
     93                    GuiHelper.runInEDTAndWait(new Runnable() {
    9494                        @Override
    9595                        public void run() {
     
    104104                        }
    105105                    });
    106                         } else {
    107                             // Always use WGS84 in headless mode (used for unit tests only)
    108                             crs = wgs84;
    109                         }
     106                } else {
     107                    // Always use WGS84 in headless mode (used for unit tests only)
     108                    crs = wgs84;
     109                }
    110110                if (crs != null) {
    111111                    findMathTransform(parent, true);
     
    113113                    throw new GeoCrsException(tr("Unable to detect CRS !"));
    114114                }
    115                         }
    116                        
    117                         OsmPrimitive primitive = null;
    118                        
    119                         if (geometry.getValue() instanceof Point) {
    120                                 primitive = createOrGetEmptyNode((Point) geometry.getValue());
    121                                
    122                         } else if (geometry.getValue() instanceof GeometryCollection) { // Deals with both MultiLineString and MultiPolygon
    123                                 GeometryCollection mp = (GeometryCollection) geometry.getValue();
    124                                 int nGeometries = mp.getNumGeometries();
    125                                 if (nGeometries < 1) {
    126                                         System.err.println("Error: empty geometry collection found");
    127                                 } else {
    128                                         Relation r = null;
    129                                         Way w = null;
    130                                        
    131                                         for (int i=0; i<nGeometries; i++) {
    132                                                 Geometry g = mp.getGeometryN(i);
    133                                                 if (g instanceof Polygon) {
    134                                                         Polygon p = (Polygon) g;
    135                                                         // Do not create relation if there's only one polygon without interior ring
    136                                                         // except if handler prefers it
    137                                                         if (r == null && (nGeometries > 1 || p.getNumInteriorRing() > 0 || (handler != null && handler.preferMultipolygonToSimpleWay()))) {
    138                                                                 r = createMultipolygon();
    139                                                         }
    140                                                         w = createWay(p.getExteriorRing());
    141                                                         if (r != null) {
    142                                                                 addWayToMp(r, "outer", w);
    143                                                                 for (int j=0; j<p.getNumInteriorRing(); j++) {
    144                                                                         addWayToMp(r, "inner", createWay(p.getInteriorRingN(j)));
    145                                                                 }
    146                                                         }
    147                                                 } else if (g instanceof LineString) {
    148                                                         w = createWay((LineString) g);
    149                                                 } else if (g instanceof Point) {
    150                                                         // Some belgian data sets hold points into collections ?!
    151                                                         readNonGeometricAttributes(feature, createOrGetNode((Point) g));
    152                                                 } else {
    153                                                         System.err.println("Error: unsupported geometry : "+g);
    154                                                 }
    155                                         }
    156                                         primitive = r != null ? r : w;
    157                                 }
    158                         } else {
    159                                 // Debug unknown geometry
    160                                 Main.debug("\ttype: "+geometry.getType());
    161                                 Main.debug("\tbounds: "+geometry.getBounds());
    162                                 Main.debug("\tdescriptor: "+desc);
    163                                 Main.debug("\tname: "+geometry.getName());
    164                                 Main.debug("\tvalue: "+geometry.getValue());
    165                                 Main.debug("\tid: "+geometry.getIdentifier());
    166                                 Main.debug("-------------------------------------------------------------");
    167                         }
    168                        
    169                         if (primitive != null) {
    170                                 // Read primitive non geometric attributes
    171                                 readNonGeometricAttributes(feature, primitive);
    172                         }
    173                 }
    174         }
    175 
    176         public DataSet parse(File file, ProgressMonitor instance) throws IOException {
    177                 crs = null;
    178                 transform = null;
    179                 try {
    180                         if (file != null) {
    181                         Map<String, Serializable> params = new HashMap<>();
    182                         Charset charset = null;
    183                         params.put(ShapefileDataStoreFactory.URLP.key, file.toURI().toURL());
    184                         if (handler != null && handler.getDbfCharset() != null) {
    185                             charset = handler.getDbfCharset();
    186                         } else {
    187                             String path = file.getAbsolutePath();
    188                             // See http://gis.stackexchange.com/a/3663/17245
    189                             path = path.substring(0, path.lastIndexOf('.')) + ".cpg";
     115            }
     116           
     117            OsmPrimitive primitive = null;
     118           
     119            if (geometry.getValue() instanceof Point) {
     120                primitive = createOrGetEmptyNode((Point) geometry.getValue());
     121               
     122            } else if (geometry.getValue() instanceof GeometryCollection) { // Deals with both MultiLineString and MultiPolygon
     123                GeometryCollection mp = (GeometryCollection) geometry.getValue();
     124                int nGeometries = mp.getNumGeometries();
     125                if (nGeometries < 1) {
     126                    System.err.println("Error: empty geometry collection found");
     127                } else {
     128                    Relation r = null;
     129                    Way w = null;
     130                   
     131                    for (int i=0; i<nGeometries; i++) {
     132                        Geometry g = mp.getGeometryN(i);
     133                        if (g instanceof Polygon) {
     134                            Polygon p = (Polygon) g;
     135                            // Do not create relation if there's only one polygon without interior ring
     136                            // except if handler prefers it
     137                            if (r == null && (nGeometries > 1 || p.getNumInteriorRing() > 0 || (handler != null && handler.preferMultipolygonToSimpleWay()))) {
     138                                r = createMultipolygon();
     139                            }
     140                            w = createWay(p.getExteriorRing());
     141                            if (r != null) {
     142                                addWayToMp(r, "outer", w);
     143                                for (int j=0; j<p.getNumInteriorRing(); j++) {
     144                                    addWayToMp(r, "inner", createWay(p.getInteriorRingN(j)));
     145                                }
     146                            }
     147                        } else if (g instanceof LineString) {
     148                            w = createWay((LineString) g);
     149                        } else if (g instanceof Point) {
     150                            // Some belgian data sets hold points into collections ?!
     151                            readNonGeometricAttributes(feature, createOrGetNode((Point) g));
     152                        } else {
     153                            System.err.println("Error: unsupported geometry : "+g);
     154                        }
     155                    }
     156                    primitive = r != null ? r : w;
     157                }
     158            } else {
     159                // Debug unknown geometry
     160                Main.debug("\ttype: "+geometry.getType());
     161                Main.debug("\tbounds: "+geometry.getBounds());
     162                Main.debug("\tdescriptor: "+desc);
     163                Main.debug("\tname: "+geometry.getName());
     164                Main.debug("\tvalue: "+geometry.getValue());
     165                Main.debug("\tid: "+geometry.getIdentifier());
     166                Main.debug("-------------------------------------------------------------");
     167            }
     168           
     169            if (primitive != null) {
     170                // Read primitive non geometric attributes
     171                readNonGeometricAttributes(feature, primitive);
     172            }
     173        }
     174    }
     175
     176    public DataSet parse(File file, ProgressMonitor instance) throws IOException {
     177        crs = null;
     178        transform = null;
     179        try {
     180            if (file != null) {
     181                Map<String, Serializable> params = new HashMap<>();
     182                Charset charset = null;
     183                params.put(ShapefileDataStoreFactory.URLP.key, file.toURI().toURL());
     184                if (handler != null && handler.getDbfCharset() != null) {
     185                    charset = handler.getDbfCharset();
     186                } else {
     187                    String path = file.getAbsolutePath();
     188                    // See http://gis.stackexchange.com/a/3663/17245
     189                    path = path.substring(0, path.lastIndexOf('.')) + ".cpg";
    190190                    Path cpg = new File(path).toPath();
    191                             if (Files.exists(cpg)) {
    192                                 try (BufferedReader reader = Files.newBufferedReader(cpg, StandardCharsets.UTF_8)) {
    193                                     charset = Charset.forName(reader.readLine());
     191                    if (Files.exists(cpg)) {
     192                        try (BufferedReader reader = Files.newBufferedReader(cpg, StandardCharsets.UTF_8)) {
     193                            charset = Charset.forName(reader.readLine());
    194194                        } catch (IOException | UnsupportedCharsetException | IllegalCharsetNameException e) {
    195195                            Main.warn(e);
    196196                        }
    197                             }
    198                         }
    199                         if (charset != null) {
    200                             Main.info("Using charset "+charset);
    201                             params.put(ShapefileDataStoreFactory.DBFCHARSET.key, charset.name());
    202                         }
    203                                 DataStore dataStore = new ShapefileDataStoreFactory().createDataStore(params);
    204                                 if (dataStore == null) {
    205                                         throw new IOException(tr("Unable to find a data store for file {0}", file.getName()));
    206                                 }
    207                                
    208                                 String[] typeNames = dataStore.getTypeNames();
    209                                 String typeName = typeNames[0];
    210        
    211                                 FeatureSource<?,?> featureSource = dataStore.getFeatureSource(typeName);
    212                                 FeatureCollection<?,?> collection = featureSource.getFeatures();
    213                                 FeatureIterator<?> iterator = collection.features();
    214                                
    215                                 if (instance != null) {
    216                                         instance.beginTask(tr("Loading shapefile ({0} features)", collection.size()), collection.size());
    217                                 }
    218                                
    219                                 int n = 0;
    220                                
    221                                 Component parent = instance != null ? instance.getWindowParent() : Main.parent;
    222                                
    223                                 try {
    224                                         while (iterator.hasNext()) {
    225                                                 n++;
    226                                                 try {
    227                                                         Feature feature = iterator.next();
    228                                                         parseFeature(feature, parent);
    229                                                         if (handler != null) {
    230                                                                 handler.notifyFeatureParsed(feature, ds, featurePrimitives);
    231                                                         }
    232                                                 } catch (UserCancelException e) {
     197                    }
     198                }
     199                if (charset != null) {
     200                    Main.info("Using charset "+charset);
     201                    params.put(ShapefileDataStoreFactory.DBFCHARSET.key, charset.name());
     202                }
     203                DataStore dataStore = new ShapefileDataStoreFactory().createDataStore(params);
     204                if (dataStore == null) {
     205                    throw new IOException(tr("Unable to find a data store for file {0}", file.getName()));
     206                }
     207               
     208                String[] typeNames = dataStore.getTypeNames();
     209                String typeName = typeNames[0];
     210   
     211                FeatureSource<?,?> featureSource = dataStore.getFeatureSource(typeName);
     212                FeatureCollection<?,?> collection = featureSource.getFeatures();
     213                FeatureIterator<?> iterator = collection.features();
     214               
     215                if (instance != null) {
     216                    instance.beginTask(tr("Loading shapefile ({0} features)", collection.size()), collection.size());
     217                }
     218               
     219                int n = 0;
     220               
     221                Component parent = instance != null ? instance.getWindowParent() : Main.parent;
     222               
     223                try {
     224                    while (iterator.hasNext()) {
     225                        n++;
     226                        try {
     227                            Feature feature = iterator.next();
     228                            parseFeature(feature, parent);
     229                            if (handler != null) {
     230                                handler.notifyFeatureParsed(feature, ds, featurePrimitives);
     231                            }
     232                        } catch (UserCancelException e) {
    233233                            e.printStackTrace();
    234                                                         return ds;
    235                                                 }
    236                                                 if (instance != null) {
    237                                                         instance.worked(1);
    238                                                         instance.setCustomText(n+"/"+collection.size());
    239                                                 }
    240                                         }
    241                                 } catch (Throwable e) {
     234                            return ds;
     235                        }
     236                        if (instance != null) {
     237                            instance.worked(1);
     238                            instance.setCustomText(n+"/"+collection.size());
     239                        }
     240                    }
     241                } catch (Throwable e) {
    242242                    e.printStackTrace();
    243                                 } finally {
    244                                         iterator.close();
    245                                         nodes.clear();
    246                                         if (instance != null) {
    247                                                 instance.setCustomText(null);
    248                                         }
    249                                 }
    250                         }
    251                 } catch (IOException e) {
     243                } finally {
     244                    iterator.close();
     245                    nodes.clear();
     246                    if (instance != null) {
     247                        instance.setCustomText(null);
     248                    }
     249                }
     250            }
     251        } catch (IOException e) {
    252252            e.printStackTrace();
    253                         throw e;
    254                 } catch (Throwable t) {
     253            throw e;
     254        } catch (Throwable t) {
    255255            t.printStackTrace();
    256                         throw new IOException(t);
    257                 }
    258                 return ds;
    259         }
    260        
    261         private static final void readNonGeometricAttributes(Feature feature, OsmPrimitive primitive) {
     256            throw new IOException(t);
     257        }
     258        return ds;
     259    }
     260   
     261    private static final void readNonGeometricAttributes(Feature feature, OsmPrimitive primitive) {
    262262            try {
    263                 for (Property prop : feature.getProperties()) {
    264                         if (!(prop instanceof GeometryAttribute)) {
    265                                 Name name = prop.getName();
    266                                 Object value = prop.getValue();
    267                                 if (name != null && value != null) {
    268                                         String sName = name.toString();
    269                                         String sValue = value.toString();
    270                                         if (!sName.isEmpty() && !sValue.isEmpty()) {
     263        for (Property prop : feature.getProperties()) {
     264            if (!(prop instanceof GeometryAttribute)) {
     265                Name name = prop.getName();
     266                Object value = prop.getValue();
     267                if (name != null && value != null) {
     268                    String sName = name.toString();
     269                    String sValue = value.toString();
     270                    if (!sName.isEmpty() && !sValue.isEmpty()) {
    271271                                               primitive.put(sName, sValue);
    272                                         }
    273                                 }
    274                         }
    275                 }
     272                    }
     273                }
     274            }
     275        }
    276276            } catch (Exception e) {
    277277                e.printStackTrace();
    278278            }
    279         }
    280 
    281         @Override
    282         protected Node createOrGetNode(Point p) throws MismatchedDimensionException, TransformException {
    283                 Node n = super.createOrGetNode(p);
    284                 featurePrimitives.add(n);
    285                 return n;
    286         }
    287        
    288         @Override
    289         protected <T extends OsmPrimitive> T addOsmPrimitive(T p) {
    290                 featurePrimitives.add(p);
    291                 return super.addOsmPrimitive(p);
    292         }
     279    }
     280
     281    @Override
     282    protected Node createOrGetNode(Point p) throws MismatchedDimensionException, TransformException {
     283        Node n = super.createOrGetNode(p);
     284        featurePrimitives.add(n);
     285        return n;
     286    }
     287   
     288    @Override
     289    protected <T extends OsmPrimitive> T addOsmPrimitive(T p) {
     290        featurePrimitives.add(p);
     291        return super.addOsmPrimitive(p);
     292    }
    293293}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/geographic/TabReader.java

    r30575 r30723  
    2929public class TabReader extends AbstractMapInfoReader {
    3030
    31         private Charset datCharset;
    32         private final AbstractDataSetHandler handler;
    33        
    34         public TabReader(AbstractDataSetHandler handler) {
    35                 this.handler = handler;
    36         }
     31    private Charset datCharset;
     32    private final AbstractDataSetHandler handler;
     33   
     34    public TabReader(AbstractDataSetHandler handler) {
     35        this.handler = handler;
     36    }
    3737
    38         public static DataSet parseDataSet(InputStream in, File file,
    39                         AbstractDataSetHandler handler, ProgressMonitor instance) throws IOException {
    40                 return new TabReader(handler).parse(in, file, instance, Charset.forName(OdConstants.ISO8859_15));
    41         }
    42                
    43         private class TabOsmReader extends SpreadSheetReader {
     38    public static DataSet parseDataSet(InputStream in, File file,
     39            AbstractDataSetHandler handler, ProgressMonitor instance) throws IOException {
     40        return new TabReader(handler).parse(in, file, instance, Charset.forName(OdConstants.ISO8859_15));
     41    }
     42       
     43    private class TabOsmReader extends SpreadSheetReader {
    4444
    45                 private final DbaseFileReader dbfReader;
    46                 public TabOsmReader(SpreadSheetHandler handler, TabFiles tabFiles) throws IOException {
    47                         super(handler);
    48                         this.dbfReader = new DbaseFileReader(tabFiles, false, datCharset, null);
    49                 }
     45        private final DbaseFileReader dbfReader;
     46        public TabOsmReader(SpreadSheetHandler handler, TabFiles tabFiles) throws IOException {
     47            super(handler);
     48            this.dbfReader = new DbaseFileReader(tabFiles, false, datCharset, null);
     49        }
    5050
    51                 @Override
    52                 protected void initResources(InputStream in,
    53                                 ProgressMonitor progressMonitor) throws IOException {
    54                 }
     51        @Override
     52        protected void initResources(InputStream in,
     53                ProgressMonitor progressMonitor) throws IOException {
     54        }
    5555
    56                 @Override
    57                 protected String[] readLine(ProgressMonitor progressMonitor)
    58                                 throws IOException {
    59                         if (!dbfReader.hasNext()) {
    60                                 return null;
    61                         }
    62                 List<String> result = new ArrayList<>();
    63                         Row row = dbfReader.readRow();
    64                 for (int i=0; i<columns.size(); i++) {
    65                         Object o = row.read(i);
    66                         if (o != null) {
    67                                 result.add(o.toString());
    68                         } else {
    69                                 result.add("");
    70                         }
    71                 }
    72                 return result.toArray(new String[0]);
    73                 }
    74         }
     56        @Override
     57        protected String[] readLine(ProgressMonitor progressMonitor)
     58                throws IOException {
     59            if (!dbfReader.hasNext()) {
     60                return null;
     61            }
     62            List<String> result = new ArrayList<>();
     63            Row row = dbfReader.readRow();
     64            for (int i=0; i<columns.size(); i++) {
     65                Object o = row.read(i);
     66                if (o != null) {
     67                    result.add(o.toString());
     68                } else {
     69                    result.add("");
     70                }
     71            }
     72            return result.toArray(new String[0]);
     73        }
     74    }
    7575
    76         private DataSet parse(InputStream in, File file, ProgressMonitor instance, Charset charset) throws IOException {
    77                 headerReader = new BufferedReader(new InputStreamReader(in, charset));
    78                 parseHeader();
     76    private DataSet parse(InputStream in, File file, ProgressMonitor instance, Charset charset) throws IOException {
     77        headerReader = new BufferedReader(new InputStreamReader(in, charset));
     78        parseHeader();
    7979        try {
    80                 File dataFile = getDataFile(file, ".dat");
    81                 ds = new TabOsmReader(handler != null ? handler.getSpreadSheetHandler() : null, new TabFiles(file, dataFile)).
    82                                 doParse(columns.toArray(new String[0]), instance);
     80            File dataFile = getDataFile(file, ".dat");
     81            ds = new TabOsmReader(handler != null ? handler.getSpreadSheetHandler() : null, new TabFiles(file, dataFile)).
     82                    doParse(columns.toArray(new String[0]), instance);
    8383        } catch (IOException e) {
    84                 System.err.println(e.getMessage());
     84            System.err.println(e.getMessage());
    8585        }
    86                 return ds;
    87         }
     86        return ds;
     87    }
    8888
    89         @Override
    90         protected void parseHeaderLine(String[] words) throws IOException {
    91                 if (words[0].equalsIgnoreCase("!table")) {
    92                         // Do nothing
    93                 } else if (words[0].equalsIgnoreCase("!version")) {
    94                         parseVersion(words);
    95                 } else if (words[0].equalsIgnoreCase("!charset")) {
    96                         parseCharset(words);
    97                 } else if (numcolumns > 0) {
    98                         parseField(words);
    99                 } else if (words[0].equalsIgnoreCase("Definition")) {
    100                         // Do nothing
    101                 } else if (words[0].equalsIgnoreCase("Type")) {
    102                         parseType(words);
    103                 } else if (words[0].equalsIgnoreCase("Fields")) {
    104                         parseColumns(words);
    105                 } else if (!line.isEmpty()) {
    106                         System.err.println("Line "+lineNum+". Unknown clause in header: "+line);
    107                 }
    108         }
     89    @Override
     90    protected void parseHeaderLine(String[] words) throws IOException {
     91        if (words[0].equalsIgnoreCase("!table")) {
     92            // Do nothing
     93        } else if (words[0].equalsIgnoreCase("!version")) {
     94            parseVersion(words);
     95        } else if (words[0].equalsIgnoreCase("!charset")) {
     96            parseCharset(words);
     97        } else if (numcolumns > 0) {
     98            parseField(words);
     99        } else if (words[0].equalsIgnoreCase("Definition")) {
     100            // Do nothing
     101        } else if (words[0].equalsIgnoreCase("Type")) {
     102            parseType(words);
     103        } else if (words[0].equalsIgnoreCase("Fields")) {
     104            parseColumns(words);
     105        } else if (!line.isEmpty()) {
     106            System.err.println("Line "+lineNum+". Unknown clause in header: "+line);
     107        }
     108    }
    109109
    110         private void parseField(String[] words) {
    111                 columns.add(words[0]);
    112                 --numcolumns;
    113         }
     110    private void parseField(String[] words) {
     111        columns.add(words[0]);
     112        --numcolumns;
     113    }
    114114
    115         private void parseType(String[] words) throws IllegalCharsetNameException, UnsupportedCharsetException {
    116                 if (words[1].equalsIgnoreCase("NATIVE") && words[2].equalsIgnoreCase("Charset")) {
    117                         datCharset = parseCharset(words, 3);
    118                 } else {
    119                         System.err.println("Line "+lineNum+". Unknown Type clause in header: "+line);
    120                 }
    121         }
     115    private void parseType(String[] words) throws IllegalCharsetNameException, UnsupportedCharsetException {
     116        if (words[1].equalsIgnoreCase("NATIVE") && words[2].equalsIgnoreCase("Charset")) {
     117            datCharset = parseCharset(words, 3);
     118        } else {
     119            System.err.println("Line "+lineNum+". Unknown Type clause in header: "+line);
     120        }
     121    }
    122122}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/tabular/CsvHandler.java

    r30340 r30723  
    66public interface CsvHandler extends SpreadSheetHandler {
    77
    8         public void setCharset(Charset charset);
     8    public void setCharset(Charset charset);
    99
    10         public void setCharset(String charset);
     10    public void setCharset(String charset);
    1111
    12         public Charset getCharset();
     12    public Charset getCharset();
    1313
    14         public void setSeparator(String sep);
    15        
    16         public String getSeparator();
     14    public void setSeparator(String sep);
     15   
     16    public String getSeparator();
    1717}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/tabular/CsvImporter.java

    r30563 r30723  
    2323   
    2424    public static final String COLOMBUS_HEADER = "INDEX,TAG,DATE,TIME,LATITUDE N/S,LONGITUDE E/W,HEIGHT,SPEED,HEADING,FIX MODE,VALID,PDOP,HDOP,VDOP,VOX";
    25        
     25   
    2626    public CsvImporter() {
    2727        super(CSV_FILE_FILTER);
    2828    }
    2929
    30         @Override
    31         protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
    32                         throws IllegalDataException {
    33                 try {
    34                         return CsvReader.parseDataSet(in, handler, instance);
    35                 } catch (IOException e) {
    36                         throw new IllegalDataException(e);
    37                 }
    38         }
     30    @Override
     31    protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
     32            throws IllegalDataException {
     33        try {
     34            return CsvReader.parseDataSet(in, handler, instance);
     35        } catch (IOException e) {
     36            throw new IllegalDataException(e);
     37        }
     38    }
    3939
    4040    @Override
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/tabular/CsvReader.java

    r30568 r30723  
    1717public class CsvReader extends SpreadSheetReader {
    1818
    19         private final Charset charset;
    20         private String sep;
    21        
    22         private BufferedReader reader;
    23         private String line;
     19    private final Charset charset;
     20    private String sep;
     21   
     22    private BufferedReader reader;
     23    private String line;
    2424
    25         public CsvReader(CsvHandler handler) {
    26                 this(handler, ";");
    27         }
     25    public CsvReader(CsvHandler handler) {
     26        this(handler, ";");
     27    }
    2828
    29         public CsvReader(CsvHandler handler, String defaultSep) {
    30                 super(handler);
    31                 this.charset = handler != null && handler.getCharset() != null ? handler.getCharset() : Charset.forName(OdConstants.UTF8);
    32                 this.sep = handler != null && handler.getSeparator() != null ? handler.getSeparator() : defaultSep;
    33         }
    34        
    35         public static DataSet parseDataSet(InputStream in, AbstractDataSetHandler handler, ProgressMonitor instance) throws IOException {
    36                 CsvHandler csvHandler = null;
    37                 if (handler != null && handler.getSpreadSheetHandler() instanceof CsvHandler) {
    38                         csvHandler = (CsvHandler) handler.getSpreadSheetHandler();
    39                 }
    40                 CsvReader csvReader = new CsvReader(csvHandler);
    41                 try {
    42                         return csvReader.parse(in, instance);
    43                 } catch (IllegalArgumentException e) {
    44                         if (csvHandler == null || csvHandler.getSeparator() == null || ";".equals(csvHandler.getSeparator())) {
    45                                 // If default sep has been used, try comma
    46                                 Main.warn(e.getMessage());
    47                                 csvReader.sep = ",";
    48                                 return csvReader.doParse(csvReader.splitLine(), instance);
    49                         } else {
    50                                 throw e;
    51                         }
    52                 }
    53         }
     29    public CsvReader(CsvHandler handler, String defaultSep) {
     30        super(handler);
     31        this.charset = handler != null && handler.getCharset() != null ? handler.getCharset() : Charset.forName(OdConstants.UTF8);
     32        this.sep = handler != null && handler.getSeparator() != null ? handler.getSeparator() : defaultSep;
     33    }
     34   
     35    public static DataSet parseDataSet(InputStream in, AbstractDataSetHandler handler, ProgressMonitor instance) throws IOException {
     36        CsvHandler csvHandler = null;
     37        if (handler != null && handler.getSpreadSheetHandler() instanceof CsvHandler) {
     38            csvHandler = (CsvHandler) handler.getSpreadSheetHandler();
     39        }
     40        CsvReader csvReader = new CsvReader(csvHandler);
     41        try {
     42            return csvReader.parse(in, instance);
     43        } catch (IllegalArgumentException e) {
     44            if (csvHandler == null || csvHandler.getSeparator() == null || ";".equals(csvHandler.getSeparator())) {
     45                // If default sep has been used, try comma
     46                Main.warn(e.getMessage());
     47                csvReader.sep = ",";
     48                return csvReader.doParse(csvReader.splitLine(), instance);
     49            } else {
     50                throw e;
     51            }
     52        }
     53    }
    5454
    55         @Override
    56         protected void initResources(InputStream in, ProgressMonitor progressMonitor) throws IOException {
    57                 Main.info("Parsing CSV file using charset "+charset+" and separator '"+sep+"'");
     55    @Override
     56    protected void initResources(InputStream in, ProgressMonitor progressMonitor) throws IOException {
     57        Main.info("Parsing CSV file using charset "+charset+" and separator '"+sep+"'");
    5858
    59                 reader = new BufferedReader(new InputStreamReader(in, charset));
    60         }
     59        reader = new BufferedReader(new InputStreamReader(in, charset));
     60    }
    6161
    62         @Override
    63         protected String[] readLine(ProgressMonitor progressMonitor) throws IOException {
    64                 line = reader.readLine();
    65                 return splitLine();
    66         }
    67        
    68         private final String[] splitLine() {
    69                 if (line != null) {
    70                         return OdUtils.stripQuotesAndExtraChars(line.split(sep), sep);
    71                 } else {
    72                         return null;
    73                 }
    74         }
     62    @Override
     63    protected String[] readLine(ProgressMonitor progressMonitor) throws IOException {
     64        line = reader.readLine();
     65        return splitLine();
     66    }
     67   
     68    private final String[] splitLine() {
     69        if (line != null) {
     70            return OdUtils.stripQuotesAndExtraChars(line.split(sep), sep);
     71        } else {
     72            return null;
     73        }
     74    }
    7575}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/tabular/DefaultCsvHandler.java

    r30340 r30723  
    66public class DefaultCsvHandler extends DefaultSpreadSheetHandler implements CsvHandler {
    77
    8         private Charset charset = null;
    9         private String separator = null;
    10        
    11         @Override
    12         public void setCharset(Charset cs) {
    13                 charset = cs;
    14         }
     8    private Charset charset = null;
     9    private String separator = null;
     10   
     11    @Override
     12    public void setCharset(Charset cs) {
     13        charset = cs;
     14    }
    1515
    16         @Override
    17         public void setCharset(String charset) {
    18                 setCharset(Charset.forName(charset));
    19         }
     16    @Override
     17    public void setCharset(String charset) {
     18        setCharset(Charset.forName(charset));
     19    }
    2020
    21         @Override
    22         public Charset getCharset() {
    23                 return charset;
    24         }
     21    @Override
     22    public Charset getCharset() {
     23        return charset;
     24    }
    2525
    26         @Override
    27         public void setSeparator(String sep) {
    28                 separator = sep;
    29         }
     26    @Override
     27    public void setSeparator(String sep) {
     28        separator = sep;
     29    }
    3030
    31         @Override
    32         public String getSeparator() {
    33                 return separator;
    34         }
     31    @Override
     32    public String getSeparator() {
     33        return separator;
     34    }
    3535}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/tabular/DefaultSpreadSheetHandler.java

    r30340 r30723  
    1212public class DefaultSpreadSheetHandler implements SpreadSheetHandler {
    1313
    14         private int sheetNumber = -1;
    15         private int lineNumber = -1;
    16         private boolean handlesProjection = false;
    17        
    18         private int xCol = -1;
    19         private int yCol = -1;
    20        
    21         @Override
    22         public int getSheetNumber() {
    23                 return sheetNumber;
    24         }
     14    private int sheetNumber = -1;
     15    private int lineNumber = -1;
     16    private boolean handlesProjection = false;
     17   
     18    private int xCol = -1;
     19    private int yCol = -1;
     20   
     21    @Override
     22    public int getSheetNumber() {
     23        return sheetNumber;
     24    }
    2525
    26         @Override
    27         public void setSheetNumber(int n) {
    28                 sheetNumber = n;
    29         }
    30        
    31         @Override
    32         public boolean handlesProjection() {
    33                 return handlesProjection;
    34         }
     26    @Override
     27    public void setSheetNumber(int n) {
     28        sheetNumber = n;
     29    }
     30   
     31    @Override
     32    public boolean handlesProjection() {
     33        return handlesProjection;
     34    }
    3535
    36         @Override
    37         public void setHandlesProjection(boolean handle) {
    38                 handlesProjection = handle;
    39         }
     36    @Override
     37    public void setHandlesProjection(boolean handle) {
     38        handlesProjection = handle;
     39    }
    4040
    41         @Override
    42         public LatLon getCoor(EastNorth en, String[] fields) {
    43                 return null;
    44         }
     41    @Override
     42    public LatLon getCoor(EastNorth en, String[] fields) {
     43        return null;
     44    }
    4545
    46         @Override
    47         public void setLineNumber(int n) {
    48                 lineNumber = n;
    49         }
     46    @Override
     47    public void setLineNumber(int n) {
     48        lineNumber = n;
     49    }
    5050
    51         @Override
    52         public int getLineNumber() {
    53                 return lineNumber;
    54         }
     51    @Override
     52    public int getLineNumber() {
     53        return lineNumber;
     54    }
    5555
    56         @Override
    57         public void setXCol(int i) {
    58                 xCol = i;
    59         }
     56    @Override
     57    public void setXCol(int i) {
     58        xCol = i;
     59    }
    6060
    61         @Override
    62         public void setYCol(int i) {
    63                 yCol = i;
    64         }
     61    @Override
     62    public void setYCol(int i) {
     63        yCol = i;
     64    }
    6565
    66         @Override
    67         public int getXCol() {
    68                 return xCol;
    69         }
     66    @Override
     67    public int getXCol() {
     68        return xCol;
     69    }
    7070
    71         @Override
    72         public int getYCol() {
    73                 return yCol;
    74         }
     71    @Override
     72    public int getYCol() {
     73        return yCol;
     74    }
    7575
    7676    @Override
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/tabular/OdsDocument.java

    r30568 r30723  
    1818public class OdsDocument extends OpenDocument {
    1919
    20         public OdsDocument(InputStream in) {
    21                 loadFrom(in);
    22         }
    23        
    24         private InputSource getEntryInputSource(ZipInputStream zis) throws IOException {
     20    public OdsDocument(InputStream in) {
     21        loadFrom(in);
     22    }
     23   
     24    private InputSource getEntryInputSource(ZipInputStream zis) throws IOException {
    2525        int n = -1;
    26                 final byte[] buffer = new byte[4096];
     26        final byte[] buffer = new byte[4096];
    2727        final ByteArrayOutputStream baos = new ByteArrayOutputStream();
    2828        while ((n = zis.read(buffer, 0, buffer.length)) != -1) {
    29                 baos.write(buffer, 0, n);
     29            baos.write(buffer, 0, n);
    3030        }
    31                 return new InputSource(new ByteArrayInputStream(baos.toByteArray()));
    32         }
     31        return new InputSource(new ByteArrayInputStream(baos.toByteArray()));
     32    }
    3333
    3434    public void loadFrom(final InputStream in) {
     
    4343           
    4444            while (!contentParsed && (entry = zis.getNextEntry()) != null) {
    45                 if (entry.getName().equals("content.xml")) {
     45                if (entry.getName().equals("content.xml")) {
    4646                    rdr.setContentHandler(contentHandler);
    4747                    Main.info("Parsing content.xml");
    4848                    rdr.parse(getEntryInputSource(zis));
    49                         contentParsed = true;
    50                 }
     49                    contentParsed = true;
     50                }
    5151            }
    5252           
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/tabular/OdsImporter.java

    r30563 r30723  
    1515
    1616public class OdsImporter extends AbstractImporter {
    17        
     17   
    1818    public static final ExtensionFileFilter ODS_FILE_FILTER = new ExtensionFileFilter(
    1919            OdConstants.ODS_EXT, OdConstants.ODS_EXT, tr("ODS files") + " (*."+OdConstants.ODS_EXT+")");
     
    2323    }
    2424
    25         @Override
    26         protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
    27                         throws IllegalDataException {
    28                 try {
    29                         return OdsReader.parseDataSet(in, handler, instance);
    30                 } catch (IOException e) {
    31                         throw new IllegalDataException(e);
    32                 }
    33         }
     25    @Override
     26    protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
     27            throws IllegalDataException {
     28        try {
     29            return OdsReader.parseDataSet(in, handler, instance);
     30        } catch (IOException e) {
     31            throw new IllegalDataException(e);
     32        }
     33    }
    3434}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/tabular/OdsReader.java

    r30568 r30723  
    2020public class OdsReader extends SpreadSheetReader {
    2121
    22         private OpenDocument doc;
    23         private TableTable sheet;
    24         private List<TableTableRow> rows;
    25         private int rowIndex;
    26        
    27         private static final String SEP = "TextP:[";
    28        
    29         public OdsReader(SpreadSheetHandler handler) {
    30                 super(handler);
    31         }
     22    private OpenDocument doc;
     23    private TableTable sheet;
     24    private List<TableTableRow> rows;
     25    private int rowIndex;
     26   
     27    private static final String SEP = "TextP:[";
     28   
     29    public OdsReader(SpreadSheetHandler handler) {
     30        super(handler);
     31    }
    3232
    33         public static DataSet parseDataSet(InputStream in,
    34                         AbstractDataSetHandler handler, ProgressMonitor instance) throws IOException {
    35                 return new OdsReader(handler != null ? handler.getSpreadSheetHandler() : null).parse(in, instance);
    36         }
     33    public static DataSet parseDataSet(InputStream in,
     34            AbstractDataSetHandler handler, ProgressMonitor instance) throws IOException {
     35        return new OdsReader(handler != null ? handler.getSpreadSheetHandler() : null).parse(in, instance);
     36    }
    3737
    38         @Override
    39         protected void initResources(InputStream in, ProgressMonitor progressMonitor) throws IOException {
    40                 try {
    41                         Main.info("Parsing ODS file");
    42                         doc = new OdsDocument(in);
    43                         List<OfficeSpreadsheet> spreadsheets = doc.getBody().getOfficeSpreadsheets();
    44                         if (spreadsheets != null && spreadsheets.size() > 0) {
    45                                 List<TableTable> tables = spreadsheets.get(0).getTables();
    46                                 if (tables != null && tables.size() > 0) {
    47                                         sheet = tables.get(getSheetNumber());
    48                                         if (sheet != null) {
    49                                                 rows = sheet.getRows();
    50                                         }
    51                                 }
    52                         }
    53                         rowIndex = 0;
    54                 } catch (Exception e) {
    55                         throw new IOException(e);
    56                 }
    57         }
     38    @Override
     39    protected void initResources(InputStream in, ProgressMonitor progressMonitor) throws IOException {
     40        try {
     41            Main.info("Parsing ODS file");
     42            doc = new OdsDocument(in);
     43            List<OfficeSpreadsheet> spreadsheets = doc.getBody().getOfficeSpreadsheets();
     44            if (spreadsheets != null && spreadsheets.size() > 0) {
     45                List<TableTable> tables = spreadsheets.get(0).getTables();
     46                if (tables != null && tables.size() > 0) {
     47                    sheet = tables.get(getSheetNumber());
     48                    if (sheet != null) {
     49                        rows = sheet.getRows();
     50                    }
     51                }
     52            }
     53            rowIndex = 0;
     54        } catch (Exception e) {
     55            throw new IOException(e);
     56        }
     57    }
    5858
    59         @Override
    60         protected String[] readLine(ProgressMonitor progressMonitor) throws IOException {
    61                 if (rows != null && rowIndex < rows.size()) {
    62                         TableTableRow row = rows.get(rowIndex++);
     59    @Override
     60    protected String[] readLine(ProgressMonitor progressMonitor) throws IOException {
     61        if (rows != null && rowIndex < rows.size()) {
     62            TableTableRow row = rows.get(rowIndex++);
    6363
    64                         if (rowIndex % 5000 == 0) {
    65                                 Main.info("Lines read: "+rowIndex);
    66                         }
     64            if (rowIndex % 5000 == 0) {
     65                Main.info("Lines read: "+rowIndex);
     66            }
    6767
    68                         List<String> result = new ArrayList<>();
    69                         boolean allFieldsBlank = true;
    70                         for (TableTableCell cell : row.getAllCells()) {
    71                             TextP textP = cell.getTextP();
    72                             String text = textP == null ? "" : textP.toString().replace(SEP, "").replace("]", "").replace("null", "").trim();
     68            List<String> result = new ArrayList<>();
     69            boolean allFieldsBlank = true;
     70            for (TableTableCell cell : row.getAllCells()) {
     71                TextP textP = cell.getTextP();
     72                String text = textP == null ? "" : textP.toString().replace(SEP, "").replace("]", "").replace("null", "").trim();
    7373                result.add(text);
    7474                if (allFieldsBlank && !text.isEmpty()) {
    7575                    allFieldsBlank = false;
    7676                }
    77                         }
    78                        
    79                         return rowIndex == 1 || !allFieldsBlank ? result.toArray(new String[0]) : null;
    80                 }
    81                 return null;
    82         }
     77            }
     78           
     79            return rowIndex == 1 || !allFieldsBlank ? result.toArray(new String[0]) : null;
     80        }
     81        return null;
     82    }
    8383}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/tabular/SpreadSheetHandler.java

    r30340 r30723  
    1212public interface SpreadSheetHandler {
    1313
    14         public void setSheetNumber(int n);
    15        
    16         public int getSheetNumber();
     14    public void setSheetNumber(int n);
     15   
     16    public int getSheetNumber();
    1717
    18         public void setHandlesProjection(boolean handle);
    19        
    20         public boolean handlesProjection();
     18    public void setHandlesProjection(boolean handle);
     19   
     20    public boolean handlesProjection();
    2121
    22         public LatLon getCoor(EastNorth en, String[] fields);
     22    public LatLon getCoor(EastNorth en, String[] fields);
    2323
    24         public void setLineNumber(int n);
    25        
    26         public int getLineNumber();
     24    public void setLineNumber(int n);
     25   
     26    public int getLineNumber();
    2727
    28         public void setXCol(int i);
     28    public void setXCol(int i);
    2929
    30         public void setYCol(int i);
    31        
    32         public int getXCol();
     30    public void setYCol(int i);
     31   
     32    public int getXCol();
    3333
    34         public int getYCol();
     34    public int getYCol();
    3535
    3636    public void nodesAdded(DataSet ds, Map<CoordinateColumns, Node> nodes, String[] fields, int lineNumber);
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/tabular/SpreadSheetReader.java

    r30583 r30723  
    2828
    2929public abstract class SpreadSheetReader extends AbstractReader {
    30        
    31         private static final NumberFormat formatFrance = NumberFormat.getInstance(Locale.FRANCE);
    32         private static final NumberFormat formatUK = NumberFormat.getInstance(Locale.UK);
    33        
    34         protected final SpreadSheetHandler handler;
    35 
    36         public SpreadSheetReader(SpreadSheetHandler handler) {
    37                 this.handler = handler;
    38         }
    39 
    40         protected static double parseDouble(String value) throws ParseException {
    41                 if (value.contains(",")) {
    42                         return formatFrance.parse(value.replace(" ", "")).doubleValue();
    43                 } else {
    44                         return formatUK.parse(value.replace(" ", "")).doubleValue();
    45                 }
    46         }
    47        
    48         protected abstract void initResources(InputStream in, ProgressMonitor progressMonitor) throws IOException;
    49        
    50         protected abstract String[] readLine(ProgressMonitor progressMonitor) throws IOException;
    51        
    52         protected final int getSheetNumber() {
    53                 return handler != null && handler.getSheetNumber() > -1 ? handler.getSheetNumber() : 0;
    54         }
    55        
    56         protected final int getLineNumber() {
    57                 return handler != null ? handler.getLineNumber() : -1;
    58         }
    59        
    60         public static class CoordinateColumns {
     30   
     31    private static final NumberFormat formatFrance = NumberFormat.getInstance(Locale.FRANCE);
     32    private static final NumberFormat formatUK = NumberFormat.getInstance(Locale.UK);
     33   
     34    protected final SpreadSheetHandler handler;
     35
     36    public SpreadSheetReader(SpreadSheetHandler handler) {
     37        this.handler = handler;
     38    }
     39
     40    protected static double parseDouble(String value) throws ParseException {
     41        if (value.contains(",")) {
     42            return formatFrance.parse(value.replace(" ", "")).doubleValue();
     43        } else {
     44            return formatUK.parse(value.replace(" ", "")).doubleValue();
     45        }
     46    }
     47   
     48    protected abstract void initResources(InputStream in, ProgressMonitor progressMonitor) throws IOException;
     49   
     50    protected abstract String[] readLine(ProgressMonitor progressMonitor) throws IOException;
     51   
     52    protected final int getSheetNumber() {
     53        return handler != null && handler.getSheetNumber() > -1 ? handler.getSheetNumber() : 0;
     54    }
     55   
     56    protected final int getLineNumber() {
     57        return handler != null ? handler.getLineNumber() : -1;
     58    }
     59   
     60    public static class CoordinateColumns {
    6161        public Projection proj = null;
    62                 public int xCol = -1;
    63                 public int yCol = -1;
    64                 public final boolean isOk() {
    65                         return xCol > -1 && yCol > -1;
    66                 }
     62        public int xCol = -1;
     63        public int yCol = -1;
     64        public final boolean isOk() {
     65            return xCol > -1 && yCol > -1;
     66        }
    6767        @Override
    6868        public String toString() {
    6969            return "CoordinateColumns [proj=" + proj + ", xCol=" + xCol + ", yCol=" + yCol + "]";
    7070        }
    71         }
    72        
    73         private final CoordinateColumns addCoorColIfNeeded(List<CoordinateColumns> columns, CoordinateColumns col) {
     71    }
     72   
     73    private final CoordinateColumns addCoorColIfNeeded(List<CoordinateColumns> columns, CoordinateColumns col) {
    7474        if (col == null || col.isOk()) {
    7575            columns.add(col = new CoordinateColumns());
    7676        }
    7777        return col;
    78         }
    79        
    80         public DataSet doParse(String[] header, ProgressMonitor progressMonitor) throws IOException {
    81                 Main.info("Header: "+Arrays.toString(header));
    82                
    83                 Map<ProjectionPatterns, List<CoordinateColumns>> projColumns = new HashMap<>();
    84                
    85                 for (int i = 0; i<header.length; i++) {
    86                         for (ProjectionPatterns pp : OdConstants.PROJECTIONS) {
    87                             List<CoordinateColumns> columns = projColumns.get(pp);
    88                             if (columns == null) {
    89                                 projColumns.put(pp, columns = new ArrayList<>());
    90                             }
    91                                 CoordinateColumns col = columns.isEmpty() ? null : columns.get(columns.size()-1);
    92                                 if (pp.getXPattern().matcher(header[i]).matches()) {
    93                                     addCoorColIfNeeded(columns, col).xCol = i;
    94                                         break;
    95                                 } else if (pp.getYPattern().matcher(header[i]).matches()) {
    96                                     addCoorColIfNeeded(columns, col).yCol = i;
    97                                         break;
    98                                 }
    99                         }
    100                 }
    101 
    102                 final List<CoordinateColumns> columns = new ArrayList<>();
    103                
    104                 for (ProjectionPatterns pp : projColumns.keySet()) {
    105                     for (CoordinateColumns col : projColumns.get(pp)) {
    106                     if (col.isOk()) {
     78    }
     79   
     80    public DataSet doParse(String[] header, ProgressMonitor progressMonitor) throws IOException {
     81        Main.info("Header: "+Arrays.toString(header));
     82       
     83        Map<ProjectionPatterns, List<CoordinateColumns>> projColumns = new HashMap<>();
     84       
     85        for (int i = 0; i<header.length; i++) {
     86            for (ProjectionPatterns pp : OdConstants.PROJECTIONS) {
     87                List<CoordinateColumns> columns = projColumns.get(pp);
     88                if (columns == null) {
     89                    projColumns.put(pp, columns = new ArrayList<>());
     90                }
     91                CoordinateColumns col = columns.isEmpty() ? null : columns.get(columns.size()-1);
     92                if (pp.getXPattern().matcher(header[i]).matches()) {
     93                    addCoorColIfNeeded(columns, col).xCol = i;
     94                    break;
     95                } else if (pp.getYPattern().matcher(header[i]).matches()) {
     96                    addCoorColIfNeeded(columns, col).yCol = i;
     97                    break;
     98                }
     99            }
     100        }
     101
     102        final List<CoordinateColumns> columns = new ArrayList<>();
     103       
     104        for (ProjectionPatterns pp : projColumns.keySet()) {
     105            for (CoordinateColumns col : projColumns.get(pp)) {
     106                if (col.isOk()) {
    107107                    columns.add(col);
    108                         if (col.proj == null) {
    109                             col.proj = pp.getProjection(header[col.xCol], header[col.yCol]);
    110                         }
    111                     }
    112                     }
    113                 }
    114 
    115                 final boolean handlerOK = handler != null && handler.handlesProjection();
    116 
    117                 boolean projFound = false;
    118                
    119                 for (CoordinateColumns c : columns) {
    120                     if (c.proj != null) {
    121                         projFound = true;
    122                         break;
    123                     }
    124                 }
    125                
    126                 if (projFound) {
    127                         // projection identified, do nothing
    128                 } else if (!columns.isEmpty()) {
    129                         if (!handlerOK) {
     108                    if (col.proj == null) {
     109                        col.proj = pp.getProjection(header[col.xCol], header[col.yCol]);
     110                    }
     111                }
     112            }
     113        }
     114
     115        final boolean handlerOK = handler != null && handler.handlesProjection();
     116
     117        boolean projFound = false;
     118       
     119        for (CoordinateColumns c : columns) {
     120            if (c.proj != null) {
     121                projFound = true;
     122                break;
     123            }
     124        }
     125       
     126        if (projFound) {
     127            // projection identified, do nothing
     128        } else if (!columns.isEmpty()) {
     129            if (!handlerOK) {
    130130                if (GraphicsEnvironment.isHeadless()) {
    131131                    throw new IllegalArgumentException("No valid coordinates have been found and cannot prompt user in headless mode.");
    132                             }
    133                                 // TODO: filter proposed projections with min/max values ?
     132                }
     133                // TODO: filter proposed projections with min/max values ?
    134134                Projection p = ChooserLauncher.askForProjection(progressMonitor);
    135                                 if (p == null) {
    136                                         return null; // User clicked Cancel
    137                                 }
    138                         for (CoordinateColumns c : columns) {
    139                             c.proj = p;
    140                         }
    141                         }
    142                        
    143                 } else {
    144                         throw new IllegalArgumentException(tr("No valid coordinates have been found."));
    145                 }
    146 
    147                 String message = "";
    148                 for (CoordinateColumns c : columns) {
    149                     if (!message.isEmpty()) {
    150                         message += "; ";
    151                     }
    152                     message += c.proj + "("+header[c.xCol]+", "+header[c.yCol]+")";
    153                 }
    154                
    155                 Main.info("Loading data using projections "+message);
    156                
    157                 final DataSet ds = new DataSet();
    158                 int lineNumber = 1;
    159                
    160                 String[] fields;
    161                 while ((fields = readLine(progressMonitor)) != null) {
    162                         lineNumber++;
    163                         if (handler != null) {
    164                                 handler.setXCol(-1);
    165                                 handler.setYCol(-1);
    166                         }
    167                        
     135                if (p == null) {
     136                    return null; // User clicked Cancel
     137                }
     138                for (CoordinateColumns c : columns) {
     139                    c.proj = p;
     140                }
     141            }
     142           
     143        } else {
     144            throw new IllegalArgumentException(tr("No valid coordinates have been found."));
     145        }
     146
     147        String message = "";
     148        for (CoordinateColumns c : columns) {
     149            if (!message.isEmpty()) {
     150                message += "; ";
     151            }
     152            message += c.proj + "("+header[c.xCol]+", "+header[c.yCol]+")";
     153        }
     154       
     155        Main.info("Loading data using projections "+message);
     156       
     157        final DataSet ds = new DataSet();
     158        int lineNumber = 1;
     159       
     160        String[] fields;
     161        while ((fields = readLine(progressMonitor)) != null) {
     162            lineNumber++;
     163            if (handler != null) {
     164                handler.setXCol(-1);
     165                handler.setYCol(-1);
     166            }
     167           
    168168            final Map<CoordinateColumns, EastNorth> ens = new HashMap<>();
    169                         final Map<CoordinateColumns, Node> nodes = new HashMap<>();
    170                         for (CoordinateColumns c : columns) {
    171                             nodes.put(c, new Node());
    172                             ens.put(c, new EastNorth(Double.NaN, Double.NaN));
    173                         }
    174                        
    175                         if (fields.length > header.length) {
    176                             Main.warn(tr("Invalid file. Bad length on line {0}. Expected {1} columns, got {2}.", lineNumber, header.length, fields.length));
    177                             Main.warn(Arrays.toString(fields));
    178                         }
    179                        
    180                         for (int i = 0; i<Math.min(fields.length, header.length); i++) {
    181                                 try {
    182                                     boolean coordinate = false;
    183                                     for (CoordinateColumns c : columns) {
    184                                         EastNorth en = ens.get(c);
     169            final Map<CoordinateColumns, Node> nodes = new HashMap<>();
     170            for (CoordinateColumns c : columns) {
     171                nodes.put(c, new Node());
     172                ens.put(c, new EastNorth(Double.NaN, Double.NaN));
     173            }
     174           
     175            if (fields.length > header.length) {
     176                Main.warn(tr("Invalid file. Bad length on line {0}. Expected {1} columns, got {2}.", lineNumber, header.length, fields.length));
     177                Main.warn(Arrays.toString(fields));
     178            }
     179           
     180            for (int i = 0; i<Math.min(fields.length, header.length); i++) {
     181                try {
     182                    boolean coordinate = false;
     183                    for (CoordinateColumns c : columns) {
     184                        EastNorth en = ens.get(c);
    185185                        if (i == c.xCol) {
    186186                            coordinate = true;
     
    195195                                handler.setYCol(i);
    196196                            }
    197                         }                                              
    198                                     }
     197                        }                           
     198                    }
    199199                    if (!coordinate) {
    200200                        if (!fields[i].isEmpty()) {
     
    202202                        }
    203203                    }
    204                                 } catch (ParseException e) {
    205                                         System.err.println("Warning: Parsing error on line "+lineNumber+": "+e.getMessage());
    206                                 }
    207                         }
    208                         Node firstNode = null;
    209                         for (CoordinateColumns c : columns) {
    210                             Node n = nodes.get(c);
    211                             EastNorth en = ens.get(c);
    212                         if (en.isValid()) {
    213                                 n.setCoor(c.proj != null && !handlerOK ? c.proj.eastNorth2latlon(en) : handler.getCoor(en, fields));
    214                         } else {
    215                                 System.err.println("Warning: Skipping line "+lineNumber+" because no valid coordinates have been found at columns "+c);
    216                         }
    217                         if (n.getCoor() != null) {
    218                             if (firstNode == null) {
    219                                 firstNode = n;
    220                             }
    221                             if (n == firstNode || n.getCoor().greatCircleDistance(firstNode.getCoor()) > Main.pref.getDouble(OdConstants.PREF_TOLERANCE, OdConstants.DEFAULT_TOLERANCE)) {
    222                                 ds.addPrimitive(n);
    223                             } else {
    224                                 nodes.remove(c);
    225                             }
    226                         }
    227                         }
    228                         if (handler != null && !Main.pref.getBoolean(OdConstants.PREF_RAWDATA)) {
    229                             handler.nodesAdded(ds, nodes, header, lineNumber);
    230                         }
    231                 }
    232                
    233                 return ds;
    234         }
    235        
    236         public final DataSet parse(InputStream in, ProgressMonitor progressMonitor) throws IOException {
    237                
    238                 initResources(in, progressMonitor);
    239                
    240                 String[] header = null;
    241                 int length = 0;
    242                 int n = 0;
    243                
    244                 while (header == null || length == 0) {
    245                         n++;
    246                         header = readLine(progressMonitor);
    247                         length = 0;
    248                         if (header == null && n > getLineNumber()) {
    249                                 return null;
    250                         } else if (header != null && (getLineNumber() == -1 || getLineNumber() == n)) {
    251                                 for (String field : header) {
    252                                         length += field.length();
    253                                 }
    254                         }
    255                 }
    256                
    257                 return doParse(header, progressMonitor);
    258         }
     204                } catch (ParseException e) {
     205                    System.err.println("Warning: Parsing error on line "+lineNumber+": "+e.getMessage());
     206                }
     207            }
     208            Node firstNode = null;
     209            for (CoordinateColumns c : columns) {
     210                Node n = nodes.get(c);
     211                EastNorth en = ens.get(c);
     212                if (en.isValid()) {
     213                    n.setCoor(c.proj != null && !handlerOK ? c.proj.eastNorth2latlon(en) : handler.getCoor(en, fields));
     214                } else {
     215                    System.err.println("Warning: Skipping line "+lineNumber+" because no valid coordinates have been found at columns "+c);
     216                }
     217                if (n.getCoor() != null) {
     218                    if (firstNode == null) {
     219                        firstNode = n;
     220                    }
     221                    if (n == firstNode || n.getCoor().greatCircleDistance(firstNode.getCoor()) > Main.pref.getDouble(OdConstants.PREF_TOLERANCE, OdConstants.DEFAULT_TOLERANCE)) {
     222                        ds.addPrimitive(n);
     223                    } else {
     224                        nodes.remove(c);
     225                    }
     226                }
     227            }
     228            if (handler != null && !Main.pref.getBoolean(OdConstants.PREF_RAWDATA)) {
     229                handler.nodesAdded(ds, nodes, header, lineNumber);
     230            }
     231        }
     232       
     233        return ds;
     234    }
     235   
     236    public final DataSet parse(InputStream in, ProgressMonitor progressMonitor) throws IOException {
     237       
     238        initResources(in, progressMonitor);
     239       
     240        String[] header = null;
     241        int length = 0;
     242        int n = 0;
     243       
     244        while (header == null || length == 0) {
     245            n++;
     246            header = readLine(progressMonitor);
     247            length = 0;
     248            if (header == null && n > getLineNumber()) {
     249                return null;
     250            } else if (header != null && (getLineNumber() == -1 || getLineNumber() == n)) {
     251                for (String field : header) {
     252                    length += field.length();
     253                }
     254            }
     255        }
     256       
     257        return doParse(header, progressMonitor);
     258    }
    259259}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/tabular/XlsImporter.java

    r30563 r30723  
    1515
    1616public class XlsImporter extends AbstractImporter {
    17        
     17   
    1818    public static final ExtensionFileFilter XLS_FILE_FILTER = new ExtensionFileFilter(
    1919            OdConstants.XLS_EXT, OdConstants.XLS_EXT, tr("XLS files") + " (*."+OdConstants.XLS_EXT+")");
     
    2323    }
    2424
    25         @Override
    26         protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
    27                         throws IllegalDataException {
    28                 try {
    29                         return XlsReader.parseDataSet(in, handler, instance);
    30                 } catch (IOException e) {
    31                         throw new IllegalDataException(e);
    32                 }
    33         }
     25    @Override
     26    protected DataSet parseDataSet(InputStream in, ProgressMonitor instance)
     27            throws IllegalDataException {
     28        try {
     29            return XlsReader.parseDataSet(in, handler, instance);
     30        } catch (IOException e) {
     31            throw new IllegalDataException(e);
     32        }
     33    }
    3434}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/io/tabular/XlsReader.java

    r30568 r30723  
    2121public class XlsReader extends SpreadSheetReader {
    2222
    23         private Workbook wb;
    24         private Sheet sheet;
    25         private int rowIndex;
    26        
    27         public XlsReader(SpreadSheetHandler handler) {
    28                 super(handler);
    29         }
     23    private Workbook wb;
     24    private Sheet sheet;
     25    private int rowIndex;
     26   
     27    public XlsReader(SpreadSheetHandler handler) {
     28        super(handler);
     29    }
    3030
    31         public static DataSet parseDataSet(InputStream in,
    32                         AbstractDataSetHandler handler, ProgressMonitor instance) throws IOException {
    33                 return new XlsReader(handler != null ? handler.getSpreadSheetHandler() : null).parse(in, instance);
    34         }
     31    public static DataSet parseDataSet(InputStream in,
     32            AbstractDataSetHandler handler, ProgressMonitor instance) throws IOException {
     33        return new XlsReader(handler != null ? handler.getSpreadSheetHandler() : null).parse(in, instance);
     34    }
    3535
    36         @Override
    37         protected void initResources(InputStream in, ProgressMonitor progressMonitor) throws IOException {
    38             Main.info("Parsing XLS file");
    39                 try {
    40                         wb = new HSSFWorkbook(new POIFSFileSystem(in));
    41                         sheet = wb.getSheetAt(getSheetNumber());
    42                         rowIndex = 0;
    43                 } catch (ExceptionInInitializerError e) {
    44                         Throwable ex = e.getException();
    45                         if (ex != null && ex.getMessage() != null) {
    46                                 System.err.println(ex.getClass()+": "+ex.getMessage());
    47                         }
    48                         throw new IOException(e);
    49             } catch (Throwable t) {
    50                         throw new IOException(t);
    51                 }
    52         }
     36    @Override
     37    protected void initResources(InputStream in, ProgressMonitor progressMonitor) throws IOException {
     38        Main.info("Parsing XLS file");
     39        try {
     40            wb = new HSSFWorkbook(new POIFSFileSystem(in));
     41            sheet = wb.getSheetAt(getSheetNumber());
     42            rowIndex = 0;
     43        } catch (ExceptionInInitializerError e) {
     44            Throwable ex = e.getException();
     45            if (ex != null && ex.getMessage() != null) {
     46                System.err.println(ex.getClass()+": "+ex.getMessage());
     47            }
     48            throw new IOException(e);
     49        } catch (Throwable t) {
     50            throw new IOException(t);
     51        }
     52    }
    5353
    54         @Override
    55         protected String[] readLine(ProgressMonitor progressMonitor) throws IOException {
    56                 if (sheet != null) {
    57                         Row row = sheet.getRow(rowIndex++);
    58                         if (row != null) {
    59                                 List<String> result = new ArrayList<>();
    60                                 for (Cell cell : row) {
    61                             switch (cell.getCellType()) {
    62                                 case Cell.CELL_TYPE_STRING:
    63                                     result.add(cell.getRichStringCellValue().getString());
    64                                     break;
    65                                 case Cell.CELL_TYPE_NUMERIC:
    66                                     if (DateUtil.isCellDateFormatted(cell)) {
    67                                         result.add(cell.getDateCellValue().toString());
    68                                     } else {
    69                                         result.add(Double.toString(cell.getNumericCellValue()));
    70                                     }
    71                                     break;
    72                                 case Cell.CELL_TYPE_BOOLEAN:
    73                                         result.add(Boolean.toString(cell.getBooleanCellValue()));
    74                                     break;
    75                                 case Cell.CELL_TYPE_FORMULA:
    76                                         result.add(cell.getCellFormula());
    77                                     break;
    78                                 default:
    79                                     result.add("");
    80                         }
    81                                 }
    82                                 return result.toArray(new String[0]);
    83                         }
    84                 }
    85                 return null;
    86         }
     54    @Override
     55    protected String[] readLine(ProgressMonitor progressMonitor) throws IOException {
     56        if (sheet != null) {
     57            Row row = sheet.getRow(rowIndex++);
     58            if (row != null) {
     59                List<String> result = new ArrayList<>();
     60                for (Cell cell : row) {
     61                    switch (cell.getCellType()) {
     62                        case Cell.CELL_TYPE_STRING:
     63                            result.add(cell.getRichStringCellValue().getString());
     64                            break;
     65                        case Cell.CELL_TYPE_NUMERIC:
     66                            if (DateUtil.isCellDateFormatted(cell)) {
     67                                result.add(cell.getDateCellValue().toString());
     68                            } else {
     69                                result.add(Double.toString(cell.getNumericCellValue()));
     70                            }
     71                            break;
     72                        case Cell.CELL_TYPE_BOOLEAN:
     73                            result.add(Boolean.toString(cell.getBooleanCellValue()));
     74                            break;
     75                        case Cell.CELL_TYPE_FORMULA:
     76                            result.add(cell.getCellFormula());
     77                            break;
     78                        default:
     79                            result.add("");
     80                    }
     81                }
     82                return result.toArray(new String[0]);
     83            }
     84        }
     85        return null;
     86    }
    8787}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/layers/OdDataLayer.java

    r30563 r30723  
    3030public class OdDataLayer extends OsmDataLayer implements OdLayer, LayerChangeListener {
    3131
    32         public OdDiffLayer diffLayer;
    33         public OdOsmDataLayer osmLayer;
    34        
    35         public final AbstractDataSetHandler handler;
    36        
    37         private Bounds bounds;
    38        
    39         public OdDataLayer(DataSet data, String name, File associatedFile, AbstractDataSetHandler handler) {
    40                 super(data, name, associatedFile);
    41                 setUploadDiscouraged(true);
    42                 this.handler = handler;
    43                 for (Node node : data.getNodes()) {
    44                         if (this.bounds == null) {
    45                                 this.bounds = new Bounds(node.getCoor());
    46                         } else {
    47                                 this.bounds.extend(node.getCoor());
    48                         }
    49                 }
    50                 MapView.addLayerChangeListener(this);
    51         }
    52        
     32    public OdDiffLayer diffLayer;
     33    public OdOsmDataLayer osmLayer;
     34   
     35    public final AbstractDataSetHandler handler;
     36   
     37    private Bounds bounds;
     38   
     39    public OdDataLayer(DataSet data, String name, File associatedFile, AbstractDataSetHandler handler) {
     40        super(data, name, associatedFile);
     41        setUploadDiscouraged(true);
     42        this.handler = handler;
     43        for (Node node : data.getNodes()) {
     44            if (this.bounds == null) {
     45                this.bounds = new Bounds(node.getCoor());
     46            } else {
     47                this.bounds.extend(node.getCoor());
     48            }
     49        }
     50        MapView.addLayerChangeListener(this);
     51    }
     52   
    5353    @Override public Icon getBaseIcon() {
    54         return OdUtils.getImageIcon(handler != null ? handler.getDataLayerIconName() : OdConstants.ICON_CORE_16);
     54        return OdUtils.getImageIcon(handler != null ? handler.getDataLayerIconName() : OdConstants.ICON_CORE_16);
    5555    }
    5656
    5757    public void addOsmLayer(OdOsmDataLayer layer) {
    58         removeOsmLayer();
    59         osmLayer = layer;
    60         Main.main.addLayer(osmLayer);
     58        removeOsmLayer();
     59        osmLayer = layer;
     60        Main.main.addLayer(osmLayer);
    6161    }
    6262
    6363    public void removeOsmLayer() {
    64         if (osmLayer != null) {
    65                 Main.main.removeLayer(osmLayer);
    66                 osmLayer = null;
    67         }
     64        if (osmLayer != null) {
     65            Main.main.removeLayer(osmLayer);
     66            osmLayer = null;
     67        }
    6868    }
    6969   
    7070    public void addDiffLayer(OdDiffLayer layer) {
    71         removeDiffLayer();
    72         diffLayer = layer;
    73         Main.main.addLayer(diffLayer);
     71        removeDiffLayer();
     72        diffLayer = layer;
     73        Main.main.addLayer(diffLayer);
    7474    }
    7575   
    7676    public void removeDiffLayer() {
    77         if (diffLayer != null) {
    78                 Main.main.removeLayer(diffLayer);
    79                 diffLayer = null;
    80         }
     77        if (diffLayer != null) {
     78            Main.main.removeLayer(diffLayer);
     79            diffLayer = null;
     80        }
    8181    }
    8282   
    83         public final void downloadOsmData() {
    84                 String oapiReq = handler.getOverpassApiRequest(bounds);
    85                 Collection<String> xapiReqs = handler.getOsmXapiRequests(bounds);
    86                 if (oapiReq != null || xapiReqs != null) {
    87                         DataSet dataSet = new DataSet();
    88                         final OdOsmDataLayer layer = new OdOsmDataLayer(this, dataSet, getName()+"/OSM");
    89                         addOsmLayer(layer);
    90                         Main.map.mapView.setActiveLayer(osmLayer);
    91                         if (oapiReq != null) {
    92                                 OsmDownloader.downloadOapi(oapiReq);
    93                                 // Overpass API does not allow to exclude tags :(
    94                                 layer.removeForbiddenTags();
    95                         } else {
    96                                 OsmDownloader.downloadXapi(xapiReqs);
    97                         }
    98                 }
    99         }
     83    public final void downloadOsmData() {
     84        String oapiReq = handler.getOverpassApiRequest(bounds);
     85        Collection<String> xapiReqs = handler.getOsmXapiRequests(bounds);
     86        if (oapiReq != null || xapiReqs != null) {
     87            DataSet dataSet = new DataSet();
     88            final OdOsmDataLayer layer = new OdOsmDataLayer(this, dataSet, getName()+"/OSM");
     89            addOsmLayer(layer);
     90            Main.map.mapView.setActiveLayer(osmLayer);
     91            if (oapiReq != null) {
     92                OsmDownloader.downloadOapi(oapiReq);
     93                // Overpass API does not allow to exclude tags :(
     94                layer.removeForbiddenTags();
     95            } else {
     96                OsmDownloader.downloadXapi(xapiReqs);
     97            }
     98        }
     99    }
    100100
    101         @Override
    102         public void activeLayerChange(Layer oldLayer, Layer newLayer) {
    103             if (newLayer == this && this.handler != null) {
    104                 this.handler.notifyActive();
    105             }
    106         }
     101    @Override
     102    public void activeLayerChange(Layer oldLayer, Layer newLayer) {
     103        if (newLayer == this && this.handler != null) {
     104            this.handler.notifyActive();
     105        }
     106    }
    107107
    108         @Override
    109         public void layerAdded(Layer newLayer) {
    110         }
     108    @Override
     109    public void layerAdded(Layer newLayer) {
     110    }
    111111
    112         @Override
    113         public void layerRemoved(Layer oldLayer) {
    114                 if (oldLayer == this) {
    115                         removeOsmLayer();
    116                         removeDiffLayer();
    117                 } else if (oldLayer == osmLayer) {
    118                         osmLayer = null;
    119                 } else if (oldLayer == diffLayer) {
    120                         diffLayer = null;
    121                 }
    122         }
     112    @Override
     113    public void layerRemoved(Layer oldLayer) {
     114        if (oldLayer == this) {
     115            removeOsmLayer();
     116            removeDiffLayer();
     117        } else if (oldLayer == osmLayer) {
     118            osmLayer = null;
     119        } else if (oldLayer == diffLayer) {
     120            diffLayer = null;
     121        }
     122    }
    123123
    124         @Override
    125         public Action[] getMenuEntries() {
    126                 List<Action> result = new ArrayList<>();
    127                 for (Action entry : super.getMenuEntries()) {
    128                         result.add(entry);
    129                 }
    130                 if (this.handler != null) {
    131                         if (this.handler.getWikiURL() != null || this.handler.getLocalPortalURL() != null || this.handler.getNationalPortalURL() != null) {
    132                                 result.add(SeparatorLayerAction.INSTANCE);
    133                         }
    134                         if (this.handler.getWikiURL() != null) {
    135                                 result.add(new OpenLinkAction(this.handler.getWikiURL(), OdConstants.ICON_OSM_24,
    136                                                 tr("View OSM Wiki page"), tr("Launch browser to the OSM Wiki page of the selected data set")));
    137                         }
    138                         if (this.handler.getLocalPortalURL() != null) {
    139                                 result.add(new OpenLinkAction(this.handler.getLocalPortalURL(), this.handler.getLocalPortalIconName(),
    140                                                 tr("View Local Portal page"), tr("Launch browser to the local portal page of the selected data set")));
    141                         }
    142                         if (this.handler.getNationalPortalURL() != null) {
    143                                 result.add(new OpenLinkAction(this.handler.getNationalPortalURL(), this.handler.getNationalPortalIconName(),
    144                                                 tr("View National Portal page"), tr("Launch browser to the national portal page of the selected data set")));
    145                         }
    146                         if (this.handler.getLicense() != null) {
    147                                 License lic = this.handler.getLicense();
    148                                 if (lic.getURL() != null && lic.getURL().getProtocol().startsWith("http")) {
    149                                         result.add(new OpenLinkAction(lic.getURL(), OdConstants.ICON_AGREEMENT_24,
    150                                                         tr("View License"), tr("Launch browser to the license page of the selected data set")));
    151                                 }
    152                                 if (lic.getSummaryURL() != null && lic.getSummaryURL().getProtocol().startsWith("http")) {
    153                                         result.add(new OpenLinkAction(lic.getSummaryURL(), OdConstants.ICON_AGREEMENT_24,
    154                                                         tr("View License (summary)"), tr("Launch browser to the summary license page of the selected data set")));
    155                                 }
    156                                 if ((lic.getURL() != null && !lic.getURL().getProtocol().startsWith("http")) || (lic.getSummaryURL() != null && !lic.getSummaryURL().getProtocol().startsWith("http"))) {
    157                                         result.add(new ViewLicenseAction(lic, tr("View License"), tr("View the license of the selected data set")));
    158                                 }
    159                         }
    160                 }
    161                 return result.toArray(new Action[0]);
    162         }
     124    @Override
     125    public Action[] getMenuEntries() {
     126        List<Action> result = new ArrayList<>();
     127        for (Action entry : super.getMenuEntries()) {
     128            result.add(entry);
     129        }
     130        if (this.handler != null) {
     131            if (this.handler.getWikiURL() != null || this.handler.getLocalPortalURL() != null || this.handler.getNationalPortalURL() != null) {
     132                result.add(SeparatorLayerAction.INSTANCE);
     133            }
     134            if (this.handler.getWikiURL() != null) {
     135                result.add(new OpenLinkAction(this.handler.getWikiURL(), OdConstants.ICON_OSM_24,
     136                        tr("View OSM Wiki page"), tr("Launch browser to the OSM Wiki page of the selected data set")));
     137            }
     138            if (this.handler.getLocalPortalURL() != null) {
     139                result.add(new OpenLinkAction(this.handler.getLocalPortalURL(), this.handler.getLocalPortalIconName(),
     140                        tr("View Local Portal page"), tr("Launch browser to the local portal page of the selected data set")));
     141            }
     142            if (this.handler.getNationalPortalURL() != null) {
     143                result.add(new OpenLinkAction(this.handler.getNationalPortalURL(), this.handler.getNationalPortalIconName(),
     144                        tr("View National Portal page"), tr("Launch browser to the national portal page of the selected data set")));
     145            }
     146            if (this.handler.getLicense() != null) {
     147                License lic = this.handler.getLicense();
     148                if (lic.getURL() != null && lic.getURL().getProtocol().startsWith("http")) {
     149                    result.add(new OpenLinkAction(lic.getURL(), OdConstants.ICON_AGREEMENT_24,
     150                            tr("View License"), tr("Launch browser to the license page of the selected data set")));
     151                }
     152                if (lic.getSummaryURL() != null && lic.getSummaryURL().getProtocol().startsWith("http")) {
     153                    result.add(new OpenLinkAction(lic.getSummaryURL(), OdConstants.ICON_AGREEMENT_24,
     154                            tr("View License (summary)"), tr("Launch browser to the summary license page of the selected data set")));
     155                }
     156                if ((lic.getURL() != null && !lic.getURL().getProtocol().startsWith("http")) || (lic.getSummaryURL() != null && !lic.getSummaryURL().getProtocol().startsWith("http"))) {
     157                    result.add(new ViewLicenseAction(lic, tr("View License"), tr("View the license of the selected data set")));
     158                }
     159            }
     160        }
     161        return result.toArray(new Action[0]);
     162    }
    163163
    164         @Override
    165         public OdDataLayer getDataLayer() {
    166                 return this;
    167         }
     164    @Override
     165    public OdDataLayer getDataLayer() {
     166        return this;
     167    }
    168168
    169         public void makeDiff() {
    170                 final OdDiffLayer layer = new OdDiffLayer(this, getName()+"/Diff");
    171                 addDiffLayer(layer);
    172                 Main.map.mapView.setActiveLayer(diffLayer);
    173         }
     169    public void makeDiff() {
     170        final OdDiffLayer layer = new OdDiffLayer(this, getName()+"/Diff");
     171        addDiffLayer(layer);
     172        Main.map.mapView.setActiveLayer(diffLayer);
     173    }
    174174}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/layers/OdDiffLayer.java

    r30563 r30723  
    2222public class OdDiffLayer extends Layer implements OdLayer {
    2323
    24         private final OdDataLayer dataLayer;
    25        
    26         public final List<Pair<OsmPrimitive,OsmPrimitive>> differentPrimitives;
    27         public final List<OsmPrimitive> onlyInTlsPrimitives;
    28         public final List<OsmPrimitive> onlyInOsmPrimitives;
    29        
    30         public OdDiffLayer(OdDataLayer dataLayer, String name) {
    31                 super(name);
    32                 this.dataLayer = dataLayer;
    33                 this.differentPrimitives = new ArrayList<>();
    34                 this.onlyInTlsPrimitives = new ArrayList<>();
    35                 this.onlyInOsmPrimitives = new ArrayList<>();
    36                 initDiff(dataLayer.data, dataLayer.osmLayer.data);
    37         }
    38        
    39         private void initDiff(DataSet tlsData, DataSet osmData) {
    40                 for (OsmPrimitive p1 : tlsData.allPrimitives()) {
    41                         if (dataLayer.handler.isRelevant(p1)) {
    42                                 OsmPrimitive p2 = findPrimitiveAt(osmData, p1);
    43                                 if (p2 == null) {
    44                                         onlyInTlsPrimitives.add(p1);
    45                                 } else if (!dataLayer.handler.equals(p1, p2)) {
    46                                         differentPrimitives.add(new Pair<>(p1, p2));
    47                                 }
    48                         }
    49                 }
    50                 for (OsmPrimitive p1 : osmData.allPrimitives()) {
    51                         if (dataLayer.handler.isRelevant(p1)) {
    52                                 if (findPrimitiveAt(tlsData, p1) == null) {
    53                                         onlyInOsmPrimitives.add(p1);
    54                                 }
    55                         }
    56                 }
    57         }
    58        
    59         private double distance(OsmPrimitive p1, OsmPrimitive p2) {
    60                 return p1.getBBox().getCenter().greatCircleDistance(p2.getBBox().getCenter());
    61         }
    62        
    63         private OsmPrimitive findPrimitiveAt(DataSet dataSet, OsmPrimitive source) {
    64                 double maxDistance = Main.pref.getDouble(OdConstants.PREF_MAXDISTANCE, OdConstants.DEFAULT_MAXDISTANCE);
    65                 //List<OsmPrimitive> samePrimitives = new ArrayList<OsmPrimitive>();
    66                 OsmPrimitive nearestSamePrimitive = null;
    67                 //List<OsmPrimitive> potentialPrimitives = new ArrayList<OsmPrimitive>();
    68                 OsmPrimitive nearestPotentialPrimitive = null;
    69                 for (OsmPrimitive p : dataSet.allPrimitives()) {
    70                         if (dataLayer.handler.isRelevant(p)) {
    71                                 double dist = distance(source, p);
    72                                 if (dist <= maxDistance) {
    73                                         if (dataLayer.handler.equals(p, source)) {
    74                                                 //samePrimitives.add(p);
    75                                                 if (nearestSamePrimitive == null || distance(p, nearestSamePrimitive) > dist) {
    76                                                         nearestSamePrimitive = p;
    77                                                 }
    78                                         } else {
    79                                                 //potentialPrimitives.add(p);
    80                                                 if (nearestPotentialPrimitive == null || distance(p, nearestPotentialPrimitive) > dist) {
    81                                                         nearestPotentialPrimitive = p;
    82                                                 }
    83                                         }
    84                                 }
    85                         }
    86                 }
    87                 return nearestSamePrimitive != null ? nearestSamePrimitive : nearestPotentialPrimitive;
    88         }
     24    private final OdDataLayer dataLayer;
     25   
     26    public final List<Pair<OsmPrimitive,OsmPrimitive>> differentPrimitives;
     27    public final List<OsmPrimitive> onlyInTlsPrimitives;
     28    public final List<OsmPrimitive> onlyInOsmPrimitives;
     29   
     30    public OdDiffLayer(OdDataLayer dataLayer, String name) {
     31        super(name);
     32        this.dataLayer = dataLayer;
     33        this.differentPrimitives = new ArrayList<>();
     34        this.onlyInTlsPrimitives = new ArrayList<>();
     35        this.onlyInOsmPrimitives = new ArrayList<>();
     36        initDiff(dataLayer.data, dataLayer.osmLayer.data);
     37    }
     38   
     39    private void initDiff(DataSet tlsData, DataSet osmData) {
     40        for (OsmPrimitive p1 : tlsData.allPrimitives()) {
     41            if (dataLayer.handler.isRelevant(p1)) {
     42                OsmPrimitive p2 = findPrimitiveAt(osmData, p1);
     43                if (p2 == null) {
     44                    onlyInTlsPrimitives.add(p1);
     45                } else if (!dataLayer.handler.equals(p1, p2)) {
     46                    differentPrimitives.add(new Pair<>(p1, p2));
     47                }
     48            }
     49        }
     50        for (OsmPrimitive p1 : osmData.allPrimitives()) {
     51            if (dataLayer.handler.isRelevant(p1)) {
     52                if (findPrimitiveAt(tlsData, p1) == null) {
     53                    onlyInOsmPrimitives.add(p1);
     54                }
     55            }
     56        }
     57    }
     58   
     59    private double distance(OsmPrimitive p1, OsmPrimitive p2) {
     60        return p1.getBBox().getCenter().greatCircleDistance(p2.getBBox().getCenter());
     61    }
     62   
     63    private OsmPrimitive findPrimitiveAt(DataSet dataSet, OsmPrimitive source) {
     64        double maxDistance = Main.pref.getDouble(OdConstants.PREF_MAXDISTANCE, OdConstants.DEFAULT_MAXDISTANCE);
     65        //List<OsmPrimitive> samePrimitives = new ArrayList<OsmPrimitive>();
     66        OsmPrimitive nearestSamePrimitive = null;
     67        //List<OsmPrimitive> potentialPrimitives = new ArrayList<OsmPrimitive>();
     68        OsmPrimitive nearestPotentialPrimitive = null;
     69        for (OsmPrimitive p : dataSet.allPrimitives()) {
     70            if (dataLayer.handler.isRelevant(p)) {
     71                double dist = distance(source, p);
     72                if (dist <= maxDistance) {
     73                    if (dataLayer.handler.equals(p, source)) {
     74                        //samePrimitives.add(p);
     75                        if (nearestSamePrimitive == null || distance(p, nearestSamePrimitive) > dist) {
     76                            nearestSamePrimitive = p;
     77                        }
     78                    } else {
     79                        //potentialPrimitives.add(p);
     80                        if (nearestPotentialPrimitive == null || distance(p, nearestPotentialPrimitive) > dist) {
     81                            nearestPotentialPrimitive = p;
     82                        }
     83                    }
     84                }
     85            }
     86        }
     87        return nearestSamePrimitive != null ? nearestSamePrimitive : nearestPotentialPrimitive;
     88    }
    8989
    90         @Override
    91         public void paint(Graphics2D g, MapView mv, Bounds box) {
    92                 // TODO Auto-generated method stub
    93         }
     90    @Override
     91    public void paint(Graphics2D g, MapView mv, Bounds box) {
     92        // TODO Auto-generated method stub
     93    }
    9494
    95         @Override
    96         public Icon getIcon() {
    97                 return ImageProvider.get("layer", "diff");
    98         }
     95    @Override
     96    public Icon getIcon() {
     97        return ImageProvider.get("layer", "diff");
     98    }
    9999
    100         @Override
    101         public String getToolTipText() {
    102                 // TODO Auto-generated method stub
    103                 return null;
    104         }
     100    @Override
     101    public String getToolTipText() {
     102        // TODO Auto-generated method stub
     103        return null;
     104    }
    105105
    106         @Override
    107         public void mergeFrom(Layer from) {
    108         }
     106    @Override
     107    public void mergeFrom(Layer from) {
     108    }
    109109
    110         @Override
    111         public boolean isMergable(Layer other) {
    112                 return false;
    113         }
     110    @Override
     111    public boolean isMergable(Layer other) {
     112        return false;
     113    }
    114114
    115         @Override
    116         public void visitBoundingBox(BoundingXYVisitor v) {
    117                 // TODO Auto-generated method stub
    118         }
     115    @Override
     116    public void visitBoundingBox(BoundingXYVisitor v) {
     117        // TODO Auto-generated method stub
     118    }
    119119
    120         @Override
    121         public Object getInfoComponent() {
    122                 // TODO Auto-generated method stub
    123                 return null;
    124         }
     120    @Override
     121    public Object getInfoComponent() {
     122        // TODO Auto-generated method stub
     123        return null;
     124    }
    125125
    126         @Override
    127         public Action[] getMenuEntries() {
    128                 return null;
    129         }
     126    @Override
     127    public Action[] getMenuEntries() {
     128        return null;
     129    }
    130130
    131         @Override
    132         public OdDataLayer getDataLayer() {
    133                 return dataLayer;
    134         }
     131    @Override
     132    public OdDataLayer getDataLayer() {
     133        return dataLayer;
     134    }
    135135}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/layers/OdLayer.java

    r30340 r30723  
    33
    44public interface OdLayer {
    5         public OdDataLayer getDataLayer();
     5    public OdDataLayer getDataLayer();
    66}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/layers/OdOsmDataLayer.java

    r30532 r30723  
    1616public class OdOsmDataLayer extends OsmDataLayer implements OdLayer {
    1717
    18         private final OdDataLayer dataLayer;
     18    private final OdDataLayer dataLayer;
    1919
    20         public OdOsmDataLayer(OdDataLayer dataLayer, DataSet data, String name) {
    21                 super(data, name, null);
    22                 this.dataLayer = dataLayer;
    23         }
    24        
     20    public OdOsmDataLayer(OdDataLayer dataLayer, DataSet data, String name) {
     21        super(data, name, null);
     22        this.dataLayer = dataLayer;
     23    }
     24   
    2525    public final void removeForbiddenTags() {
    26                 if (dataLayer != null && dataLayer.handler != null && dataLayer.handler.hasForbiddenTags()) {
    27                         Main.worker.submit(new Runnable() {
    28                                 @Override
    29                                 public void run() {
    30                                         data.clearSelection();
    31                                         for (Iterator<OsmPrimitive> it = data.allPrimitives().iterator(); it.hasNext();) {
    32                                                 OsmPrimitive p = it.next();
    33                                                 if (dataLayer.handler.isForbidden(p)) {
    34                                                         data.addSelected(p);
    35                                                        
    36                                                         List<Node> nodes = null;
    37                                                         if (p instanceof Way) {
    38                                                                 nodes = ((Way) p).getNodes();
    39                                                         }
    40                                                         //data.removePrimitive(p);
    41                                                         if (nodes != null) {
    42                                                                 for (Node n : nodes) {
    43                                                                         List<OsmPrimitive> refferingAllowedWays = new ArrayList<>();
    44                                                                         for (OsmPrimitive referrer : n.getReferrers()) {
    45                                                                                 if (referrer instanceof Way && !dataLayer.handler.isForbidden(referrer)) {
    46                                                                                         refferingAllowedWays.add(referrer);
    47                                                                                 }
    48                                                                         }
    49                                                                        
    50                                                                         if (refferingAllowedWays.isEmpty()) {
    51                                                                                 //data.removePrimitive(n);
    52                                                                                 data.addSelected(n);
    53                                                                         }
    54                                                                 }
    55                                                         }
    56                                                         /*for (OsmPrimitive referrer : p.getReferrers()) {
    57                                                                 System.out.println(referrer);
    58                                                         }*/
    59                                                 }
    60                                         }
    61                                         Collection<OsmPrimitive> sel = data.getSelected();
    62                                         if (!sel.isEmpty()) {
    63                                                 Main.main.menu.purge.actionPerformed(null);
    64                                         }
    65                                 }
    66                         });
    67                 }
     26        if (dataLayer != null && dataLayer.handler != null && dataLayer.handler.hasForbiddenTags()) {
     27            Main.worker.submit(new Runnable() {
     28                @Override
     29                public void run() {
     30                    data.clearSelection();
     31                    for (Iterator<OsmPrimitive> it = data.allPrimitives().iterator(); it.hasNext();) {
     32                        OsmPrimitive p = it.next();
     33                        if (dataLayer.handler.isForbidden(p)) {
     34                            data.addSelected(p);
     35                           
     36                            List<Node> nodes = null;
     37                            if (p instanceof Way) {
     38                                nodes = ((Way) p).getNodes();
     39                            }
     40                            //data.removePrimitive(p);
     41                            if (nodes != null) {
     42                                for (Node n : nodes) {
     43                                    List<OsmPrimitive> refferingAllowedWays = new ArrayList<>();
     44                                    for (OsmPrimitive referrer : n.getReferrers()) {
     45                                        if (referrer instanceof Way && !dataLayer.handler.isForbidden(referrer)) {
     46                                            refferingAllowedWays.add(referrer);
     47                                        }
     48                                    }
     49                                   
     50                                    if (refferingAllowedWays.isEmpty()) {
     51                                        //data.removePrimitive(n);
     52                                        data.addSelected(n);
     53                                    }
     54                                }
     55                            }
     56                            /*for (OsmPrimitive referrer : p.getReferrers()) {
     57                                System.out.println(referrer);
     58                            }*/
     59                        }
     60                    }
     61                    Collection<OsmPrimitive> sel = data.getSelected();
     62                    if (!sel.isEmpty()) {
     63                        Main.main.menu.purge.actionPerformed(null);
     64                    }
     65                }
     66            });
     67        }
    6868    }
    6969
    70         @Override
    71         public OdDataLayer getDataLayer() {
    72                 return dataLayer;
    73         }
     70    @Override
     71    public OdDataLayer getDataLayer() {
     72        return dataLayer;
     73    }
    7474}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/licenses/LOOL.java

    r30563 r30723  
    66
    77public class LOOL extends License {
    8        
     8   
    99    //public static final String URL_FR = "http://www.data.gouv.fr/Licence-Ouverte-Open-Licence";
    1010   
    11         public LOOL() {
    12                 setIcon(OdUtils.getImageIcon(OdConstants.ICON_LOOL_48, true));
    13                 setURL(LOOL.class.getResource(OdConstants.RESOURCE_PATH+"Licence-Ouverte-Open-Licence-ENG.rtf"), "en");
    14                 setURL(LOOL.class.getResource(OdConstants.RESOURCE_PATH+"Licence-Ouverte-Open-Licence.rtf"), "fr");
    15         }
     11    public LOOL() {
     12        setIcon(OdUtils.getImageIcon(OdConstants.ICON_LOOL_48, true));
     13        setURL(LOOL.class.getResource(OdConstants.RESOURCE_PATH+"Licence-Ouverte-Open-Licence-ENG.rtf"), "en");
     14        setURL(LOOL.class.getResource(OdConstants.RESOURCE_PATH+"Licence-Ouverte-Open-Licence.rtf"), "fr");
     15    }
    1616}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/licenses/License.java

    r30532 r30723  
    1313
    1414public abstract class License {
    15        
    16         public static final ODbL ODbL = new ODbL();
    17         public static final LOOL LOOL = new LOOL();
    18        
    19         private final Map<String, URL> urls = new HashMap<>();
    20         private final Map<String, URL> summaryURLs = new HashMap<>();
    21        
    22         private Icon icon;
    23        
    24         private static final URL getURL(Map<String, URL> map) {
    25                 // Find URL for current language
    26                 String lang = OdUtils.getJosmLanguage();
    27                 for (String l : map.keySet()) {
    28                         if (lang.startsWith(l)) {
    29                                 return map.get(l);
    30                         }
    31                 }
    32                 // If not found, return english URL
    33                 URL url = map.get("en");
    34                 if (url != null) {
    35                         return url;
    36                 }
    37                 // If not found, return first non-null url
    38                 if (map.keySet().size() > 0) {
    39                         for (Iterator<String> it=map.keySet().iterator(); it.hasNext(); ) {
    40                                 url = map.get(it.next());
    41                                 if (url != null) {
    42                                         return url;
    43                                 }
    44                         }
    45                 }
    46                 // If empty, return null
    47                 return null;
    48         }
     15   
     16    public static final ODbL ODbL = new ODbL();
     17    public static final LOOL LOOL = new LOOL();
     18   
     19    private final Map<String, URL> urls = new HashMap<>();
     20    private final Map<String, URL> summaryURLs = new HashMap<>();
     21   
     22    private Icon icon;
     23   
     24    private static final URL getURL(Map<String, URL> map) {
     25        // Find URL for current language
     26        String lang = OdUtils.getJosmLanguage();
     27        for (String l : map.keySet()) {
     28            if (lang.startsWith(l)) {
     29                return map.get(l);
     30            }
     31        }
     32        // If not found, return english URL
     33        URL url = map.get("en");
     34        if (url != null) {
     35            return url;
     36        }
     37        // If not found, return first non-null url
     38        if (map.keySet().size() > 0) {
     39            for (Iterator<String> it=map.keySet().iterator(); it.hasNext(); ) {
     40                url = map.get(it.next());
     41                if (url != null) {
     42                    return url;
     43                }
     44            }
     45        }
     46        // If empty, return null
     47        return null;
     48    }
    4949
    50         public URL getURL() {
    51                 return getURL(urls);
    52         }
     50    public URL getURL() {
     51        return getURL(urls);
     52    }
    5353
    54         public URL getSummaryURL() {
    55                 return getURL(summaryURLs);
    56         }
    57        
    58         public final void setURL(URL url) {
    59                 setURL(url, "en");
    60         }
     54    public URL getSummaryURL() {
     55        return getURL(summaryURLs);
     56    }
     57   
     58    public final void setURL(URL url) {
     59        setURL(url, "en");
     60    }
    6161
    62         public final void setURL(String url, String lang) throws MalformedURLException {
    63                 setURL(new URL(url), lang);
    64         }
     62    public final void setURL(String url, String lang) throws MalformedURLException {
     63        setURL(new URL(url), lang);
     64    }
    6565
    66         public final void setURL(String url) throws MalformedURLException {
    67                 setURL(new URL(url), "en");
    68         }
     66    public final void setURL(String url) throws MalformedURLException {
     67        setURL(new URL(url), "en");
     68    }
    6969
    70         public final void setURL(URL url, String lang) {
    71                 if (url != null) {
    72                         urls.put(lang, url);
    73                 }
    74         }
     70    public final void setURL(URL url, String lang) {
     71        if (url != null) {
     72            urls.put(lang, url);
     73        }
     74    }
    7575
    76         public final void setSummaryURL(URL url) {
    77                 setSummaryURL(url, "en");
    78         }
     76    public final void setSummaryURL(URL url) {
     77        setSummaryURL(url, "en");
     78    }
    7979
    80         public final void setSummaryURL(String url, String lang) throws MalformedURLException {
    81                 setSummaryURL(new URL(url), lang);
    82         }
     80    public final void setSummaryURL(String url, String lang) throws MalformedURLException {
     81        setSummaryURL(new URL(url), lang);
     82    }
    8383
    84         public final void setSummaryURL(String url) throws MalformedURLException {
    85                 setSummaryURL(new URL(url), "en");
    86         }
     84    public final void setSummaryURL(String url) throws MalformedURLException {
     85        setSummaryURL(new URL(url), "en");
     86    }
    8787
    88         public final void setSummaryURL(URL url, String lang) {
    89                 if (url != null) {
    90                         summaryURLs.put(lang, url);
    91                 }
    92         }
     88    public final void setSummaryURL(URL url, String lang) {
     89        if (url != null) {
     90            summaryURLs.put(lang, url);
     91        }
     92    }
    9393
    94         public final Icon getIcon() {
    95                 return icon;
    96         }
     94    public final Icon getIcon() {
     95        return icon;
     96    }
    9797
    98         public final void setIcon(Icon icon) {
    99                 this.icon = icon;
    100         }
     98    public final void setIcon(Icon icon) {
     99        this.icon = icon;
     100    }
    101101
    102         @Override
    103         public String toString() {
    104                 return "License [" + (urls != null ? "urls=" + urls + ", " : "")
    105                                 + (summaryURLs != null ? "summaryURLs=" + summaryURLs : "")
    106                                 + "]";
    107         }
     102    @Override
     103    public String toString() {
     104        return "License [" + (urls != null ? "urls=" + urls + ", " : "")
     105                + (summaryURLs != null ? "summaryURLs=" + summaryURLs : "")
     106                + "]";
     107    }
    108108}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/licenses/ODbL.java

    r30563 r30723  
    55
    66public class ODbL extends License {
    7        
     7   
    88    //public static final String URL            = "http://opendatacommons.org/licenses/odbl/1-0";
    99    //public static final String SUMMARY_URL    = "http://opendatacommons.org/licenses/odbl/summary";
     
    1111    //public static final String SUMMARY_URL_FR = "http://vvlibri.org/fr/licence/odbl/10/fr";
    1212   
    13         public ODbL() {
    14                 for (String lang : new String[]{"", "fr"}) {
    15                         if (lang.isEmpty()) {
    16                                 setURL(ODbL.class.getResource(OdConstants.RESOURCE_PATH+"odbl-1.0.htm"));
    17                                 setSummaryURL(ODbL.class.getResource(OdConstants.RESOURCE_PATH+"odbl-summary-1.0.htm"));
    18                         } else {
    19                                 setURL(ODbL.class.getResource(OdConstants.RESOURCE_PATH+"odbl-1.0-"+lang+".htm"), lang);
    20                                 setSummaryURL(ODbL.class.getResource(OdConstants.RESOURCE_PATH+"odbl-summary-1.0-"+lang+".htm"), lang);
    21                         }
    22                 }
    23         }
     13    public ODbL() {
     14        for (String lang : new String[]{"", "fr"}) {
     15            if (lang.isEmpty()) {
     16                setURL(ODbL.class.getResource(OdConstants.RESOURCE_PATH+"odbl-1.0.htm"));
     17                setSummaryURL(ODbL.class.getResource(OdConstants.RESOURCE_PATH+"odbl-summary-1.0.htm"));
     18            } else {
     19                setURL(ODbL.class.getResource(OdConstants.RESOURCE_PATH+"odbl-1.0-"+lang+".htm"), lang);
     20                setSummaryURL(ODbL.class.getResource(OdConstants.RESOURCE_PATH+"odbl-summary-1.0-"+lang+".htm"), lang);
     21            }
     22        }
     23    }
    2424}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/modules/AbstractModule.java

    r30563 r30723  
    1919public abstract class AbstractModule implements Module {
    2020
    21         protected final List<Class<? extends AbstractDataSetHandler>> handlers = new ArrayList<>();
     21    protected final List<Class<? extends AbstractDataSetHandler>> handlers = new ArrayList<>();
    2222
    23         private final List<AbstractDataSetHandler> instanciatedHandlers = new ArrayList<>();
     23    private final List<AbstractDataSetHandler> instanciatedHandlers = new ArrayList<>();
    2424
    25         protected final ModuleInformation info;
    26        
    27         public AbstractModule(ModuleInformation info) {
    28                 this.info = info;
    29         }
     25    protected final ModuleInformation info;
     26   
     27    public AbstractModule(ModuleInformation info) {
     28        this.info = info;
     29    }
    3030
    31         @Override
    32         public ModuleInformation getModuleInformation() {
    33                 return info;
    34         }
     31    @Override
     32    public ModuleInformation getModuleInformation() {
     33        return info;
     34    }
    3535
    36         @Override
    37         public List<Class<? extends AbstractDataSetHandler>> getHandlers() {
    38                 return handlers;
    39         }
     36    @Override
     37    public List<Class<? extends AbstractDataSetHandler>> getHandlers() {
     38        return handlers;
     39    }
    4040
    41         @Override
    42         public String getDisplayedName() {
    43                 return info.name;
    44         }
     41    @Override
     42    public String getDisplayedName() {
     43        return info.name;
     44    }
    4545
    46         @Override
    47         public SourceProvider getMapPaintStyleSourceProvider() {
    48                 final List<SourceEntry> sources = new ArrayList<>();
    49                 for (AbstractDataSetHandler handler : getInstanciatedHandlers()) {
    50                         ExtendedSourceEntry src;
    51                         if (handler != null && (src = handler.getMapPaintStyle()) != null) {
    52                                 try {
    53                                         // Copy style sheet to disk to allow JOSM to load it at startup (even making the plugin "early" does not allow it)
    54                                         String path = OdPlugin.getInstance().getResourcesDirectory()+File.separator+src.url.replace(OdConstants.PROTO_RSRC, "").replace('/', File.separatorChar);
    55                                        
    56                                         int n = 0;
    57                                         byte[] buffer = new byte[4096];
    58                                         InputStream in = getClass().getResourceAsStream(src.url.substring(OdConstants.PROTO_RSRC.length()-1));
    59                                         new File(path.substring(0, path.lastIndexOf(File.separatorChar))).mkdirs();
    60                                         FileOutputStream out = new FileOutputStream(path);
    61                                         while ((n = in.read(buffer)) > 0) {
    62                                                 out.write(buffer, 0, n);
    63                                         }
    64                                         out.close();
    65                                         in.close();
     46    @Override
     47    public SourceProvider getMapPaintStyleSourceProvider() {
     48        final List<SourceEntry> sources = new ArrayList<>();
     49        for (AbstractDataSetHandler handler : getInstanciatedHandlers()) {
     50            ExtendedSourceEntry src;
     51            if (handler != null && (src = handler.getMapPaintStyle()) != null) {
     52                try {
     53                    // Copy style sheet to disk to allow JOSM to load it at startup (even making the plugin "early" does not allow it)
     54                    String path = OdPlugin.getInstance().getResourcesDirectory()+File.separator+src.url.replace(OdConstants.PROTO_RSRC, "").replace('/', File.separatorChar);
     55                   
     56                    int n = 0;
     57                    byte[] buffer = new byte[4096];
     58                    InputStream in = getClass().getResourceAsStream(src.url.substring(OdConstants.PROTO_RSRC.length()-1));
     59                    new File(path.substring(0, path.lastIndexOf(File.separatorChar))).mkdirs();
     60                    FileOutputStream out = new FileOutputStream(path);
     61                    while ((n = in.read(buffer)) > 0) {
     62                        out.write(buffer, 0, n);
     63                    }
     64                    out.close();
     65                    in.close();
    6666
    67                                         // Add source pointing to the local file
    68                                         src.url = OdConstants.PROTO_FILE+path;
    69                                         sources.add(src);
    70                                 } catch (IOException e) {
    71                                         System.err.println(e.getMessage());
    72                                 }
    73                         }
    74                 }
    75                 return sources.isEmpty() ? null : new SourceProvider() {
    76                         @Override
    77                         public Collection<SourceEntry> getSources() {
    78                                 return sources;
    79                         }
    80                 };
    81         }
     67                    // Add source pointing to the local file
     68                    src.url = OdConstants.PROTO_FILE+path;
     69                    sources.add(src);
     70                } catch (IOException e) {
     71                    System.err.println(e.getMessage());
     72                }
     73            }
     74        }
     75        return sources.isEmpty() ? null : new SourceProvider() {
     76            @Override
     77            public Collection<SourceEntry> getSources() {
     78                return sources;
     79            }
     80        };
     81    }
    8282
    83         @Override
    84         public SourceProvider getPresetSourceProvider() {
    85                 final List<SourceEntry> sources = new ArrayList<>();
    86                 for (AbstractDataSetHandler handler : getInstanciatedHandlers()) {
    87                         if (handler != null && handler.getTaggingPreset() != null) {
    88                                 sources.add(handler.getTaggingPreset());
    89                         }
    90                 }
    91                 return sources.isEmpty() ? null : new SourceProvider() {
    92                         @Override
    93                         public Collection<SourceEntry> getSources() {
    94                                 return sources;
    95                         }
    96                 };
    97         }
    98        
    99         @Override
    100         public final List<AbstractDataSetHandler> getNewlyInstanciatedHandlers() {
    101                 List<AbstractDataSetHandler> result = new ArrayList<>();
    102                 for (Class<? extends AbstractDataSetHandler> handlerClass : handlers) {
    103                         if (handlerClass != null) {
    104                                 try {
    105                                         result.add(handlerClass.newInstance());
    106                                 } catch (Throwable t) {
    107                                         System.err.println("Cannot instantiate "+handlerClass+" because of "+t.getClass().getName()+": "+t.getMessage());
    108                                 }
    109                         }
    110                 }
    111                 return result;
    112         }
     83    @Override
     84    public SourceProvider getPresetSourceProvider() {
     85        final List<SourceEntry> sources = new ArrayList<>();
     86        for (AbstractDataSetHandler handler : getInstanciatedHandlers()) {
     87            if (handler != null && handler.getTaggingPreset() != null) {
     88                sources.add(handler.getTaggingPreset());
     89            }
     90        }
     91        return sources.isEmpty() ? null : new SourceProvider() {
     92            @Override
     93            public Collection<SourceEntry> getSources() {
     94                return sources;
     95            }
     96        };
     97    }
     98   
     99    @Override
     100    public final List<AbstractDataSetHandler> getNewlyInstanciatedHandlers() {
     101        List<AbstractDataSetHandler> result = new ArrayList<>();
     102        for (Class<? extends AbstractDataSetHandler> handlerClass : handlers) {
     103            if (handlerClass != null) {
     104                try {
     105                    result.add(handlerClass.newInstance());
     106                } catch (Throwable t) {
     107                    System.err.println("Cannot instantiate "+handlerClass+" because of "+t.getClass().getName()+": "+t.getMessage());
     108                }
     109            }
     110        }
     111        return result;
     112    }
    113113
    114         private final List<AbstractDataSetHandler> getInstanciatedHandlers() {
    115                 if (instanciatedHandlers.isEmpty()) {
    116                         instanciatedHandlers.addAll(getNewlyInstanciatedHandlers());
    117                 }
    118                 return instanciatedHandlers;
    119         }
     114    private final List<AbstractDataSetHandler> getInstanciatedHandlers() {
     115        if (instanciatedHandlers.isEmpty()) {
     116            instanciatedHandlers.addAll(getNewlyInstanciatedHandlers());
     117        }
     118        return instanciatedHandlers;
     119    }
    120120}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/modules/Module.java

    r30340 r30723  
    99public interface Module {
    1010
    11         public String getDisplayedName();
     11    public String getDisplayedName();
    1212
    13         public List<Class<? extends AbstractDataSetHandler>> getHandlers();
     13    public List<Class<? extends AbstractDataSetHandler>> getHandlers();
    1414
    15         public List<AbstractDataSetHandler> getNewlyInstanciatedHandlers();
     15    public List<AbstractDataSetHandler> getNewlyInstanciatedHandlers();
    1616
    17         public SourceProvider getMapPaintStyleSourceProvider();
    18        
    19         public SourceProvider getPresetSourceProvider();
    20        
    21         public ModuleInformation getModuleInformation();
     17    public SourceProvider getMapPaintStyleSourceProvider();
     18   
     19    public SourceProvider getPresetSourceProvider();
     20   
     21    public ModuleInformation getModuleInformation();
    2222}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/modules/ModuleHandler.java

    r30563 r30723  
    230230                Module mod = module.load(klass);
    231231                if (moduleList.add(mod)) {
    232                         SourceProvider styleProvider = mod.getMapPaintStyleSourceProvider();
    233                         if (styleProvider != null) {
    234                                 MapPaintPreference.registerSourceProvider(styleProvider);
    235                         }
    236                         SourceProvider presetProvider = mod.getPresetSourceProvider();
    237                         if (presetProvider != null) {
    238                                 TaggingPresetPreference.registerSourceProvider(presetProvider);
    239                         }
     232                    SourceProvider styleProvider = mod.getMapPaintStyleSourceProvider();
     233                    if (styleProvider != null) {
     234                        MapPaintPreference.registerSourceProvider(styleProvider);
     235                    }
     236                    SourceProvider presetProvider = mod.getPresetSourceProvider();
     237                    if (presetProvider != null) {
     238                        TaggingPresetPreference.registerSourceProvider(presetProvider);
     239                    }
    240240                }
    241241            }
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/modules/ModuleInformation.java

    r30563 r30723  
    145145   
    146146    private static final ImageIcon extractIcon(String iconPath, File jarFile, boolean suppressWarnings) {
    147         return new ImageProvider(iconPath).setArchive(jarFile).setMaxWidth(24).setMaxHeight(24).setOptional(true).setSuppressWarnings(suppressWarnings).get();
     147        return new ImageProvider(iconPath).setArchive(jarFile).setMaxWidth(24).setMaxHeight(24).setOptional(true).setSuppressWarnings(suppressWarnings).get();
    148148    }
    149149
     
    159159            try {
    160160                @SuppressWarnings("unused")
    161                                 URL url = new URL(s);
     161                URL url = new URL(s);
    162162            } catch (MalformedURLException e) {
    163163                System.out.println(tr("Invalid URL ''{0}'' in module {1}", s, name));
     
    183183            // if not found, extract icon from the plugin jar file
    184184            if (icon == null) {
    185                 icon = extractIcon(iconPath, OdPlugin.getInstance().getPluginInformation().file, true);
     185                icon = extractIcon(iconPath, OdPlugin.getInstance().getPluginInformation().file, true);
    186186            }
    187187        }
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/util/NamesFrUtils.java

    r30563 r30723  
    1616
    1717public abstract class NamesFrUtils {
    18        
    19         private static Map<String, String> dictionary = initDictionary();
    20 
    21         public static final String checkDictionary(String value) {
    22                 String result = "";
    23                 for (String word : value.split(" ")) {
    24                         if (!result.isEmpty()) {
    25                                 result += " ";
    26                         }
    27                         result += dictionary.containsKey(word) ?  dictionary.get(word) : word;
    28                 }
    29                 return result;
    30         }
    31        
    32         private static Map<String, String> initDictionary() {
    33                 Map<String, String> result = new HashMap<>();
    34                 try {
    35                         BufferedReader reader = new BufferedReader(new InputStreamReader(
    36                                         SimpleDataSetHandler.class.getResourceAsStream(OdConstants.DICTIONARY_FR), OdConstants.UTF8));
    37                         String line = reader.readLine(); // Skip first line
    38                         while ((line = reader.readLine()) != null) {
    39                                 String[] tab = line.split(";");
    40                                 result.put(tab[0].replace("\"", ""), tab[1].replace("\"", ""));
    41                         }
    42                         reader.close();
    43                 } catch (IOException e) {
    44                         e.printStackTrace();
    45                 }
    46                 return result;
    47         }
    48 
    49         public static final String getStreetLabel(String label) {
    50                 if (label == null) {
    51                         return label;
    52                 } else if (label.equals("All")) {
    53                         return "Allée";
    54                 } else if (label.equals("Autoroute")) {
    55                         return label;
    56                 } else if (label.startsWith("Anc")) { // Anc, Ancien
    57                         return "Ancien";
    58                 } else if (label.equals("Av")) {
    59                         return "Avenue";
    60                 } else if (label.equals("Bd")) {
    61                         return "Boulevard";
    62                 } else if (label.equals("Bre")) {
    63                         return "Bré";
    64                 } else if (label.equals("Caminot")) {
    65                         return label;
    66                 } else if (label.equals("Carrefour")) {
    67                         return label;
    68                 } else if (label.startsWith("Che")) { // Che, Chem
    69                         return "Chemin";
    70                 } else if (label.equals("Cite")) {
    71                         return "Cité";
    72                 } else if (label.equals("Clos")) {
    73                         return label;
    74                 } else if (label.equals("Cote")) {
    75                         return "Côte";
    76                 } else if (label.equals("Cours")) {
    77                         return label;
    78                 } else if (label.equals("Dom")) {
    79                         return "Domaine";
    80                 } else if (label.equals("Dsc")) {
    81                         return "Descente";
    82                 } else if (label.equals("Esp")) {
    83                         return "Esplanade";
    84                 } else if (label.equals("Espa")) {
    85                         return "Espace";
    86                 } else if (label.equals("Giratoire")) {
    87                         return label;
    88                 } else if (label.equals("Grande-rue")) {
    89                         return label;
    90                 } else if (label.equals("Hameau")) {
    91                         return label;
    92                 } else if (label.equals("Imp")) {
    93                         return "Impasse";
    94                 } else if (label.equals("Itineraire")) {
    95                         return "Itinéraire";
    96                 } else if (label.equals("Jardin")) {
    97                         return label;
    98                 } else if (label.startsWith("L'") || label.equals("La") || label.equals("Le") || label.equals("Les") || label.equals("Saint")) { // Lieux-dits
    99                         return label;
    100                 } else if (label.equals("Lot")) {
    101                         return "Lotissement";
    102                 } else if (label.equals("Mail")) {
    103                         return label;
    104                 } else if (label.equals("Mas")) {
    105                         return label;
    106                 } else if (label.equals("Parc")) {
    107                         return label;
    108                 } else if (label.equals("Pas")) {
    109                         return "Passage";
    110                 } else if (label.equals("Passerelle")) {
    111                         return label;
    112                 } else if (label.equals("Pch")) {
    113                         return "Petit Chemin";
    114                 } else if (label.equals("Petit")) {
    115                         return label;
    116                 } else if (label.equals("Petite-allée")) {
    117                         return label;
    118                 } else if (label.equals("Petite-rue")) {
    119                         return label;
    120                 } else if (label.equals("Pl")) {
    121                         return "Place";
    122                 } else if (label.equals("Plan")) {
    123                         return label;
    124                 } else if (label.equals("Pont")) {
    125                         return label;
    126                 } else if (label.equals("Port")) {
    127                         return label;
    128                 } else if (label.equals("Porte")) {
    129                         return label;
    130                 } else if (label.equals("Prom")) {
    131                         return "Promenade";
    132                 } else if (label.equals("Prv")) {
    133                         return "Parvis";
    134                 } else if (label.equals("Qu")) {
    135                         return "Quai";
    136                 } else if (label.equals("Rampe")) {
    137                         return label;
    138                 } else if (label.equals("Residence")) {
    139                         return "Résidence";
    140                 } else if (label.equals("Rocade")) {
    141                         return label;
    142                 } else if (label.equals("Rpt")) {
    143                         return "Rond-Point";
    144                 } else if (label.equals("Rte")) {
    145                         return "Route";
    146                 } else if (label.equals("Rue")) {
    147                         return label;
    148                 } else if (label.equals("Sentier")) {
    149                         return label;
    150                 } else if (label.equals("Sq")) {
    151                         return "Square";
    152                 } else if (label.equals("Tra")) {
    153                         return "Traverse";
    154                 } else if (label.equals("Vieux")) {
    155                         return label;
    156                 } else if (label.equals("Voie")) {
    157                         return label;
    158                 } else if (label.equals("Zone")) {
    159                         return label;
    160                 } else {
    161                         System.err.println("Warning: unknown street label: "+label);
    162                         return label;
    163                 }
    164         }
    165 
    166         public static final String checkStreetName(OsmPrimitive p, String key) {
    167                 String value = null;
    168                 if (p != null) {
    169                         value = p.get(key);
    170                         if (value != null) {
    171                                 value = WordUtils.capitalizeFully(value);
    172                                 // Cas particuliers
    173                                 if (value.equals("Boulingrin")) { // square Boulingrin, mal formé
    174                                         value = "Sq Boulingrin";
    175                                 } else if (value.matches("A[0-9]+")) { // Autoroutes sans le mot "Autoroute"
    176                                         value = "Autoroute "+value;
    177                                 } else if (value.equals("All A61")) { // A61 qualifiée d'Allée ?
    178                                         value = "Autoroute A61";
    179                                 } else if (value.startsWith("Che Vieux Che")) { // "Che" redondant
    180                                         value = value.replaceFirst("Che ", "");
    181                                 } else if (value.startsWith("Petite Allee ")) { // Tiret, comme grand-rue, petite-rue
    182                                         value = value.replaceFirst("Petite Allee ", "Petite-allée ");
    183                                 } else if (value.startsWith("Ld De ")) { // Lieux-dit
    184                                         value = value.replaceFirst("Ld De ", "");
    185                                 }
    186                                 while (value.startsWith("Ld ")) { // Lieux-dit, inutile. Plus le cas avec "Ld Ld"
    187                                         value = value.replaceFirst("Ld ", "");
    188                                 }
    189                                 if (value.startsWith("L ")) {
    190                                         value = value.replaceFirst("L ", "L'");
    191                                 }
    192                                 String[] words = value.split(" ");
    193                                 if (words.length > 0) {
    194                                         value = "";
    195                                         List<String> list = Arrays.asList(words);
    196                                         words[0] = getStreetLabel(words[0]);
    197                                         if (words[0].equals("Ancien") && words.length > 1 && words[1].equals("Che")) {
    198                                                 words[1] = "Chemin";
    199                                         }
    200                                         for (int i = 0; i < words.length; i++) {
    201                                                 if (i > 0) {
    202                                                         value += " ";
    203                                                         // Prénoms/Noms propres abrégés
    204                                                         if (words[i].equals("A") && list.contains("Bernard")) {
    205                                                                 words[i] = "Arnaud";
    206                                                         } else if (words[i].equals("A") && list.contains("Passerieu")) {
    207                                                                 words[i] = "Ariste";
    208                                                         } else if (words[i].equals("A") && list.contains("Bougainville")) {
    209                                                                 words[i] = "Antoine";
    210                                                         } else if (words[i].equals("Ch") && list.contains("Leconte")) {
    211                                                                 words[i] = "Charles";
    212                                                         } else if (words[i].equals("Frs") && list.contains("Dugua")) {
    213                                                                 words[i] = "François";
    214                                                         } else if (words[i].equals("G") && list.contains("Latecoere")) {
    215                                                                 words[i] = "Georges";
    216                                                         } else if (words[i].equals("H") && list.contains("Lautrec")) {
    217                                                                 words[i] = "Henri";
    218                                                         } else if (words[i].equals("J") && list.contains("Dieulafoy")) {
    219                                                                 words[i] = "Jane";
    220                                                         } else if (words[i].equals("J") && (list.contains("Champollion") || list.contains("Stanislas"))) {
    221                                                                 words[i] = "Jean";
    222                                                         } else if (words[i].equals("L") && list.contains("Zamenhof")) {
    223                                                                 words[i] = "Ludwik";
    224                                                         } else if (words[i].equals("L") && list.contains("Sacha")) {
    225                                                                 words[i] = "Lucien";
    226                                                                 if (!list.contains("Et")) {
    227                                                                         words[i] += " et";
    228                                                                 }
    229                                                         } else if (words[i].equals("L") && (list.contains("Vauquelin") || list.contains("Bougainville"))) {
    230                                                                 words[i] = "Louis";
    231                                                         } else if (words[i].equals("M") && list.contains("Dieulafoy")) {
    232                                                                 words[i] = "Marcel";
    233                                                         } else if (words[i].equals("M") && list.contains("Arifat")) {
    234                                                                 words[i] = "Marie";
    235                                                         } else if (words[i].equals("N") && list.contains("Djamena")) {
    236                                                                 words[i] = "N'";
    237                                                         } else if (words[i].equals("Oo")) {
    238                                                                 words[i] = "Oô";
    239                                                         } else if (words[i].equals("Ph") && list.contains("Ravary")) {
    240                                                                 words[i] = "Philippe";
    241                                                         } else if (words[i].equals("R") && list.contains("Folliot")) {
    242                                                                 words[i] = "Raphaël";
    243                                                         } else if (words[i].equals("W") && list.contains("Booth")) {
    244                                                                 words[i] = "William";
    245                                                         // Mots de liaison non couverts par le dictionnaire
    246                                                         } else if (words[i].equals("A")) {
    247                                                                 words[i] = "à";
    248                                                         } else if (words[i].equals("D") || words[i].equals("L")) {
    249                                                                 words[i] = words[i].toLowerCase()+"'";
    250                                                         } else if (words[i].equals("La") || words[i].equals("Le")) {
    251                                                                 words[i] = words[i].toLowerCase();
    252                                                         }
    253                                                 }
    254                                                 value += words[i];
    255                                         }
    256                                 }
    257                                 // Ponctuation
    258                                 value = value.replace("' ", "'");
    259                                 // Dictionnaire
    260                                 value = checkDictionary(value);
    261                                 p.put(key, value);
    262                         }
    263                 }
    264                 return value;
    265         }
     18   
     19    private static Map<String, String> dictionary = initDictionary();
     20
     21    public static final String checkDictionary(String value) {
     22        String result = "";
     23        for (String word : value.split(" ")) {
     24            if (!result.isEmpty()) {
     25                result += " ";
     26            }
     27            result += dictionary.containsKey(word) ?  dictionary.get(word) : word;
     28        }
     29        return result;
     30    }
     31   
     32    private static Map<String, String> initDictionary() {
     33        Map<String, String> result = new HashMap<>();
     34        try {
     35            BufferedReader reader = new BufferedReader(new InputStreamReader(
     36                    SimpleDataSetHandler.class.getResourceAsStream(OdConstants.DICTIONARY_FR), OdConstants.UTF8));
     37            String line = reader.readLine(); // Skip first line
     38            while ((line = reader.readLine()) != null) {
     39                String[] tab = line.split(";");
     40                result.put(tab[0].replace("\"", ""), tab[1].replace("\"", ""));
     41            }
     42            reader.close();
     43        } catch (IOException e) {
     44            e.printStackTrace();
     45        }
     46        return result;
     47    }
     48
     49    public static final String getStreetLabel(String label) {
     50        if (label == null) {
     51            return label;
     52        } else if (label.equals("All")) {
     53            return "Allée";
     54        } else if (label.equals("Autoroute")) {
     55            return label;
     56        } else if (label.startsWith("Anc")) { // Anc, Ancien
     57            return "Ancien";
     58        } else if (label.equals("Av")) {
     59            return "Avenue";
     60        } else if (label.equals("Bd")) {
     61            return "Boulevard";
     62        } else if (label.equals("Bre")) {
     63            return "Bré";
     64        } else if (label.equals("Caminot")) {
     65            return label;
     66        } else if (label.equals("Carrefour")) {
     67            return label;
     68        } else if (label.startsWith("Che")) { // Che, Chem
     69            return "Chemin";
     70        } else if (label.equals("Cite")) {
     71            return "Cité";
     72        } else if (label.equals("Clos")) {
     73            return label;
     74        } else if (label.equals("Cote")) {
     75            return "Côte";
     76        } else if (label.equals("Cours")) {
     77            return label;
     78        } else if (label.equals("Dom")) {
     79            return "Domaine";
     80        } else if (label.equals("Dsc")) {
     81            return "Descente";
     82        } else if (label.equals("Esp")) {
     83            return "Esplanade";
     84        } else if (label.equals("Espa")) {
     85            return "Espace";
     86        } else if (label.equals("Giratoire")) {
     87            return label;
     88        } else if (label.equals("Grande-rue")) {
     89            return label;
     90        } else if (label.equals("Hameau")) {
     91            return label;
     92        } else if (label.equals("Imp")) {
     93            return "Impasse";
     94        } else if (label.equals("Itineraire")) {
     95            return "Itinéraire";
     96        } else if (label.equals("Jardin")) {
     97            return label;
     98        } else if (label.startsWith("L'") || label.equals("La") || label.equals("Le") || label.equals("Les") || label.equals("Saint")) { // Lieux-dits
     99            return label;
     100        } else if (label.equals("Lot")) {
     101            return "Lotissement";
     102        } else if (label.equals("Mail")) {
     103            return label;
     104        } else if (label.equals("Mas")) {
     105            return label;
     106        } else if (label.equals("Parc")) {
     107            return label;
     108        } else if (label.equals("Pas")) {
     109            return "Passage";
     110        } else if (label.equals("Passerelle")) {
     111            return label;
     112        } else if (label.equals("Pch")) {
     113            return "Petit Chemin";
     114        } else if (label.equals("Petit")) {
     115            return label;
     116        } else if (label.equals("Petite-allée")) {
     117            return label;
     118        } else if (label.equals("Petite-rue")) {
     119            return label;
     120        } else if (label.equals("Pl")) {
     121            return "Place";
     122        } else if (label.equals("Plan")) {
     123            return label;
     124        } else if (label.equals("Pont")) {
     125            return label;
     126        } else if (label.equals("Port")) {
     127            return label;
     128        } else if (label.equals("Porte")) {
     129            return label;
     130        } else if (label.equals("Prom")) {
     131            return "Promenade";
     132        } else if (label.equals("Prv")) {
     133            return "Parvis";
     134        } else if (label.equals("Qu")) {
     135            return "Quai";
     136        } else if (label.equals("Rampe")) {
     137            return label;
     138        } else if (label.equals("Residence")) {
     139            return "Résidence";
     140        } else if (label.equals("Rocade")) {
     141            return label;
     142        } else if (label.equals("Rpt")) {
     143            return "Rond-Point";
     144        } else if (label.equals("Rte")) {
     145            return "Route";
     146        } else if (label.equals("Rue")) {
     147            return label;
     148        } else if (label.equals("Sentier")) {
     149            return label;
     150        } else if (label.equals("Sq")) {
     151            return "Square";
     152        } else if (label.equals("Tra")) {
     153            return "Traverse";
     154        } else if (label.equals("Vieux")) {
     155            return label;
     156        } else if (label.equals("Voie")) {
     157            return label;
     158        } else if (label.equals("Zone")) {
     159            return label;
     160        } else {
     161            System.err.println("Warning: unknown street label: "+label);
     162            return label;
     163        }
     164    }
     165
     166    public static final String checkStreetName(OsmPrimitive p, String key) {
     167        String value = null;
     168        if (p != null) {
     169            value = p.get(key);
     170            if (value != null) {
     171                value = WordUtils.capitalizeFully(value);
     172                // Cas particuliers
     173                if (value.equals("Boulingrin")) { // square Boulingrin, mal formé
     174                    value = "Sq Boulingrin";
     175                } else if (value.matches("A[0-9]+")) { // Autoroutes sans le mot "Autoroute"
     176                    value = "Autoroute "+value;
     177                } else if (value.equals("All A61")) { // A61 qualifiée d'Allée ?
     178                    value = "Autoroute A61";
     179                } else if (value.startsWith("Che Vieux Che")) { // "Che" redondant
     180                    value = value.replaceFirst("Che ", "");
     181                } else if (value.startsWith("Petite Allee ")) { // Tiret, comme grand-rue, petite-rue
     182                    value = value.replaceFirst("Petite Allee ", "Petite-allée ");
     183                } else if (value.startsWith("Ld De ")) { // Lieux-dit
     184                    value = value.replaceFirst("Ld De ", "");
     185                }
     186                while (value.startsWith("Ld ")) { // Lieux-dit, inutile. Plus le cas avec "Ld Ld"
     187                    value = value.replaceFirst("Ld ", "");
     188                }
     189                if (value.startsWith("L ")) {
     190                    value = value.replaceFirst("L ", "L'");
     191                }
     192                String[] words = value.split(" ");
     193                if (words.length > 0) {
     194                    value = "";
     195                    List<String> list = Arrays.asList(words);
     196                    words[0] = getStreetLabel(words[0]);
     197                    if (words[0].equals("Ancien") && words.length > 1 && words[1].equals("Che")) {
     198                        words[1] = "Chemin";
     199                    }
     200                    for (int i = 0; i < words.length; i++) {
     201                        if (i > 0) {
     202                            value += " ";
     203                            // Prénoms/Noms propres abrégés
     204                            if (words[i].equals("A") && list.contains("Bernard")) {
     205                                words[i] = "Arnaud";
     206                            } else if (words[i].equals("A") && list.contains("Passerieu")) {
     207                                words[i] = "Ariste";
     208                            } else if (words[i].equals("A") && list.contains("Bougainville")) {
     209                                words[i] = "Antoine";
     210                            } else if (words[i].equals("Ch") && list.contains("Leconte")) {
     211                                words[i] = "Charles";
     212                            } else if (words[i].equals("Frs") && list.contains("Dugua")) {
     213                                words[i] = "François";
     214                            } else if (words[i].equals("G") && list.contains("Latecoere")) {
     215                                words[i] = "Georges";
     216                            } else if (words[i].equals("H") && list.contains("Lautrec")) {
     217                                words[i] = "Henri";
     218                            } else if (words[i].equals("J") && list.contains("Dieulafoy")) {
     219                                words[i] = "Jane";
     220                            } else if (words[i].equals("J") && (list.contains("Champollion") || list.contains("Stanislas"))) {
     221                                words[i] = "Jean";
     222                            } else if (words[i].equals("L") && list.contains("Zamenhof")) {
     223                                words[i] = "Ludwik";
     224                            } else if (words[i].equals("L") && list.contains("Sacha")) {
     225                                words[i] = "Lucien";
     226                                if (!list.contains("Et")) {
     227                                    words[i] += " et";
     228                                }
     229                            } else if (words[i].equals("L") && (list.contains("Vauquelin") || list.contains("Bougainville"))) {
     230                                words[i] = "Louis";
     231                            } else if (words[i].equals("M") && list.contains("Dieulafoy")) {
     232                                words[i] = "Marcel";
     233                            } else if (words[i].equals("M") && list.contains("Arifat")) {
     234                                words[i] = "Marie";
     235                            } else if (words[i].equals("N") && list.contains("Djamena")) {
     236                                words[i] = "N'";
     237                            } else if (words[i].equals("Oo")) {
     238                                words[i] = "Oô";
     239                            } else if (words[i].equals("Ph") && list.contains("Ravary")) {
     240                                words[i] = "Philippe";
     241                            } else if (words[i].equals("R") && list.contains("Folliot")) {
     242                                words[i] = "Raphaël";
     243                            } else if (words[i].equals("W") && list.contains("Booth")) {
     244                                words[i] = "William";
     245                            // Mots de liaison non couverts par le dictionnaire
     246                            } else if (words[i].equals("A")) {
     247                                words[i] = "à";
     248                            } else if (words[i].equals("D") || words[i].equals("L")) {
     249                                words[i] = words[i].toLowerCase()+"'";
     250                            } else if (words[i].equals("La") || words[i].equals("Le")) {
     251                                words[i] = words[i].toLowerCase();
     252                            }
     253                        }
     254                        value += words[i];
     255                    }
     256                }
     257                // Ponctuation
     258                value = value.replace("' ", "'");
     259                // Dictionnaire
     260                value = checkDictionary(value);
     261                p.put(key, value);
     262            }
     263        }
     264        return value;
     265    }
    266266}
  • applications/editors/josm/plugins/opendata/src/org/openstreetmap/josm/plugins/opendata/core/util/OdUtils.java

    r30532 r30723  
    2121
    2222public abstract class OdUtils {
    23        
     23   
    2424    private static final String TEMP_DIR_PREFIX = "josm_opendata_temp_";
    2525   
     
    2828    }
    2929   
    30         public static final String[] stripQuotesAndExtraChars(String[] split, String sep) {
    31                 List<String> result = new ArrayList<>();
    32                 boolean append = false;
    33                 for (int i = 0; i<split.length; i++) {
    34                         if (append) {
    35                                 int index = result.size()-1;
    36                                 if (split[i].endsWith("\"") && StringUtils.countMatches(split[i], "\"") % 2 == 1) {
    37                                         append = false;
    38                                 }
    39                                 result.set(index, result.get(index)+sep+split[i].replaceAll("\"", ""));
    40                         } else if (split[i].startsWith("\"")) {
    41                                 if (!(split[i].endsWith("\"") && StringUtils.countMatches(split[i], "\"") % 2 == 0)) {
    42                                         append = true;
    43                                 }
    44                                 result.add(split[i].replaceAll("\"", ""));
    45                         } else {
    46                                 result.add(split[i]);
    47                         }
    48                 }
    49                 // Remove exotic characters such as U+FEFF found in some CSV files
    50                 for (ListIterator<String> it = result.listIterator(); it.hasNext();) {
    51                     it.set(Utils.strip(it.next()));
    52                 }
    53                 return result.toArray(new String[0]);
    54         }
    55        
    56         public static final ImageIcon getImageIcon(String iconName) {
    57                 return getImageIcon(iconName, false);
    58         }
    59        
    60         public static final ImageIcon getImageIcon(String iconName, boolean optional) {
    61                 return new ImageProvider(iconName).setOptional(optional).setAdditionalClassLoaders(ModuleHandler.getResourceClassLoaders()).get();
    62         }
    63        
    64         public static final String getJosmLanguage() {
    65                 String lang = Main.pref.get("language");
    66                 if (lang == null || lang.isEmpty()) {
    67                         lang = Locale.getDefault().toString();
    68                 }
    69                 return lang;
    70         }
    71        
     30    public static final String[] stripQuotesAndExtraChars(String[] split, String sep) {
     31        List<String> result = new ArrayList<>();
     32        boolean append = false;
     33        for (int i = 0; i<split.length; i++) {
     34            if (append) {
     35                int index = result.size()-1;
     36                if (split[i].endsWith("\"") && StringUtils.countMatches(split[i], "\"") % 2 == 1) {
     37                    append = false;
     38                }
     39                result.set(index, result.get(index)+sep+split[i].replaceAll("\"", ""));
     40            } else if (split[i].startsWith("\"")) {
     41                if (!(split[i].endsWith("\"") && StringUtils.countMatches(split[i], "\"") % 2 == 0)) {
     42                    append = true;
     43                }
     44                result.add(split[i].replaceAll("\"", ""));
     45            } else {
     46                result.add(split[i]);
     47            }
     48        }
     49        // Remove exotic characters such as U+FEFF found in some CSV files
     50        for (ListIterator<String> it = result.listIterator(); it.hasNext();) {
     51            it.set(Utils.strip(it.next()));
     52        }
     53        return result.toArray(new String[0]);
     54    }
     55   
     56    public static final ImageIcon getImageIcon(String iconName) {
     57        return getImageIcon(iconName, false);
     58    }
     59   
     60    public static final ImageIcon getImageIcon(String iconName, boolean optional) {
     61        return new ImageProvider(iconName).setOptional(optional).setAdditionalClassLoaders(ModuleHandler.getResourceClassLoaders()).get();
     62    }
     63   
     64    public static final String getJosmLanguage() {
     65        String lang = Main.pref.get("language");
     66        if (lang == null || lang.isEmpty()) {
     67            lang = Locale.getDefault().toString();
     68        }
     69        return lang;
     70    }
     71   
    7272    public static final double convertMinuteSecond(double minute, double second) {
    7373        return (minute/60.0) + (second/3600.0);
Note: See TracChangeset for help on using the changeset viewer.