Ignore:
Timestamp:
2010-10-31T17:18:52+01:00 (14 years ago)
Author:
oliverw
Message:
  • Bugfix: Address cache did not consider all objects -> moved to NodeFactory
  • Bugfix: Process also ways when changing a tag
Location:
applications/editors/josm/plugins/FixAddresses/src/org/openstreetmap/josm/plugins/fixAddresses
Files:
6 edited

Legend:

Unmodified
Added
Removed
  • applications/editors/josm/plugins/FixAddresses/src/org/openstreetmap/josm/plugins/fixAddresses/AddressEditContainer.java

    r23966 r23967  
    6868        private List<AddressNode> shadowIncompleteAddresses = new ArrayList<AddressNode>(100);
    6969       
    70         private HashMap<String, AddressNode> addressCache = new HashMap<String, AddressNode>();
    7170        private HashSet<Node> visitedNodes = new HashSet<Node>();
    7271        private HashSet<Way> visitedWays = new HashSet<Way>();
     
    135134                }
    136135
     136                AddressNode aNode = null;
    137137                // Address nodes are recycled in order to keep instance variables like guessed names
    138                 String aid = "" + n.getId();
    139                 AddressNode aNode = null;
    140                 if (!addressCache.containsKey(aid)) {
    141                         aNode = NodeFactory.createNode(n);
    142                         if (aNode != null) {
    143                                 addressCache.put(aid, aNode);
    144                         }
    145                 } else {
    146                         aNode = addressCache.get(aid);
    147                         aNode.setOsmObject(n);
    148                 }
    149                
     138                aNode = NodeFactory.createNode(n);
     139                                               
    150140                if (aNode != null) {
    151141                        addAndClassifyAddress(aNode);
    152                 } else {
     142                } /*else {
    153143                        // check, if node is referred by a way
    154144                        for (OsmPrimitive osm : n.getReferrers()) {
     
    161151                        }
    162152                       
    163                 }
     153                }*/
    164154                markNodeAsVisited(n);
    165155        }
     156       
     157        /* (non-Javadoc)
     158         * @see org.openstreetmap.josm.data.osm.visitor.Visitor#visit(org.openstreetmap.josm.data.osm.Way)
     159         */
     160        @Override
     161        public void visit(Way w) {
     162                // This doesn't matter, we just need the street name
     163                //if (w.isIncomplete()) return;
     164               
     165                if (hasBeenVisited(w)) {
     166                        return;
     167                }
     168               
     169                createNodeFromWay(w);
     170                markWayAsVisited(w);
     171        }
     172
    166173
    167174        private void addAndClassifyAddress(AddressNode aNode) {
     
    176183        }
    177184       
    178         /* (non-Javadoc)
    179          * @see org.openstreetmap.josm.data.osm.visitor.Visitor#visit(org.openstreetmap.josm.data.osm.Way)
    180          */
    181         @Override
    182         public void visit(Way w) {
    183                 // This doesn't matter, we just need the street name
    184                 //if (w.isIncomplete()) return;
    185                
    186                 createNodeFromWay(w);
    187                 /*
    188         for (Node n : w.getNodes()) {
    189            
    190         }*/
    191         }
    192185
    193186        /**
     
    198191        private void createNodeFromWay(Way w) {
    199192                INodeEntity ne = NodeFactory.createNodeFromWay(w);
    200                
    201                 processNode(ne, w);
    202                
    203                 markWayAsVisited(w);
    204                
    205                 // Look also into nodes for addresses (unlikely, but at least they
    206                 // get marked as visited).
    207                 for (Node n : w.getNodes()) {
    208                         visit(n);
    209                 }
    210                
    211                 for (String key : w.keySet()) {
    212                         if (!tags.contains(key)) {
    213                                 tags.add(key);
     193
     194               
     195                if (!processNode(ne, w)) {
     196
     197                        // Look also into nodes for addresses (unlikely, but at least they
     198                        // get marked as visited).
     199                        for (Node n : w.getNodes()) {
     200                                visit(n);
     201                        }
     202
     203                        for (String key : w.keySet()) {
     204                                if (!tags.contains(key)) {
     205                                        tags.add(key);
     206                                }
    214207                        }
    215208                }
     
    219212         * Process a entity node.
    220213         *
    221          * @param ne the ne
    222          * @param w the w
    223          */
    224         private void processNode(INodeEntity ne, Way w) {
     214         * @param ne the entity node.
     215         * @param w the corresponding OSM way
     216         * @return true, if node has been processed
     217         */
     218        private boolean processNode(INodeEntity ne, Way w) {
    225219                if (ne != null) {
     220                        // Node is a street (segment)
    226221                        if (ne instanceof StreetSegmentNode) {
    227222                                StreetSegmentNode newSegment = (StreetSegmentNode) ne;
     
    229224                                if (newSegment != null) {
    230225                                        String name = newSegment.getName();
    231                                         if (StringUtils.isNullOrEmpty(name)) return;
     226                                        if (StringUtils.isNullOrEmpty(name)) return false;
    232227
    233228                                        StreetNode sNode = null;
     
    243238                                                // names are the same. Then the streets should be split up...
    244239                                                sNode.addStreetSegment(newSegment);
     240                                                return true;
    245241                                        } else {
    246242                                                throw new RuntimeException("Street node is null!");
     
    252248                        if (ne instanceof AddressNode) {
    253249                                AddressNode aNode = (AddressNode) ne;
    254                                 addAndClassifyAddress(aNode);                   
    255                         }
    256                 }
     250                                addAndClassifyAddress(aNode);
     251                                return true;
     252                        }
     253                }
     254                return false;
    257255        }
    258256
  • applications/editors/josm/plugins/FixAddresses/src/org/openstreetmap/josm/plugins/fixAddresses/AddressFinderThread.java

    r23962 r23967  
    172172                                if (nearestName != null) {
    173173                                        progressMonitor.subTask(String.format("%s: %s (%4.1f m)", tr("Guess"), nearestName, minDist));
     174                                        System.out.println("Guessed street: " + nearestName + " for node " + aNode);
    174175                                        aNode.setGuessedStreetName(nearestName);
    175176                                        nearestName = null;
     177                                } else {
     178                                        System.out.println("Did not find a street for " + aNode);
    176179                                }
    177180                                // report progress
  • applications/editors/josm/plugins/FixAddresses/src/org/openstreetmap/josm/plugins/fixAddresses/AddressNode.java

    r23966 r23967  
    4949        public String getStreet() {
    5050                if (osmObject == null) return MISSING_TAG;
    51                
     51                /*
    5252                if (!TagUtils.hasAddrStreetTag(osmObject)) {
    5353                        // check, if referrers have a street
     
    6262                        }
    6363                        return MISSING_TAG; // nothing found
    64                 }
    65                 return TagUtils.getAddrStreetValue(osmObject);
     64                }*/
     65                if (!TagUtils.hasAddrStreetTag(osmObject)) {
     66                        return MISSING_TAG;
     67                } else {
     68                        String sName = TagUtils.getAddrStreetValue(osmObject);
     69                        if (!StringUtils.isNullOrEmpty(sName)) {
     70                                return sName;
     71                        } else {
     72                                return MISSING_TAG;
     73                        }
     74                }
    6675        }
    6776       
  • applications/editors/josm/plugins/FixAddresses/src/org/openstreetmap/josm/plugins/fixAddresses/NodeEntityBase.java

    r23961 r23967  
    111111         */
    112112        protected void setOSMTag(String tag, String newValue) {
    113                 Node oldNode = (Node)osmObject;
    114                 OsmPrimitive newNode = new Node(oldNode);
    115                 newNode.put(tag, newValue);
    116                 Main.main.undoRedo.add( new ChangeCommand(oldNode, newNode));
    117                 fireEntityChanged(this);
     113                OsmPrimitive oldObject = osmObject;
     114                OsmPrimitive newObject = null;
     115                       
     116                // I would appreciate a clone method...
     117                if (oldObject instanceof Node) {
     118                        newObject = new Node();
     119                } else if (oldObject instanceof Way) {
     120                        newObject = new Way();
     121                }
     122               
     123                if (newObject != null) {
     124                        newObject.cloneFrom(oldObject);
     125                        newObject.put(tag, newValue);
     126                        Main.main.undoRedo.add( new ChangeCommand(oldObject, newObject));
     127                        fireEntityChanged(this);
     128                } else {
     129                        throw new RuntimeException("Cannot modify tag for " + osmObject);
     130                }
    118131        }
    119132
  • applications/editors/josm/plugins/FixAddresses/src/org/openstreetmap/josm/plugins/fixAddresses/NodeFactory.java

    r23966 r23967  
    1414package org.openstreetmap.josm.plugins.fixAddresses;
    1515
     16import java.util.HashMap;
     17
    1618import org.openstreetmap.josm.data.osm.Node;
    1719import org.openstreetmap.josm.data.osm.Way;
    1820
    1921public class NodeFactory {
     22        private static HashMap<String, AddressNode> addressCache = new HashMap<String, AddressNode>();
     23       
    2024        /**
    2125         * Creates an address node from an OSM node, if possible.
    22          * @param osm
     26         * @param node
    2327         * @return
    2428         */
    25         public static AddressNode createNode(Node osm) {
    26                 if (TagUtils.isAddress(osm)) {
    27                         return new AddressNode(osm);
     29        public static AddressNode createNode(Node node) {
     30                if (TagUtils.isAddress(node)) {
     31                        String aid = "" + node.getId();
     32                       
     33                        AddressNode aNode = lookup(aid);
     34                        if (aNode == null) {
     35                                aNode = new AddressNode(node);
     36                                addressCache.put(aid, aNode);
     37                        } else {
     38                                aNode.setOsmObject(node);
     39                        }
     40                        return aNode;
    2841                }
    2942               
     
    4356                // Check for building with address
    4457                if (way.isClosed() && TagUtils.hasBuildingTag(way)  && TagUtils.isAddress(way)) {
    45                         return new AddressNode(way);
     58                        String aid = "" + way.getId();
     59                       
     60                        AddressNode aNode = lookup(aid);
     61                        if (aNode == null) {
     62                                aNode = new AddressNode(way);
     63                                addressCache.put(aid, aNode);
     64                        } else {
     65                                aNode.setOsmObject(way);
     66                        }
     67       
     68                        return aNode;
     69                }
     70                return null;
     71        }
     72       
     73        private static AddressNode lookup(String aid) {                         
     74                if (addressCache.containsKey(aid)) {
     75                        return addressCache.get(aid);                   
    4676                }
    4777                return null;
  • applications/editors/josm/plugins/FixAddresses/src/org/openstreetmap/josm/plugins/fixAddresses/SelectIncompleteAddressesAction.java

    r23964 r23967  
    2828       
    2929        private AddressEditContainer addressEditContainer;
    30 
    31         /**
    32          *
    33          */
     30       
    3431        public SelectIncompleteAddressesAction() {
    3532                super(tr("Select incomplete addresses"), "select_invaddr_24",
Note: See TracChangeset for help on using the changeset viewer.